foc.c 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  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. hall_sensor_init();
  18. HAL_ADC1_Enable();
  19. /* init pwm hardware timer */
  20. PWM_TimerEnable();
  21. /* enable tim4 to run the foc normal task */
  22. TIM4_Enable();
  23. task_start(foc_measure_task, 0);
  24. }
  25. static void foc_defulat_value(void){
  26. memset(&mFOC, 0, sizeof(mFOC));
  27. mFOC.state = IDLE;
  28. mFOC.mosGate = false;
  29. mFOC.vbus = 12.0f;
  30. phase_current_init(&mFOC.current_samp);
  31. }
  32. void foc_clear(void) {
  33. PWM_Stop();
  34. mFOC.mosGate = false;
  35. foc_defulat_value();
  36. }
  37. FOCState FOC_STM_State(void){
  38. return mFOC.state;
  39. }
  40. FError FOC_STM_NextState(FOCState state) {
  41. bool changed = false;
  42. if (state == mFOC.state) {
  43. return NoError;
  44. }
  45. if (state == START) {
  46. if (mFOC.state == IDLE) {
  47. changed = true;
  48. }
  49. }else if (state == IDLE) {
  50. if (mFOC.state == ANY_STOP) {
  51. changed = true;
  52. }
  53. }else if (state == ANY_STOP) {
  54. if (mFOC.state != IDLE) {
  55. changed = true;
  56. }
  57. }else if (state == CURRENT_CALIBRATE) {
  58. if (mFOC.state == START) {
  59. changed = true;
  60. }
  61. }else if (state == READY_TO_RUN) {
  62. if (mFOC.state == CURRENT_CALIBRATE) {
  63. changed = true;
  64. }
  65. }else if (state == RAMPINT_START) {
  66. if (mFOC.state == READY_TO_RUN) {
  67. changed = true;
  68. }
  69. }else if (state == RUNNING) {
  70. if (mFOC.state == RAMPINT_START) {
  71. changed = true;
  72. }
  73. }
  74. if (changed) {
  75. mFOC.state = state;
  76. return NoError;
  77. }
  78. return STMNotAllow;
  79. }
  80. /* ÉèÖÃÆô¶¯rampµçÁ÷ºÍʱ¼ä */
  81. void Foc_Set_StartRamp(float final, u32 duration_ms){
  82. ramp_ctrl_init(&mFOC.start_ramp, 0.0f, final, duration_ms);
  83. }
  84. FError foc_start_motor(void){
  85. return FOC_STM_NextState(START);
  86. }
  87. FError foc_stop_motor(void) {
  88. return FOC_STM_NextState(ANY_STOP);
  89. }
  90. void foc_overide_theta(bool enable){
  91. mFOC.override.is_theta = enable;
  92. }
  93. void foc_overide_vdq(bool enable){
  94. mFOC.override.is_vdq = enable;
  95. }
  96. void foc_overide_set_theta(float theta){
  97. mFOC.override.theta = theta;
  98. }
  99. void foc_overide_set_vdq(float d, float q){
  100. mFOC.override.vdq.d = d;
  101. mFOC.override.vdq.q = q;
  102. }
  103. static u32 foc_measure_task(void){
  104. vbus_sample_voltage();
  105. ntc_sensor_sample();
  106. return 1;
  107. }
  108. void foc_brake_handler(void) {
  109. }
  110. void foc_pwm_up_handler(void){
  111. phase_current_adc_triger(&mFOC.current_samp);
  112. }
  113. void current_sample_handler(void) {
  114. FOC_Fast_Task(&mFOC);
  115. }
  116. void foc_slow_task_handler(void) {
  117. FOC_Normal_Task(&mFOC);
  118. }
  119. void foc_pwm_start(bool start) {
  120. if (start == mFOC.mosGate) {
  121. return;
  122. }
  123. if (start) {
  124. PWM_Start();
  125. }else {
  126. PWM_Stop();
  127. }
  128. mFOC.mosGate = start;
  129. }