SVMF32.cpp 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260
  1. #include "SVMF32.h"
  2. #include <stdio.h>
  3. #include "Error.h"
  4. void SVMF32::test_svm_linear_predict_f32()
  5. {
  6. const float32_t *inp = samples.ptr();
  7. int32_t *outp = output.ptr();
  8. int32_t *result;
  9. result=outp;
  10. for(int i =0; i < this->nbTestSamples; i++)
  11. {
  12. arm_svm_linear_predict_f32(&this->linear,inp,result);
  13. result++;
  14. inp += this->vecDim;
  15. }
  16. ASSERT_EQ(ref,output);
  17. }
  18. void SVMF32::test_svm_polynomial_predict_f32()
  19. {
  20. const float32_t *inp = samples.ptr();
  21. int32_t *outp = output.ptr();
  22. int32_t *result;
  23. result=outp;
  24. for(int i =0; i < this->nbTestSamples; i++)
  25. {
  26. arm_svm_polynomial_predict_f32(&this->poly,inp,result);
  27. result++;
  28. inp += this->vecDim;
  29. }
  30. ASSERT_EQ(ref,output);
  31. }
  32. void SVMF32::test_svm_rbf_predict_f32()
  33. {
  34. const float32_t *inp = samples.ptr();
  35. int32_t *outp = output.ptr();
  36. int32_t *result;
  37. result=outp;
  38. for(int i =0; i < this->nbTestSamples; i++)
  39. {
  40. arm_svm_rbf_predict_f32(&this->rbf,inp,result);
  41. result++;
  42. inp += this->vecDim;
  43. }
  44. ASSERT_EQ(ref,output);
  45. }
  46. void SVMF32::test_svm_sigmoid_predict_f32()
  47. {
  48. const float32_t *inp = samples.ptr();
  49. int32_t *outp = output.ptr();
  50. int32_t *result;
  51. result=outp;
  52. for(int i =0; i < this->nbTestSamples; i++)
  53. {
  54. arm_svm_sigmoid_predict_f32(&this->sigmoid,inp,result);
  55. result++;
  56. inp += this->vecDim;
  57. }
  58. ASSERT_EQ(ref,output);
  59. }
  60. void SVMF32::setUp(Testing::testID_t id,std::vector<Testing::param_t>& testparams,Client::PatternMgr *mgr)
  61. {
  62. int kind;
  63. Testing::nbSamples_t nb=MAX_NB_SAMPLES;
  64. (void)testparams;
  65. switch(id)
  66. {
  67. case SVMF32::TEST_SVM_LINEAR_PREDICT_F32_1:
  68. {
  69. samples.reload(SVMF32::SAMPLES1_F32_ID,mgr,nb);
  70. params.reload(SVMF32::PARAMS1_F32_ID,mgr,nb);
  71. dims.reload(SVMF32::DIMS1_S16_ID,mgr,nb);
  72. ref.reload(SVMF32::REF1_S32_ID,mgr,nb);
  73. }
  74. break;
  75. case SVMF32::TEST_SVM_POLYNOMIAL_PREDICT_F32_2:
  76. {
  77. samples.reload(SVMF32::SAMPLES2_F32_ID,mgr,nb);
  78. params.reload(SVMF32::PARAMS2_F32_ID,mgr,nb);
  79. dims.reload(SVMF32::DIMS2_S16_ID,mgr,nb);
  80. ref.reload(SVMF32::REF2_S32_ID,mgr,nb);
  81. }
  82. break;
  83. case SVMF32::TEST_SVM_RBF_PREDICT_F32_3:
  84. {
  85. samples.reload(SVMF32::SAMPLES3_F32_ID,mgr,nb);
  86. params.reload(SVMF32::PARAMS3_F32_ID,mgr,nb);
  87. dims.reload(SVMF32::DIMS3_S16_ID,mgr,nb);
  88. ref.reload(SVMF32::REF3_S32_ID,mgr,nb);
  89. }
  90. break;
  91. case SVMF32::TEST_SVM_SIGMOID_PREDICT_F32_4:
  92. {
  93. samples.reload(SVMF32::SAMPLES4_F32_ID,mgr,nb);
  94. params.reload(SVMF32::PARAMS4_F32_ID,mgr,nb);
  95. dims.reload(SVMF32::DIMS4_S16_ID,mgr,nb);
  96. ref.reload(SVMF32::REF4_S32_ID,mgr,nb);
  97. }
  98. break;
  99. #if 0
  100. case SVMF32::TEST_SVM_RBF_PREDICT_F32_5:
  101. {
  102. samples.reload(SVMF32::SAMPLES5_F32_ID,mgr,nb);
  103. params.reload(SVMF32::PARAMS5_F32_ID,mgr,nb);
  104. dims.reload(SVMF32::DIMS5_S16_ID,mgr,nb);
  105. ref.reload(SVMF32::REF5_S32_ID,mgr,nb);
  106. }
  107. break;
  108. #endif
  109. }
  110. const int16_t *dimsp = dims.ptr();
  111. const float32_t *paramsp = params.ptr();
  112. kind = dimsp[0];
  113. this->classes[0] = dimsp[1];
  114. this->classes[1] = dimsp[2];
  115. this->nbTestSamples=dimsp[3];
  116. this->vecDim = dimsp[4];
  117. this->nbSupportVectors = dimsp[5];
  118. this->intercept=paramsp[this->vecDim*this->nbSupportVectors + this->nbSupportVectors];
  119. this->supportVectors=paramsp;
  120. this->dualCoefs=paramsp + (this->vecDim*this->nbSupportVectors);
  121. switch(kind)
  122. {
  123. case SVMF32::POLY:
  124. this->degree = dimsp[6];
  125. this->coef0 =paramsp[this->vecDim*this->nbSupportVectors + this->nbSupportVectors + 1] ;
  126. this->gamma=paramsp[this->vecDim*this->nbSupportVectors + this->nbSupportVectors + 2];
  127. break;
  128. case SVMF32::RBF:
  129. this->gamma=paramsp[this->vecDim*this->nbSupportVectors + this->nbSupportVectors + 1];
  130. break;
  131. case SVMF32::SIGMOID:
  132. this->coef0 =paramsp[this->vecDim*this->nbSupportVectors + this->nbSupportVectors + 1] ;
  133. this->gamma=paramsp[this->vecDim*this->nbSupportVectors + this->nbSupportVectors + 2];
  134. break;
  135. }
  136. switch(id)
  137. {
  138. case SVMF32::TEST_SVM_LINEAR_PREDICT_F32_1:
  139. //case SVMF32::TEST_SVM_RBF_PREDICT_F32_5:
  140. {
  141. arm_svm_linear_init_f32(&linear,
  142. this->nbSupportVectors,
  143. this->vecDim,
  144. this->intercept,
  145. this->dualCoefs,
  146. this->supportVectors,
  147. this->classes);
  148. }
  149. break;
  150. case SVMF32::TEST_SVM_POLYNOMIAL_PREDICT_F32_2:
  151. {
  152. arm_svm_polynomial_init_f32(&poly,
  153. this->nbSupportVectors,
  154. this->vecDim,
  155. this->intercept,
  156. this->dualCoefs,
  157. this->supportVectors,
  158. this->classes,
  159. this->degree,
  160. this->coef0,
  161. this->gamma
  162. );
  163. }
  164. break;
  165. case SVMF32::TEST_SVM_RBF_PREDICT_F32_3:
  166. {
  167. arm_svm_rbf_init_f32(&rbf,
  168. this->nbSupportVectors,
  169. this->vecDim,
  170. this->intercept,
  171. this->dualCoefs,
  172. this->supportVectors,
  173. this->classes,
  174. this->gamma
  175. );
  176. }
  177. break;
  178. case SVMF32::TEST_SVM_SIGMOID_PREDICT_F32_4:
  179. {
  180. arm_svm_sigmoid_init_f32(&sigmoid,
  181. this->nbSupportVectors,
  182. this->vecDim,
  183. this->intercept,
  184. this->dualCoefs,
  185. this->supportVectors,
  186. this->classes,
  187. this->coef0,
  188. this->gamma
  189. );
  190. }
  191. break;
  192. }
  193. output.create(ref.nbSamples(),SVMF32::OUT_S32_ID,mgr);
  194. }
  195. void SVMF32::tearDown(Testing::testID_t id,Client::PatternMgr *mgr)
  196. {
  197. (void)id;
  198. output.dump(mgr);
  199. }