声振论坛

 找回密码
 我要加入

QQ登录

只需一步,快速开始

查看: 2004|回复: 0

[综合讨论] 求教高手帮忙看下这个S函数是什么问题

[复制链接]
发表于 2012-3-31 20:58 | 显示全部楼层 |阅读模式

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

您需要 登录 才可以下载或查看,没有账号?我要加入

x
本帖最后由 lxwalyssa 于 2012-3-31 21:04 编辑

如下是一个二阶微分方程组的S函数,4个变量xb,yb,fb,fl
function[sys,x0,str,ts]=sfunl_try_1_4(t,x,u,flag)
switch flag,
    case 0
        [sys,x0,str,ts]=mdlInitializeSizes;
    case 1
        sys=mdlDerivatives(t,x,u);
    case 3
        sys=mdlOutputs(t,x,u);
    case {2,4,9}
        sys=[];
    otherwise
        error(['Unhandled flag=',num2str(flag)]);
end;
%%%%%%%%%%%%%%%
function[sys,x0,str,ts]=mdlInitializeSizes
sizes=simsizes;
sizes.NumContStates=8;
sizes.NumDiscStates=0;
sizes.NumOutputs=8;
sizes.NumInputs=2;   %u1,u0
sizes.DirFeedthrough=1;
sizes.NumSampleTimes = 1;
sys=simsizes(sizes);
x0=[0; 0.49; -0.1447; 0.2; 0.3326; 0.0011; -2.8399; -0.6524];  
%初始值: xb,yb,fb,fl,dotxb,dotyb,dotfb,dotfl 分别对应微分里的x(1),x(2), x(3), x(4), x(5), x(6), x(7), x(8),
str=[];
ts=[0 0];
%%%%%%%%%%%%%%%
function sys=mdlDeriatives(t,x,u)
u1=u(1);  
u0=u(2);
%定义两个输入信号
x_new(1)=x(5); %dotxb即xb的一阶微分
x_new(2)=x(6); %dotyb
x_new(3)=x(7); %dotfb
x_new(4)=x(8); %dotfl
%二阶化一阶
x_new(5)=XXX;  %xb"
x_new(6)=XXX;  %yb"
x_new(7)=XXX;  %fb"
x_new(8)=XXX;  %fl"%%中间冗长的x_new(5,6,7,8)的微分方程是从Maple拷过来的,应该没错。

sys=x_new; %微分结果
%%%%%%%%%%%%%%%
function sys=mdlOutputs(t,x,u)
sys=[x(1);x(2);x(3);x(4);x_new(1);x_new(2);x_new(3);x_new(4)];  %求4个变量及一阶导数值

如上的S函数。运行后总是出错如下:
Block Error: Error in 'sfunl_1_4/S-Function' while executing MATLAB S-function 'sfunl_try_1_4', flag = 3 (output), at time 0.0.
和Model Error: Undefined function or method 'x_new' for input arguments of type 'double'.

请高手帮忙看看哪里问题呢?网上找些资料说第二个错是路径问题,可是改过还是出错,是我定义X_new有问题吗?我是新手可能有些写错了。麻烦高手指教。


回复
分享到:

使用道具 举报

您需要登录后才可以回帖 登录 | 我要加入

本版积分规则

QQ|小黑屋|Archiver|手机版|联系我们|声振论坛

GMT+8, 2024-12-1 10:45 , Processed in 0.059427 second(s), 17 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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