park_clark.h 816 B

1234567891011121314151617181920212223242526272829
  1. #ifndef _Park_Clark_H__
  2. #define _Park_Clark_H__
  3. #include "foc/foc_type.h"
  4. #include "math/fast_math.h"
  5. /* ·´Park ±ä»» */
  6. static __INLINE void Rev_Park(dq_t *dq, float angle, alpha_beta_t *alpha_bata) {
  7. float c,s;
  8. fast_sincos(angle, &s, &c);
  9. alpha_bata->alpha = dq->d * c - dq->q * s;
  10. alpha_bata->beta = dq->d * s + dq->q * c;
  11. }
  12. static __INLINE void Clark(float phaseU, float phaseV, float phaseW, alpha_beta_t *alpha_bata){
  13. alpha_bata->alpha = (2.0f * phaseU - phaseV - phaseW) / 3.0f;
  14. alpha_bata->beta = (ONE_BY_SQRT3 * (phaseV - phaseW));
  15. }
  16. static __INLINE void Park(alpha_beta_t *alpha_beta, float angle, dq_t *dq) {
  17. float c,s;
  18. fast_sincos(angle, &s, &c);
  19. dq->d = alpha_beta->alpha * c + alpha_beta->beta * s;
  20. dq->q = -alpha_beta->alpha * s + alpha_beta->beta * c;
  21. }
  22. #endif /* _Park_Clark_H__ */