MISCQ31.cpp 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774
  1. #include "arm_vec_math.h"
  2. #include "MISCQ31.h"
  3. #include <stdio.h>
  4. #include "Error.h"
  5. #include "Test.h"
  6. #define SNR_THRESHOLD 100
  7. /*
  8. Reference patterns are generated with
  9. a double precision computation.
  10. */
  11. #define ABS_ERROR_Q31 ((q31_t)2)
  12. /*
  13. For tests of the error value of the Levinson Durbin algorithm
  14. */
  15. #define ABS_LD_ERROR ((q31_t)30)
  16. void MISCQ31::test_levinson_durbin_q31()
  17. {
  18. const q31_t *inpA=inputA.ptr();
  19. const q31_t *errs=inputB.ptr();
  20. q31_t *outp=output.ptr();
  21. q31_t err;
  22. q31_t refError=errs[this->errOffset];
  23. arm_levinson_durbin_q31(inpA,outp,&err,this->nba);
  24. ASSERT_EMPTY_TAIL(output);
  25. ASSERT_SNR(ref,output,(q31_t)SNR_THRESHOLD);
  26. ASSERT_NEAR_EQ(ref,output,ABS_LD_ERROR);
  27. ASSERT_NEAR_EQ(refError,err,ABS_LD_ERROR);
  28. }
  29. void MISCQ31::test_correlate_q31()
  30. {
  31. const q31_t *inpA=inputA.ptr();
  32. const q31_t *inpB=inputB.ptr();
  33. q31_t *outp=output.ptr();
  34. arm_correlate_q31(inpA, inputA.nbSamples(),
  35. inpB, inputB.nbSamples(),
  36. outp);
  37. ASSERT_SNR(ref,output,(q31_t)SNR_THRESHOLD);
  38. ASSERT_NEAR_EQ(ref,output,ABS_ERROR_Q31);
  39. }
  40. void MISCQ31::test_conv_q31()
  41. {
  42. const q31_t *inpA=inputA.ptr();
  43. const q31_t *inpB=inputB.ptr();
  44. q31_t *outp=output.ptr();
  45. arm_conv_q31(inpA, inputA.nbSamples(),
  46. inpB, inputB.nbSamples(),
  47. outp);
  48. ASSERT_SNR(ref,output,(q31_t)SNR_THRESHOLD);
  49. ASSERT_NEAR_EQ(ref,output,ABS_ERROR_Q31);
  50. }
  51. void MISCQ31::setUp(Testing::testID_t id,std::vector<Testing::param_t>& paramsArgs,Client::PatternMgr *mgr)
  52. {
  53. (void)paramsArgs;
  54. switch(id)
  55. {
  56. case MISCQ31::TEST_CORRELATE_Q31_1:
  57. {
  58. this->nba = 4;
  59. this->nbb = 1;
  60. ref.reload(MISCQ31::REF1_Q31_ID,mgr);
  61. }
  62. break;
  63. case MISCQ31::TEST_CORRELATE_Q31_2:
  64. {
  65. this->nba = 4;
  66. this->nbb = 2;
  67. ref.reload(MISCQ31::REF2_Q31_ID,mgr);
  68. }
  69. break;
  70. case MISCQ31::TEST_CORRELATE_Q31_3:
  71. {
  72. this->nba = 4;
  73. this->nbb = 3;
  74. ref.reload(MISCQ31::REF3_Q31_ID,mgr);
  75. }
  76. break;
  77. case MISCQ31::TEST_CORRELATE_Q31_4:
  78. {
  79. this->nba = 4;
  80. this->nbb = 8;
  81. ref.reload(MISCQ31::REF4_Q31_ID,mgr);
  82. }
  83. break;
  84. case MISCQ31::TEST_CORRELATE_Q31_5:
  85. {
  86. this->nba = 4;
  87. this->nbb = 11;
  88. ref.reload(MISCQ31::REF5_Q31_ID,mgr);
  89. }
  90. break;
  91. case MISCQ31::TEST_CORRELATE_Q31_6:
  92. {
  93. this->nba = 5;
  94. this->nbb = 1;
  95. ref.reload(MISCQ31::REF6_Q31_ID,mgr);
  96. }
  97. break;
  98. case MISCQ31::TEST_CORRELATE_Q31_7:
  99. {
  100. this->nba = 5;
  101. this->nbb = 2;
  102. ref.reload(MISCQ31::REF7_Q31_ID,mgr);
  103. }
  104. break;
  105. case MISCQ31::TEST_CORRELATE_Q31_8:
  106. {
  107. this->nba = 5;
  108. this->nbb = 3;
  109. ref.reload(MISCQ31::REF8_Q31_ID,mgr);
  110. }
  111. break;
  112. case MISCQ31::TEST_CORRELATE_Q31_9:
  113. {
  114. this->nba = 5;
  115. this->nbb = 8;
  116. ref.reload(MISCQ31::REF9_Q31_ID,mgr);
  117. }
  118. break;
  119. case MISCQ31::TEST_CORRELATE_Q31_10:
  120. {
  121. this->nba = 5;
  122. this->nbb = 11;
  123. ref.reload(MISCQ31::REF10_Q31_ID,mgr);
  124. }
  125. break;
  126. case MISCQ31::TEST_CORRELATE_Q31_11:
  127. {
  128. this->nba = 6;
  129. this->nbb = 1;
  130. ref.reload(MISCQ31::REF11_Q31_ID,mgr);
  131. }
  132. break;
  133. case MISCQ31::TEST_CORRELATE_Q31_12:
  134. {
  135. this->nba = 6;
  136. this->nbb = 2;
  137. ref.reload(MISCQ31::REF12_Q31_ID,mgr);
  138. }
  139. break;
  140. case MISCQ31::TEST_CORRELATE_Q31_13:
  141. {
  142. this->nba = 6;
  143. this->nbb = 3;
  144. ref.reload(MISCQ31::REF13_Q31_ID,mgr);
  145. }
  146. break;
  147. case MISCQ31::TEST_CORRELATE_Q31_14:
  148. {
  149. this->nba = 6;
  150. this->nbb = 8;
  151. ref.reload(MISCQ31::REF14_Q31_ID,mgr);
  152. }
  153. break;
  154. case MISCQ31::TEST_CORRELATE_Q31_15:
  155. {
  156. this->nba = 6;
  157. this->nbb = 11;
  158. ref.reload(MISCQ31::REF15_Q31_ID,mgr);
  159. }
  160. break;
  161. case MISCQ31::TEST_CORRELATE_Q31_16:
  162. {
  163. this->nba = 9;
  164. this->nbb = 1;
  165. ref.reload(MISCQ31::REF16_Q31_ID,mgr);
  166. }
  167. break;
  168. case MISCQ31::TEST_CORRELATE_Q31_17:
  169. {
  170. this->nba = 9;
  171. this->nbb = 2;
  172. ref.reload(MISCQ31::REF17_Q31_ID,mgr);
  173. }
  174. break;
  175. case MISCQ31::TEST_CORRELATE_Q31_18:
  176. {
  177. this->nba = 9;
  178. this->nbb = 3;
  179. ref.reload(MISCQ31::REF18_Q31_ID,mgr);
  180. }
  181. break;
  182. case MISCQ31::TEST_CORRELATE_Q31_19:
  183. {
  184. this->nba = 9;
  185. this->nbb = 8;
  186. ref.reload(MISCQ31::REF19_Q31_ID,mgr);
  187. }
  188. break;
  189. case MISCQ31::TEST_CORRELATE_Q31_20:
  190. {
  191. this->nba = 9;
  192. this->nbb = 11;
  193. ref.reload(MISCQ31::REF20_Q31_ID,mgr);
  194. }
  195. break;
  196. case MISCQ31::TEST_CORRELATE_Q31_21:
  197. {
  198. this->nba = 10;
  199. this->nbb = 1;
  200. ref.reload(MISCQ31::REF21_Q31_ID,mgr);
  201. }
  202. break;
  203. case MISCQ31::TEST_CORRELATE_Q31_22:
  204. {
  205. this->nba = 10;
  206. this->nbb = 2;
  207. ref.reload(MISCQ31::REF22_Q31_ID,mgr);
  208. }
  209. break;
  210. case MISCQ31::TEST_CORRELATE_Q31_23:
  211. {
  212. this->nba = 10;
  213. this->nbb = 3;
  214. ref.reload(MISCQ31::REF23_Q31_ID,mgr);
  215. }
  216. break;
  217. case MISCQ31::TEST_CORRELATE_Q31_24:
  218. {
  219. this->nba = 10;
  220. this->nbb = 8;
  221. ref.reload(MISCQ31::REF24_Q31_ID,mgr);
  222. }
  223. break;
  224. case MISCQ31::TEST_CORRELATE_Q31_25:
  225. {
  226. this->nba = 10;
  227. this->nbb = 11;
  228. ref.reload(MISCQ31::REF25_Q31_ID,mgr);
  229. }
  230. break;
  231. case MISCQ31::TEST_CORRELATE_Q31_26:
  232. {
  233. this->nba = 11;
  234. this->nbb = 1;
  235. ref.reload(MISCQ31::REF26_Q31_ID,mgr);
  236. }
  237. break;
  238. case MISCQ31::TEST_CORRELATE_Q31_27:
  239. {
  240. this->nba = 11;
  241. this->nbb = 2;
  242. ref.reload(MISCQ31::REF27_Q31_ID,mgr);
  243. }
  244. break;
  245. case MISCQ31::TEST_CORRELATE_Q31_28:
  246. {
  247. this->nba = 11;
  248. this->nbb = 3;
  249. ref.reload(MISCQ31::REF28_Q31_ID,mgr);
  250. }
  251. break;
  252. case MISCQ31::TEST_CORRELATE_Q31_29:
  253. {
  254. this->nba = 11;
  255. this->nbb = 8;
  256. ref.reload(MISCQ31::REF29_Q31_ID,mgr);
  257. }
  258. break;
  259. case MISCQ31::TEST_CORRELATE_Q31_30:
  260. {
  261. this->nba = 11;
  262. this->nbb = 11;
  263. ref.reload(MISCQ31::REF30_Q31_ID,mgr);
  264. }
  265. break;
  266. case MISCQ31::TEST_CORRELATE_Q31_31:
  267. {
  268. this->nba = 12;
  269. this->nbb = 1;
  270. ref.reload(MISCQ31::REF31_Q31_ID,mgr);
  271. }
  272. break;
  273. case MISCQ31::TEST_CORRELATE_Q31_32:
  274. {
  275. this->nba = 12;
  276. this->nbb = 2;
  277. ref.reload(MISCQ31::REF32_Q31_ID,mgr);
  278. }
  279. break;
  280. case MISCQ31::TEST_CORRELATE_Q31_33:
  281. {
  282. this->nba = 12;
  283. this->nbb = 3;
  284. ref.reload(MISCQ31::REF33_Q31_ID,mgr);
  285. }
  286. break;
  287. case MISCQ31::TEST_CORRELATE_Q31_34:
  288. {
  289. this->nba = 12;
  290. this->nbb = 8;
  291. ref.reload(MISCQ31::REF34_Q31_ID,mgr);
  292. }
  293. break;
  294. case MISCQ31::TEST_CORRELATE_Q31_35:
  295. {
  296. this->nba = 12;
  297. this->nbb = 11;
  298. ref.reload(MISCQ31::REF35_Q31_ID,mgr);
  299. }
  300. break;
  301. case MISCQ31::TEST_CORRELATE_Q31_36:
  302. {
  303. this->nba = 13;
  304. this->nbb = 1;
  305. ref.reload(MISCQ31::REF36_Q31_ID,mgr);
  306. }
  307. break;
  308. case MISCQ31::TEST_CORRELATE_Q31_37:
  309. {
  310. this->nba = 13;
  311. this->nbb = 2;
  312. ref.reload(MISCQ31::REF37_Q31_ID,mgr);
  313. }
  314. break;
  315. case MISCQ31::TEST_CORRELATE_Q31_38:
  316. {
  317. this->nba = 13;
  318. this->nbb = 3;
  319. ref.reload(MISCQ31::REF38_Q31_ID,mgr);
  320. }
  321. break;
  322. case MISCQ31::TEST_CORRELATE_Q31_39:
  323. {
  324. this->nba = 13;
  325. this->nbb = 8;
  326. ref.reload(MISCQ31::REF39_Q31_ID,mgr);
  327. }
  328. break;
  329. case MISCQ31::TEST_CORRELATE_Q31_40:
  330. {
  331. this->nba = 13;
  332. this->nbb = 11;
  333. ref.reload(MISCQ31::REF40_Q31_ID,mgr);
  334. }
  335. break;
  336. case MISCQ31::TEST_CONV_Q31_41:
  337. {
  338. this->nba = 4;
  339. this->nbb = 1;
  340. ref.reload(MISCQ31::REF41_Q31_ID,mgr);
  341. }
  342. break;
  343. case MISCQ31::TEST_CONV_Q31_42:
  344. {
  345. this->nba = 4;
  346. this->nbb = 2;
  347. ref.reload(MISCQ31::REF42_Q31_ID,mgr);
  348. }
  349. break;
  350. case MISCQ31::TEST_CONV_Q31_43:
  351. {
  352. this->nba = 4;
  353. this->nbb = 3;
  354. ref.reload(MISCQ31::REF43_Q31_ID,mgr);
  355. }
  356. break;
  357. case MISCQ31::TEST_CONV_Q31_44:
  358. {
  359. this->nba = 4;
  360. this->nbb = 8;
  361. ref.reload(MISCQ31::REF44_Q31_ID,mgr);
  362. }
  363. break;
  364. case MISCQ31::TEST_CONV_Q31_45:
  365. {
  366. this->nba = 4;
  367. this->nbb = 11;
  368. ref.reload(MISCQ31::REF45_Q31_ID,mgr);
  369. }
  370. break;
  371. case MISCQ31::TEST_CONV_Q31_46:
  372. {
  373. this->nba = 5;
  374. this->nbb = 1;
  375. ref.reload(MISCQ31::REF46_Q31_ID,mgr);
  376. }
  377. break;
  378. case MISCQ31::TEST_CONV_Q31_47:
  379. {
  380. this->nba = 5;
  381. this->nbb = 2;
  382. ref.reload(MISCQ31::REF47_Q31_ID,mgr);
  383. }
  384. break;
  385. case MISCQ31::TEST_CONV_Q31_48:
  386. {
  387. this->nba = 5;
  388. this->nbb = 3;
  389. ref.reload(MISCQ31::REF48_Q31_ID,mgr);
  390. }
  391. break;
  392. case MISCQ31::TEST_CONV_Q31_49:
  393. {
  394. this->nba = 5;
  395. this->nbb = 8;
  396. ref.reload(MISCQ31::REF49_Q31_ID,mgr);
  397. }
  398. break;
  399. case MISCQ31::TEST_CONV_Q31_50:
  400. {
  401. this->nba = 5;
  402. this->nbb = 11;
  403. ref.reload(MISCQ31::REF50_Q31_ID,mgr);
  404. }
  405. break;
  406. case MISCQ31::TEST_CONV_Q31_51:
  407. {
  408. this->nba = 6;
  409. this->nbb = 1;
  410. ref.reload(MISCQ31::REF51_Q31_ID,mgr);
  411. }
  412. break;
  413. case MISCQ31::TEST_CONV_Q31_52:
  414. {
  415. this->nba = 6;
  416. this->nbb = 2;
  417. ref.reload(MISCQ31::REF52_Q31_ID,mgr);
  418. }
  419. break;
  420. case MISCQ31::TEST_CONV_Q31_53:
  421. {
  422. this->nba = 6;
  423. this->nbb = 3;
  424. ref.reload(MISCQ31::REF53_Q31_ID,mgr);
  425. }
  426. break;
  427. case MISCQ31::TEST_CONV_Q31_54:
  428. {
  429. this->nba = 6;
  430. this->nbb = 8;
  431. ref.reload(MISCQ31::REF54_Q31_ID,mgr);
  432. }
  433. break;
  434. case MISCQ31::TEST_CONV_Q31_55:
  435. {
  436. this->nba = 6;
  437. this->nbb = 11;
  438. ref.reload(MISCQ31::REF55_Q31_ID,mgr);
  439. }
  440. break;
  441. case MISCQ31::TEST_CONV_Q31_56:
  442. {
  443. this->nba = 9;
  444. this->nbb = 1;
  445. ref.reload(MISCQ31::REF56_Q31_ID,mgr);
  446. }
  447. break;
  448. case MISCQ31::TEST_CONV_Q31_57:
  449. {
  450. this->nba = 9;
  451. this->nbb = 2;
  452. ref.reload(MISCQ31::REF57_Q31_ID,mgr);
  453. }
  454. break;
  455. case MISCQ31::TEST_CONV_Q31_58:
  456. {
  457. this->nba = 9;
  458. this->nbb = 3;
  459. ref.reload(MISCQ31::REF58_Q31_ID,mgr);
  460. }
  461. break;
  462. case MISCQ31::TEST_CONV_Q31_59:
  463. {
  464. this->nba = 9;
  465. this->nbb = 8;
  466. ref.reload(MISCQ31::REF59_Q31_ID,mgr);
  467. }
  468. break;
  469. case MISCQ31::TEST_CONV_Q31_60:
  470. {
  471. this->nba = 9;
  472. this->nbb = 11;
  473. ref.reload(MISCQ31::REF60_Q31_ID,mgr);
  474. }
  475. break;
  476. case MISCQ31::TEST_CONV_Q31_61:
  477. {
  478. this->nba = 10;
  479. this->nbb = 1;
  480. ref.reload(MISCQ31::REF61_Q31_ID,mgr);
  481. }
  482. break;
  483. case MISCQ31::TEST_CONV_Q31_62:
  484. {
  485. this->nba = 10;
  486. this->nbb = 2;
  487. ref.reload(MISCQ31::REF62_Q31_ID,mgr);
  488. }
  489. break;
  490. case MISCQ31::TEST_CONV_Q31_63:
  491. {
  492. this->nba = 10;
  493. this->nbb = 3;
  494. ref.reload(MISCQ31::REF63_Q31_ID,mgr);
  495. }
  496. break;
  497. case MISCQ31::TEST_CONV_Q31_64:
  498. {
  499. this->nba = 10;
  500. this->nbb = 8;
  501. ref.reload(MISCQ31::REF64_Q31_ID,mgr);
  502. }
  503. break;
  504. case MISCQ31::TEST_CONV_Q31_65:
  505. {
  506. this->nba = 10;
  507. this->nbb = 11;
  508. ref.reload(MISCQ31::REF65_Q31_ID,mgr);
  509. }
  510. break;
  511. case MISCQ31::TEST_CONV_Q31_66:
  512. {
  513. this->nba = 11;
  514. this->nbb = 1;
  515. ref.reload(MISCQ31::REF66_Q31_ID,mgr);
  516. }
  517. break;
  518. case MISCQ31::TEST_CONV_Q31_67:
  519. {
  520. this->nba = 11;
  521. this->nbb = 2;
  522. ref.reload(MISCQ31::REF67_Q31_ID,mgr);
  523. }
  524. break;
  525. case MISCQ31::TEST_CONV_Q31_68:
  526. {
  527. this->nba = 11;
  528. this->nbb = 3;
  529. ref.reload(MISCQ31::REF68_Q31_ID,mgr);
  530. }
  531. break;
  532. case MISCQ31::TEST_CONV_Q31_69:
  533. {
  534. this->nba = 11;
  535. this->nbb = 8;
  536. ref.reload(MISCQ31::REF69_Q31_ID,mgr);
  537. }
  538. break;
  539. case MISCQ31::TEST_CONV_Q31_70:
  540. {
  541. this->nba = 11;
  542. this->nbb = 11;
  543. ref.reload(MISCQ31::REF70_Q31_ID,mgr);
  544. }
  545. break;
  546. case MISCQ31::TEST_CONV_Q31_71:
  547. {
  548. this->nba = 12;
  549. this->nbb = 1;
  550. ref.reload(MISCQ31::REF71_Q31_ID,mgr);
  551. }
  552. break;
  553. case MISCQ31::TEST_CONV_Q31_72:
  554. {
  555. this->nba = 12;
  556. this->nbb = 2;
  557. ref.reload(MISCQ31::REF72_Q31_ID,mgr);
  558. }
  559. break;
  560. case MISCQ31::TEST_CONV_Q31_73:
  561. {
  562. this->nba = 12;
  563. this->nbb = 3;
  564. ref.reload(MISCQ31::REF73_Q31_ID,mgr);
  565. }
  566. break;
  567. case MISCQ31::TEST_CONV_Q31_74:
  568. {
  569. this->nba = 12;
  570. this->nbb = 8;
  571. ref.reload(MISCQ31::REF74_Q31_ID,mgr);
  572. }
  573. break;
  574. case MISCQ31::TEST_CONV_Q31_75:
  575. {
  576. this->nba = 12;
  577. this->nbb = 11;
  578. ref.reload(MISCQ31::REF75_Q31_ID,mgr);
  579. }
  580. break;
  581. case MISCQ31::TEST_CONV_Q31_76:
  582. {
  583. this->nba = 13;
  584. this->nbb = 1;
  585. ref.reload(MISCQ31::REF76_Q31_ID,mgr);
  586. }
  587. break;
  588. case MISCQ31::TEST_CONV_Q31_77:
  589. {
  590. this->nba = 13;
  591. this->nbb = 2;
  592. ref.reload(MISCQ31::REF77_Q31_ID,mgr);
  593. }
  594. break;
  595. case MISCQ31::TEST_CONV_Q31_78:
  596. {
  597. this->nba = 13;
  598. this->nbb = 3;
  599. ref.reload(MISCQ31::REF78_Q31_ID,mgr);
  600. }
  601. break;
  602. case MISCQ31::TEST_CONV_Q31_79:
  603. {
  604. this->nba = 13;
  605. this->nbb = 8;
  606. ref.reload(MISCQ31::REF79_Q31_ID,mgr);
  607. }
  608. break;
  609. case MISCQ31::TEST_CONV_Q31_80:
  610. {
  611. this->nba = 13;
  612. this->nbb = 11;
  613. ref.reload(MISCQ31::REF80_Q31_ID,mgr);
  614. }
  615. break;
  616. case MISCQ31::TEST_LEVINSON_DURBIN_Q31_81:
  617. {
  618. this->nba = 3;
  619. inputA.reload(MISCQ31::INPUTPHI_A_Q31_ID,mgr);
  620. this->errOffset=0;
  621. inputB.reload(MISCQ31::INPUT_ERRORS_Q31_ID,mgr);
  622. ref.reload(MISCQ31::REF81_Q31_ID,mgr);
  623. }
  624. break;
  625. case MISCQ31::TEST_LEVINSON_DURBIN_Q31_82:
  626. {
  627. this->nba = 8;
  628. inputA.reload(MISCQ31::INPUTPHI_B_Q31_ID,mgr);
  629. this->errOffset=1;
  630. inputB.reload(MISCQ31::INPUT_ERRORS_Q31_ID,mgr);
  631. ref.reload(MISCQ31::REF82_Q31_ID,mgr);
  632. }
  633. break;
  634. case MISCQ31::TEST_LEVINSON_DURBIN_Q31_83:
  635. {
  636. this->nba = 11;
  637. inputA.reload(MISCQ31::INPUTPHI_C_Q31_ID,mgr);
  638. this->errOffset=2;
  639. inputB.reload(MISCQ31::INPUT_ERRORS_Q31_ID,mgr);
  640. ref.reload(MISCQ31::REF83_Q31_ID,mgr);
  641. }
  642. break;
  643. }
  644. if (id < TEST_LEVINSON_DURBIN_Q31_81)
  645. {
  646. inputA.reload(MISCQ31::INPUTA_Q31_ID,mgr,nba);
  647. inputB.reload(MISCQ31::INPUTB_Q31_ID,mgr,nbb);
  648. }
  649. output.create(ref.nbSamples(),MISCQ31::OUT_Q31_ID,mgr);
  650. }
  651. void MISCQ31::tearDown(Testing::testID_t id,Client::PatternMgr *mgr)
  652. {
  653. (void)id;
  654. output.dump(mgr);
  655. }