#include "ardour/tempo.h" #include "tempo_test.h" CPPUNIT_TEST_SUITE_REGISTRATION (TempoTest); using namespace std; using namespace ARDOUR; using namespace Timecode; void TempoTest::recomputeMapTest () { int const sampling_rate = 48000; TempoMap map (sampling_rate); Meter meterA (4, 4); map.add_meter (meterA, 0.0, BBT_Time (1, 1, 0), 0, AudioTime); /* 120bpm at bar 1, 240bpm at bar 4 120bpm = 24e3 samples per beat 240bpm = 12e3 samples per beat */ /* 120bpm 240bpm 0 beats 12 beats 0 frames 288e3 frames 0 pulses 3 pulses | | | | | | 1.1 1.2 1.3 1.4 | 2.1 2.2 2.3.2.4 | 3.1 3.2 3.3 3.4 | 4.1 4.2 4.3 | */ Tempo tempoA (120); map.add_tempo (tempoA, 0.0, 0, TempoSection::Constant, AudioTime); Tempo tempoB (240); map.add_tempo (tempoB, 3.0, 0, TempoSection::Constant, MusicTime); Meter meterB (3, 4); map.add_meter (meterB, 12.0, BBT_Time (4, 1, 0), 0, MusicTime); list::iterator i = map._metrics.begin(); CPPUNIT_ASSERT_EQUAL (framepos_t (0), (*i)->frame ()); i = map._metrics.end(); --i; CPPUNIT_ASSERT_EQUAL (framepos_t (288e3), (*i)->frame ()); } void TempoTest::rampTest () { int const sampling_rate = 48000; TempoMap map (sampling_rate); Meter meterA (4, 4); Tempo tempoA (77.0, 4.0); Tempo tempoB (217.0, 4.0); map.add_tempo (tempoA, 0.0, 0, TempoSection::Ramp, AudioTime); map.add_tempo (tempoB, 0.0, (framepos_t) 60 * sampling_rate, TempoSection::Ramp, AudioTime); map.add_meter (meterA, 0.0, BBT_Time (1, 1, 0), 0, AudioTime); /* 77bpm / note typeA 217bpm / note type B 0 frames 60 * sample rate frames | | | | | | *| | * | | * | | * | | * | | * | | * | | * | | | * | | | * | | | -------------------|-----------|----------------------- 20 seconds 125.0 bpm / note_type */ TempoSection* tA = 0; TempoSection* tB; list::iterator i; for (i = map._metrics.begin(); i != map._metrics.end(); ++i) { if ((tB = dynamic_cast (*i)) != 0) { if (tA) { break; } tA = tB; } } map.recompute_map (map._metrics); CPPUNIT_ASSERT_EQUAL (tB->frame(), tA->frame_at_tempo (tB->beats_per_minute() / tB->note_type(), 300.0, sampling_rate)); CPPUNIT_ASSERT_EQUAL (tB->frame(), tA->frame_at_pulse (tB->pulse(), sampling_rate)); /* self-check tempo at pulse @ 125 bpm. */ CPPUNIT_ASSERT_DOUBLES_EQUAL (125.0 / 4.0, tA->tempo_at_pulse (tA->pulse_at_tempo (125.0 / 4.0, 0, sampling_rate)), 0.00000000000000001); /* self-check frame at pulse 20 seconds in. */ const framepos_t target = 20 * sampling_rate; const framepos_t result = tA->frame_at_pulse (tA->pulse_at_frame (target, sampling_rate), sampling_rate); CPPUNIT_ASSERT_EQUAL (target, result); }