MISCF16.cpp 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711
  1. #include "MISCF16.h"
  2. #include <stdio.h>
  3. #include "Error.h"
  4. #include "Test.h"
  5. #define SNR_THRESHOLD 60
  6. /*
  7. Reference patterns are generated with
  8. a double precision computation.
  9. */
  10. #define REL_ERROR (1.0e-4)
  11. #define ABS_ERROR (1.0e-3)
  12. void MISCF16::test_correlate_f16()
  13. {
  14. const float16_t *inpA=inputA.ptr();
  15. const float16_t *inpB=inputB.ptr();
  16. float16_t *outp=output.ptr();
  17. arm_correlate_f16(inpA, inputA.nbSamples(),
  18. inpB, inputB.nbSamples(),
  19. outp);
  20. ASSERT_SNR(ref,output,(float16_t)SNR_THRESHOLD);
  21. ASSERT_CLOSE_ERROR(ref,output,ABS_ERROR,REL_ERROR);
  22. }
  23. /*
  24. void MISCF16::test_conv_f16()
  25. {
  26. const float16_t *inpA=inputA.ptr();
  27. const float16_t *inpB=inputB.ptr();
  28. float16_t *outp=output.ptr();
  29. arm_conv_f16(inpA, inputA.nbSamples(),
  30. inpB, inputB.nbSamples(),
  31. outp);
  32. ASSERT_SNR(ref,output,(float16_t)SNR_THRESHOLD);
  33. ASSERT_CLOSE_ERROR(ref,output,ABS_ERROR,REL_ERROR);
  34. }
  35. */
  36. void MISCF16::setUp(Testing::testID_t id,std::vector<Testing::param_t>& paramsArgs,Client::PatternMgr *mgr)
  37. {
  38. (void)paramsArgs;
  39. switch(id)
  40. {
  41. case MISCF16::TEST_CORRELATE_F16_1:
  42. {
  43. this->nba = 4;
  44. this->nbb = 1;
  45. ref.reload(MISCF16::REF1_F16_ID,mgr);
  46. }
  47. break;
  48. case MISCF16::TEST_CORRELATE_F16_2:
  49. {
  50. this->nba = 4;
  51. this->nbb = 2;
  52. ref.reload(MISCF16::REF2_F16_ID,mgr);
  53. }
  54. break;
  55. case MISCF16::TEST_CORRELATE_F16_3:
  56. {
  57. this->nba = 4;
  58. this->nbb = 3;
  59. ref.reload(MISCF16::REF3_F16_ID,mgr);
  60. }
  61. break;
  62. case MISCF16::TEST_CORRELATE_F16_4:
  63. {
  64. this->nba = 4;
  65. this->nbb = 8;
  66. ref.reload(MISCF16::REF4_F16_ID,mgr);
  67. }
  68. break;
  69. case MISCF16::TEST_CORRELATE_F16_5:
  70. {
  71. this->nba = 4;
  72. this->nbb = 11;
  73. ref.reload(MISCF16::REF5_F16_ID,mgr);
  74. }
  75. break;
  76. case MISCF16::TEST_CORRELATE_F16_6:
  77. {
  78. this->nba = 5;
  79. this->nbb = 1;
  80. ref.reload(MISCF16::REF6_F16_ID,mgr);
  81. }
  82. break;
  83. case MISCF16::TEST_CORRELATE_F16_7:
  84. {
  85. this->nba = 5;
  86. this->nbb = 2;
  87. ref.reload(MISCF16::REF7_F16_ID,mgr);
  88. }
  89. break;
  90. case MISCF16::TEST_CORRELATE_F16_8:
  91. {
  92. this->nba = 5;
  93. this->nbb = 3;
  94. ref.reload(MISCF16::REF8_F16_ID,mgr);
  95. }
  96. break;
  97. case MISCF16::TEST_CORRELATE_F16_9:
  98. {
  99. this->nba = 5;
  100. this->nbb = 8;
  101. ref.reload(MISCF16::REF9_F16_ID,mgr);
  102. }
  103. break;
  104. case MISCF16::TEST_CORRELATE_F16_10:
  105. {
  106. this->nba = 5;
  107. this->nbb = 11;
  108. ref.reload(MISCF16::REF10_F16_ID,mgr);
  109. }
  110. break;
  111. case MISCF16::TEST_CORRELATE_F16_11:
  112. {
  113. this->nba = 6;
  114. this->nbb = 1;
  115. ref.reload(MISCF16::REF11_F16_ID,mgr);
  116. }
  117. break;
  118. case MISCF16::TEST_CORRELATE_F16_12:
  119. {
  120. this->nba = 6;
  121. this->nbb = 2;
  122. ref.reload(MISCF16::REF12_F16_ID,mgr);
  123. }
  124. break;
  125. case MISCF16::TEST_CORRELATE_F16_13:
  126. {
  127. this->nba = 6;
  128. this->nbb = 3;
  129. ref.reload(MISCF16::REF13_F16_ID,mgr);
  130. }
  131. break;
  132. case MISCF16::TEST_CORRELATE_F16_14:
  133. {
  134. this->nba = 6;
  135. this->nbb = 8;
  136. ref.reload(MISCF16::REF14_F16_ID,mgr);
  137. }
  138. break;
  139. case MISCF16::TEST_CORRELATE_F16_15:
  140. {
  141. this->nba = 6;
  142. this->nbb = 11;
  143. ref.reload(MISCF16::REF15_F16_ID,mgr);
  144. }
  145. break;
  146. case MISCF16::TEST_CORRELATE_F16_16:
  147. {
  148. this->nba = 9;
  149. this->nbb = 1;
  150. ref.reload(MISCF16::REF16_F16_ID,mgr);
  151. }
  152. break;
  153. case MISCF16::TEST_CORRELATE_F16_17:
  154. {
  155. this->nba = 9;
  156. this->nbb = 2;
  157. ref.reload(MISCF16::REF17_F16_ID,mgr);
  158. }
  159. break;
  160. case MISCF16::TEST_CORRELATE_F16_18:
  161. {
  162. this->nba = 9;
  163. this->nbb = 3;
  164. ref.reload(MISCF16::REF18_F16_ID,mgr);
  165. }
  166. break;
  167. case MISCF16::TEST_CORRELATE_F16_19:
  168. {
  169. this->nba = 9;
  170. this->nbb = 8;
  171. ref.reload(MISCF16::REF19_F16_ID,mgr);
  172. }
  173. break;
  174. case MISCF16::TEST_CORRELATE_F16_20:
  175. {
  176. this->nba = 9;
  177. this->nbb = 11;
  178. ref.reload(MISCF16::REF20_F16_ID,mgr);
  179. }
  180. break;
  181. case MISCF16::TEST_CORRELATE_F16_21:
  182. {
  183. this->nba = 10;
  184. this->nbb = 1;
  185. ref.reload(MISCF16::REF21_F16_ID,mgr);
  186. }
  187. break;
  188. case MISCF16::TEST_CORRELATE_F16_22:
  189. {
  190. this->nba = 10;
  191. this->nbb = 2;
  192. ref.reload(MISCF16::REF22_F16_ID,mgr);
  193. }
  194. break;
  195. case MISCF16::TEST_CORRELATE_F16_23:
  196. {
  197. this->nba = 10;
  198. this->nbb = 3;
  199. ref.reload(MISCF16::REF23_F16_ID,mgr);
  200. }
  201. break;
  202. case MISCF16::TEST_CORRELATE_F16_24:
  203. {
  204. this->nba = 10;
  205. this->nbb = 8;
  206. ref.reload(MISCF16::REF24_F16_ID,mgr);
  207. }
  208. break;
  209. case MISCF16::TEST_CORRELATE_F16_25:
  210. {
  211. this->nba = 10;
  212. this->nbb = 11;
  213. ref.reload(MISCF16::REF25_F16_ID,mgr);
  214. }
  215. break;
  216. case MISCF16::TEST_CORRELATE_F16_26:
  217. {
  218. this->nba = 11;
  219. this->nbb = 1;
  220. ref.reload(MISCF16::REF26_F16_ID,mgr);
  221. }
  222. break;
  223. case MISCF16::TEST_CORRELATE_F16_27:
  224. {
  225. this->nba = 11;
  226. this->nbb = 2;
  227. ref.reload(MISCF16::REF27_F16_ID,mgr);
  228. }
  229. break;
  230. case MISCF16::TEST_CORRELATE_F16_28:
  231. {
  232. this->nba = 11;
  233. this->nbb = 3;
  234. ref.reload(MISCF16::REF28_F16_ID,mgr);
  235. }
  236. break;
  237. case MISCF16::TEST_CORRELATE_F16_29:
  238. {
  239. this->nba = 11;
  240. this->nbb = 8;
  241. ref.reload(MISCF16::REF29_F16_ID,mgr);
  242. }
  243. break;
  244. case MISCF16::TEST_CORRELATE_F16_30:
  245. {
  246. this->nba = 11;
  247. this->nbb = 11;
  248. ref.reload(MISCF16::REF30_F16_ID,mgr);
  249. }
  250. break;
  251. case MISCF16::TEST_CORRELATE_F16_31:
  252. {
  253. this->nba = 12;
  254. this->nbb = 1;
  255. ref.reload(MISCF16::REF31_F16_ID,mgr);
  256. }
  257. break;
  258. case MISCF16::TEST_CORRELATE_F16_32:
  259. {
  260. this->nba = 12;
  261. this->nbb = 2;
  262. ref.reload(MISCF16::REF32_F16_ID,mgr);
  263. }
  264. break;
  265. case MISCF16::TEST_CORRELATE_F16_33:
  266. {
  267. this->nba = 12;
  268. this->nbb = 3;
  269. ref.reload(MISCF16::REF33_F16_ID,mgr);
  270. }
  271. break;
  272. case MISCF16::TEST_CORRELATE_F16_34:
  273. {
  274. this->nba = 12;
  275. this->nbb = 8;
  276. ref.reload(MISCF16::REF34_F16_ID,mgr);
  277. }
  278. break;
  279. case MISCF16::TEST_CORRELATE_F16_35:
  280. {
  281. this->nba = 12;
  282. this->nbb = 11;
  283. ref.reload(MISCF16::REF35_F16_ID,mgr);
  284. }
  285. break;
  286. case MISCF16::TEST_CORRELATE_F16_36:
  287. {
  288. this->nba = 13;
  289. this->nbb = 1;
  290. ref.reload(MISCF16::REF36_F16_ID,mgr);
  291. }
  292. break;
  293. case MISCF16::TEST_CORRELATE_F16_37:
  294. {
  295. this->nba = 13;
  296. this->nbb = 2;
  297. ref.reload(MISCF16::REF37_F16_ID,mgr);
  298. }
  299. break;
  300. case MISCF16::TEST_CORRELATE_F16_38:
  301. {
  302. this->nba = 13;
  303. this->nbb = 3;
  304. ref.reload(MISCF16::REF38_F16_ID,mgr);
  305. }
  306. break;
  307. case MISCF16::TEST_CORRELATE_F16_39:
  308. {
  309. this->nba = 13;
  310. this->nbb = 8;
  311. ref.reload(MISCF16::REF39_F16_ID,mgr);
  312. }
  313. break;
  314. case MISCF16::TEST_CORRELATE_F16_40:
  315. {
  316. this->nba = 13;
  317. this->nbb = 11;
  318. ref.reload(MISCF16::REF40_F16_ID,mgr);
  319. }
  320. break;
  321. #if 0
  322. case MISCF16::TEST_CONV_F16_41:
  323. {
  324. this->nba = 4;
  325. this->nbb = 1;
  326. ref.reload(MISCF16::REF41_F16_ID,mgr);
  327. }
  328. break;
  329. case MISCF16::TEST_CONV_F16_42:
  330. {
  331. this->nba = 4;
  332. this->nbb = 2;
  333. ref.reload(MISCF16::REF42_F16_ID,mgr);
  334. }
  335. break;
  336. case MISCF16::TEST_CONV_F16_43:
  337. {
  338. this->nba = 4;
  339. this->nbb = 3;
  340. ref.reload(MISCF16::REF43_F16_ID,mgr);
  341. }
  342. break;
  343. case MISCF16::TEST_CONV_F16_44:
  344. {
  345. this->nba = 4;
  346. this->nbb = 8;
  347. ref.reload(MISCF16::REF44_F16_ID,mgr);
  348. }
  349. break;
  350. case MISCF16::TEST_CONV_F16_45:
  351. {
  352. this->nba = 4;
  353. this->nbb = 11;
  354. ref.reload(MISCF16::REF45_F16_ID,mgr);
  355. }
  356. break;
  357. case MISCF16::TEST_CONV_F16_46:
  358. {
  359. this->nba = 5;
  360. this->nbb = 1;
  361. ref.reload(MISCF16::REF46_F16_ID,mgr);
  362. }
  363. break;
  364. case MISCF16::TEST_CONV_F16_47:
  365. {
  366. this->nba = 5;
  367. this->nbb = 2;
  368. ref.reload(MISCF16::REF47_F16_ID,mgr);
  369. }
  370. break;
  371. case MISCF16::TEST_CONV_F16_48:
  372. {
  373. this->nba = 5;
  374. this->nbb = 3;
  375. ref.reload(MISCF16::REF48_F16_ID,mgr);
  376. }
  377. break;
  378. case MISCF16::TEST_CONV_F16_49:
  379. {
  380. this->nba = 5;
  381. this->nbb = 8;
  382. ref.reload(MISCF16::REF49_F16_ID,mgr);
  383. }
  384. break;
  385. case MISCF16::TEST_CONV_F16_50:
  386. {
  387. this->nba = 5;
  388. this->nbb = 11;
  389. ref.reload(MISCF16::REF50_F16_ID,mgr);
  390. }
  391. break;
  392. case MISCF16::TEST_CONV_F16_51:
  393. {
  394. this->nba = 6;
  395. this->nbb = 1;
  396. ref.reload(MISCF16::REF51_F16_ID,mgr);
  397. }
  398. break;
  399. case MISCF16::TEST_CONV_F16_52:
  400. {
  401. this->nba = 6;
  402. this->nbb = 2;
  403. ref.reload(MISCF16::REF52_F16_ID,mgr);
  404. }
  405. break;
  406. case MISCF16::TEST_CONV_F16_53:
  407. {
  408. this->nba = 6;
  409. this->nbb = 3;
  410. ref.reload(MISCF16::REF53_F16_ID,mgr);
  411. }
  412. break;
  413. case MISCF16::TEST_CONV_F16_54:
  414. {
  415. this->nba = 6;
  416. this->nbb = 8;
  417. ref.reload(MISCF16::REF54_F16_ID,mgr);
  418. }
  419. break;
  420. case MISCF16::TEST_CONV_F16_55:
  421. {
  422. this->nba = 6;
  423. this->nbb = 11;
  424. ref.reload(MISCF16::REF55_F16_ID,mgr);
  425. }
  426. break;
  427. case MISCF16::TEST_CONV_F16_56:
  428. {
  429. this->nba = 9;
  430. this->nbb = 1;
  431. ref.reload(MISCF16::REF56_F16_ID,mgr);
  432. }
  433. break;
  434. case MISCF16::TEST_CONV_F16_57:
  435. {
  436. this->nba = 9;
  437. this->nbb = 2;
  438. ref.reload(MISCF16::REF57_F16_ID,mgr);
  439. }
  440. break;
  441. case MISCF16::TEST_CONV_F16_58:
  442. {
  443. this->nba = 9;
  444. this->nbb = 3;
  445. ref.reload(MISCF16::REF58_F16_ID,mgr);
  446. }
  447. break;
  448. case MISCF16::TEST_CONV_F16_59:
  449. {
  450. this->nba = 9;
  451. this->nbb = 8;
  452. ref.reload(MISCF16::REF59_F16_ID,mgr);
  453. }
  454. break;
  455. case MISCF16::TEST_CONV_F16_60:
  456. {
  457. this->nba = 9;
  458. this->nbb = 11;
  459. ref.reload(MISCF16::REF60_F16_ID,mgr);
  460. }
  461. break;
  462. case MISCF16::TEST_CONV_F16_61:
  463. {
  464. this->nba = 10;
  465. this->nbb = 1;
  466. ref.reload(MISCF16::REF61_F16_ID,mgr);
  467. }
  468. break;
  469. case MISCF16::TEST_CONV_F16_62:
  470. {
  471. this->nba = 10;
  472. this->nbb = 2;
  473. ref.reload(MISCF16::REF62_F16_ID,mgr);
  474. }
  475. break;
  476. case MISCF16::TEST_CONV_F16_63:
  477. {
  478. this->nba = 10;
  479. this->nbb = 3;
  480. ref.reload(MISCF16::REF63_F16_ID,mgr);
  481. }
  482. break;
  483. case MISCF16::TEST_CONV_F16_64:
  484. {
  485. this->nba = 10;
  486. this->nbb = 8;
  487. ref.reload(MISCF16::REF64_F16_ID,mgr);
  488. }
  489. break;
  490. case MISCF16::TEST_CONV_F16_65:
  491. {
  492. this->nba = 10;
  493. this->nbb = 11;
  494. ref.reload(MISCF16::REF65_F16_ID,mgr);
  495. }
  496. break;
  497. case MISCF16::TEST_CONV_F16_66:
  498. {
  499. this->nba = 11;
  500. this->nbb = 1;
  501. ref.reload(MISCF16::REF66_F16_ID,mgr);
  502. }
  503. break;
  504. case MISCF16::TEST_CONV_F16_67:
  505. {
  506. this->nba = 11;
  507. this->nbb = 2;
  508. ref.reload(MISCF16::REF67_F16_ID,mgr);
  509. }
  510. break;
  511. case MISCF16::TEST_CONV_F16_68:
  512. {
  513. this->nba = 11;
  514. this->nbb = 3;
  515. ref.reload(MISCF16::REF68_F16_ID,mgr);
  516. }
  517. break;
  518. case MISCF16::TEST_CONV_F16_69:
  519. {
  520. this->nba = 11;
  521. this->nbb = 8;
  522. ref.reload(MISCF16::REF69_F16_ID,mgr);
  523. }
  524. break;
  525. case MISCF16::TEST_CONV_F16_70:
  526. {
  527. this->nba = 11;
  528. this->nbb = 11;
  529. ref.reload(MISCF16::REF70_F16_ID,mgr);
  530. }
  531. break;
  532. case MISCF16::TEST_CONV_F16_71:
  533. {
  534. this->nba = 12;
  535. this->nbb = 1;
  536. ref.reload(MISCF16::REF71_F16_ID,mgr);
  537. }
  538. break;
  539. case MISCF16::TEST_CONV_F16_72:
  540. {
  541. this->nba = 12;
  542. this->nbb = 2;
  543. ref.reload(MISCF16::REF72_F16_ID,mgr);
  544. }
  545. break;
  546. case MISCF16::TEST_CONV_F16_73:
  547. {
  548. this->nba = 12;
  549. this->nbb = 3;
  550. ref.reload(MISCF16::REF73_F16_ID,mgr);
  551. }
  552. break;
  553. case MISCF16::TEST_CONV_F16_74:
  554. {
  555. this->nba = 12;
  556. this->nbb = 8;
  557. ref.reload(MISCF16::REF74_F16_ID,mgr);
  558. }
  559. break;
  560. case MISCF16::TEST_CONV_F16_75:
  561. {
  562. this->nba = 12;
  563. this->nbb = 11;
  564. ref.reload(MISCF16::REF75_F16_ID,mgr);
  565. }
  566. break;
  567. case MISCF16::TEST_CONV_F16_76:
  568. {
  569. this->nba = 13;
  570. this->nbb = 1;
  571. ref.reload(MISCF16::REF76_F16_ID,mgr);
  572. }
  573. break;
  574. case MISCF16::TEST_CONV_F16_77:
  575. {
  576. this->nba = 13;
  577. this->nbb = 2;
  578. ref.reload(MISCF16::REF77_F16_ID,mgr);
  579. }
  580. break;
  581. case MISCF16::TEST_CONV_F16_78:
  582. {
  583. this->nba = 13;
  584. this->nbb = 3;
  585. ref.reload(MISCF16::REF78_F16_ID,mgr);
  586. }
  587. break;
  588. case MISCF16::TEST_CONV_F16_79:
  589. {
  590. this->nba = 13;
  591. this->nbb = 8;
  592. ref.reload(MISCF16::REF79_F16_ID,mgr);
  593. }
  594. break;
  595. case MISCF16::TEST_CONV_F16_80:
  596. {
  597. this->nba = 13;
  598. this->nbb = 11;
  599. ref.reload(MISCF16::REF80_F16_ID,mgr);
  600. }
  601. break;
  602. #endif
  603. }
  604. inputA.reload(MISCF16::INPUTA_F16_ID,mgr,nba);
  605. inputB.reload(MISCF16::INPUTB_F16_ID,mgr,nbb);
  606. output.create(ref.nbSamples(),MISCF16::OUT_F16_ID,mgr);
  607. }
  608. void MISCF16::tearDown(Testing::testID_t id,Client::PatternMgr *mgr)
  609. {
  610. (void)id;
  611. output.dump(mgr);
  612. }