can_foc_msg.c 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212
  1. #include "libs/utils.h"
  2. #include "prot/can_message.h"
  3. #include "prot/can_foc_msg.h"
  4. #include "foc/commands.h"
  5. #include "foc/samples.h"
  6. #include "foc/motor/motor.h"
  7. #include "foc/core/PMSM_FOC_Core.h"
  8. #include "foc/core/foc_observer.h"
  9. static float can_get_speed(void) {
  10. float speed = PMSM_FOC_GetSpeed();
  11. if (!PMSM_FOC_Is_Start() || foc_observer_is_encoder()) {
  12. speed = motor_encoder_get_speed();
  13. }else {
  14. if (foc_observer_sensorless_stable()) {
  15. speed = foc_observer_sensorless_speed();
  16. }else {
  17. speed = 0;
  18. }
  19. }
  20. return speed;
  21. }
  22. void can_report_speed(u8 can, s16 rpm) {
  23. u8 data[6];
  24. encoder_can_key(data, CMD_2_CAN_KEY(Foc_Report_Speed));
  25. encode_s16(data + 2, rpm);
  26. can_send_message(get_indicator_can_id(can), data, sizeof(data), 0);
  27. }
  28. void can_report_power(u8 can) {
  29. u8 data[8];
  30. s16 rpm = (s16)can_get_speed();
  31. float vDC = get_vbus_float();
  32. float iDC = PMSM_FOC_GetVbusCurrent();
  33. s16 v = S16Q5(vDC);
  34. s16 i = S16Q5(iDC);
  35. encoder_can_key(data, CMD_2_CAN_KEY(Foc_Report_Power));
  36. encode_s16(data + 2, ABS(rpm));
  37. encode_s16(data + 4, v);
  38. encode_s16(data + 6, i);
  39. can_send_message(get_indicator_can_id(can), data, sizeof(data), 0);
  40. }
  41. void can_report_phase_current(u8 can) {
  42. u8 data[8];
  43. encoder_can_key(data, CMD_2_CAN_KEY(Foc_Report_Phase_Current));
  44. encode_s16(data + 2, S16Q5(PMSM_FOC_Get()->in.s_iABC[0]));
  45. encode_s16(data + 4, S16Q5(PMSM_FOC_Get()->in.s_iABC[1]));
  46. encode_s16(data + 6, S16Q5(PMSM_FOC_Get()->in.s_iABC[2]));
  47. can_send_message(get_indicator_can_id(can), data, sizeof(data), 0);
  48. }
  49. void can_report_phase_voltage(u8 can) {
  50. u8 data[8];
  51. float s_vABC[3];
  52. get_phase_vols(s_vABC);
  53. encoder_can_key(data, CMD_2_CAN_KEY(Foc_Report_Phase_Vol));
  54. encode_s16(data + 2, S16Q5(s_vABC[0]));
  55. encode_s16(data + 4, S16Q5(s_vABC[1]));
  56. encode_s16(data + 6, S16Q5(s_vABC[2]));
  57. can_send_message(get_indicator_can_id(can), data, sizeof(data), 0);
  58. }
  59. void can_report_dq_current(u8 can) {
  60. u8 data[6];
  61. encoder_can_key(data, CMD_2_CAN_KEY(Foc_Report_Dq_Current));
  62. float id = PMSM_FOC_Get()->out.s_FilterIdq.d;
  63. float iq = PMSM_FOC_Get()->out.s_FilterIdq.q;
  64. encode_s16(data + 2, S16Q5(id));
  65. encode_s16(data + 4, S16Q5(iq));
  66. can_send_message(get_indicator_can_id(can), data, sizeof(data), 0);
  67. }
  68. void can_response_hall_offset(u8 can, int offset) {
  69. u8 data[7];
  70. encoder_can_key(data, CMD_2_CAN_KEY(Foc_Cali_Hall_Offset));
  71. encode_u8(data + 2, 1);
  72. encode_u32(data + 3, offset);
  73. can_send_message(get_indicator_can_id(can), data, sizeof(data), 0);
  74. }
  75. void can_report_pid_value(u8 can, u8 id) {
  76. float kp, ki, kd;
  77. PMSM_FOC_GetPid(id, &kp, &ki, &kd);
  78. u8 data[15];
  79. encoder_can_key(data, CMD_2_CAN_KEY(Foc_Report_Pid));
  80. data[2] = id;
  81. encode_float(data + 3, kp);
  82. encode_float(data + 7, ki);
  83. encode_float(data + 11, kd);
  84. can_send_message(get_indicator_can_id(can), data, sizeof(data), 0);
  85. }
  86. void can_report_foc_status(u8 can) {
  87. u8 data[16];
  88. encoder_can_key(data, CMD_2_CAN_KEY(Foc_Report_Status));
  89. mc_get_running_status(data+2);
  90. u32 errMask = mc_get_critical_error();
  91. encode_u32(data + 3, errMask);
  92. encode_s16(data + 7, get_motor_temp());
  93. encode_s16(data + 9, get_mos_temp());
  94. encode_u24(data + 11, shark_get_seconds());
  95. encode_u8(data + 14, mc_get_gear());
  96. encode_u8(data + 15, mc_params()->mos_lim | (mc_params()->motor_lim<<4));
  97. can_send_message(get_indicator_can_id(can), data, sizeof(data), 0);
  98. }
  99. /* 采用组播方式上报,目的7E */
  100. void can_mcast_foc_status2(void) {
  101. u8 data[8];
  102. encode_u16(data, mc_get_running_status2());
  103. encode_u16(data + 2, ABS((s16)(can_get_speed())));
  104. float vDC = get_vbus_float();
  105. encode_s16(data + 4, (s16)(vDC*10));
  106. float iDC = PMSM_FOC_GetVbusCurrent();
  107. if (!PMSM_FOC_Is_Start()) {
  108. iDC = 0;
  109. }
  110. encode_s16(data + 6, (s16)(iDC*10));
  111. shark_can0_send_message(get_indicator_can_id(0x7F), data, sizeof(data));
  112. }
  113. void can_report_mpta_values(u8 can) {
  114. u8 data[8];
  115. if (!PMSM_FOC_Get()->in.b_MTPA_calibrate) {
  116. return;
  117. }
  118. encoder_can_key(data, CMD_2_CAN_KEY(Foc_Report_MTPA_DQ_Angle));
  119. encode_s16(data + 2, S16Q5(PMSM_FOC_Get()->out.s_RealCurrentFiltered));
  120. encode_s16(data + 4, S16Q5(PMSM_FOC_Get()->out.s_FilterIdq.d));
  121. encode_s16(data + 6, S16Q5(PMSM_FOC_Get()->out.s_FilterIdq.q));
  122. can_send_message(get_indicator_can_id(can), data, sizeof(data), 0);
  123. }
  124. void can_report_ext_status(u8 can) {
  125. u8 data[8] = {0x0, 0x0, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF};
  126. data[0] = (get_vbus_int()>60?1:0) << 5;
  127. data[0] |= (mc_is_epm()?1:0) << 6;
  128. data[0] |= (mc_is_epm()?1:0) << 7;
  129. data[1] = mc_is_start()?0:1;
  130. data[1] |= (mc_is_cruise_enabled()?1:0) << 3;
  131. data[1] |= mc_get_gear() << 6;
  132. encode_s16(data + 2, ABS((s16)(can_get_speed()/4.0f)));
  133. float vDC = get_vbus_float();
  134. encode_s16(data + 4, (s16)(vDC*10));
  135. float iDC = PMSM_FOC_GetVbusCurrent();
  136. if (!PMSM_FOC_Is_Start()) {
  137. iDC = 0;
  138. }
  139. encode_s16(data + 6, (s16)(iDC*10));
  140. shark_can0_send_ext_message(0x1A014D43, data, sizeof(data));
  141. }
  142. void can_response_vols(u8 can, u8 key) {
  143. u8 data[16];
  144. int len;
  145. encoder_can_key(data, CMD_2_CAN_KEY(key));
  146. len = 2;
  147. float thro = get_throttle_float() * 10.0f;
  148. encode_s16(data + len, (s16)thro);
  149. len += 2;
  150. float acc = get_acc_vol() * 10.0f;
  151. encode_s16(data + len, (s16)acc);
  152. len += 2;
  153. float vbus = get_vbus_float() * 10.0f;
  154. encode_s16(data + len, (s16)vbus);
  155. len += 2;
  156. float thro_5v = get_thro_5v_float() * 10.0f;
  157. encode_s16(data + len, (s16)thro_5v);
  158. len += 2;
  159. thro = get_throttle2_float() * 10.0f;
  160. encode_s16(data + len, (s16)thro);
  161. len += 2;
  162. thro_5v = get_thro2_5v_float() * 10.0f;
  163. encode_s16(data + len, (s16)thro_5v);
  164. len += 2;
  165. can_send_response(can, data, len);
  166. }
  167. void can_report_plot_values(u8 can) {
  168. s16 trq_ref = eCtrl_get_RefTorque() * 10;
  169. s16 real_ref = PMSM_FOC_Get_Real_dqVector() * 10;
  170. can_plot2(trq_ref, real_ref);
  171. }
  172. void can_plot1(s16 v1) {
  173. u8 data[4];
  174. encoder_can_key(data, CMD_2_CAN_KEY(Foc_Report_Plot));
  175. encode_s16(data + 2, v1);
  176. can_send_message(get_indicator_can_id(0x45), data, sizeof(data), 0);
  177. }
  178. void can_plot2(s16 v1, s16 v2) {
  179. u8 data[6];
  180. encoder_can_key(data, CMD_2_CAN_KEY(Foc_Report_Plot));
  181. encode_s16(data + 2, v1);
  182. encode_s16(data + 4, v2);
  183. can_send_message(get_indicator_can_id(0x45), data, sizeof(data), 0);
  184. }
  185. void can_plot3(s16 v1, s16 v2, s16 v3) {
  186. u8 data[8];
  187. encoder_can_key(data, CMD_2_CAN_KEY(Foc_Report_Plot));
  188. encode_s16(data + 2, v1);
  189. encode_s16(data + 4, v2);
  190. encode_s16(data + 6, v3);
  191. can_send_message(get_indicator_can_id(0x45), data, sizeof(data), 0);
  192. }