Labfans是一个针对大学生、工程师和科研工作者的技术社区。 论坛首页 | 联系我们(Contact Us)
MATLAB爱好者论坛-LabFans.com
返回   MATLAB爱好者论坛-LabFans.com > 人工智能 > 深度神经网络/深度学习
深度神经网络/深度学习 A discussion board for Deep Neural Network|Deep Learning.
回复
 
主题工具 显示模式
旧 2019-03-22, 11:46   #1
kougen
初级会员
 
注册日期: 2019-03-22
年龄: 27
帖子: 1
声望力: 0
kougen 正向着好的方向发展
帖子 单神经元pid仿真时出现错误

这是我做的单神经元pid的simulink和s函数,仿真时候出现了“未定义函数或变量 'u1'。”的错误,请问是怎么回事?
这是我的s函数m文件

function [sys,x0,str,ts]=neuropid(t,x,u,flag)
switch flag
case 0
[sys,x0,str,ts]=mdlInitializeSizes;
case 1
sys=[ ];
case 2
sys=mdlUpdate(t,x,u);
case 3
sys=mdlOutputs(t,x,u);
case 4
sys=[ ];
case 9
sys=[ ];
otherwise
error(['Unhandled flag=',num2str(flag)]);
end

function [sys,x0,str,ts]=mdlInitializeSizes
sizes=simsizes;
sizes.NumContStates=0;
sizes.NumDiscStates=3;
sizes.NumOutputs=1;
sizes.NumInputs=4;
sizes.DirFeedthrough=1;
sizes.NumSampleTimes=1;
sys=simsizes(sizes);
x0=[0.3,0.3,0.3];%初始权值
str=[ ];
ts=[-1 0];

function sys=mdlUpdate(t,x,u)
sys(1)=x(1)+0.3*u(1)*u(1);%x(1)=e(k)
sys(2)=x(2)+0.3*u(1)*(u(1)-u(2));%x(2)=e(k)-e(k-1)
sys(3)=x(3)+0.5*u(1)*(u(1)-2*u(2)+u(3));%x(3)=e(k)-2e(k-1)+e(k-2)

function sys=mdlOutputs(t,x,u)
sys=u(4)+0.12*(x(1)*u(1)+x(2)*(u(1)-u(2))+x(3)*(u1-2*u(2)+u(3)))/(abs(x(1))+abs(x(2))+abs(x(3)));
上传的图像
文件类型: jpg 单神经元pid.jpg (14.1 KB, 1 次查看)
kougen 当前离线   回复时引用此帖
回复

主题工具
显示模式

发帖规则
不可以发表新主题
不可以发表回复
不可以上传附件
不可以编辑自己的帖子

启用 BB 代码
论坛启用 表情符号
论坛启用 [IMG] 代码
论坛禁用 HTML 代码



所有时间均为北京时间。现在的时间是 20:13


Powered by vBulletin
版权所有 ©2000 - 2025,Jelsoft Enterprises Ltd.