From 35f74ab36af2487423b2ef7b7d22438efe2e9fbd Mon Sep 17 00:00:00 2001 From: John Glover Date: Wed, 12 Sep 2012 20:15:41 +0200 Subject: [base, synthesis] Allow synthesis sample arrays to be created and destroyed independently of input audio sample arrays in Frame objects. Fix bug in Cython synthesis wrapper that prevented the hop size from being changed correctly. Don't create memory in non-real-time synthesis function as it is now managed by the Frame object itself. --- simpl/synthesis.pyx | 1 + src/simpl/base.cpp | 23 +++++++++++++++-------- src/simpl/base.h | 2 ++ src/simpl/synthesis.cpp | 5 +---- tests/test_synthesis.cpp | 8 ++++++-- 5 files changed, 25 insertions(+), 14 deletions(-) diff --git a/simpl/synthesis.pyx b/simpl/synthesis.pyx index 8e4a050..fd945ed 100644 --- a/simpl/synthesis.pyx +++ b/simpl/synthesis.pyx @@ -44,6 +44,7 @@ cdef class Synthesis: cdef np.ndarray[dtype_t, ndim=1] output = np.zeros(len(frames) * size) for i in range(len(frames)): frames[i].synth = np.zeros(size) + frames[i].synth_size = size self.synth_frame(frames[i]) output[i * size:(i + 1) * size] = frames[i].synth return output diff --git a/src/simpl/base.cpp b/src/simpl/base.cpp index 9683df3..c97e8bc 100644 --- a/src/simpl/base.cpp +++ b/src/simpl/base.cpp @@ -63,20 +63,27 @@ void Frame::init() { void Frame::create_arrays() { _audio = new sample[_size]; - _synth = new sample[_synth_size]; _residual = new sample[_size]; - _synth_residual = new sample[_synth_size]; - memset(_audio, 0.0, sizeof(sample) * _size); - memset(_synth, 0.0, sizeof(sample) * _synth_size); memset(_residual, 0.0, sizeof(sample) * _size); - memset(_synth_residual, 0.0, sizeof(sample) * _synth_size); + create_synth_arrays(); } void Frame::destroy_arrays() { delete [] _audio; - delete [] _synth; delete [] _residual; + destroy_synth_arrays(); +} + +void Frame::create_synth_arrays() { + _synth = new sample[_synth_size]; + _synth_residual = new sample[_synth_size]; + memset(_synth, 0.0, sizeof(sample) * _synth_size); + memset(_synth_residual, 0.0, sizeof(sample) * _synth_size); +} + +void Frame::destroy_synth_arrays() { + delete [] _synth; delete [] _synth_residual; } @@ -214,8 +221,8 @@ void Frame::synth_size(int new_size) { _synth_size = new_size; if(_alloc_memory) { - destroy_arrays(); - create_arrays(); + destroy_synth_arrays(); + create_synth_arrays(); } } diff --git a/src/simpl/base.h b/src/simpl/base.h index 5a3bf5b..cfa139c 100644 --- a/src/simpl/base.h +++ b/src/simpl/base.h @@ -60,6 +60,8 @@ class Frame { bool _alloc_memory; void create_arrays(); void destroy_arrays(); + void create_synth_arrays(); + void destroy_synth_arrays(); public: Frame(); diff --git a/src/simpl/synthesis.cpp b/src/simpl/synthesis.cpp index 5784522..3f48c78 100644 --- a/src/simpl/synthesis.cpp +++ b/src/simpl/synthesis.cpp @@ -51,10 +51,7 @@ void Synthesis::synth_frame(Frame* frame) { Frames Synthesis::synth(Frames frames) { for(int i = 0; i < frames.size(); i++) { - sample* synth_audio = new sample[_frame_size]; - memset(synth_audio, 0.0, sizeof(sample) * _frame_size); - frames[i]->synth(synth_audio); - frames[i]->synth_size(_frame_size); + frames[i]->synth_size(_hop_size); synth_frame(frames[i]); } return frames; diff --git a/tests/test_synthesis.cpp b/tests/test_synthesis.cpp index f4d215d..50ca6ed 100644 --- a/tests/test_synthesis.cpp +++ b/tests/test_synthesis.cpp @@ -39,8 +39,12 @@ protected: frames = synth->synth(frames); for(int i = 0; i < frames.size(); i++) { - CPPUNIT_ASSERT(frames[i]->num_peaks() > 0); - CPPUNIT_ASSERT(frames[i]->num_partials() > 0); + // if Loris thinPeaks is used, final frame will have no peaks + // so don't check it + if(i < frames.size() - 1) { + CPPUNIT_ASSERT(frames[i]->num_peaks() > 0); + CPPUNIT_ASSERT(frames[i]->num_partials() > 0); + } double energy = 0.f; for(int j = 0; j < synth->hop_size(); j++) { -- cgit v1.2.3