[742c9b8] | 1 | #! /usr/bin/python |
---|
| 2 | |
---|
| 3 | if __name__ == '__main__': |
---|
| 4 | import sys, Gnuplot |
---|
| 5 | from aubio.gnuplot import gnuplot_create |
---|
| 6 | from aubio.txtfile import read_datafile |
---|
| 7 | from aubio.plot.keyboard import draw_keyboard |
---|
| 8 | lines = [] |
---|
| 9 | titles = [] |
---|
| 10 | for file in range(len(sys.argv)-1): |
---|
| 11 | l = read_datafile(sys.argv[file+1]) |
---|
| 12 | notes, score = [],[] |
---|
| 13 | for i in range(len(l)): |
---|
| 14 | notes.append(l[i][0]) |
---|
| 15 | score.append(l[i][2]) |
---|
| 16 | lines.append(Gnuplot.Data(notes,score, |
---|
| 17 | with='linespoints', |
---|
| 18 | title=sys.argv[file+1].split('.')[-1])) |
---|
| 19 | titles.append(sys.argv[file+1].split('.')[-1]) |
---|
| 20 | blacks,whites = draw_keyboard(firstnote = notes[0], lastnote = notes[-1], |
---|
| 21 | y0= 40, y1 = 50) |
---|
| 22 | |
---|
| 23 | g = gnuplot_create(sys.argv[file+1].split('.')[-3],'ps') |
---|
| 24 | #g = gnuplot_create('','') |
---|
| 25 | #g = gnuplot_create('/tmp/test','eps') |
---|
| 26 | g('set yrange [40:100]') |
---|
| 27 | #g('set xrange [%f:%f]' % (notes[0],notes[-1]+60)) |
---|
| 28 | g('set size 0.5') |
---|
| 29 | g('set key outside') |
---|
| 30 | |
---|
| 31 | g('set border 3') |
---|
| 32 | g('set xtics nomirror') |
---|
| 33 | g('set ytics nomirror') |
---|
| 34 | multiplot = 1 |
---|
| 35 | oplots = lines |
---|
| 36 | g('set size 1,2') |
---|
| 37 | if multiplot: |
---|
| 38 | height = 2. |
---|
| 39 | g('set lmargin 10') |
---|
| 40 | #g('set rmargin 15') |
---|
| 41 | g('set multiplot') |
---|
| 42 | g('set yrange [50:100]') |
---|
| 43 | g('set xrange [%f:%f]' % (notes[0],notes[-1])) |
---|
| 44 | g('set xtics %f,12' % notes[0]) |
---|
| 45 | g('set nokey') |
---|
| 46 | for i in range(len(oplots)): |
---|
| 47 | g.ylabel(titles[i]) |
---|
| 48 | g('set size %f,%f' % (1.,height*.85/float(len(oplots)))) |
---|
| 49 | g('set origin 0,%f' % (height*(.15+.85*float(len(oplots)-i-1)/float(len(oplots))))) |
---|
| 50 | g.plot(oplots[i]) |
---|
| 51 | g('set title "Raw pitch accuracy (%) against midi note numbers"') |
---|
| 52 | g('set noxtics') |
---|
| 53 | g('set noytics') |
---|
| 54 | g('set size %f,%f' % (1.,.15*height)) |
---|
| 55 | g('set origin 0,%f' % 0) |
---|
| 56 | g('set yrange [40:50]') |
---|
| 57 | g('set xrange [%f:%f]' % (notes[0],notes[-1])) |
---|
| 58 | g.xlabel('') |
---|
| 59 | g.ylabel('') |
---|
| 60 | g.plot(whites,blacks) |
---|
| 61 | g('unset multiplot') |
---|
| 62 | else: |
---|
| 63 | g.plot(whites,blacks,*lines) |
---|