Mercurial > hg > cc > cirrus_home
view bin/hist @ 56:c0c030e8b219
too big for /dev/shm, split in half
author | Henry S. Thompson <ht@inf.ed.ac.uk> |
---|---|
date | Tue, 14 Apr 2020 17:52:34 +0100 |
parents | b976a7449d41 |
children |
line wrap: on
line source
#!/bin/sh # Usage: hist file bins [-max n] [-min n] [-ll n] [-t title] [-ntile n] file=$1 shift nb=$1 shift date=`date` while case "x$1" in x-max) shift; max=$1 ;; x-ll) shift; ll=$1 ;; x-min) shift; min=$1 ;; x-t) shift; title=$1 ;; x-ntile) shift; ntile=$1 ;; x) break ;; *) echo hunh 1>&2; exit 1 ;; esac do shift done if [ \( -z "$max" -o -z "$min" \) ] then rfile=/tmp/hist$$ sort -n $file > $rfile fi perl -e " (\$max,\$min,\$nb,\$ll,\$title,\$ntile)=(${max:-`tail -1 /tmp/hist$$`}, ${min:-`head -1 /tmp/hist$$`} ,$nb,${ll:-80},\"${title:-$file}\",${ntile:-0});"' $#bins=$nb; $range=$max-$min; while (<>) { if ($_<$min) { $minn+=1; } elsif ($_>$max) { $maxn+=1; } else { $n+=1; $i=(($_-$min)/$range)*$nb; if ($i==$nb) {$bins[$i-1]+=1} else {$bins[int($i)]+=1}; }; }; $start=$min+$range/(2*$nb); $step=$range/$nb; foreach $i (0..$nb-1) { $mb=$bins[$i] if ($bins[$i]>$mb); }; $bscale=$mb/($ll-16); $bscale=1 if ($bscale<1); print "$title ",`date`,"\n"; print " n min max width maxcnt bscale"; if ($ntile) { print " ntiles tilew"; $tile=$tstep=($n/$ntile); $ntile--; } print "\n"; printf("%7d%7.3f %7.3f%7.3f%6d %7.3f",$n,$min,$max,$step,$mb,$bscale); printf("%5d %7.2f",$ntile+1,$tstep) if ($ntile); print "\n\n"; if ($minn) {printf("<%7.3f%7d\n",$min,$minn)}; foreach $i (0..$nb-1) { $n=$bins[$i]; if ($ntile) { $cum+=$n; if ($cum>=$tile) { print "-"; $tile+=$tstep; $ntile--; } else { print " "; }; } else { print " "; }; printf("%7.3f%7d ",$start+($i*$step),$bins[$i]); $nx=$bins[$i]/$bscale; $nx=1 if (($nx<1) && ($bins[$i]>0)); print "*" x $nx; print "\n"; }; if ($maxn) {printf(">%7.3f%7d\n",$max,$maxn)};' ${rfile:-$file} if [ "$rfile" ] then rm $rfile fi