MISCF32.cpp 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840
  1. #include "arm_vec_math.h"
  2. #include "MISCF32.h"
  3. #include <stdio.h>
  4. #include "Error.h"
  5. #include "Test.h"
  6. #define SNR_THRESHOLD 120
  7. /*
  8. Reference patterns are generated with
  9. a double precision computation.
  10. */
  11. #define REL_ERROR (1.0e-6)
  12. #define ABS_ERROR (1.0e-5)
  13. /*
  14. For tests of the error value of the Levinson Durbin algorithm
  15. */
  16. #define REL_LD_ERROR (1.0e-6)
  17. #define ABS_LD_ERROR (1.0e-6)
  18. void MISCF32::test_levinson_durbin_f32()
  19. {
  20. const float32_t *inpA=inputA.ptr();
  21. const float32_t *errs=inputB.ptr();
  22. float32_t *outp=output.ptr();
  23. float32_t err;
  24. float32_t refError=errs[this->errOffset];
  25. arm_levinson_durbin_f32(inpA,outp,&err,this->nba);
  26. ASSERT_EMPTY_TAIL(output);
  27. ASSERT_SNR(ref,output,(float32_t)SNR_THRESHOLD);
  28. ASSERT_CLOSE_ERROR(ref,output,ABS_LD_ERROR,REL_LD_ERROR);
  29. ASSERT_CLOSE_ERROR(refError,err,ABS_LD_ERROR,REL_LD_ERROR);
  30. }
  31. void MISCF32::test_correlate_f32()
  32. {
  33. const float32_t *inpA=inputA.ptr();
  34. const float32_t *inpB=inputB.ptr();
  35. float32_t *outp=output.ptr();
  36. arm_correlate_f32(inpA, inputA.nbSamples(),
  37. inpB, inputB.nbSamples(),
  38. outp);
  39. ASSERT_SNR(ref,output,(float32_t)SNR_THRESHOLD);
  40. ASSERT_CLOSE_ERROR(ref,output,ABS_ERROR,REL_ERROR);
  41. }
  42. void MISCF32::test_conv_f32()
  43. {
  44. const float32_t *inpA=inputA.ptr();
  45. const float32_t *inpB=inputB.ptr();
  46. float32_t *outp=output.ptr();
  47. arm_conv_f32(inpA, inputA.nbSamples(),
  48. inpB, inputB.nbSamples(),
  49. outp);
  50. ASSERT_SNR(ref,output,(float32_t)SNR_THRESHOLD);
  51. ASSERT_CLOSE_ERROR(ref,output,ABS_ERROR,REL_ERROR);
  52. }
  53. // This value must be coherent with the Python script
  54. // generating the test patterns
  55. #define NBPOINTS 4
  56. void MISCF32::test_conv_partial_f32()
  57. {
  58. const float32_t *inpA=inputA.ptr();
  59. const float32_t *inpB=inputB.ptr();
  60. float32_t *outp=output.ptr();
  61. float32_t *tmpp=tmp.ptr();
  62. arm_status status=arm_conv_partial_f32(inpA, inputA.nbSamples(),
  63. inpB, inputB.nbSamples(),
  64. outp,
  65. this->first,
  66. NBPOINTS);
  67. memcpy((void*)tmpp,(void*)&outp[this->first],NBPOINTS*sizeof(float32_t));
  68. ASSERT_TRUE(status==ARM_MATH_SUCCESS);
  69. ASSERT_SNR(ref,tmp,(float32_t)SNR_THRESHOLD);
  70. ASSERT_CLOSE_ERROR(ref,tmp,ABS_ERROR,REL_ERROR);
  71. }
  72. void MISCF32::setUp(Testing::testID_t id,std::vector<Testing::param_t>& paramsArgs,Client::PatternMgr *mgr)
  73. {
  74. (void)paramsArgs;
  75. switch(id)
  76. {
  77. case MISCF32::TEST_CORRELATE_F32_1:
  78. {
  79. this->nba = 4;
  80. this->nbb = 1;
  81. ref.reload(MISCF32::REF1_F32_ID,mgr);
  82. }
  83. break;
  84. case MISCF32::TEST_CORRELATE_F32_2:
  85. {
  86. this->nba = 4;
  87. this->nbb = 2;
  88. ref.reload(MISCF32::REF2_F32_ID,mgr);
  89. }
  90. break;
  91. case MISCF32::TEST_CORRELATE_F32_3:
  92. {
  93. this->nba = 4;
  94. this->nbb = 3;
  95. ref.reload(MISCF32::REF3_F32_ID,mgr);
  96. }
  97. break;
  98. case MISCF32::TEST_CORRELATE_F32_4:
  99. {
  100. this->nba = 4;
  101. this->nbb = 8;
  102. ref.reload(MISCF32::REF4_F32_ID,mgr);
  103. }
  104. break;
  105. case MISCF32::TEST_CORRELATE_F32_5:
  106. {
  107. this->nba = 4;
  108. this->nbb = 11;
  109. ref.reload(MISCF32::REF5_F32_ID,mgr);
  110. }
  111. break;
  112. case MISCF32::TEST_CORRELATE_F32_6:
  113. {
  114. this->nba = 5;
  115. this->nbb = 1;
  116. ref.reload(MISCF32::REF6_F32_ID,mgr);
  117. }
  118. break;
  119. case MISCF32::TEST_CORRELATE_F32_7:
  120. {
  121. this->nba = 5;
  122. this->nbb = 2;
  123. ref.reload(MISCF32::REF7_F32_ID,mgr);
  124. }
  125. break;
  126. case MISCF32::TEST_CORRELATE_F32_8:
  127. {
  128. this->nba = 5;
  129. this->nbb = 3;
  130. ref.reload(MISCF32::REF8_F32_ID,mgr);
  131. }
  132. break;
  133. case MISCF32::TEST_CORRELATE_F32_9:
  134. {
  135. this->nba = 5;
  136. this->nbb = 8;
  137. ref.reload(MISCF32::REF9_F32_ID,mgr);
  138. }
  139. break;
  140. case MISCF32::TEST_CORRELATE_F32_10:
  141. {
  142. this->nba = 5;
  143. this->nbb = 11;
  144. ref.reload(MISCF32::REF10_F32_ID,mgr);
  145. }
  146. break;
  147. case MISCF32::TEST_CORRELATE_F32_11:
  148. {
  149. this->nba = 6;
  150. this->nbb = 1;
  151. ref.reload(MISCF32::REF11_F32_ID,mgr);
  152. }
  153. break;
  154. case MISCF32::TEST_CORRELATE_F32_12:
  155. {
  156. this->nba = 6;
  157. this->nbb = 2;
  158. ref.reload(MISCF32::REF12_F32_ID,mgr);
  159. }
  160. break;
  161. case MISCF32::TEST_CORRELATE_F32_13:
  162. {
  163. this->nba = 6;
  164. this->nbb = 3;
  165. ref.reload(MISCF32::REF13_F32_ID,mgr);
  166. }
  167. break;
  168. case MISCF32::TEST_CORRELATE_F32_14:
  169. {
  170. this->nba = 6;
  171. this->nbb = 8;
  172. ref.reload(MISCF32::REF14_F32_ID,mgr);
  173. }
  174. break;
  175. case MISCF32::TEST_CORRELATE_F32_15:
  176. {
  177. this->nba = 6;
  178. this->nbb = 11;
  179. ref.reload(MISCF32::REF15_F32_ID,mgr);
  180. }
  181. break;
  182. case MISCF32::TEST_CORRELATE_F32_16:
  183. {
  184. this->nba = 9;
  185. this->nbb = 1;
  186. ref.reload(MISCF32::REF16_F32_ID,mgr);
  187. }
  188. break;
  189. case MISCF32::TEST_CORRELATE_F32_17:
  190. {
  191. this->nba = 9;
  192. this->nbb = 2;
  193. ref.reload(MISCF32::REF17_F32_ID,mgr);
  194. }
  195. break;
  196. case MISCF32::TEST_CORRELATE_F32_18:
  197. {
  198. this->nba = 9;
  199. this->nbb = 3;
  200. ref.reload(MISCF32::REF18_F32_ID,mgr);
  201. }
  202. break;
  203. case MISCF32::TEST_CORRELATE_F32_19:
  204. {
  205. this->nba = 9;
  206. this->nbb = 8;
  207. ref.reload(MISCF32::REF19_F32_ID,mgr);
  208. }
  209. break;
  210. case MISCF32::TEST_CORRELATE_F32_20:
  211. {
  212. this->nba = 9;
  213. this->nbb = 11;
  214. ref.reload(MISCF32::REF20_F32_ID,mgr);
  215. }
  216. break;
  217. case MISCF32::TEST_CORRELATE_F32_21:
  218. {
  219. this->nba = 10;
  220. this->nbb = 1;
  221. ref.reload(MISCF32::REF21_F32_ID,mgr);
  222. }
  223. break;
  224. case MISCF32::TEST_CORRELATE_F32_22:
  225. {
  226. this->nba = 10;
  227. this->nbb = 2;
  228. ref.reload(MISCF32::REF22_F32_ID,mgr);
  229. }
  230. break;
  231. case MISCF32::TEST_CORRELATE_F32_23:
  232. {
  233. this->nba = 10;
  234. this->nbb = 3;
  235. ref.reload(MISCF32::REF23_F32_ID,mgr);
  236. }
  237. break;
  238. case MISCF32::TEST_CORRELATE_F32_24:
  239. {
  240. this->nba = 10;
  241. this->nbb = 8;
  242. ref.reload(MISCF32::REF24_F32_ID,mgr);
  243. }
  244. break;
  245. case MISCF32::TEST_CORRELATE_F32_25:
  246. {
  247. this->nba = 10;
  248. this->nbb = 11;
  249. ref.reload(MISCF32::REF25_F32_ID,mgr);
  250. }
  251. break;
  252. case MISCF32::TEST_CORRELATE_F32_26:
  253. {
  254. this->nba = 11;
  255. this->nbb = 1;
  256. ref.reload(MISCF32::REF26_F32_ID,mgr);
  257. }
  258. break;
  259. case MISCF32::TEST_CORRELATE_F32_27:
  260. {
  261. this->nba = 11;
  262. this->nbb = 2;
  263. ref.reload(MISCF32::REF27_F32_ID,mgr);
  264. }
  265. break;
  266. case MISCF32::TEST_CORRELATE_F32_28:
  267. {
  268. this->nba = 11;
  269. this->nbb = 3;
  270. ref.reload(MISCF32::REF28_F32_ID,mgr);
  271. }
  272. break;
  273. case MISCF32::TEST_CORRELATE_F32_29:
  274. {
  275. this->nba = 11;
  276. this->nbb = 8;
  277. ref.reload(MISCF32::REF29_F32_ID,mgr);
  278. }
  279. break;
  280. case MISCF32::TEST_CORRELATE_F32_30:
  281. {
  282. this->nba = 11;
  283. this->nbb = 11;
  284. ref.reload(MISCF32::REF30_F32_ID,mgr);
  285. }
  286. break;
  287. case MISCF32::TEST_CORRELATE_F32_31:
  288. {
  289. this->nba = 12;
  290. this->nbb = 1;
  291. ref.reload(MISCF32::REF31_F32_ID,mgr);
  292. }
  293. break;
  294. case MISCF32::TEST_CORRELATE_F32_32:
  295. {
  296. this->nba = 12;
  297. this->nbb = 2;
  298. ref.reload(MISCF32::REF32_F32_ID,mgr);
  299. }
  300. break;
  301. case MISCF32::TEST_CORRELATE_F32_33:
  302. {
  303. this->nba = 12;
  304. this->nbb = 3;
  305. ref.reload(MISCF32::REF33_F32_ID,mgr);
  306. }
  307. break;
  308. case MISCF32::TEST_CORRELATE_F32_34:
  309. {
  310. this->nba = 12;
  311. this->nbb = 8;
  312. ref.reload(MISCF32::REF34_F32_ID,mgr);
  313. }
  314. break;
  315. case MISCF32::TEST_CORRELATE_F32_35:
  316. {
  317. this->nba = 12;
  318. this->nbb = 11;
  319. ref.reload(MISCF32::REF35_F32_ID,mgr);
  320. }
  321. break;
  322. case MISCF32::TEST_CORRELATE_F32_36:
  323. {
  324. this->nba = 13;
  325. this->nbb = 1;
  326. ref.reload(MISCF32::REF36_F32_ID,mgr);
  327. }
  328. break;
  329. case MISCF32::TEST_CORRELATE_F32_37:
  330. {
  331. this->nba = 13;
  332. this->nbb = 2;
  333. ref.reload(MISCF32::REF37_F32_ID,mgr);
  334. }
  335. break;
  336. case MISCF32::TEST_CORRELATE_F32_38:
  337. {
  338. this->nba = 13;
  339. this->nbb = 3;
  340. ref.reload(MISCF32::REF38_F32_ID,mgr);
  341. }
  342. break;
  343. case MISCF32::TEST_CORRELATE_F32_39:
  344. {
  345. this->nba = 13;
  346. this->nbb = 8;
  347. ref.reload(MISCF32::REF39_F32_ID,mgr);
  348. }
  349. break;
  350. case MISCF32::TEST_CORRELATE_F32_40:
  351. {
  352. this->nba = 13;
  353. this->nbb = 11;
  354. ref.reload(MISCF32::REF40_F32_ID,mgr);
  355. }
  356. break;
  357. case MISCF32::TEST_CONV_F32_41:
  358. {
  359. this->nba = 4;
  360. this->nbb = 1;
  361. ref.reload(MISCF32::REF41_F32_ID,mgr);
  362. }
  363. break;
  364. case MISCF32::TEST_CONV_F32_42:
  365. {
  366. this->nba = 4;
  367. this->nbb = 2;
  368. ref.reload(MISCF32::REF42_F32_ID,mgr);
  369. }
  370. break;
  371. case MISCF32::TEST_CONV_F32_43:
  372. {
  373. this->nba = 4;
  374. this->nbb = 3;
  375. ref.reload(MISCF32::REF43_F32_ID,mgr);
  376. }
  377. break;
  378. case MISCF32::TEST_CONV_F32_44:
  379. {
  380. this->nba = 4;
  381. this->nbb = 8;
  382. ref.reload(MISCF32::REF44_F32_ID,mgr);
  383. }
  384. break;
  385. case MISCF32::TEST_CONV_F32_45:
  386. {
  387. this->nba = 4;
  388. this->nbb = 11;
  389. ref.reload(MISCF32::REF45_F32_ID,mgr);
  390. }
  391. break;
  392. case MISCF32::TEST_CONV_F32_46:
  393. {
  394. this->nba = 5;
  395. this->nbb = 1;
  396. ref.reload(MISCF32::REF46_F32_ID,mgr);
  397. }
  398. break;
  399. case MISCF32::TEST_CONV_F32_47:
  400. {
  401. this->nba = 5;
  402. this->nbb = 2;
  403. ref.reload(MISCF32::REF47_F32_ID,mgr);
  404. }
  405. break;
  406. case MISCF32::TEST_CONV_F32_48:
  407. {
  408. this->nba = 5;
  409. this->nbb = 3;
  410. ref.reload(MISCF32::REF48_F32_ID,mgr);
  411. }
  412. break;
  413. case MISCF32::TEST_CONV_F32_49:
  414. {
  415. this->nba = 5;
  416. this->nbb = 8;
  417. ref.reload(MISCF32::REF49_F32_ID,mgr);
  418. }
  419. break;
  420. case MISCF32::TEST_CONV_F32_50:
  421. {
  422. this->nba = 5;
  423. this->nbb = 11;
  424. ref.reload(MISCF32::REF50_F32_ID,mgr);
  425. }
  426. break;
  427. case MISCF32::TEST_CONV_F32_51:
  428. {
  429. this->nba = 6;
  430. this->nbb = 1;
  431. ref.reload(MISCF32::REF51_F32_ID,mgr);
  432. }
  433. break;
  434. case MISCF32::TEST_CONV_F32_52:
  435. {
  436. this->nba = 6;
  437. this->nbb = 2;
  438. ref.reload(MISCF32::REF52_F32_ID,mgr);
  439. }
  440. break;
  441. case MISCF32::TEST_CONV_F32_53:
  442. {
  443. this->nba = 6;
  444. this->nbb = 3;
  445. ref.reload(MISCF32::REF53_F32_ID,mgr);
  446. }
  447. break;
  448. case MISCF32::TEST_CONV_F32_54:
  449. {
  450. this->nba = 6;
  451. this->nbb = 8;
  452. ref.reload(MISCF32::REF54_F32_ID,mgr);
  453. }
  454. break;
  455. case MISCF32::TEST_CONV_F32_55:
  456. {
  457. this->nba = 6;
  458. this->nbb = 11;
  459. ref.reload(MISCF32::REF55_F32_ID,mgr);
  460. }
  461. break;
  462. case MISCF32::TEST_CONV_F32_56:
  463. {
  464. this->nba = 9;
  465. this->nbb = 1;
  466. ref.reload(MISCF32::REF56_F32_ID,mgr);
  467. }
  468. break;
  469. case MISCF32::TEST_CONV_F32_57:
  470. {
  471. this->nba = 9;
  472. this->nbb = 2;
  473. ref.reload(MISCF32::REF57_F32_ID,mgr);
  474. }
  475. break;
  476. case MISCF32::TEST_CONV_F32_58:
  477. {
  478. this->nba = 9;
  479. this->nbb = 3;
  480. ref.reload(MISCF32::REF58_F32_ID,mgr);
  481. }
  482. break;
  483. case MISCF32::TEST_CONV_F32_59:
  484. {
  485. this->nba = 9;
  486. this->nbb = 8;
  487. ref.reload(MISCF32::REF59_F32_ID,mgr);
  488. }
  489. break;
  490. case MISCF32::TEST_CONV_F32_60:
  491. {
  492. this->nba = 9;
  493. this->nbb = 11;
  494. ref.reload(MISCF32::REF60_F32_ID,mgr);
  495. }
  496. break;
  497. case MISCF32::TEST_CONV_F32_61:
  498. {
  499. this->nba = 10;
  500. this->nbb = 1;
  501. ref.reload(MISCF32::REF61_F32_ID,mgr);
  502. }
  503. break;
  504. case MISCF32::TEST_CONV_F32_62:
  505. {
  506. this->nba = 10;
  507. this->nbb = 2;
  508. ref.reload(MISCF32::REF62_F32_ID,mgr);
  509. }
  510. break;
  511. case MISCF32::TEST_CONV_F32_63:
  512. {
  513. this->nba = 10;
  514. this->nbb = 3;
  515. ref.reload(MISCF32::REF63_F32_ID,mgr);
  516. }
  517. break;
  518. case MISCF32::TEST_CONV_F32_64:
  519. {
  520. this->nba = 10;
  521. this->nbb = 8;
  522. ref.reload(MISCF32::REF64_F32_ID,mgr);
  523. }
  524. break;
  525. case MISCF32::TEST_CONV_F32_65:
  526. {
  527. this->nba = 10;
  528. this->nbb = 11;
  529. ref.reload(MISCF32::REF65_F32_ID,mgr);
  530. }
  531. break;
  532. case MISCF32::TEST_CONV_F32_66:
  533. {
  534. this->nba = 11;
  535. this->nbb = 1;
  536. ref.reload(MISCF32::REF66_F32_ID,mgr);
  537. }
  538. break;
  539. case MISCF32::TEST_CONV_F32_67:
  540. {
  541. this->nba = 11;
  542. this->nbb = 2;
  543. ref.reload(MISCF32::REF67_F32_ID,mgr);
  544. }
  545. break;
  546. case MISCF32::TEST_CONV_F32_68:
  547. {
  548. this->nba = 11;
  549. this->nbb = 3;
  550. ref.reload(MISCF32::REF68_F32_ID,mgr);
  551. }
  552. break;
  553. case MISCF32::TEST_CONV_F32_69:
  554. {
  555. this->nba = 11;
  556. this->nbb = 8;
  557. ref.reload(MISCF32::REF69_F32_ID,mgr);
  558. }
  559. break;
  560. case MISCF32::TEST_CONV_F32_70:
  561. {
  562. this->nba = 11;
  563. this->nbb = 11;
  564. ref.reload(MISCF32::REF70_F32_ID,mgr);
  565. }
  566. break;
  567. case MISCF32::TEST_CONV_F32_71:
  568. {
  569. this->nba = 12;
  570. this->nbb = 1;
  571. ref.reload(MISCF32::REF71_F32_ID,mgr);
  572. }
  573. break;
  574. case MISCF32::TEST_CONV_F32_72:
  575. {
  576. this->nba = 12;
  577. this->nbb = 2;
  578. ref.reload(MISCF32::REF72_F32_ID,mgr);
  579. }
  580. break;
  581. case MISCF32::TEST_CONV_F32_73:
  582. {
  583. this->nba = 12;
  584. this->nbb = 3;
  585. ref.reload(MISCF32::REF73_F32_ID,mgr);
  586. }
  587. break;
  588. case MISCF32::TEST_CONV_F32_74:
  589. {
  590. this->nba = 12;
  591. this->nbb = 8;
  592. ref.reload(MISCF32::REF74_F32_ID,mgr);
  593. }
  594. break;
  595. case MISCF32::TEST_CONV_F32_75:
  596. {
  597. this->nba = 12;
  598. this->nbb = 11;
  599. ref.reload(MISCF32::REF75_F32_ID,mgr);
  600. }
  601. break;
  602. case MISCF32::TEST_CONV_F32_76:
  603. {
  604. this->nba = 13;
  605. this->nbb = 1;
  606. ref.reload(MISCF32::REF76_F32_ID,mgr);
  607. }
  608. break;
  609. case MISCF32::TEST_CONV_F32_77:
  610. {
  611. this->nba = 13;
  612. this->nbb = 2;
  613. ref.reload(MISCF32::REF77_F32_ID,mgr);
  614. }
  615. break;
  616. case MISCF32::TEST_CONV_F32_78:
  617. {
  618. this->nba = 13;
  619. this->nbb = 3;
  620. ref.reload(MISCF32::REF78_F32_ID,mgr);
  621. }
  622. break;
  623. case MISCF32::TEST_CONV_F32_79:
  624. {
  625. this->nba = 13;
  626. this->nbb = 8;
  627. ref.reload(MISCF32::REF79_F32_ID,mgr);
  628. }
  629. break;
  630. case MISCF32::TEST_CONV_F32_80:
  631. {
  632. this->nba = 13;
  633. this->nbb = 11;
  634. ref.reload(MISCF32::REF80_F32_ID,mgr);
  635. }
  636. break;
  637. case MISCF32::TEST_LEVINSON_DURBIN_F32_81:
  638. {
  639. this->nba = 3;
  640. inputA.reload(MISCF32::INPUTPHI_A_F32_ID,mgr);
  641. this->errOffset=0;
  642. inputB.reload(MISCF32::INPUT_ERRORS_F32_ID,mgr);
  643. ref.reload(MISCF32::REF81_F32_ID,mgr);
  644. }
  645. break;
  646. case MISCF32::TEST_LEVINSON_DURBIN_F32_82:
  647. {
  648. this->nba = 8;
  649. inputA.reload(MISCF32::INPUTPHI_B_F32_ID,mgr);
  650. this->errOffset=1;
  651. inputB.reload(MISCF32::INPUT_ERRORS_F32_ID,mgr);
  652. ref.reload(MISCF32::REF82_F32_ID,mgr);
  653. }
  654. break;
  655. case MISCF32::TEST_LEVINSON_DURBIN_F32_83:
  656. {
  657. this->nba = 11;
  658. inputA.reload(MISCF32::INPUTPHI_C_F32_ID,mgr);
  659. this->errOffset=2;
  660. inputB.reload(MISCF32::INPUT_ERRORS_F32_ID,mgr);
  661. ref.reload(MISCF32::REF83_F32_ID,mgr);
  662. }
  663. break;
  664. case MISCF32::TEST_CONV_PARTIAL_F32_84:
  665. {
  666. this->first=3;
  667. this->nba = 6;
  668. this->nbb = 8;
  669. ref.reload(MISCF32::REF84_F32_ID,mgr);
  670. tmp.create(ref.nbSamples(),MISCF32::TMP_F32_ID,mgr);
  671. }
  672. break;
  673. case MISCF32::TEST_CONV_PARTIAL_F32_85:
  674. {
  675. this->first=9;
  676. this->nba = 6;
  677. this->nbb = 8;
  678. ref.reload(MISCF32::REF85_F32_ID,mgr);
  679. tmp.create(ref.nbSamples(),MISCF32::TMP_F32_ID,mgr);
  680. }
  681. break;
  682. case MISCF32::TEST_CONV_PARTIAL_F32_86:
  683. {
  684. this->first=7;
  685. this->nba = 6;
  686. this->nbb = 8;
  687. ref.reload(MISCF32::REF86_F32_ID,mgr);
  688. tmp.create(ref.nbSamples(),MISCF32::TMP_F32_ID,mgr);
  689. }
  690. break;
  691. }
  692. if (id < TEST_LEVINSON_DURBIN_F32_81)
  693. {
  694. inputA.reload(MISCF32::INPUTA_F32_ID,mgr,nba);
  695. inputB.reload(MISCF32::INPUTB_F32_ID,mgr,nbb);
  696. }
  697. if (id > TEST_LEVINSON_DURBIN_F32_83)
  698. {
  699. inputA.reload(MISCF32::INPUTA2_F32_ID,mgr,nba);
  700. inputB.reload(MISCF32::INPUTB2_F32_ID,mgr,nbb);
  701. }
  702. output.create(ref.nbSamples(),MISCF32::OUT_F32_ID,mgr);
  703. }
  704. void MISCF32::tearDown(Testing::testID_t id,Client::PatternMgr *mgr)
  705. {
  706. (void)id;
  707. output.dump(mgr);
  708. }