test_torquesensor.cpp 7.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237
  1. #include "gtest/gtest.h"
  2. #include <gtest/gtest.h>
  3. #include <stdint.h>
  4. #include <tuple>
  5. #include "scope.h"
  6. #include "test_user.h"
  7. class TorqueSensorTest : public testing::Test
  8. {
  9. protected:
  10. static void SetUpTestSuite()
  11. {
  12. torsensor_voTorSensorInit();
  13. }
  14. virtual void SetUp() override
  15. {
  16. }
  17. virtual void TearDown() override
  18. {
  19. torsensor_voTorSensorInit();
  20. torsensor_stTorSensorCof.uwTorqueOffsetConfirmFlg = FALSE;
  21. /* Coef Reset */
  22. torsensor_stTorSensorCof.uwTorqueOffsetOrign = 0;
  23. torsensor_stTorSensorCof.uwTorqueOffsetNow1 = 0;
  24. torsensor_stTorSensorCof.uwTorqueOffsetNow2 = 0;
  25. torsensor_stTorSensorCof.uwTorqueOffsetNow3 = 0;
  26. torsensor_stTorSensorCof.uwTorqueOffsetNow4 = 0;
  27. }
  28. };
  29. class TorqueSensorTest1 : public TorqueSensorTest, public testing::WithParamInterface<double>
  30. {};
  31. TEST_P(TorqueSensorTest1, TorqCal)
  32. {
  33. /* Coef Cal */
  34. torsensor_stTorSensorCof.uwBikeTorStep1ADC = 1310;
  35. torsensor_stTorSensorCof.uwBikeTorStep2ADC = 1806;
  36. torsensor_stTorSensorCof.uwBikeTorStep3ADC = 2411;
  37. torsensor_stTorSensorCof.uwBikeTorStep4ADC = 3009;
  38. torsensor_stTorSensorCof.uwBikeTorStep1RealNm = 25;
  39. torsensor_stTorSensorCof.uwBikeTorStep2RealNm = 50;
  40. torsensor_stTorSensorCof.uwBikeTorStep3RealNm = 75;
  41. torsensor_stTorSensorCof.uwBikeTorStep4RealNm = 100;
  42. hw_uwADC0[7] = 720; // 上电零点
  43. torsensor_voTorSensorCof();
  44. /* Torque Input */
  45. double torqVol = GetParam();
  46. hw_uwADC0[7] = (uint16_t) (torqVol * 4096 / 3.3);
  47. /* Torque Pu Cal */
  48. torsensor_voTorADC();
  49. double reg2Pu1 = (double)(torsensor_stTorSensorCof.uwBikeTorStep1RealNm - 0) * 16777216 /
  50. (torsensor_stTorSensorCof.uwBikeTorStep1ADC - torsensor_stTorSensorCof.uwTorqueOffset) /TORQUEBASE; // Q24
  51. double reg2Pu2 = (double)(torsensor_stTorSensorCof.uwBikeTorStep2RealNm - torsensor_stTorSensorCof.uwBikeTorStep1RealNm) * 16777216 /
  52. (torsensor_stTorSensorCof.uwBikeTorStep2ADC - torsensor_stTorSensorCof.uwBikeTorStep1ADC) / TORQUEBASE; // Q24
  53. double reg2Pu3 = (double)(torsensor_stTorSensorCof.uwBikeTorStep3RealNm - torsensor_stTorSensorCof.uwBikeTorStep2RealNm) * 16777216 /
  54. (torsensor_stTorSensorCof.uwBikeTorStep3ADC - torsensor_stTorSensorCof.uwBikeTorStep2ADC) / TORQUEBASE; // Q24
  55. double reg2Pu4 = (double)(torsensor_stTorSensorCof.uwBikeTorStep4RealNm - torsensor_stTorSensorCof.uwBikeTorStep3RealNm) * 16777216 /
  56. (torsensor_stTorSensorCof.uwBikeTorStep4ADC - torsensor_stTorSensorCof.uwBikeTorStep3ADC) / TORQUEBASE; // Q24
  57. double torqPu = 0;
  58. if(hw_uwADC0[7] <= torsensor_stTorSensorCof.uwTorqueOffset)
  59. {
  60. torqPu = 0;
  61. }
  62. else if(hw_uwADC0[7] <= torsensor_stTorSensorCof.uwBikeTorStep1ADC)
  63. {
  64. torqPu = (double)(hw_uwADC0[7] - torsensor_stTorSensorCof.uwTorqueOffset)* reg2Pu1 / 1024;
  65. }
  66. else if(hw_uwADC0[7] <= torsensor_stTorSensorCof.uwBikeTorStep2ADC)
  67. {
  68. torqPu = torsensor_stTorSensorCof.uwBikeTorStep1NmPu + (double)(hw_uwADC0[7] - torsensor_stTorSensorCof.uwBikeTorStep1ADC) * reg2Pu2 / 1024;
  69. }
  70. else if(hw_uwADC0[7] <= torsensor_stTorSensorCof.uwBikeTorStep3ADC)
  71. {
  72. torqPu = torsensor_stTorSensorCof.uwBikeTorStep2NmPu + (double)(hw_uwADC0[7] - torsensor_stTorSensorCof.uwBikeTorStep2ADC) * reg2Pu3 / 1024;
  73. }
  74. else if(hw_uwADC0[7] <= torsensor_stTorSensorCof.uwBikeTorStep4ADC)
  75. {
  76. torqPu = torsensor_stTorSensorCof.uwBikeTorStep3NmPu + (double)(hw_uwADC0[7] - torsensor_stTorSensorCof.uwBikeTorStep3ADC) * reg2Pu4 / 1024;
  77. }
  78. else
  79. {
  80. torqPu = torsensor_stTorSensorCof.uwBikeTorStep4NmPu;
  81. }
  82. EXPECT_NEAR(torsensor_stTorSensorOut.uwTorquePu , torqPu, 2);
  83. }
  84. INSTANTIATE_TEST_SUITE_P(DiffTorq, TorqueSensorTest1, ::testing::Values(0, 0.1, 0.8, 1.2, 1.7, 2.5, 1.9));
  85. class TorqueSensorTest2 : public TorqueSensorTest, public testing::WithParamInterface<::std::tuple<double,double>>
  86. {};
  87. TEST_P(TorqueSensorTest2, OffsetUpdate)
  88. {
  89. /* Coef Cal */
  90. torsensor_stTorSensorCof.uwBikeTorStep1ADC = 1200;
  91. torsensor_stTorSensorCof.uwBikeTorStep2ADC = 1900;
  92. torsensor_stTorSensorCof.uwBikeTorStep3ADC = 2600;
  93. torsensor_stTorSensorCof.uwBikeTorStep4ADC = 3100;
  94. torsensor_stTorSensorCof.uwBikeTorStep1RealNm = 25;
  95. torsensor_stTorSensorCof.uwBikeTorStep2RealNm = 50;
  96. torsensor_stTorSensorCof.uwBikeTorStep3RealNm = 75;
  97. torsensor_stTorSensorCof.uwBikeTorStep4RealNm = 100;
  98. hw_uwADC0[7] = 500; // 上电零点
  99. torsensor_voTorSensorCof();
  100. /* Torque Input */
  101. double minReg = get<0>(GetParam());
  102. double maxReg = get<1>(GetParam());
  103. if(minReg > maxReg)
  104. {
  105. minReg = maxReg;
  106. }
  107. if(maxReg > torsensor_stTorSensorCof.uwBikeTorStep1ADC)
  108. {
  109. maxReg = torsensor_stTorSensorCof.uwBikeTorStep1ADC;
  110. }
  111. int j = 0;
  112. for(int i = 0; i < 10000000 ; i++)
  113. {
  114. if(i % TORQUE_1S_1MSCNT == 0)
  115. {
  116. j++;
  117. }
  118. if(i < (TORQUE_1S_1MSCNT * j - TORQUE_1S_1MSCNT / 2))
  119. {
  120. hw_uwADC0[7] = (uint16_t)minReg;
  121. }
  122. else if(i < TORQUE_1S_1MSCNT * j)
  123. {
  124. hw_uwADC0[7] = (uint16_t)maxReg;
  125. }
  126. else
  127. {
  128. // do nothing
  129. }
  130. /* Torque Pu Cal */
  131. torsensor_voTorADC();
  132. torsensor_voOffsetUpdate();
  133. //UdpScope::Send(0, torsensor_stTorSensorCof.uwTorqueOffset);
  134. // UdpScope::Send(0, torsensor_stTorSensorCof.uwTorqueOffsetConfirmFlg);
  135. }
  136. if(maxReg - minReg <= 40)
  137. {
  138. EXPECT_NEAR(torsensor_stTorSensorCof.uwTorqueOffset, (maxReg + minReg)/2, 2);
  139. }
  140. else
  141. {
  142. EXPECT_NEAR(torsensor_stTorSensorCof.uwTorqueOffset, 500, 2);
  143. }
  144. }
  145. INSTANTIATE_TEST_SUITE_P(DiffTorqOffset, TorqueSensorTest2,
  146. ::testing::Combine(::testing::Values(480,495,500), ::testing::Values(510, 530, 600)));
  147. class TorquePowerOnTest: public testing::Test
  148. {
  149. protected:
  150. static void SetUpTestSuite()
  151. {
  152. torsensor_voTorSensorInit();
  153. }
  154. virtual void SetUp() override
  155. {
  156. }
  157. virtual void TearDown() override
  158. {
  159. torsensor_voTorSensorInit();
  160. torsensor_stTorSensorCof.uwTorqueOffsetConfirmFlg = FALSE;
  161. }
  162. };
  163. class TorquePowerOnTest1 : public TorquePowerOnTest, public testing::WithParamInterface<double>
  164. {};
  165. int i = 0;
  166. double offsetLast[4] = {0,0,0,0};
  167. TEST_P(TorquePowerOnTest1, OffsetUpdate)
  168. {
  169. /* Coef Cal */
  170. torsensor_stTorSensorCof.uwBikeTorStep1ADC = 1310;
  171. torsensor_stTorSensorCof.uwBikeTorStep2ADC = 1806;
  172. torsensor_stTorSensorCof.uwBikeTorStep3ADC = 2411;
  173. torsensor_stTorSensorCof.uwBikeTorStep4ADC = 3009;
  174. torsensor_stTorSensorCof.uwBikeTorStep1RealNm = 25;
  175. torsensor_stTorSensorCof.uwBikeTorStep2RealNm = 50;
  176. torsensor_stTorSensorCof.uwBikeTorStep3RealNm = 75;
  177. torsensor_stTorSensorCof.uwBikeTorStep4RealNm = 100;
  178. hw_uwADC0[7] = (uint16_t)GetParam(); // 上电零点
  179. torsensor_voTorSensorCof();
  180. i++;
  181. if(i > 1)
  182. {
  183. double offsetAvg = 0;
  184. if(offsetLast[0] == 0)
  185. {
  186. offsetAvg = torsensor_stTorSensorCof.uwTorqueOffsetOrign;
  187. }
  188. else
  189. {
  190. offsetAvg = (offsetLast[0] + offsetLast[1] + offsetLast[2] + offsetLast[3]) / 4;
  191. }
  192. if(abs((double)hw_uwADC0[7] - offsetAvg) > 200)
  193. {
  194. EXPECT_NEAR(torsensor_stTorSensorCof.uwTorqueOffset, offsetAvg, 2);
  195. }
  196. else
  197. {
  198. offsetLast[0] = offsetLast[1];
  199. offsetLast[1] = offsetLast[2];
  200. offsetLast[2] = offsetLast[3];
  201. offsetLast[3] = torsensor_stTorSensorCof.uwTorqueOffset;
  202. EXPECT_NEAR(torsensor_stTorSensorCof.uwTorqueOffset, hw_uwADC0[7], 2);
  203. }
  204. }
  205. }
  206. INSTANTIATE_TEST_SUITE_P(DiffTorqOffset, TorquePowerOnTest1, ::testing::Values(500, 536, 600, 810, 630, 680, 460, 1000, 350, 2000, 520));