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