Mercurial > ~darius > hgwebdir.cgi > pyinst
changeset 33:e80c2ff5fa87
Add program to plot data files from sitesurvey.py
author | Daniel O'Connor <darius@dons.net.au> |
---|---|
date | Wed, 21 Sep 2011 15:34:49 +0930 (2011-09-21) |
parents | 660a2997e720 |
children | 182c42e7bf03 |
files | plotss.py |
diffstat | 1 files changed, 50 insertions(+), 0 deletions(-) [+] |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/plotss.py Wed Sep 21 15:34:49 2011 +0930 @@ -0,0 +1,50 @@ +#!/usr/bin/env python + +import exceptions +import numpy +import pylab +import sys + +def doplot(fname): + f = file(fname) + opts = {} + for line in f: + key, value = line.strip().split(' ', 1) + try: + opts[key] = int(value) + except exceptions.ValueError, e: + try: + opts[key] = float(value) + except exceptions.ValueError, e: + opts[key] = value + + xdata = numpy.fromstring(opts['XDATA'], sep = ', ') + ydata = numpy.fromstring(opts['YDATA'], sep = ', ') + xdata /= 1e6 + pylab.title("Tag \'" + opts['TAG'] + "\' at " + opts['TIMESTAMP']) + pylab.xlabel("Frequency (MHz)") + pylab.ylabel("Level (dBm)") + annstr = "FStart\t%.2f MHz\nFStop\t%.2f MHz\nPoints\t%d" % ( + float(opts['FSTART']) / 1e6, + float(opts['FSTOP']) / 1e6, + len(xdata)) + pylab.annotate(annstr, xy=(5, -40), xycoords='axes points') + + annstr = "Video BW\t%.1f kHz\nResol. BW\t%.1f kHz\nAttenuation\t%.1f dB\nRef Level\t%.1f dBm" % ( + float(opts['VIDBW']) / 1e3, + float(opts['RESBW']) / 1e3, + float(opts['ATTEN']), + float(opts['REFLEV'])) + pylab.annotate(annstr, xy=(-140, -55), xycoords='axes points') + pylab.grid(True) + pylab.plot(xdata, ydata, linestyle='solid', marker='.') + pylab.show() + +if __name__ == "__main__": + if len(sys.argv) < 2: + print "Need at least one file to plot" + sys.exit(1) + + for fn in sys.argv[1:]: + doplot(fn) +