BasicMathsBenchmarksQ7.cpp 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. #include "BasicMathsBenchmarksQ7.h"
  2. #include "Error.h"
  3. void BasicMathsBenchmarksQ7::vec_mult_q7()
  4. {
  5. q7_t *inp1=input1.ptr();
  6. q7_t *inp2=input2.ptr();
  7. q7_t *outp=output.ptr();
  8. arm_mult_q7(inp1,inp2,outp,this->nb);
  9. }
  10. void BasicMathsBenchmarksQ7::vec_add_q7()
  11. {
  12. q7_t *inp1=input1.ptr();
  13. q7_t *inp2=input2.ptr();
  14. q7_t *outp=output.ptr();
  15. arm_add_q7(inp1,inp2,outp,this->nb);
  16. }
  17. void BasicMathsBenchmarksQ7::vec_sub_q7()
  18. {
  19. q7_t *inp1=input1.ptr();
  20. q7_t *inp2=input2.ptr();
  21. q7_t *outp=output.ptr();
  22. arm_sub_q7(inp1,inp2,outp,this->nb);
  23. }
  24. void BasicMathsBenchmarksQ7::vec_abs_q7()
  25. {
  26. q7_t *inp1=input1.ptr();
  27. q7_t *inp2=input2.ptr();
  28. q7_t *outp=output.ptr();
  29. arm_abs_q7(inp1,outp,this->nb);
  30. }
  31. void BasicMathsBenchmarksQ7::vec_negate_q7()
  32. {
  33. q7_t *inp1=input1.ptr();
  34. q7_t *outp=output.ptr();
  35. arm_negate_q7(inp1,outp,this->nb);
  36. }
  37. void BasicMathsBenchmarksQ7::vec_offset_q7()
  38. {
  39. q7_t *inp1=input1.ptr();
  40. q7_t *inp2=input2.ptr();
  41. q7_t *outp=output.ptr();
  42. arm_offset_q7(inp1,1.0,outp,this->nb);
  43. }
  44. void BasicMathsBenchmarksQ7::vec_scale_q7()
  45. {
  46. q7_t *inp1=input1.ptr();
  47. q7_t *inp2=input2.ptr();
  48. q7_t *outp=output.ptr();
  49. arm_scale_q7(inp1,0x45,1,outp,this->nb);
  50. }
  51. void BasicMathsBenchmarksQ7::vec_dot_q7()
  52. {
  53. q7_t *inp1=input1.ptr();
  54. q7_t *inp2=input2.ptr();
  55. q31_t result;
  56. arm_dot_prod_q7(inp1,inp2,this->nb,&result);
  57. }
  58. void BasicMathsBenchmarksQ7::setUp(Testing::testID_t id,std::vector<Testing::param_t>& params,Client::PatternMgr *mgr)
  59. {
  60. std::vector<Testing::param_t>::iterator it = params.begin();
  61. this->nb = *it;
  62. input1.reload(BasicMathsBenchmarksQ7::INPUT1_Q7_ID,mgr,this->nb);
  63. input2.reload(BasicMathsBenchmarksQ7::INPUT2_Q7_ID,mgr,this->nb);
  64. output.create(this->nb,BasicMathsBenchmarksQ7::OUT_SAMPLES_Q7_ID,mgr);
  65. }
  66. void BasicMathsBenchmarksQ7::tearDown(Testing::testID_t id,Client::PatternMgr *mgr)
  67. {
  68. }