X-Git-Url: https://scm.cri.mines-paristech.fr/git/minwii.git/blobdiff_plain/fa75b1df8242dff846bd0fd6c2a274170892b73a..e20495c66925a06496b90ccbe566cebecc74efa6:/src/minwii/loganalyse.py diff --git a/src/minwii/loganalyse.py b/src/minwii/loganalyse.py index ab8c819..61b0382 100755 --- a/src/minwii/loganalyse.py +++ b/src/minwii/loganalyse.py @@ -44,29 +44,41 @@ def statsresults(m) : computeList.__doc__ = m.__doc__ return computeList +def timebased(m) : + m.timebased = True + return m + class LogFileAnalyser(LogFileReader) : POSSIBLE_ANALYSES = {'BEGINNER' : ('songDuration', 'playingDuration', 'noteEndNoteOnLatency', 'realisationRate') + ,'EASY' : ('songDuration', 'playingDuration', 'noteEndNoteOnLatency', 'realisationRate', - 'missCount') + 'missCount', + 'getMissPerTimeFrame') + ,'NORMAL' : ('songDuration', 'playingDuration', 'realisationRate', - 'missCount') + 'missCount', + 'getMissPerTimeFrame') + ,'ADVANCED' : ('songDuration', 'playingDuration', 'realisationRate', - 'missCount') + 'missCount', + 'getMissPerTimeFrame') + ,'EXPERT' : ('songDuration', 'playingDuration', 'realisationRate', - 'missCount') + 'missCount', + 'getMissPerTimeFrame') } def analyse(self) : @@ -74,14 +86,14 @@ class LogFileAnalyser(LogFileReader) : try : self.mode = mode = self.getMode() - results.append(('Mode de jeu', PLAYING_MODES.get(mode, mode))) + results.append(('Mode de jeu', PLAYING_MODES.get(mode, mode), False)) self.songTitle = LogFileAnalyser.getSongTitle(self.getSongFile()) - results.append(('Chanson', self.songTitle)) + results.append(('Chanson', self.songTitle, False)) for name in self.POSSIBLE_ANALYSES[mode] : meth = getattr(self, name) - results.append((meth.__doc__, meth())) + results.append( (meth.__doc__, meth(), getattr(meth, 'timebased', False)) ) except : raise @@ -127,10 +139,7 @@ class LogFileAnalyser(LogFileReader) : songFile = self.getSongFile() song = musicXml2Song(songFile) - duration = 0 - for note, verseIndex in song.iterNotes() : - duration = duration + note.duration - duration = duration * song.quarterNoteDuration # en milisecondes + duration = song.duration return self._toTimeDelta(duration) @statsresults @@ -202,6 +211,46 @@ class LogFileAnalyser(LogFileReader) : miss = miss + 1 return miss + + @timebased + def getMissPerTimeFrame(self, timeFrame=10000) : + "Nombre d'erreurs en fonction du temps" + eIter = self.getEventsIterator() + firstTicks = self.getFirstEventTicks() + frames = [0] + + if self.mode in ('EASY', 'NORMAL') : + catchColUp = False + for ticks, eventName, message in eIter : + if ticks - firstTicks > timeFrame : + firstTicks = ticks + frames.append(0) + + if eventName == 'COLDOWN' : + colState = message.split(None, 2)[1] + colState = colState == 'True' + if colState : + catchColUp = False + continue + else : + catchColUp = True + elif eventName == 'NOTEON' : + catchColUp = False + elif eventName == 'COLUP' and catchColUp : + frames[-1] = frames[-1] + 1 + else : + for ticks, eventName, message in eIter : + if ticks - firstTicks > timeFrame : + firstTicks = ticks + frames.append(0) + + if eventName == 'COLDOWN' : + colState = message.split(None, 2)[1] + colState = colState == 'True' + if not colState : + frames[-1] = frames[-1] + 1 + + return frames