找回密码
 立即注册

QQ登录

只需一步,快速开始

手机号码,快捷登录

手机号码,快捷登录

Flux电机有限元分析教程西莫团购入口 | 奖励入口当当网购物入口 | 奖励入口欢迎使用!西莫论坛App开放下载Motor-CAD电机多物理域设计教材购买入口 | 奖励入口
★新会员论坛须知★《西莫电机技术》第40期发售火热进行中
Flux电机电磁阀有限元分析教程团购入口 | 奖励入口论坛微信公众平台欢迎入驻
西莫电机及相关产品供需交流群开放邀请★ 论坛VIP会员申请 ★Motor-CAD.MANATEE电磁热振动噪声教程 | 奖励入口西莫团队欢迎您的加盟!
宣传推广合作请联系QQ:25941174西莫电机论坛微信群正式开放Flux变压器与电抗器有限元分析团购入口 | 奖励入口西莫电机论坛技术版区QQ群汇总
查看: 1047|回复: 4

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

[复制链接]

该用户从未签到

发表于 2019-9-29 09:26 | 显示全部楼层 |阅读模式 来自: 中国黑龙江哈尔滨

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

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

×
请问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|浙公网安备33010502012192号 )

GMT+8, 2025-3-4 22:30 , Processed in 0.044072 second(s), 23 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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