diff options
| author | John Glover <john@john-glovers-macbook.local> | 2010-12-24 19:28:27 +0000 | 
|---|---|---|
| committer | John Glover <john@john-glovers-macbook.local> | 2010-12-24 19:28:27 +0000 | 
| commit | 8f29130d9c2612a7e7867458cae71dbb73b51aeb (patch) | |
| tree | b1cfacad8f49ba8f3c7702e76921c9b4466e31c6 /mq.py | |
| parent | ba40f572b4fcdf48defa5e93d4d5e56920356a9e (diff) | |
| download | simpl-8f29130d9c2612a7e7867458cae71dbb73b51aeb.tar.gz simpl-8f29130d9c2612a7e7867458cae71dbb73b51aeb.tar.bz2 simpl-8f29130d9c2612a7e7867458cae71dbb73b51aeb.zip | |
Updated MQSynthesis to simpl 0.2
Diffstat (limited to 'mq.py')
| -rw-r--r-- | mq.py | 17 | 
1 files changed, 10 insertions, 7 deletions
| @@ -322,6 +322,7 @@ class MQSynthesis(simpl.Synthesis):      def __init__(self):          simpl.Synthesis.__init__(self)          self._current_frame = simpl.zeros(self.frame_size) +        self._previous_partials = [simpl.Peak() for i in range(self.max_partials)]      def hz_to_radians(self, frequency):          if not frequency: @@ -329,24 +330,23 @@ class MQSynthesis(simpl.Synthesis):          else:              return (frequency * 2.0 * np.pi) / self.sampling_rate -    def synth_frame(self, peaks): +    def synth_frame(self, frame):          "Synthesises a frame of audio, given a list of peaks from tracks"          self._current_frame *= 0.0 -        for p in peaks: +        for n, p in enumerate(frame.partials):              # get values for last amplitude, frequency and phase              # these are the initial values of the instantaneous amplitude/frequency/phase              current_freq = self.hz_to_radians(p.frequency) -            if not p.previous_peak: -                prev_amp = 0.0 +            prev_amp = self._previous_partials[n].amplitude +            if prev_amp == 0:                  prev_freq = current_freq                   prev_phase = p.phase - (current_freq * self.frame_size)                  while prev_phase >= np.pi: prev_phase -= 2.0 * np.pi                   while prev_phase < -np.pi: prev_phase += 2.0 * np.pi              else: -                prev_amp = p.previous_peak.amplitude -                prev_freq = self.hz_to_radians(p.previous_peak.frequency) -                prev_phase = p.previous_peak.phase +                prev_freq = self.hz_to_radians(self._previous_partials[n].frequency) +                prev_phase = self._previous_partials[n].phase              # amplitudes are linearly interpolated between frames              inst_amp = prev_amp @@ -368,5 +368,8 @@ class MQSynthesis(simpl.Synthesis):                  inst_phase = prev_phase + (prev_freq * i) + (alpha * (i**2)) + (beta * (i**3))                  self._current_frame[i] += (2.0 * inst_amp) * np.cos(inst_phase) +            # update previous partials list +            self._previous_partials[n] = p +          return self._current_frame |