foc.c 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194
  1. #include <string.h>
  2. #include "libs/task.h"
  3. #include "bsp/bsp.h"
  4. #include "foc/foc.h"
  5. #include "foc/park_clark.h"
  6. #include "foc/svpwm.h"
  7. #include "foc/foc_task.h"
  8. #include "foc/phase_current.h"
  9. #include "foc/hall_sensor.h"
  10. #include "foc/vbus_sensor.h"
  11. #include "foc/ntc_sensor.h"
  12. static u32 foc_measure_task(void);
  13. static void foc_defulat_value(void);
  14. static motor_foc_t mFOC;
  15. void foc_init(void) {
  16. foc_defulat_value();
  17. HAL_ADC1_Enable();
  18. /* init pwm hardware timer */
  19. PWM_TimerEnable();
  20. /* enable tim4 to run the foc normal task */
  21. TIM4_Enable();
  22. hall_sensor_init();
  23. vbus_sensor_init();
  24. ntc_sensor_init();
  25. task_start(foc_measure_task, 0);
  26. //hall_sensor_calibrate(2.0f, mFOC.hall_table);
  27. }
  28. static void foc_defulat_value(void){
  29. memset(&mFOC, 0, sizeof(mFOC));
  30. mFOC.state = IDLE;
  31. mFOC.mosGate = false;
  32. mFOC.vbus = 12.0f;
  33. phase_current_init(&mFOC.current_samp);
  34. }
  35. void foc_clear(void) {
  36. PWM_Stop();
  37. mFOC.mosGate = false;
  38. foc_defulat_value();
  39. }
  40. FOCState FOC_STM_State(void){
  41. return mFOC.state;
  42. }
  43. FError FOC_STM_NextState(FOCState state) {
  44. bool changed = false;
  45. if (state == mFOC.state) {
  46. return NoError;
  47. }
  48. if (state == START) {
  49. if (mFOC.state == IDLE) {
  50. changed = true;
  51. }
  52. }else if (state == IDLE) {
  53. if (mFOC.state == ANY_STOP) {
  54. changed = true;
  55. }
  56. }else if (state == ANY_STOP) {
  57. if (mFOC.state != IDLE) {
  58. changed = true;
  59. }
  60. }else if (state == CURRENT_CALIBRATE) {
  61. if (mFOC.state == START) {
  62. changed = true;
  63. }
  64. }else if (state == READY_TO_RUN) {
  65. if (mFOC.state == CURRENT_CALIBRATE) {
  66. changed = true;
  67. }
  68. }else if (state == RAMPING_START) {
  69. if (mFOC.state == READY_TO_RUN) {
  70. changed = true;
  71. }
  72. }else if (state == RUNNING) {
  73. if (mFOC.state == RAMPING_START) {
  74. changed = true;
  75. }
  76. }
  77. if (changed) {
  78. mFOC.state = state;
  79. return NoError;
  80. }
  81. return STMNotAllow;
  82. }
  83. /* ÉèÖÃÆô¶¯rampµçÁ÷ºÍʱ¼ä */
  84. void Foc_Set_StartRamp(float final, u32 duration_ms){
  85. ramp_ctrl_init(&mFOC.start_ramp, 0.0f, final, duration_ms);
  86. }
  87. FError foc_start_motor(void){
  88. return FOC_STM_NextState(START);
  89. }
  90. FError foc_stop_motor(void) {
  91. return FOC_STM_NextState(ANY_STOP);
  92. }
  93. void foc_current_calibrate(void){
  94. mFOC.current_samp.adc_offset_a = 0;
  95. mFOC.current_samp.adc_offset_b = 0;
  96. mFOC.current_samp.adc_offset_c = 0;
  97. PWM_Disable_Channels();
  98. //foc_pwm_start(false);
  99. task_udelay(10);
  100. phase_current_init(&mFOC.current_samp);
  101. mFOC.current_samp.is_calibrating = true;
  102. mFOC.current_samp.sector = SECTOR_5;
  103. foc_pwm_start(true);
  104. HAL_ADC1_InJ_StartConvert();
  105. while(mFOC.current_samp.offset_sample_count != 0){};
  106. foc_pwm_start(false);
  107. task_udelay(100);
  108. phase_current_init(&mFOC.current_samp);
  109. mFOC.current_samp.sector = SECTOR_1;
  110. foc_pwm_start(true);
  111. while(mFOC.current_samp.offset_sample_count != 0){};
  112. mFOC.current_samp.is_calibrating = false;
  113. foc_pwm_start(false);
  114. PWM_Enable_Channels();
  115. }
  116. void foc_overide_theta(bool enable){
  117. mFOC.override.is_theta = enable;
  118. }
  119. void foc_overide_vdq(bool enable){
  120. mFOC.override.is_vdq = enable;
  121. }
  122. void foc_overide_set_theta(float theta){
  123. mFOC.override.theta = theta;
  124. }
  125. void foc_overide_set_vdq(float d, float q){
  126. mFOC.override.vdq.d = d;
  127. mFOC.override.vdq.q = q;
  128. }
  129. static u32 foc_measure_task(void){
  130. vbus_sample_voltage();
  131. ntc_sensor_sample();
  132. mFOC.vbus = vbus_get_voltage();
  133. wdog_reload();
  134. return 1;
  135. }
  136. void foc_brake_handler(void) {
  137. }
  138. void foc_pwm_up_handler(void){
  139. phase_current_adc_triger(&mFOC.current_samp);
  140. }
  141. void current_sample_handler(void) {
  142. if (mFOC.current_samp.is_calibrating) {
  143. phase_current_offset(&mFOC.current_samp);
  144. }else {
  145. FOC_Fast_Task(&mFOC);
  146. }
  147. }
  148. void foc_slow_task_handler(void) {
  149. FOC_Normal_Task(&mFOC);
  150. }
  151. void foc_pwm_start(bool start) {
  152. if (start == mFOC.mosGate) {
  153. return;
  154. }
  155. if (start) {
  156. PWM_Start();
  157. }else {
  158. PWM_Stop();
  159. }
  160. mFOC.mosGate = start;
  161. }