annotate tests/TestWindow.cpp @ 118:4920d100b290 pvoc

Don't use tabs
author Chris Cannam
date Wed, 02 Oct 2013 18:22:06 +0100
parents 469d234acb9e
children 263181813eec
rev   line source
Chris@118 1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */
Chris@110 2
Chris@110 3 #include "base/Window.h"
Chris@110 4
Chris@110 5 #include <iostream>
Chris@110 6
Chris@110 7 #define BOOST_TEST_DYN_LINK
Chris@110 8 #define BOOST_TEST_MAIN
Chris@110 9
Chris@110 10 #include <boost/test/unit_test.hpp>
Chris@110 11
Chris@110 12 BOOST_AUTO_TEST_SUITE(TestWindow)
Chris@110 13
Chris@110 14 using std::cout;
Chris@110 15 using std::endl;
Chris@110 16
Chris@110 17 #define COMPARE_ARRAY(a, b) \
Chris@110 18 for (int cmp_i = 0; cmp_i < (int)(sizeof(a)/sizeof(a[0])); ++cmp_i) { \
Chris@110 19 BOOST_CHECK_SMALL(a[cmp_i] - b[cmp_i], 1e-4); \
Chris@110 20 }
Chris@110 21
Chris@110 22 void
Chris@110 23 testSymmetric(double *d, int n)
Chris@110 24 {
Chris@110 25 for (int i = 0; i <= n/2; ++i) {
Chris@110 26 BOOST_CHECK_CLOSE(d[i], d[n-i-1], 1e-10);
Chris@110 27 }
Chris@110 28 }
Chris@110 29
Chris@110 30 BOOST_AUTO_TEST_CASE(periodic)
Chris@110 31 {
Chris@110 32 // We can't actually test whether a function is periodic, given
Chris@110 33 // only one cycle of it! But we can make sure that all but the
Chris@110 34 // first sample is symmetric, which is what a symmetric window
Chris@110 35 // becomes when generated in periodic mode
Chris@110 36 double d[9];
Chris@110 37 for (int n = 8; n <= 9; ++n) {
Chris@110 38 for (int wt = (int)FirstWindow; wt <= (int)LastWindow; ++wt) {
Chris@110 39 for (int i = 0; i < n; ++i) d[i] = 1.0;
Chris@110 40 Window<double> w((WindowType)wt, n);
Chris@110 41 w.cut(d);
Chris@110 42 testSymmetric(d + 1, n - 1);
Chris@110 43 }
Chris@110 44 }
Chris@110 45 }
Chris@110 46
Chris@110 47 template <int N>
Chris@110 48 void testWindow(WindowType type, const double expected[N])
Chris@110 49 {
Chris@110 50 double d[N];
Chris@110 51 for (int i = 0; i < N; ++i) d[i] = 1.0;
Chris@110 52 Window<double> w(type, N);
Chris@110 53 w.cut(d);
Chris@110 54 COMPARE_ARRAY(d, expected);
Chris@111 55
Chris@111 56 double d0[N], d1[N];
Chris@111 57 for (int i = 0; i < N; ++i) d0[i] = 0.5 + (1.0 / (N * 2)) * (i + 1);
Chris@111 58 w.cut(d0, d1);
Chris@111 59 for (int i = 0; i < N; ++i) {
Chris@111 60 BOOST_CHECK_SMALL(d1[i] - d0[i] * expected[i], 1e-4);
Chris@111 61 }
Chris@110 62 }
Chris@110 63
Chris@110 64 BOOST_AUTO_TEST_CASE(bartlett)
Chris@110 65 {
Chris@110 66 double e1[] = { 1 };
Chris@110 67 testWindow<1>(BartlettWindow, e1);
Chris@110 68
Chris@110 69 double e2[] = { 0, 0 };
Chris@110 70 testWindow<2>(BartlettWindow, e2);
Chris@110 71
Chris@110 72 double e3[] = { 0, 2./3., 2./3. };
Chris@110 73 testWindow<3>(BartlettWindow, e3);
Chris@110 74
Chris@110 75 double e4[] = { 0, 1./2., 1., 1./2. };
Chris@110 76 testWindow<4>(BartlettWindow, e4);
Chris@110 77
Chris@110 78 double e5[] = { 0, 1./2., 1., 1., 1./2. };
Chris@110 79 testWindow<5>(BartlettWindow, e5);
Chris@110 80
Chris@110 81 double e6[] = { 0, 1./3., 2./3., 1., 2./3., 1./3. };
Chris@110 82 testWindow<6>(BartlettWindow, e6);
Chris@110 83 }
Chris@110 84
Chris@110 85 BOOST_AUTO_TEST_CASE(hamming)
Chris@110 86 {
Chris@110 87 double e1[] = { 1 };
Chris@110 88 testWindow<1>(HammingWindow, e1);
Chris@110 89
Chris@110 90 double e10[] = {
Chris@110 91 0.0800, 0.1679, 0.3979, 0.6821, 0.9121,
Chris@110 92 1.0000, 0.9121, 0.6821, 0.3979, 0.1679
Chris@110 93 };
Chris@110 94 testWindow<10>(HammingWindow, e10);
Chris@110 95 }
Chris@110 96
Chris@110 97 BOOST_AUTO_TEST_CASE(hann)
Chris@110 98 {
Chris@110 99 double e1[] = { 1 };
Chris@110 100 testWindow<1>(HanningWindow, e1);
Chris@110 101
Chris@110 102 double e10[] = {
Chris@110 103 0, 0.0955, 0.3455, 0.6545, 0.9045,
Chris@110 104 1.0000, 0.9045, 0.6545, 0.3455, 0.0955,
Chris@110 105 };
Chris@110 106 testWindow<10>(HanningWindow, e10);
Chris@110 107 }
Chris@110 108
Chris@110 109 BOOST_AUTO_TEST_CASE(blackman)
Chris@110 110 {
Chris@110 111 double e1[] = { 1 };
Chris@110 112 testWindow<1>(BlackmanWindow, e1);
Chris@110 113
Chris@110 114 double e10[] = {
Chris@110 115 0, 0.0402, 0.2008, 0.5098, 0.8492,
Chris@110 116 1.0000, 0.8492, 0.5098, 0.2008, 0.0402,
Chris@110 117 };
Chris@110 118 testWindow<10>(BlackmanWindow, e10);
Chris@110 119 }
Chris@110 120
Chris@110 121 BOOST_AUTO_TEST_SUITE_END()
Chris@110 122