indicate mean value in bar position
[barcat.git] / graph
diff --git a/graph b/graph
index cce0d3cd4d2bedfcd57e10c792023e8d10ba90d3..2de4b90502073fa0122789a697fce3b6a298945d 100755 (executable)
--- a/graph
+++ b/graph
@@ -8,16 +8,23 @@ my $width = $ENV{COLUMNS} || 80;
 my @lines = readline;
 chomp for @lines;
 my @values = map { s/^\h*([0-9]*)// and $1 } @lines;
-my $maxval = max @values;
-my $lenval = 1 + int log($maxval) / log 10;  # max string length
+my @order  = sort { $b <=> $a } @values;
+my $lenval = 1 + int log($order[0]) / log 10;  # max string length
 my $len    = 1 + max map { length } @lines;  # left padding
-my $size   = ($width - $lenval - $len) / $maxval;  # bar multiplication
+my $size   = ($width - $lenval - $len) / $order[0];  # bar multiplication
+my $mean   = ($order[$#order / 2] + $order[$#order / 2 + .5]) / 2;
 
 for my $nr (0 .. $#lines) {
        my $val = $values[$nr];
-       printf "\e[90m";
+       my $color =
+               $val == $order[0] ? 32 : # max
+               $val == $order[-1] ? 31 : # min
+               90;
+       printf "\e[%sm", $color if $color;
        printf "%*s", $lenval, $val;
-       print "\e[0m";
+       print "\e[0m" if $color;
        printf '%-*s', $len, $lines[$nr];
-       say '-' x ($val * $size);
+       my $bar = '-' x ($val * $size);
+       substr $bar, int($mean * $size) - 1, 1, "\e[36m+\e[0m" if $val >= $mean;
+       say $bar;
 }