test_torquesensor.cpp 8.2 KB

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