TransformCF64.cpp 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446
  1. #include "TransformCF64.h"
  2. #include <stdio.h>
  3. #include "Error.h"
  4. #include "Test.h"
  5. #define SNR_THRESHOLD 250
  6. void TransformCF64::test_cfft_f64()
  7. {
  8. const float64_t *inp = input.ptr();
  9. float64_t *outfftp = outputfft.ptr();
  10. memcpy(outfftp,inp,sizeof(float64_t)*input.nbSamples());
  11. arm_cfft_f64(
  12. &(this->varInstCfftF64),
  13. outfftp,
  14. this->ifft,
  15. 1);
  16. ASSERT_SNR(outputfft,ref,(float64_t)SNR_THRESHOLD);
  17. ASSERT_EMPTY_TAIL(outputfft);
  18. }
  19. void TransformCF64::setUp(Testing::testID_t id,std::vector<Testing::param_t>& paramsArgs,Client::PatternMgr *mgr)
  20. {
  21. (void)paramsArgs;
  22. switch(id)
  23. {
  24. case TransformCF64::TEST_CFFT_F64_1:
  25. input.reload(TransformCF64::INPUTS_CFFT_NOISY_16_F64_ID,mgr);
  26. ref.reload( TransformCF64::REF_CFFT_NOISY_16_F64_ID,mgr);
  27. status=arm_cfft_init_f64(&varInstCfftF64,16);
  28. this->ifft=0;
  29. break;
  30. case TransformCF64::TEST_CFFT_F64_19:
  31. input.reload(TransformCF64::INPUTS_CIFFT_NOISY_16_F64_ID,mgr);
  32. ref.reload( TransformCF64::INPUTS_CFFT_NOISY_16_F64_ID,mgr);
  33. status=arm_cfft_init_f64(&varInstCfftF64,16);
  34. this->ifft=1;
  35. break;
  36. case TransformCF64::TEST_CFFT_F64_2:
  37. input.reload(TransformCF64::INPUTS_CFFT_NOISY_32_F64_ID,mgr);
  38. ref.reload( TransformCF64::REF_CFFT_NOISY_32_F64_ID,mgr);
  39. status=arm_cfft_init_f64(&varInstCfftF64,32);
  40. this->ifft=0;
  41. break;
  42. case TransformCF64::TEST_CFFT_F64_20:
  43. input.reload(TransformCF64::INPUTS_CIFFT_NOISY_32_F64_ID,mgr);
  44. ref.reload( TransformCF64::INPUTS_CFFT_NOISY_32_F64_ID,mgr);
  45. status=arm_cfft_init_f64(&varInstCfftF64,32);
  46. this->ifft=1;
  47. break;
  48. case TransformCF64::TEST_CFFT_F64_3:
  49. input.reload(TransformCF64::INPUTS_CFFT_NOISY_64_F64_ID,mgr);
  50. ref.reload( TransformCF64::REF_CFFT_NOISY_64_F64_ID,mgr);
  51. status=arm_cfft_init_f64(&varInstCfftF64,64);
  52. this->ifft=0;
  53. break;
  54. case TransformCF64::TEST_CFFT_F64_21:
  55. input.reload(TransformCF64::INPUTS_CIFFT_NOISY_64_F64_ID,mgr);
  56. ref.reload( TransformCF64::INPUTS_CFFT_NOISY_64_F64_ID,mgr);
  57. status=arm_cfft_init_f64(&varInstCfftF64,64);
  58. this->ifft=1;
  59. break;
  60. case TransformCF64::TEST_CFFT_F64_4:
  61. input.reload(TransformCF64::INPUTS_CFFT_NOISY_128_F64_ID,mgr);
  62. ref.reload( TransformCF64::REF_CFFT_NOISY_128_F64_ID,mgr);
  63. status=arm_cfft_init_f64(&varInstCfftF64,128);
  64. this->ifft=0;
  65. break;
  66. case TransformCF64::TEST_CFFT_F64_22:
  67. input.reload(TransformCF64::INPUTS_CIFFT_NOISY_128_F64_ID,mgr);
  68. ref.reload( TransformCF64::INPUTS_CFFT_NOISY_128_F64_ID,mgr);
  69. status=arm_cfft_init_f64(&varInstCfftF64,128);
  70. this->ifft=1;
  71. break;
  72. case TransformCF64::TEST_CFFT_F64_5:
  73. input.reload(TransformCF64::INPUTS_CFFT_NOISY_256_F64_ID,mgr);
  74. ref.reload( TransformCF64::REF_CFFT_NOISY_256_F64_ID,mgr);
  75. status=arm_cfft_init_f64(&varInstCfftF64,256);
  76. this->ifft=0;
  77. break;
  78. case TransformCF64::TEST_CFFT_F64_23:
  79. input.reload(TransformCF64::INPUTS_CIFFT_NOISY_256_F64_ID,mgr);
  80. ref.reload( TransformCF64::INPUTS_CFFT_NOISY_256_F64_ID,mgr);
  81. status=arm_cfft_init_f64(&varInstCfftF64,256);
  82. this->ifft=1;
  83. break;
  84. case TransformCF64::TEST_CFFT_F64_6:
  85. input.reload(TransformCF64::INPUTS_CFFT_NOISY_512_F64_ID,mgr);
  86. ref.reload( TransformCF64::REF_CFFT_NOISY_512_F64_ID,mgr);
  87. status=arm_cfft_init_f64(&varInstCfftF64,512);
  88. this->ifft=0;
  89. break;
  90. case TransformCF64::TEST_CFFT_F64_24:
  91. input.reload(TransformCF64::INPUTS_CIFFT_NOISY_512_F64_ID,mgr);
  92. ref.reload( TransformCF64::INPUTS_CFFT_NOISY_512_F64_ID,mgr);
  93. status=arm_cfft_init_f64(&varInstCfftF64,512);
  94. this->ifft=1;
  95. break;
  96. case TransformCF64::TEST_CFFT_F64_7:
  97. input.reload(TransformCF64::INPUTS_CFFT_NOISY_1024_F64_ID,mgr);
  98. ref.reload( TransformCF64::REF_CFFT_NOISY_1024_F64_ID,mgr);
  99. status=arm_cfft_init_f64(&varInstCfftF64,1024);
  100. this->ifft=0;
  101. break;
  102. case TransformCF64::TEST_CFFT_F64_25:
  103. input.reload(TransformCF64::INPUTS_CIFFT_NOISY_1024_F64_ID,mgr);
  104. ref.reload( TransformCF64::INPUTS_CFFT_NOISY_1024_F64_ID,mgr);
  105. status=arm_cfft_init_f64(&varInstCfftF64,1024);
  106. this->ifft=1;
  107. break;
  108. case TransformCF64::TEST_CFFT_F64_8:
  109. input.reload(TransformCF64::INPUTS_CFFT_NOISY_2048_F64_ID,mgr);
  110. ref.reload( TransformCF64::REF_CFFT_NOISY_2048_F64_ID,mgr);
  111. status=arm_cfft_init_f64(&varInstCfftF64,2048);
  112. this->ifft=0;
  113. break;
  114. case TransformCF64::TEST_CFFT_F64_26:
  115. input.reload(TransformCF64::INPUTS_CIFFT_NOISY_2048_F64_ID,mgr);
  116. ref.reload( TransformCF64::INPUTS_CFFT_NOISY_2048_F64_ID,mgr);
  117. status=arm_cfft_init_f64(&varInstCfftF64,2048);
  118. this->ifft=1;
  119. break;
  120. case TransformCF64::TEST_CFFT_F64_9:
  121. input.reload(TransformCF64::INPUTS_CFFT_NOISY_4096_F64_ID,mgr);
  122. ref.reload( TransformCF64::REF_CFFT_NOISY_4096_F64_ID,mgr);
  123. status=arm_cfft_init_f64(&varInstCfftF64,4096);
  124. this->ifft=0;
  125. break;
  126. case TransformCF64::TEST_CFFT_F64_27:
  127. input.reload(TransformCF64::INPUTS_CIFFT_NOISY_4096_F64_ID,mgr);
  128. ref.reload( TransformCF64::INPUTS_CFFT_NOISY_4096_F64_ID,mgr);
  129. status=arm_cfft_init_f64(&varInstCfftF64,4096);
  130. this->ifft=1;
  131. break;
  132. /* STEP FUNCTIONS */
  133. case TransformCF64::TEST_CFFT_F64_10:
  134. input.reload(TransformCF64::INPUTS_CFFT_STEP_16_F64_ID,mgr);
  135. ref.reload( TransformCF64::REF_CFFT_STEP_16_F64_ID,mgr);
  136. status=arm_cfft_init_f64(&varInstCfftF64,16);
  137. this->ifft=0;
  138. break;
  139. case TransformCF64::TEST_CFFT_F64_28:
  140. input.reload(TransformCF64::INPUTS_CIFFT_STEP_16_F64_ID,mgr);
  141. ref.reload( TransformCF64::INPUTS_CFFT_STEP_16_F64_ID,mgr);
  142. status=arm_cfft_init_f64(&varInstCfftF64,16);
  143. this->ifft=1;
  144. break;
  145. case TransformCF64::TEST_CFFT_F64_11:
  146. input.reload(TransformCF64::INPUTS_CFFT_STEP_32_F64_ID,mgr);
  147. ref.reload( TransformCF64::REF_CFFT_STEP_32_F64_ID,mgr);
  148. status=arm_cfft_init_f64(&varInstCfftF64,32);
  149. this->ifft=0;
  150. break;
  151. case TransformCF64::TEST_CFFT_F64_29:
  152. input.reload(TransformCF64::INPUTS_CIFFT_STEP_32_F64_ID,mgr);
  153. ref.reload( TransformCF64::INPUTS_CFFT_STEP_32_F64_ID,mgr);
  154. status=arm_cfft_init_f64(&varInstCfftF64,32);
  155. this->ifft=1;
  156. break;
  157. case TransformCF64::TEST_CFFT_F64_12:
  158. input.reload(TransformCF64::INPUTS_CFFT_STEP_64_F64_ID,mgr);
  159. ref.reload( TransformCF64::REF_CFFT_STEP_64_F64_ID,mgr);
  160. status=arm_cfft_init_f64(&varInstCfftF64,64);
  161. this->ifft=0;
  162. break;
  163. case TransformCF64::TEST_CFFT_F64_30:
  164. input.reload(TransformCF64::INPUTS_CIFFT_STEP_64_F64_ID,mgr);
  165. ref.reload( TransformCF64::INPUTS_CFFT_STEP_64_F64_ID,mgr);
  166. status=arm_cfft_init_f64(&varInstCfftF64,64);
  167. this->ifft=1;
  168. break;
  169. case TransformCF64::TEST_CFFT_F64_13:
  170. input.reload(TransformCF64::INPUTS_CFFT_STEP_128_F64_ID,mgr);
  171. ref.reload( TransformCF64::REF_CFFT_STEP_128_F64_ID,mgr);
  172. status=arm_cfft_init_f64(&varInstCfftF64,128);
  173. this->ifft=0;
  174. break;
  175. case TransformCF64::TEST_CFFT_F64_31:
  176. input.reload(TransformCF64::INPUTS_CIFFT_STEP_128_F64_ID,mgr);
  177. ref.reload( TransformCF64::INPUTS_CFFT_STEP_128_F64_ID,mgr);
  178. status=arm_cfft_init_f64(&varInstCfftF64,128);
  179. this->ifft=1;
  180. break;
  181. case TransformCF64::TEST_CFFT_F64_14:
  182. input.reload(TransformCF64::INPUTS_CFFT_STEP_256_F64_ID,mgr);
  183. ref.reload( TransformCF64::REF_CFFT_STEP_256_F64_ID,mgr);
  184. status=arm_cfft_init_f64(&varInstCfftF64,256);
  185. this->ifft=0;
  186. break;
  187. case TransformCF64::TEST_CFFT_F64_32:
  188. input.reload(TransformCF64::INPUTS_CIFFT_STEP_256_F64_ID,mgr);
  189. ref.reload( TransformCF64::INPUTS_CFFT_STEP_256_F64_ID,mgr);
  190. status=arm_cfft_init_f64(&varInstCfftF64,256);
  191. this->ifft=1;
  192. break;
  193. case TransformCF64::TEST_CFFT_F64_15:
  194. input.reload(TransformCF64::INPUTS_CFFT_STEP_512_F64_ID,mgr);
  195. ref.reload( TransformCF64::REF_CFFT_STEP_512_F64_ID,mgr);
  196. status=arm_cfft_init_f64(&varInstCfftF64,512);
  197. this->ifft=0;
  198. break;
  199. case TransformCF64::TEST_CFFT_F64_33:
  200. input.reload(TransformCF64::INPUTS_CIFFT_STEP_512_F64_ID,mgr);
  201. ref.reload( TransformCF64::INPUTS_CFFT_STEP_512_F64_ID,mgr);
  202. status=arm_cfft_init_f64(&varInstCfftF64,512);
  203. this->ifft=1;
  204. break;
  205. case TransformCF64::TEST_CFFT_F64_16:
  206. input.reload(TransformCF64::INPUTS_CFFT_STEP_1024_F64_ID,mgr);
  207. ref.reload( TransformCF64::REF_CFFT_STEP_1024_F64_ID,mgr);
  208. status=arm_cfft_init_f64(&varInstCfftF64,1024);
  209. this->ifft=0;
  210. break;
  211. case TransformCF64::TEST_CFFT_F64_34:
  212. input.reload(TransformCF64::INPUTS_CIFFT_STEP_1024_F64_ID,mgr);
  213. ref.reload( TransformCF64::INPUTS_CFFT_STEP_1024_F64_ID,mgr);
  214. status=arm_cfft_init_f64(&varInstCfftF64,1024);
  215. this->ifft=1;
  216. break;
  217. case TransformCF64::TEST_CFFT_F64_17:
  218. input.reload(TransformCF64::INPUTS_CFFT_STEP_2048_F64_ID,mgr);
  219. ref.reload( TransformCF64::REF_CFFT_STEP_2048_F64_ID,mgr);
  220. status=arm_cfft_init_f64(&varInstCfftF64,2048);
  221. this->ifft=0;
  222. break;
  223. case TransformCF64::TEST_CFFT_F64_35:
  224. input.reload(TransformCF64::INPUTS_CIFFT_STEP_2048_F64_ID,mgr);
  225. ref.reload( TransformCF64::INPUTS_CFFT_STEP_2048_F64_ID,mgr);
  226. status=arm_cfft_init_f64(&varInstCfftF64,2048);
  227. this->ifft=1;
  228. break;
  229. case TransformCF64::TEST_CFFT_F64_18:
  230. input.reload(TransformCF64::INPUTS_CFFT_STEP_4096_F64_ID,mgr);
  231. ref.reload( TransformCF64::REF_CFFT_STEP_4096_F64_ID,mgr);
  232. status=arm_cfft_init_f64(&varInstCfftF64,4096);
  233. this->ifft=0;
  234. break;
  235. case TransformCF64::TEST_CFFT_F64_36:
  236. input.reload(TransformCF64::INPUTS_CIFFT_STEP_4096_F64_ID,mgr);
  237. ref.reload( TransformCF64::INPUTS_CFFT_STEP_4096_F64_ID,mgr);
  238. status=arm_cfft_init_f64(&varInstCfftF64,4096);
  239. this->ifft=1;
  240. break;
  241. }
  242. outputfft.create(ref.nbSamples(),TransformCF64::OUTPUT_CFFT_F64_ID,mgr);
  243. }
  244. void TransformCF64::tearDown(Testing::testID_t id,Client::PatternMgr *mgr)
  245. {
  246. (void)id;
  247. outputfft.dump(mgr);
  248. }