TransformRF32.cpp 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473
  1. #include "TransformRF32.h"
  2. #include <stdio.h>
  3. #include "Error.h"
  4. #include "Test.h"
  5. #define SNR_THRESHOLD 120
  6. void TransformRF32::test_rfft_f32()
  7. {
  8. float32_t *inp = input.ptr();
  9. float32_t *tmp = inputchanged.ptr();
  10. float32_t *outp = outputfft.ptr();
  11. memcpy(tmp,inp,sizeof(float32_t)*input.nbSamples());
  12. arm_rfft_fast_f32(
  13. &this->instRfftF32,
  14. tmp,
  15. outp,
  16. this->ifft);
  17. ASSERT_SNR(outputfft,ref,(float32_t)SNR_THRESHOLD);
  18. ASSERT_EMPTY_TAIL(outputfft);
  19. }
  20. void TransformRF32::setUp(Testing::testID_t id,std::vector<Testing::param_t>& paramsArgs,Client::PatternMgr *mgr)
  21. {
  22. (void)paramsArgs;
  23. switch(id)
  24. {
  25. case TransformRF32::TEST_RFFT_F32_1:
  26. input.reload(TransformRF32::INPUTS_RFFT_NOISY_32_F32_ID,mgr);
  27. ref.reload( TransformRF32::REF_RFFT_NOISY_32_F32_ID,mgr);
  28. arm_rfft_fast_init_f32(&this->instRfftF32 ,32);
  29. inputchanged.create(input.nbSamples(),TransformRF32::TEMP_F32_ID,mgr);
  30. this->ifft=0;
  31. break;
  32. case TransformRF32::TEST_RFFT_F32_17:
  33. input.reload(TransformRF32::INPUTS_RIFFT_NOISY_32_F32_ID,mgr);
  34. ref.reload( TransformRF32::INPUTS_RFFT_NOISY_32_F32_ID,mgr);
  35. arm_rfft_fast_init_f32(&this->instRfftF32 ,32);
  36. inputchanged.create(input.nbSamples(),TransformRF32::TEMP_F32_ID,mgr);
  37. this->ifft=1;
  38. break;
  39. case TransformRF32::TEST_RFFT_F32_2:
  40. input.reload(TransformRF32::INPUTS_RFFT_NOISY_64_F32_ID,mgr);
  41. ref.reload( TransformRF32::REF_RFFT_NOISY_64_F32_ID,mgr);
  42. arm_rfft_fast_init_f32(&this->instRfftF32 ,64);
  43. inputchanged.create(input.nbSamples(),TransformRF32::TEMP_F32_ID,mgr);
  44. this->ifft=0;
  45. break;
  46. case TransformRF32::TEST_RFFT_F32_18:
  47. input.reload(TransformRF32::INPUTS_RIFFT_NOISY_64_F32_ID,mgr);
  48. ref.reload( TransformRF32::INPUTS_RFFT_NOISY_64_F32_ID,mgr);
  49. arm_rfft_fast_init_f32(&this->instRfftF32 ,64);
  50. inputchanged.create(input.nbSamples(),TransformRF32::TEMP_F32_ID,mgr);
  51. this->ifft=1;
  52. break;
  53. case TransformRF32::TEST_RFFT_F32_3:
  54. input.reload(TransformRF32::INPUTS_RFFT_NOISY_128_F32_ID,mgr);
  55. ref.reload( TransformRF32::REF_RFFT_NOISY_128_F32_ID,mgr);
  56. arm_rfft_fast_init_f32(&this->instRfftF32 ,128);
  57. inputchanged.create(input.nbSamples(),TransformRF32::TEMP_F32_ID,mgr);
  58. this->ifft=0;
  59. break;
  60. case TransformRF32::TEST_RFFT_F32_19:
  61. input.reload(TransformRF32::INPUTS_RIFFT_NOISY_128_F32_ID,mgr);
  62. ref.reload( TransformRF32::INPUTS_RFFT_NOISY_128_F32_ID,mgr);
  63. arm_rfft_fast_init_f32(&this->instRfftF32 ,128);
  64. inputchanged.create(input.nbSamples(),TransformRF32::TEMP_F32_ID,mgr);
  65. this->ifft=1;
  66. break;
  67. case TransformRF32::TEST_RFFT_F32_4:
  68. input.reload(TransformRF32::INPUTS_RFFT_NOISY_256_F32_ID,mgr);
  69. ref.reload( TransformRF32::REF_RFFT_NOISY_256_F32_ID,mgr);
  70. arm_rfft_fast_init_f32(&this->instRfftF32 ,256);
  71. inputchanged.create(input.nbSamples(),TransformRF32::TEMP_F32_ID,mgr);
  72. this->ifft=0;
  73. break;
  74. case TransformRF32::TEST_RFFT_F32_20:
  75. input.reload(TransformRF32::INPUTS_RIFFT_NOISY_256_F32_ID,mgr);
  76. ref.reload( TransformRF32::INPUTS_RFFT_NOISY_256_F32_ID,mgr);
  77. arm_rfft_fast_init_f32(&this->instRfftF32 ,256);
  78. inputchanged.create(input.nbSamples(),TransformRF32::TEMP_F32_ID,mgr);
  79. this->ifft=1;
  80. break;
  81. case TransformRF32::TEST_RFFT_F32_5:
  82. input.reload(TransformRF32::INPUTS_RFFT_NOISY_512_F32_ID,mgr);
  83. ref.reload( TransformRF32::REF_RFFT_NOISY_512_F32_ID,mgr);
  84. arm_rfft_fast_init_f32(&this->instRfftF32 ,512);
  85. inputchanged.create(input.nbSamples(),TransformRF32::TEMP_F32_ID,mgr);
  86. this->ifft=0;
  87. break;
  88. case TransformRF32::TEST_RFFT_F32_21:
  89. input.reload(TransformRF32::INPUTS_RIFFT_NOISY_512_F32_ID,mgr);
  90. ref.reload( TransformRF32::INPUTS_RFFT_NOISY_512_F32_ID,mgr);
  91. arm_rfft_fast_init_f32(&this->instRfftF32 ,512);
  92. inputchanged.create(input.nbSamples(),TransformRF32::TEMP_F32_ID,mgr);
  93. this->ifft=1;
  94. break;
  95. case TransformRF32::TEST_RFFT_F32_6:
  96. input.reload(TransformRF32::INPUTS_RFFT_NOISY_1024_F32_ID,mgr);
  97. ref.reload( TransformRF32::REF_RFFT_NOISY_1024_F32_ID,mgr);
  98. arm_rfft_fast_init_f32(&this->instRfftF32 ,1024);
  99. inputchanged.create(input.nbSamples(),TransformRF32::TEMP_F32_ID,mgr);
  100. this->ifft=0;
  101. break;
  102. case TransformRF32::TEST_RFFT_F32_22:
  103. input.reload(TransformRF32::INPUTS_RIFFT_NOISY_1024_F32_ID,mgr);
  104. ref.reload( TransformRF32::INPUTS_RFFT_NOISY_1024_F32_ID,mgr);
  105. arm_rfft_fast_init_f32(&this->instRfftF32 ,1024);
  106. inputchanged.create(input.nbSamples(),TransformRF32::TEMP_F32_ID,mgr);
  107. this->ifft=1;
  108. break;
  109. case TransformRF32::TEST_RFFT_F32_7:
  110. input.reload(TransformRF32::INPUTS_RFFT_NOISY_2048_F32_ID,mgr);
  111. ref.reload( TransformRF32::REF_RFFT_NOISY_2048_F32_ID,mgr);
  112. arm_rfft_fast_init_f32(&this->instRfftF32 ,2048);
  113. inputchanged.create(input.nbSamples(),TransformRF32::TEMP_F32_ID,mgr);
  114. this->ifft=0;
  115. break;
  116. case TransformRF32::TEST_RFFT_F32_23:
  117. input.reload(TransformRF32::INPUTS_RIFFT_NOISY_2048_F32_ID,mgr);
  118. ref.reload( TransformRF32::INPUTS_RFFT_NOISY_2048_F32_ID,mgr);
  119. arm_rfft_fast_init_f32(&this->instRfftF32 ,2048);
  120. inputchanged.create(input.nbSamples(),TransformRF32::TEMP_F32_ID,mgr);
  121. this->ifft=1;
  122. break;
  123. case TransformRF32::TEST_RFFT_F32_8:
  124. input.reload(TransformRF32::INPUTS_RFFT_NOISY_4096_F32_ID,mgr);
  125. ref.reload( TransformRF32::REF_RFFT_NOISY_4096_F32_ID,mgr);
  126. arm_rfft_fast_init_f32(&this->instRfftF32 ,4096);
  127. inputchanged.create(input.nbSamples(),TransformRF32::TEMP_F32_ID,mgr);
  128. this->ifft=0;
  129. break;
  130. case TransformRF32::TEST_RFFT_F32_24:
  131. input.reload(TransformRF32::INPUTS_RIFFT_NOISY_4096_F32_ID,mgr);
  132. ref.reload( TransformRF32::INPUTS_RFFT_NOISY_4096_F32_ID,mgr);
  133. arm_rfft_fast_init_f32(&this->instRfftF32 ,4096);
  134. inputchanged.create(input.nbSamples(),TransformRF32::TEMP_F32_ID,mgr);
  135. this->ifft=1;
  136. break;
  137. /* STEP FUNCTIONS */
  138. case TransformRF32::TEST_RFFT_F32_9:
  139. input.reload(TransformRF32::INPUTS_RFFT_STEP_32_F32_ID,mgr);
  140. ref.reload( TransformRF32::REF_RFFT_STEP_32_F32_ID,mgr);
  141. arm_rfft_fast_init_f32(&this->instRfftF32 ,32);
  142. inputchanged.create(input.nbSamples(),TransformRF32::TEMP_F32_ID,mgr);
  143. this->ifft=0;
  144. break;
  145. case TransformRF32::TEST_RFFT_F32_25:
  146. input.reload(TransformRF32::INPUTS_RIFFT_STEP_32_F32_ID,mgr);
  147. ref.reload( TransformRF32::INPUTS_RFFT_STEP_32_F32_ID,mgr);
  148. arm_rfft_fast_init_f32(&this->instRfftF32 ,32);
  149. inputchanged.create(input.nbSamples(),TransformRF32::TEMP_F32_ID,mgr);
  150. this->ifft=1;
  151. break;
  152. case TransformRF32::TEST_RFFT_F32_10:
  153. input.reload(TransformRF32::INPUTS_RFFT_STEP_64_F32_ID,mgr);
  154. ref.reload( TransformRF32::REF_RFFT_STEP_64_F32_ID,mgr);
  155. arm_rfft_fast_init_f32(&this->instRfftF32 ,64);
  156. inputchanged.create(input.nbSamples(),TransformRF32::TEMP_F32_ID,mgr);
  157. this->ifft=0;
  158. break;
  159. case TransformRF32::TEST_RFFT_F32_26:
  160. input.reload(TransformRF32::INPUTS_RIFFT_STEP_64_F32_ID,mgr);
  161. ref.reload( TransformRF32::INPUTS_RFFT_STEP_64_F32_ID,mgr);
  162. arm_rfft_fast_init_f32(&this->instRfftF32 ,64);
  163. inputchanged.create(input.nbSamples(),TransformRF32::TEMP_F32_ID,mgr);
  164. this->ifft=1;
  165. break;
  166. case TransformRF32::TEST_RFFT_F32_11:
  167. input.reload(TransformRF32::INPUTS_RFFT_STEP_128_F32_ID,mgr);
  168. ref.reload( TransformRF32::REF_RFFT_STEP_128_F32_ID,mgr);
  169. arm_rfft_fast_init_f32(&this->instRfftF32 ,128);
  170. inputchanged.create(input.nbSamples(),TransformRF32::TEMP_F32_ID,mgr);
  171. this->ifft=0;
  172. break;
  173. case TransformRF32::TEST_RFFT_F32_27:
  174. input.reload(TransformRF32::INPUTS_RIFFT_STEP_128_F32_ID,mgr);
  175. ref.reload( TransformRF32::INPUTS_RFFT_STEP_128_F32_ID,mgr);
  176. arm_rfft_fast_init_f32(&this->instRfftF32 ,128);
  177. inputchanged.create(input.nbSamples(),TransformRF32::TEMP_F32_ID,mgr);
  178. this->ifft=1;
  179. break;
  180. case TransformRF32::TEST_RFFT_F32_12:
  181. input.reload(TransformRF32::INPUTS_RFFT_STEP_256_F32_ID,mgr);
  182. ref.reload( TransformRF32::REF_RFFT_STEP_256_F32_ID,mgr);
  183. arm_rfft_fast_init_f32(&this->instRfftF32 ,256);
  184. inputchanged.create(input.nbSamples(),TransformRF32::TEMP_F32_ID,mgr);
  185. this->ifft=0;
  186. break;
  187. case TransformRF32::TEST_RFFT_F32_28:
  188. input.reload(TransformRF32::INPUTS_RIFFT_STEP_256_F32_ID,mgr);
  189. ref.reload( TransformRF32::INPUTS_RFFT_STEP_256_F32_ID,mgr);
  190. arm_rfft_fast_init_f32(&this->instRfftF32 ,256);
  191. inputchanged.create(input.nbSamples(),TransformRF32::TEMP_F32_ID,mgr);
  192. this->ifft=1;
  193. break;
  194. case TransformRF32::TEST_RFFT_F32_13:
  195. input.reload(TransformRF32::INPUTS_RFFT_STEP_512_F32_ID,mgr);
  196. ref.reload( TransformRF32::REF_RFFT_STEP_512_F32_ID,mgr);
  197. arm_rfft_fast_init_f32(&this->instRfftF32 ,512);
  198. inputchanged.create(input.nbSamples(),TransformRF32::TEMP_F32_ID,mgr);
  199. this->ifft=0;
  200. break;
  201. case TransformRF32::TEST_RFFT_F32_29:
  202. input.reload(TransformRF32::INPUTS_RIFFT_STEP_512_F32_ID,mgr);
  203. ref.reload( TransformRF32::INPUTS_RFFT_STEP_512_F32_ID,mgr);
  204. arm_rfft_fast_init_f32(&this->instRfftF32 ,512);
  205. inputchanged.create(input.nbSamples(),TransformRF32::TEMP_F32_ID,mgr);
  206. this->ifft=1;
  207. break;
  208. case TransformRF32::TEST_RFFT_F32_14:
  209. input.reload(TransformRF32::INPUTS_RFFT_STEP_1024_F32_ID,mgr);
  210. ref.reload( TransformRF32::REF_RFFT_STEP_1024_F32_ID,mgr);
  211. arm_rfft_fast_init_f32(&this->instRfftF32 ,1024);
  212. inputchanged.create(input.nbSamples(),TransformRF32::TEMP_F32_ID,mgr);
  213. this->ifft=0;
  214. break;
  215. case TransformRF32::TEST_RFFT_F32_30:
  216. input.reload(TransformRF32::INPUTS_RIFFT_STEP_1024_F32_ID,mgr);
  217. ref.reload( TransformRF32::INPUTS_RFFT_STEP_1024_F32_ID,mgr);
  218. arm_rfft_fast_init_f32(&this->instRfftF32 ,1024);
  219. inputchanged.create(input.nbSamples(),TransformRF32::TEMP_F32_ID,mgr);
  220. this->ifft=1;
  221. break;
  222. case TransformRF32::TEST_RFFT_F32_15:
  223. input.reload(TransformRF32::INPUTS_RFFT_STEP_2048_F32_ID,mgr);
  224. ref.reload( TransformRF32::REF_RFFT_STEP_2048_F32_ID,mgr);
  225. arm_rfft_fast_init_f32(&this->instRfftF32 ,2048);
  226. inputchanged.create(input.nbSamples(),TransformRF32::TEMP_F32_ID,mgr);
  227. this->ifft=0;
  228. break;
  229. case TransformRF32::TEST_RFFT_F32_31:
  230. input.reload(TransformRF32::INPUTS_RIFFT_STEP_2048_F32_ID,mgr);
  231. ref.reload( TransformRF32::INPUTS_RFFT_STEP_2048_F32_ID,mgr);
  232. arm_rfft_fast_init_f32(&this->instRfftF32 ,2048);
  233. inputchanged.create(input.nbSamples(),TransformRF32::TEMP_F32_ID,mgr);
  234. this->ifft=1;
  235. break;
  236. case TransformRF32::TEST_RFFT_F32_16:
  237. input.reload(TransformRF32::INPUTS_RFFT_STEP_4096_F32_ID,mgr);
  238. ref.reload( TransformRF32::REF_RFFT_STEP_4096_F32_ID,mgr);
  239. arm_rfft_fast_init_f32(&this->instRfftF32 ,4096);
  240. inputchanged.create(input.nbSamples(),TransformRF32::TEMP_F32_ID,mgr);
  241. this->ifft=0;
  242. break;
  243. case TransformRF32::TEST_RFFT_F32_32:
  244. input.reload(TransformRF32::INPUTS_RIFFT_STEP_4096_F32_ID,mgr);
  245. ref.reload( TransformRF32::INPUTS_RFFT_STEP_4096_F32_ID,mgr);
  246. arm_rfft_fast_init_f32(&this->instRfftF32 ,4096);
  247. inputchanged.create(input.nbSamples(),TransformRF32::TEMP_F32_ID,mgr);
  248. this->ifft=1;
  249. break;
  250. }
  251. outputfft.create(ref.nbSamples(),TransformRF32::OUTPUT_RFFT_F32_ID,mgr);
  252. }
  253. void TransformRF32::tearDown(Testing::testID_t id,Client::PatternMgr *mgr)
  254. {
  255. (void)id;
  256. outputfft.dump(mgr);
  257. }