西莫电机圈

 找回密码
 立即注册

QQ登录

只需一步,快速开始

手机号码,快捷登录

手机号码,快捷登录

查看: 891|回复: 4

[求助] TI滑模观测器的滑模面选择

[复制链接]

该用户从未签到

发表于 2019-9-29 09:26 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?立即注册

x
请问TI的滑模观测器算法中滑模面选择是以什么为标准选择的,我看算法里写的E0=_IQ(0.5),这里的标定大小是以什么为基准标定的。求大神指点。下面是TI的SMO算法。

#ifndef __SMOPOS_H__
#define __SMOPOS_H__


typedef struct {  _iq  Valpha;           // Input: Stationary alfa-axis stator voltage
                  _iq  Ealpha;           // Variable: Stationary alfa-axis back EMF
                  _iq  Zalpha;      // Output: Stationary alfa-axis sliding control
                  _iq  Gsmopos;            // Parameter: Motor dependent control gain
                  _iq  EstIalpha;   // Variable: Estimated stationary alfa-axis stator current
                  _iq  Fsmopos;            // Parameter: Motor dependent plant matrix
                  _iq  Vbeta;           // Input: Stationary beta-axis stator voltage
                  _iq  Ebeta;                  // Variable: Stationary beta-axis back EMF
                  _iq  Zbeta;              // Output: Stationary beta-axis sliding control
                  _iq  EstIbeta;    // Variable: Estimated stationary beta-axis stator current
                  _iq  Ialpha;          // Input: Stationary alfa-axis stator current
                  _iq  IalphaError; // Variable: Stationary alfa-axis current error                 
                  _iq  Kslide;             // Parameter: Sliding control gain
                  _iq  Ibeta;                  // Input: Stationary beta-axis stator current
                  _iq  IbetaError;  // Variable: Stationary beta-axis current error                 
                  _iq  Kslf;               // Parameter: Sliding control filter gain
                  _iq  Theta;             // Output: Compensated rotor angle
                  _iq  E0;                        // Parameter: 0.5          
                                 } SMOPOS;                   

/*-----------------------------------------------------------------------------
Default initalizer for the SMOPOS object.
-----------------------------------------------------------------------------*/                     
#define SMOPOS_DEFAULTS {  0,0,0,0,0,0,0,0,0,0,0, \
                               0,0,0,0,0,0,_IQ(0.5)   \
                                      }

/*------------------------------------------------------------------------------
Prototypes for the functions in SMOPOS.C
------------------------------------------------------------------------------*/

#define SMO_MACRO(v)                                                                                                                                                                        \
                                                                                                                                                                                                                \
    /*        Sliding mode current observer        */                                                                                                                                \
    v.EstIalpha = _IQmpy(v.Fsmopos,v.EstIalpha) + _IQmpy(v.Gsmopos,(v.Valpha-v.Ealpha-v.Zalpha));                \
    v.EstIbeta  = _IQmpy(v.Fsmopos,v.EstIbeta)  + _IQmpy(v.Gsmopos,(v.Vbeta -v.Ebeta -v.Zbeta ));                \
                                                                                                                                                                                                                \
        /*        Current errors        */                                                                                                                                                                \
    v.IalphaError = v.EstIalpha - v.Ialpha;                                                                                                                                \
    v.IbetaError  = v.EstIbeta  - v.Ibeta;                                                                                                                                \
                                                                                                                                                                                                            \
        /*  Sliding control calculator        */                                                                                                                                        \
        /* v.Zalpha=v.IalphaError*v.Kslide/v.E0) where E0=0.5 here*/                                                                                \
        v.Zalpha = _IQmpy(_IQsat(v.IalphaError,v.E0,-v.E0),_IQmpy2(v.Kslide));                                                                \
        v.Zbeta  = _IQmpy(_IQsat(v.IbetaError ,v.E0,-v.E0),_IQmpy2(v.Kslide));                                                                \
                                                                                                                                                                                                                \
        /*        Sliding control filter -> back EMF calculator        */                                                                                                \
    v.Ealpha = v.Ealpha + _IQmpy(v.Kslf,(v.Zalpha-v.Ealpha));                                                                                        \
    v.Ebeta  = v.Ebeta  + _IQmpy(v.Kslf,(v.Zbeta -v.Ebeta));                                                                                        \
                                                                                                                                                                                                                \
        /*        Rotor angle calculator -> Theta = atan(-Ealpha,Ebeta)        */                                                                                \
        v.Theta = _IQatan2PU(-v.Ealpha,v.Ebeta);

#endif
西莫电机论坛微信公众平台正式上线!★详情请点击★ 西莫电机论坛会员交流专用群欢迎您西莫电机论坛加群请注明论坛用户名及所从事专业,否则不予通过

该用户从未签到

发表于 2019-10-6 20:17 | 显示全部楼层
你要知道他的的0.5是个什么东西,这就要把他的代码仔细读一遍了
西莫电机论坛微信公众平台正式上线!★详情请点击★ 西莫电机论坛会员交流专用群欢迎您西莫电机论坛加群请注明论坛用户名及所从事专业,否则不予通过
回复

使用道具 举报

该用户从未签到

发表于 2019-10-10 10:42 | 显示全部楼层
0.5是函数sat的限幅值,目的是调节开关函数线性边界层范围(本人初学者,欢迎讨论)
西莫电机论坛微信公众平台正式上线!★详情请点击★ 西莫电机论坛会员交流专用群欢迎您西莫电机论坛加群请注明论坛用户名及所从事专业,否则不予通过
回复

使用道具 举报

该用户从未签到

发表于 2019-10-30 21:45 | 显示全部楼层
TI只能看一个思路,观测器最后还是自己写比较好,很多参数你不去调一下不理解的
西莫电机论坛微信公众平台正式上线!★详情请点击★ 西莫电机论坛会员交流专用群欢迎您西莫电机论坛加群请注明论坛用户名及所从事专业,否则不予通过
回复

使用道具 举报

该用户从未签到

发表于 2019-11-11 19:53 | 显示全部楼层
楼主软件在哪能下到
西莫电机论坛微信公众平台正式上线!★详情请点击★ 西莫电机论坛会员交流专用群欢迎您西莫电机论坛加群请注明论坛用户名及所从事专业,否则不予通过
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|小黑屋|手机版|Archiver|西莫电机圈 ( 浙ICP备10025899号-3 浙公网安备:33028202000436号

GMT+8, 2024-11-23 21:19 , Processed in 0.079508 second(s), 21 queries .

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表