Experimental event counting algo
authorTomas Mudrunka <tomas@mudrunka.cz>
Thu, 2 Aug 2012 22:24:46 +0000 (00:24 +0200)
committerTomas Mudrunka <tomas@mudrunka.cz>
Thu, 2 Aug 2012 22:24:46 +0000 (00:24 +0200)
c/goertzel/sleepplot.sh

index cd4452e113b0308a5ba93e53540013be0c043608..496690e1c06bd05a77a65ab3df2f662c6bc0833a 100755 (executable)
@@ -5,19 +5,30 @@ test -z "$1" && {
        exit 23
 }
 
+#Count:
+seconds=60
+cat "$1" | cut -f 2,5 | cut -d ' ' -f 1 | grep '1$' | while read line; do
+       time=$(echo $line | cut -d ' ' -f 1);
+       time=$(( $time + $seconds - $time%$seconds ))
+       echo "$time"
+done | uniq -c | sed -e 's/^\s*//g' | tr ' ' '\t' > "$1.counts"
+
+
+#Approximate size of graph
 size="$(tail -n 1 "$1" | cut -d . -f 1)"
 test $size -gt 3600 && size="$(( $size/10 ))" #For prolonged periods
 size="$(( 600 + $size ))"
 
+#Plot it
 gnuplot << EOF
 set output "$1.png"
-set terminal png size $size,200
+set terminal png size $size,300
 
 set title "Sleep motions"
 set xlabel "time"
 set ylabel "motion"
 
-set yrange [-0.5:1.5]
+set yrange [-0.5:3]
 
 set xdata time
 set timefmt "%s"
@@ -26,7 +37,7 @@ set timefmt "%s"
 set grid
 
 #set pointsize 0.5
-plot "$1" using 2:5 with steps
+plot "$1" using 2:5 with steps, "$1.counts" using 2:(\$1/7) with lines
 
 EOF
 
This page took 0.115545 seconds and 4 git commands to generate.