声振论坛

 找回密码
 我要加入

QQ登录

只需一步,快速开始

查看: 1260|回复: 2

[控制系统类] 哪位大侠能帮我写一个关于单神经元pid控制器的s函数?

[复制链接]
发表于 2008-6-25 22:42 | 显示全部楼层 |阅读模式

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

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

x
小弟现在正在做课程设计,是关于matlab仿真的,老师要求我们用s函数写一个单神经元pid控制器,但是我对这s函数不是很了解,所以希望各位大侠帮忙!
万分着急!!!
感激涕零……
回复
分享到:

使用道具 举报

发表于 2008-6-26 07:12 | 显示全部楼层
控制器是根据对象来设计的,你不告诉对象怎么做
 楼主| 发表于 2008-6-26 09:03 | 显示全部楼层
哎呀,这个是我的失误,忘记附上控制对象了。我现在把控制系统的s函数发过来哈。
function [sys,x0,str,ts] = mysh(t,x,u,flag)
q1=119.38;
Cv2=10.4;
Cv3=11.79;
A1=50;
A2=50;
switch flag,
  case 0
    [sys,x0,str,ts] = mdlInitializeSizes;
  case 1      
      sys=mdlDerivatives(t,x,u,q1,Cv2,Cv3,A1,A2);
        
  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  = 2;
sizes.NumDiscStates  = 0;
sizes.NumOutputs     = 1;
sizes.NumInputs      = 1;
sizes.DirFeedthrough = 1;
sizes.NumSampleTimes = 1;
sys = simsizes(sizes);
x0  = [50 0];
str = [];
ts  = [0 0];
function sys=mdlDerivatives(t,x,u,q1,Cv2,Cv3,A1,A2)
    sys(1)=x(2);
    sys(2)=(q1/(A2*x(2)+Cv3*x(1)^0.5)-A1*Cv3*x(2)/(Cv2^2*x(1)^0.5)-1)*Cv2^2/(2*A1*A2)
   
function sys = mdlOutputs(t,x,u)
sys = x(1);
您需要登录后才可以回帖 登录 | 我要加入

本版积分规则

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

GMT+8, 2024-5-22 10:25 , Processed in 0.107197 second(s), 17 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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