#! /usr/bin/env python
#
# btt blkno plotting interface
#
# (C) Copyright 2008 Hewlett-Packard Development Company, L.P.
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
#
"""
bno_plot.py
[ -h | --help ]
[ -K | --keys-below ]
[ -v | --verbose ]
[ <file...> ]
Utilizes gnuplot to generate a 3D plot of the block number output
from btt. If no <files> are specified, it will utilize all files
generated after btt was run with -B blknos (meaning: all files of the
form blknos*[rw].dat).
The -K option forces bno_plot.py to put the keys below the graph,
typically all keys for input files are put in the upper right corner
of the graph. If the number of devices exceed 10, then bno_plot.py will
automatically push the keys under the graph.
To exit the plotter, enter 'quit' or ^D at the 'gnuplot> ' prompt.
"""
import getopt, glob, os, sys, tempfile
verbose = 0
cmds = """
set title 'btt Generated Block Accesses'
set xlabel 'Time (secs)'
set ylabel 'Block Number'
set zlabel '# Blocks per IO'
set grid
"""
#-----------------------------------------------------------------------------
def parse_args(in_args):
global verbose
keys_below = False
s_opts = 'hKv'
l_opts = [ 'help', 'keys-below', 'verbose' ]
try:
(opts, args) = getopt.getopt(in_args, s_opts, l_opts)
except getopt.error, msg:
print >>sys.stderr, msg
print >>sys.stderr, __doc__
sys.exit(1)
for (o, a) in opts:
if o in ('-h', '--help'):
print __doc__
sys.exit(0)
elif o in ('-v', '--verbose'):
verbose += 1
elif o in ('-K', '--keys-below'):
keys_below = True
if len(args) > 0: bnos = args
else: bnos = glob.glob('blknos*[rw].dat')
return (bnos, keys_below)
#-----------------------------------------------------------------------------
if __name__ == '__main__':
(bnos, keys_below) = parse_args(sys.argv[1:])
if verbose:
print 'Using files:',
for bno in bnos: print bno,
if keys_below: print '\nKeys are to be placed below graph'
else: print ''
tmpdir = tempfile.mktemp()
os.mkdir(tmpdir)
plot_cmd = None
for f in bnos:
t = '%s/%s' % (tmpdir, f)
fo = open(t, 'w')
for line in open(f, 'r'):
fld = line.split(None)
print >>fo, fld[0], fld[1], int(fld[2])-int(fld[1])
fo.close()
t = t[t.rfind('/')+1:]
if plot_cmd == None: plot_cmd = "splot '%s'" % t
else: plot_cmd = "%s,'%s'" % (plot_cmd, t)
fo = open('%s/plot.cmds' % tmpdir, 'w')
print >>fo, cmds
if len(bnos) > 10 or keys_below: print >>fo, 'set key below'
print >>fo, plot_cmd
fo.close()
pid = os.fork()
if pid == 0:
cmd = '/usr/bin/gnuplot %s/plot.cmds -' % tmpdir
if verbose: print 'Executing %s' % cmd
cmd = cmd.split(None)
os.chdir(tmpdir)
os.execvp(cmd[0], cmd)
sys.exit(1)
os.waitpid(pid, 0)
os.system('/bin/rm -rf ' + tmpdir)