Mercurial > hg > qm-dsp
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 |