西莫电机圈

 找回密码
 立即注册

QQ登录

只需一步,快速开始

手机号码,快捷登录

手机号码,快捷登录

查看: 1696|回复: 2

[求助] 用S函数写的一段根据转子位置求反电势的代码,但是老是报错,盼高手点评一下

[复制链接]

该用户从未签到

发表于 2011-11-20 10:52 | 显示全部楼层 |阅读模式

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

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

x
本帖最后由 张子富 于 2011-11-20 10:53 编辑

function [sys,x0,str,ts,simStateCompliance] = emf(t,x,u,flag)
switch flag,

  %%%%%%%%%%%%%%%%%%
  % Initialization %
  %%%%%%%%%%%%%%%%%%
  case 0,
    [sys,x0,str,ts,simStateCompliance]=mdlInitializeSizes;

  case 3,
    sys=mdlOutputs(t,x,u);
  case 9,
    sys=mdlTerminate(t,x,u);
  case {1,2,4}
   sys=[];
  otherwise
    DAStudio.error('Simulink:blocks:unhandledFlag', num2str(flag));

end

function [sys,x0,str,ts,simStateCompliance]=mdlInitializeSizes(t,x,u)

sizes = simsizes;

sizes.NumContStates  = 0;
sizes.NumDiscStates  = 0;
sizes.NumOutputs     = 3;
sizes.NumInputs      = 1;
sizes.DirFeedthrough = 0;
sizes.NumSampleTimes = 1;   % at least one sample time is needed

sys = simsizes(sizes);

%
% initialize the initial conditions
%
x0  = [];

%
% str is always an empty matrix
%
str = [];

%
% initialize the array of sample times
%
ts  = [-1 0];


%
function sys=mdlDerivatives(t,x,u)

sys = [];

% end mdlDerivatives

%
%=============================================================================
% mdlUpdate
% Handle discrete state updates, sample time hits, and major time step
% requirements.
%=============================================================================
%
function sys=mdlUpdate(t,x,u)

sys = [];

% end mdlUpdate

%
%=============================================================================
% mdlOutputs
% Return the block outputs.
%=============================================================================
%
function sys=mdlOutputs(t,x,u)

if(u>=0)&&(u<pi/3)
sys=[1 -1 -u*6/pi+1];
elseif(u>=pi/3)&&(u<2*pi/3)
sys=[1 u*6/pi-3 -1];
elseif(u>=2*pi/3)&&(u<pi)
sys=[-u*6/pi+5 1 -1];
elseif(u>=pi)&&(u<4*pi/3)
sys=[-1 1 u*6/pi-7];
elseif(u>=4*pi/3)&&(u<5*pi/3)
sys=[-1 -u*6/pi+9 1];
elseif(u>=5*pi/3)&&(u<2*pi)
sys=[u*6/pi-11 -1 1];
end
% end mdlOutputs

%
%=============================================================================
% mdlGetTimeOfNextVarHit
% Return the time of the next hit for this block.  Note that the result is
% absolute time.  Note that this function is only used when you specify a
% variable discrete-time sample time [-2 0] in the sample time array in
% mdlInitializeSizes.
%=============================================================================
%
%function sys=mdlGetTimeOfNextVarHit(t,x,u)

%sampleTime = 1;    %  Example, set the next hit to be one second later.
%sys = t + sampleTime;

% end mdlGetTimeOfNextVarHit

%
%=============================================================================
% mdlTerminate
% Perform any end of simulation tasks.
%==========================================================================
%===
function sys=mdlTerminate(t,x,u)
sys = [];


错误信息如下:
Output argument "sys" (and maybe others) not assigned during call to "D:\MATLAB\R2009a\toolbox\simulink\blocks\emf.m>mdlOutputs".
% end mdlTerminate
西莫电机论坛微信公众平台正式上线!★详情请点击★ 西莫电机论坛会员交流专用群欢迎您西莫电机论坛加群请注明论坛用户名及所从事专业,否则不予通过

签到天数: 10 天

连续签到: 1 天

[LV.3]偶尔看看II

发表于 2011-11-21 09:08 | 显示全部楼层
s函数一直用的少,搞不明白,感觉很复杂。
就提示来看,好像是sys必须赋值吧。
西莫电机论坛微信公众平台正式上线!★详情请点击★ 西莫电机论坛会员交流专用群欢迎您西莫电机论坛加群请注明论坛用户名及所从事专业,否则不予通过
回复

使用道具 举报

该用户从未签到

 楼主| 发表于 2011-11-21 15:01 | 显示全部楼层
回复 2# yjhou

我也是刚用的啊,还有好多不是很了解
西莫电机论坛微信公众平台正式上线!★详情请点击★ 西莫电机论坛会员交流专用群欢迎您西莫电机论坛加群请注明论坛用户名及所从事专业,否则不予通过
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-22 11:15 , Processed in 0.094251 second(s), 26 queries .

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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