from pprint import pprint
from minwii.musicxml import musicXml2Song
from statlib import stats
from pprint import pprint
from minwii.musicxml import musicXml2Song
from statlib import stats
+from datetime import timedelta
DEFAULT_STATS = ('geometricmean',
'harmonicmean',
DEFAULT_STATS = ('geometricmean',
'harmonicmean',
meth = getattr(self, name)
results.append((meth.__doc__, meth()))
except :
meth = getattr(self, name)
results.append((meth.__doc__, meth()))
except :
+ def _toTimeDelta(self, milliseconds) :
+ duration = milliseconds / 1000.
+ duration = int(round(duration, 0))
+ return str(timedelta(seconds=duration))
+
def playingDuration(self) :
'Temps de jeu'
#retourne la durée écoulée entre le premier et de dernier message
def playingDuration(self) :
'Temps de jeu'
#retourne la durée écoulée entre le premier et de dernier message
last = self.getLastEventTicks()
first = self.getFirstEventTicks()
last = self.getLastEventTicks()
first = self.getFirstEventTicks()
+ return self._toTimeDelta(last - first)
+
+ 'Durée de référence de la chanson'
#retourne la durée de référence de la chanson
#en prenant en compte le tempo présent dans la transcription
#et en effectuant toutes les répétitions des couplets / refrains.
#retourne la durée de référence de la chanson
#en prenant en compte le tempo présent dans la transcription
#et en effectuant toutes les répétitions des couplets / refrains.
duration = 0
for note, verseIndex in song.iterNotes() :
duration = duration + note.duration
duration = 0
for note, verseIndex in song.iterNotes() :
duration = duration + note.duration
- return duration * song.quarterNoteDuration
+ duration = duration * song.quarterNoteDuration # en milisecondes
+ return self._toTimeDelta(duration)
@statsresults
def noteEndNoteOnLatency(self) :
@statsresults
def noteEndNoteOnLatency(self) :
for note, verseIndex in song.iterNotes() :
songNoteCpt = songNoteCpt + 1
for note, verseIndex in song.iterNotes() :
songNoteCpt = songNoteCpt + 1
- return int(round(self.noteOnCount() / float(songNoteCpt) * 100, 0))
+ return round(self.noteOnCount() / float(songNoteCpt) * 100, 1)
def missCount(self) :
"Nombre d'erreurs"
def missCount(self) :
"Nombre d'erreurs"