#include "tests/utils.h" #include "audiographer/general/interleaver.h" #include "audiographer/general/deinterleaver.h" using namespace AudioGrapher; class InterleaverDeInterleaverTest : public CppUnit::TestFixture { CPPUNIT_TEST_SUITE (InterleaverDeInterleaverTest); CPPUNIT_TEST (testInterleavedInput); CPPUNIT_TEST (testDeInterleavedInput); CPPUNIT_TEST_SUITE_END (); public: void setUp() { channels = 3; samples_per_channel = 128; total_samples = channels * samples_per_channel; random_data_a = TestUtils::init_random_data (total_samples, 1.0); random_data_b = TestUtils::init_random_data (samples_per_channel, 1.0); random_data_c = TestUtils::init_random_data (samples_per_channel, 1.0); deinterleaver.reset (new DeInterleaver()); interleaver.reset (new Interleaver()); sink_a.reset (new VectorSink()); sink_b.reset (new VectorSink()); sink_c.reset (new VectorSink()); } void tearDown() { delete [] random_data_a; delete [] random_data_b; delete [] random_data_c; } void testInterleavedInput() { deinterleaver->init (channels, samples_per_channel); interleaver->init (channels, samples_per_channel); deinterleaver->output (0)->add_output (interleaver->input (0)); deinterleaver->output (1)->add_output (interleaver->input (1)); deinterleaver->output (2)->add_output (interleaver->input (2)); interleaver->add_output (sink_a); // Process and assert ProcessContext c (random_data_a, total_samples, channels); deinterleaver->process (c); CPPUNIT_ASSERT (TestUtils::array_equals (random_data_a, sink_a->get_array(), total_samples)); // And a second round... samplecnt_t less_samples = (samples_per_channel / 10) * channels; deinterleaver->process (c.beginning (less_samples)); CPPUNIT_ASSERT (TestUtils::array_equals (random_data_a, sink_a->get_array(), less_samples)); } void testDeInterleavedInput() { deinterleaver->init (channels, samples_per_channel); interleaver->init (channels, samples_per_channel); interleaver->add_output (deinterleaver); deinterleaver->output (0)->add_output (sink_a); deinterleaver->output (1)->add_output (sink_b); deinterleaver->output (2)->add_output (sink_c); ProcessContext c_a (random_data_a, samples_per_channel, 1); ProcessContext c_b (random_data_b, samples_per_channel, 1); ProcessContext c_c (random_data_c, samples_per_channel, 1); // Process and assert interleaver->input (0)->process (c_a); interleaver->input (1)->process (c_b); interleaver->input (2)->process (c_c); CPPUNIT_ASSERT (TestUtils::array_equals (random_data_a, sink_a->get_array(), samples_per_channel)); CPPUNIT_ASSERT (TestUtils::array_equals (random_data_b, sink_b->get_array(), samples_per_channel)); CPPUNIT_ASSERT (TestUtils::array_equals (random_data_c, sink_c->get_array(), samples_per_channel)); // And a second round... samplecnt_t less_samples = samples_per_channel / 5; interleaver->input (0)->process (c_a.beginning (less_samples)); interleaver->input (1)->process (c_b.beginning (less_samples)); interleaver->input (2)->process (c_c.beginning (less_samples)); CPPUNIT_ASSERT (TestUtils::array_equals (random_data_a, sink_a->get_array(), less_samples)); CPPUNIT_ASSERT (TestUtils::array_equals (random_data_b, sink_b->get_array(), less_samples)); CPPUNIT_ASSERT (TestUtils::array_equals (random_data_c, sink_c->get_array(), less_samples)); } private: boost::shared_ptr > interleaver; boost::shared_ptr > deinterleaver; boost::shared_ptr > sink_a; boost::shared_ptr > sink_b; boost::shared_ptr > sink_c; float * random_data_a; float * random_data_b; float * random_data_c; samplecnt_t samples_per_channel; samplecnt_t total_samples; unsigned int channels; }; CPPUNIT_TEST_SUITE_REGISTRATION (InterleaverDeInterleaverTest);