test_torquesensor.cpp 7.9 KB

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