paradoxfx

【原创】基于TMS320F28335的电机控制Clark变换的实现

0
阅读(3893)

在电机控制中,经常用到clark变换,它的基本思想是把三相静止、互差120°的abc坐标系中的变量变化到两相静止、互差90°的αβ坐标系中,从而简化了控制过程。其基本变换的原理为如图1所示

图1 clark变换的基本原理

这里采用了模块化的思想,对clark变换进行了实现。采用了TMS320F28335 高性能浮点DSC,编程使用了全浮点的C语言。

首先列一下参数列表:

输入信号:iaib;输出信号:ialfaibeta

为了便于后续调用及模块化修改,将全部参数封装为一个结构体。首先定义头文件clarke.h如下:

typedef struct { float32 As; // Input: phase-a stator variable

float32 Bs; // Input: phase-b stator variable

float32 Alpha; // Output: stationary d-axis stator variable

float32 Beta;// Output: stationary q-axis stator variable

void (*calc)(); // Pointer to calculation function

} CLARKE;

typedef CLARKE *CLARKE_handle;

/*-----------------------------------------------------------------------------

Default initalizer for the CLARKE object.

-----------------------------------------------------------------------------*/

#define CLARKE_DEFAULTS { 0, \

0, \

0, \

0, \

(void (*)(Uint32))clarke_calc }

/*------------------------------------------------------------------------------

Prototypes for the functions in CLARKE.C

------------------------------------------------------------------------------*/

void clarke_calc(CLARKE_handle);

其次编写主程序clarke.c,即

#include "dmctype.h"

#include "clarke.h"

void clarke_calc(CLARKE *v)

{

v->Alpha = v->As;

v->Beta = (v->As + 2*v->Bs)*0.57735026918963; // 1/sqrt(3) = 0.57735026918963

}

最后是主程序中的调用,主要是对现有的结构体clarke类型进行例化,然后再赋初值,送入参数再把结果读出:

CLARKE clarkee = CLARKE_DEFAULTS;

voidmain(void)

{

……初始各变量与寄存器……

clarkee.As=ia;

clarkee.Bs=ib;

clarkee.calc(&clarkee);

ialfa=clarkee.Alpha;

ibeta=clarkee.Beta;

}

传统的教科书都会提到,坐标变换,矢量控制这些东西会占用多少资源,实现起来不容易。不过对于高性能的28335 DSC来讲,就是小菜一碟了。变量的调用、读写一般需要2个时钟周期,乘法需要稍微多一点,整个变换加起来也不过十几个时钟周期,用不了100ns就可以轻松执行完一个变换过程了;有兴趣的同学可以自己进行测试一下。

Baidu
map