comparison tests/TestWindow.cpp @ 351:5d9489187abd

Add sinc
author Chris Cannam <c.cannam@qmul.ac.uk>
date Thu, 10 Oct 2013 17:53:41 +0100
parents b247af4c23d2
children 152abaf17c62
comparison
equal deleted inserted replaced
350:a067c2eeb13c 351:5d9489187abd
1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */ 1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */
2 2
3 #include "base/Window.h" 3 #include "base/Window.h"
4 #include "base/KaiserWindow.h" 4 #include "base/KaiserWindow.h"
5 #include "base/SincWindow.h"
5 6
6 #include <iostream> 7 #include <iostream>
7 8
8 #define BOOST_TEST_DYN_LINK 9 #define BOOST_TEST_DYN_LINK
9 #define BOOST_TEST_MAIN 10 #define BOOST_TEST_MAIN
150 k.cut(d); 151 k.cut(d);
151 COMPARE_ARRAY(d, e); 152 COMPARE_ARRAY(d, e);
152 } 153 }
153 154
154 //!!! todo: tests for kaiser with attenuation and bandwidth parameters 155 //!!! todo: tests for kaiser with attenuation and bandwidth parameters
156
157 template <int N>
158 void testSinc(double p, const double expected[N])
159 {
160 double d[N];
161 for (int i = 0; i < N; ++i) d[i] = 1.0;
162 SincWindow w(N, p);
163 w.cut(d);
164 COMPARE_ARRAY(d, expected);
165
166 double d0[N], d1[N];
167 for (int i = 0; i < N; ++i) d0[i] = 0.5 + (1.0 / (N * 2)) * (i + 1);
168 w.cut(d0, d1);
169 for (int i = 0; i < N; ++i) {
170 BOOST_CHECK_SMALL(d1[i] - d0[i] * expected[i], 1e-4);
171 }
172 }
173
174 BOOST_AUTO_TEST_CASE(sinc)
175 {
176 double e1[] = { 0, 0, 1, 0, 0 };
177 testSinc<5>(1, e1);
178
179 double e2[] = { 0, 0, 1, 0, 0 };
180 testSinc<5>(2, e2);
181
182 double e3[] = { -0.2122, 0.0, 0.6366, 1.0, 0.6366, 0, -0.2122 };
183 testSinc<7>(4, e3);
184
185 double e4[] = { -0.2122, 0, 0.6366, 1, 0.6366, 0 };
186 testSinc<6>(4, e4);
187 }
155 188
156 BOOST_AUTO_TEST_SUITE_END() 189 BOOST_AUTO_TEST_SUITE_END()
157 190