source: tests/demo/bench/pitch/bench-pitch-isolated @ 066433d

feature/autosinkfeature/cnnfeature/cnn_orgfeature/constantqfeature/crepefeature/crepe_orgfeature/pitchshiftfeature/pydocstringsfeature/timestretchfix/ffmpeg5pitchshiftsamplertimestretchyinfft+
Last change on this file since 066433d was 974dddc, checked in by Paul Brossier <piem@piem.org>, 17 years ago

move tests/python/demo to tests/, add localaubio.py module helpers

  • Property mode set to 100755
File size: 6.7 KB
RevLine 
[4cc9fe5]1#! /usr/bin/python
2
3from aubio.bench.node import *
[43938de]4from aubio.task import *
[0029638]5
6class benchpitch(bench):
7       
[ee7b9da]8        """ list of values to store per file """
9        valuenames = ['mode']
10        """ list of lists to store per file """
[5d1c070]11        valuelists = ['truth', 'osil', 'esil', 'opit', 'epit', 'echr',
[807f029]12               'Msil', 'Mpit', 'Mchr',
13               'TotalPit', 'TotalPit', 'TotalChr' ]
[ee7b9da]14        """ list of values to print per dir """
[5cc94db]15        printnames_total = [ 'mode', 'MinPit', 'MaxPit', 'TotalSil', 'TotalPit', 'TotalChr']
16        printnames_notes = [ 'mode', 'Note', 'Sil', 'Pit', 'Chr']
17        printnames = printnames_notes
[ee7b9da]18
19        """ per dir """
[5d1c070]20        formats = {'mode': "%12s" ,
21                'truth': "%s",
22                'osil': "%s", 'esil': "%s",
23                'opit': "%s", 'epit': "%s", 'echr': "%s",
[5cc94db]24    'Note': "%s", 'Sil': "%s", 'Chr': "%s", 'Pit': "%s",
[807f029]25                'TotalPit': "%s", 'TotalSil': "%s", 'TotalChr': "%s",
26                'MinPit': "%s", 'MaxPit': "%s",
[5d1c070]27                'Msil': "%s", 'Mpit': "%s", 'Mchr': "%s"}
[ee7b9da]28
29        def dir_eval(self):
30                """ evaluate statistical data over the directory """
31                v = self.v
32                v['mode']      = self.params.pitchmode
33
[4f4a8a4]34        def file_exec(self,input,output):
[0029638]35                filetask = self.task(input,params=self.params)
36                computed_data = filetask.compute_all()
[807f029]37                osil, esil, opit, epit, echr = filetask.eval(computed_data,tol=0.5)
[5d1c070]38                self.v['truth'].append(int(filetask.truth))
39                assert opit > 0
[ee7b9da]40               
[5d1c070]41                self.v['osil'].append(osil)
42                self.v['esil'].append(esil)
43                self.v['opit'].append(opit)
44                self.v['epit'].append(epit)
45                self.v['echr'].append(echr)
46
47                self.v['Msil'].append(esil/float(osil)*100.)
48                self.v['Mpit'].append(epit/float(opit)*100.)
49                self.v['Mchr'].append(echr/float(opit)*100.)
[ee7b9da]50                #print results#, computed_data
[0029638]51                #print input, results, results - float(input.split('.')[-2])
52                       
[b965fb1]53        def run_bench(self,modes=['schmitt'],multiplot=0):
[ee7b9da]54                from os.path import basename
[0029638]55                self.modes = modes
[ee7b9da]56                self.pretty_titles()
[5d1c070]57                d = []
[0029638]58                for mode in self.modes:
[4f4a8a4]59                        self.params.pitchmode = mode
[807f029]60                        self.dir_exec()
61                        self.dir_eval()
[5d1c070]62                        truth   = [i for i in range(min(self.v['truth']),max(self.v['truth'])+1)]
63                        allOsil = [0 for i in range(min(self.v['truth']),max(self.v['truth'])+1)]
64                        allEsil = [0 for i in range(min(self.v['truth']),max(self.v['truth'])+1)]
65                        allOpit = [0 for i in range(min(self.v['truth']),max(self.v['truth'])+1)]
66                        allEpit = [0 for i in range(min(self.v['truth']),max(self.v['truth'])+1)]
67                        allEchr = [0 for i in range(min(self.v['truth']),max(self.v['truth'])+1)]
68                        allMsil = [0 for i in range(min(self.v['truth']),max(self.v['truth'])+1)]
69                        allMpit = [0 for i in range(min(self.v['truth']),max(self.v['truth'])+1)]
70                        allMchr = [0 for i in range(min(self.v['truth']),max(self.v['truth'])+1)]
71                        for i in range(len(self.v['truth'])):
72                                allOsil[self.v['truth'][i]-min(self.v['truth'])] += self.v['osil'][i]
73                                allEsil[self.v['truth'][i]-min(self.v['truth'])] += self.v['esil'][i]
74                                allOpit[self.v['truth'][i]-min(self.v['truth'])] += self.v['opit'][i]
75                                allEpit[self.v['truth'][i]-min(self.v['truth'])] += self.v['epit'][i]
76                                allEchr[self.v['truth'][i]-min(self.v['truth'])] += self.v['echr'][i]
77                        for i in range(len(truth)):
[807f029]78                                allOsil[i] = max(1,allOsil[i])
79                                allOpit[i] = max(1,allOpit[i])
[5d1c070]80                                allMsil[i] = allEsil[i]/float(allOsil[i])*100.
81                                allMpit[i] = allEpit[i]/float(allOpit[i])*100.
82                                allMchr[i] = allEchr[i]/float(allOpit[i])*100.
[5cc94db]83                                self.v['Sil'], self.v['Pit'], self.v['Chr'] = allMsil[i], allMpit[i], allMchr[i]
84                                self.v['Note'] = truth[i]
85                                #self.printnames = self.printnames_notes
86                                self.pretty_print()
[807f029]87                        self.v['TotalSil'] = sum(allMsil)/len(truth)
88                        self.v['TotalPit'] = sum(allMpit)/len(truth)
89                        self.v['TotalChr'] = sum(allMchr)/len(truth)
90                        self.v['MinPit'] = min(truth)
91                        self.v['MaxPit'] = max(truth)
[5cc94db]92                        #self.printnames = self.printnames_total
93                        #self.pretty_print()
[5d1c070]94
95                        plot = []
96                        self.plotpitchtessiture(plot,
97                                truth,
98                                allMpit,
99                                plottitle="%s %s" % (self.v['mode'],self.params.bufsize),
100                                plotmode='lines')
[b965fb1]101                        """
[5d1c070]102                        self.plotpitchtessiture(plot,
103                                truth,
104                                allMchr,
105                                plottitle="%s %s" % (self.v['mode'],"%12"),
106                                plotmode='lines')
107                        self.plotpitchtessiture(plot,
108                                truth,
109                                allMsil,
110                                plottitle="%s %s" % (self.v['mode'],"sil"),
111                                plotmode='lines')
112                        """
113                        title = basename(self.datadir)
[b965fb1]114                        if multiplot:
115                                d.append(plot)
116                        else:
117                                d += plot
[ee7b9da]118                outplot = "_-_".join(('pitchtessiture',title))
[b965fb1]119                self.xmin = min(self.v['truth']) #20.
120                self.xmax = max(self.v['truth'])
121                for ext in ('ps','png','svg'): #,''):
[ee7b9da]122                        self.plotplotpitchtessiture(d,
[5d1c070]123                                plottitle="".join(['Performance against MIDI Note number (',
124                                        title,
125                                        ", %s" % len(self.sndlist), " samples)"]),
[ee7b9da]126                                outplot=outplot,
[b965fb1]127                                extension=ext,multiplot=multiplot)
[5d1c070]128                #d.append('beta = .25,orig(x) title \"-2 octave\"')
129                #d.append('beta = .50,orig(x) title \"-1 octave\"')
130                #d.append('beta = 1.0,orig(x) title \"original\"')
131                #d.append('beta = 2.0,orig(x) title \"+1 octave\"')
[ee7b9da]132
133        """
134        Plot functions
135        """
136
137        def plotpitchtessiture(self,d,lx,ly,plottitle="",plotmode='linespoints'):
138                import Gnuplot, Gnuplot.funcutils
139                d.append(Gnuplot.Data(lx, ly, with=plotmode, title="%s" % (plottitle) ))
140
[5d1c070]141        def plotplotpitchtessiture(self,d,plottitle='',outplot=0,extension='',multiplot=1):
[ee7b9da]142                from aubio.gnuplot import gnuplot_create
143                g = gnuplot_create(outplot=outplot,extension=extension)
[5d1c070]144                #g.title(plottitle)
145                #g('orig(x) = beta*x')
[b965fb1]146                g.title(plottitle)
147                g('set yrange [50:100]')
148                # erase axis
149                g('set xrange [%f:%f]' % (self.xmin,self.xmax)) #(self.xmax - (self.xmax-self.xmin)*5./4.,self.xmax))
[5d1c070]150                #g.plot(*d)
[b965fb1]151                g('set border 3')
152                g('set xtics nomirror')
153                g('set ytics nomirror')
154                g('set key bottom')
[5d1c070]155                if multiplot:
156                        g('set multiplot')
157                        for i in range(len(d)):
158                                # plot onset detection functions
159                                g('set size   1,%f' % ( 1.0/float(len(d)) ) )
160                                g('set origin 0,%f' % ( 1.0*float(len(d)-i-1)/float(len(d)) ) )
161                                #g.ylabel('%Correct detections')
[b965fb1]162                                g('set xrange [%f:%f]' % (self.xmin,self.xmax)) #(self.xmax - (self.xmax-self.xmin)*5./4.,self.xmax))
[5d1c070]163                                g.plot(*d[i])
164                                g('unset title')
165                        g('unset multiplot')
166                else:
167                        g.plot(*d)
[ee7b9da]168
[0029638]169
170if __name__ == "__main__":
171        import sys
172        if len(sys.argv) > 1: datapath = sys.argv[1]
173        else: print "error: a path is required"; sys.exit(1)
[4f4a8a4]174        if len(sys.argv) > 2:
175                for each in sys.argv[3:-1]: print each
[807f029]176        modes = ['schmitt', 'yin', 'yinfft', 'mcomb', 'fcomb']
[b965fb1]177        #modes = ['mcomb']
[0029638]178
[ee7b9da]179        params = taskparams()
[b965fb1]180        params.bufsize = 2048 # 4096
[807f029]181        params.hopsize = 256
[b965fb1]182        params.silence = -60.
[5d1c070]183        params.pitchsmooth = 0
184        params.pitchmax = 20000
185        params.pitchmin = 20
[807f029]186        params.pitchyinfft = 0.95
[ee7b9da]187        benchpitch = benchpitch(datapath,params=params)
[0029638]188        benchpitch.task = taskpitch
189
[ee7b9da]190        #benchpitch.titles  = [ 'mode', 'thres', 'avg', 'avgdist' ]
191        #benchpitch.formats = ["%12s" , "| %6s", "| %6s", "| %6s", "| %6s", "| %6s" ]
[0029638]192        try:
193                benchpitch.run_bench(modes=modes)
194        except KeyboardInterrupt:
195                print "Interrupted by user"
196                sys.exit(1)
197
198        sys.exit(0)
Note: See TracBrowser for help on using the repository browser.