24小时热门版块排行榜    

查看: 2219  |  回复: 9

流毓1988

新虫 (初入文坛)

[求助] 增量式PIDmatlab仿真结果出不来,怎么回事呢??急急急....谢谢了..

%controler
clear all;
close all;

ts=0.001;
sys=tf(400,[1,50,0]);
dsys=c2d(sys,ts,'z');
dsys
num=[0 0.0001967 0.0001935 ];
den=[2 -1.951  0.9512];
%[mun,den]=tfdata(dsys,'v');
u_1=0.0;u_2=0.0;
y_1=0;y_2=0;
x(1)=0;x(2)=0;x(3)=0;
error_1=0;
error_2=0;
for k=1;1;1000
time(k)=k*ts;

rin(k)=1.0;
kp=8;
ki=0.10;
kd=10;  

du(k)=kp*x(1)+ki*x(2)+kd*x(3);
u(k)=u_1+du(k);

if u(k)>=10
    u(k)=10;
end
if u(k)<=-10
    u(k)=-10;
end
yout(k)=-den(2)*y_1-den(3)*y_2+num(2)*u_1+num(3)*u_2;

error=rin(k)-yout(k);
u_2=u_1;u_1=u(k);
y_2=y_1;y_1=yout(k);

x(1)=error-error_1;
x(2)=error-2*error_1+error_2;
x(3)=error;

error_2=error_1;
error_1=error;
end
plot(time,rin,'b',time,yout,'r');
xlable('time(s)');ylable('rin,yout');_________仿真结果是输入输出参数都为零,求各位大神解答,刚开始学习还有很多不足,谢谢了....
回复此楼
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

sunshine819

金虫 (小有名气)

【答案】应助回帖

感谢参与,应助指数 +1
在simulink里实现如何?把增量式PID控制器编成embedded function,这样至少可以保证模型是正确的,方便排查
日光之下皆覆辙 月光之下皆旧梦
2楼2013-12-05 16:42:00
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

hubery.zhu

金虫 (正式写手)

【答案】应助回帖

★ ★ ★ ★ ★ ★ ★ ★ ★
感谢参与,应助指数 +1
xzhdty: 金币+1, 谢谢参与 2013-12-06 09:41:36
流毓1988: 金币+8, ★★★★★最佳答案, 我的金币不太多,还有一个人也给我说了,所以我也给点点,不好意思,回来我有金币,就给你补回来哈 2013-12-07 15:10:00
%controler
clear all;
close all;

ts=0.001;
sys=tf(400,[1,50,0]);
dsys=c2d(sys,ts,'z');
dsys
num=[0 0.0001967 0.0001935 ];
den=[2 -1.951  0.9512];
%[mun,den]=tfdata(dsys,'v');
u_1=0.0;u_2=0.0;
y_1=0;y_2=0;
x(1)=0;x(2)=2;x(3)=0;
error_1=0;
error_2=0;
for k=1:1:1000
time(k)=k*ts;

rin(k)=1.0;
kp=8;
ki=0.10;
kd=10;  

du(k)=kp*x(1)+ki*x(2)+kd*x(3);
u(k)=u_1+du(k);

if u(k)>=10
    u(k)=10;
end
if u(k)<=-10
    u(k)=-10;
end
yout(k)=-den(2)*y_1-den(3)*y_2+num(2)*u_1+num(3)*u_2;

error=rin(k)-yout(k);
u_2=u_1;u_1=u(k);
y_2=y_1;y_1=yout(k);

x(1)=error-error_1;
x(2)=error-2*error_1+error_2;
x(3)=error;

error_2=error_1;
error_1=error;
end
plot(time,rin,'b',time,yout,'r');
xlabel('time(s)');ylabel('rin,yout');
系统是震荡的,自己调一下参数
耐得住寂寞,抵的住诱惑,拥得了繁华!
3楼2013-12-05 18:31:48
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

流毓1988

新虫 (初入文坛)

引用回帖:
2楼: Originally posted by sunshine819 at 2013-12-05 16:42:00
在simulink里实现如何?把增量式PID控制器编成embedded function,这样至少可以保证模型是正确的,方便排查

已经在simulink中实现了,就是想看看,这个程序为什么不出来结果...
4楼2013-12-06 10:25:33
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

流毓1988

新虫 (初入文坛)

引用回帖:
3楼: Originally posted by hubery.zhu at 2013-12-05 18:31:48
%controler
clear all;
close all;

ts=0.001;
sys=tf(400,);
dsys=c2d(sys,ts,'z');
dsys
num=;
den=;
%=tfdata(dsys,'v');
u_1=0.0;u_2=0.0;
y_1=0;y_2=0;
x(1)=0;x(2)=2;x(3)=0;
error_1=0;
erro ...

是PID参数值的问题吗??还是采样时间的问题??这个程序我是在matlabR2010b中运行的,结果是程序可以运行,但是输出的图形是没有的,也就是说横纵坐标都为0.我想问一下我这个具体是哪的问题,谢谢....
5楼2013-12-06 10:31:58
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

liuchao0878

木虫 (小有名气)

【答案】应助回帖

感谢参与,应助指数 +1
%controler


ts=0.001;
sys=tf(400,[1,50,0]);
dsys=c2d(sys,ts,'z');
dsys;
num=[0 0.0001967 0.0001935 ];
den=[2 -1.951  0.9512];
%[mun,den]=tfdata(dsys,'v');
u_1=0.0;u_2=0.0;
y_1=0;y_2=0;
x(1)=0;x(2)=0;x(3)=0;
error_1=0;
error_2=0;
for k=1:1000
   
time(k)=k*ts;

rin(k)=1.0;
kp=8;
ki=0.10;
kd=10;  

du(k)=kp*x(1)+ki*x(2)+kd*x(3);
u(k)=u_1+du(k);

    if u(k)>=10
         u(k)=10;
    end
    if u(k)<=-10
         u(k)=-10;
    end
yout(k)=-den(2)*y_1-den(3)*y_2+num(2)*u_1+num(3)*u_2;

error=rin(k)-yout(k);
u_2=u_1;u_1=u(k);
y_2=y_1;y_1=yout(k);

x(1)=error-error_1;
x(2)=error-2*error_1+error_2;
x(3)=error;

error_2=error_1;
error_1=error;
end

plot(time,rin,'b',time,yout,'r');
xlabel('time(s)');ylabel('rin,yout');

LZ你试试这个可以吗
喵~
6楼2013-12-06 11:07:07
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

liuchao0878

木虫 (小有名气)

【答案】应助回帖

★ ★
流毓1988: 金币+2, ★★★很有帮助, 嗯嗯,我看到喽,谢谢哦... 2013-12-07 15:11:39
LZ你的错在于
for k=1;1;1000
你用了分号
要冒号才对
for k=1:1000
喵~
7楼2013-12-06 11:08:44
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

hubery.zhu

金虫 (正式写手)

引用回帖:
5楼: Originally posted by 流毓1988 at 2013-12-06 10:31:58
是PID参数值的问题吗??还是采样时间的问题??这个程序我是在matlabR2010b中运行的,结果是程序可以运行,但是输出的图形是没有的,也就是说横纵坐标都为0.我想问一下我这个具体是哪的问题,谢谢.......

把我的程序运行一下就知道原因了
耐得住寂寞,抵的住诱惑,拥得了繁华!
8楼2013-12-06 13:13:09
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

流毓1988

新虫 (初入文坛)

引用回帖:
8楼: Originally posted by hubery.zhu at 2013-12-06 13:13:09
把我的程序运行一下就知道原因了...

嗯嗯,运行了,的确是对的。知道哪有问题了...谢谢哦!!
9楼2013-12-07 15:07:19
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

dgtd

新虫 (初入文坛)

yout(k)=-den(2)*y_1+num(2)*u_5  这个式子是怎么来的 啊?谢谢
10楼2015-10-23 21:40:17
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 流毓1988 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 0856求调剂 +3 刘梦微 2026-03-15 3/150 2026-03-16 10:00 by houyaoxu
[考研] 材料专硕306英一数二 +3 z1z2z3879 2026-03-16 3/150 2026-03-16 09:19 by Demonsssss
[考研] 290求调剂 +5 孔志浩 2026-03-12 10/500 2026-03-16 09:01 by 余晖&
[考研] 中科院材料273求调剂 +3 yzydy 2026-03-15 3/150 2026-03-15 21:15 by ms629
[考研] 机械专硕调剂 +3 笨笨兔子 2026-03-12 3/150 2026-03-15 20:02 by 栗子粥?
[考研] 中科大材料与化工319求调剂 +3 孟鑫材料 2026-03-14 3/150 2026-03-14 20:10 by ms629
[考研] 一志愿华中农业大学071010,总分三百二,求调剂 +3 困困困困坤坤 2026-03-10 3/150 2026-03-14 00:35 by JourneyLucky
[考研] 308求调剂 +3 是Lupa啊 2026-03-10 3/150 2026-03-14 00:30 by JourneyLucky
[考研] 321求调剂 +3 CUcat 2026-03-10 3/150 2026-03-14 00:25 by JourneyLucky
[考研] 327求调剂 +4 Ffff03 2026-03-10 4/200 2026-03-14 00:17 by JourneyLucky
[考研] 材料工程,326分,求调剂 +6 KRSLSR 2026-03-10 6/300 2026-03-13 23:47 by JourneyLucky
[考研] 332求调剂 +3 zjy101327 2026-03-11 6/300 2026-03-13 22:48 by JourneyLucky
[考研] 308求调剂 +5 是Lupa啊 2026-03-11 5/250 2026-03-13 22:13 by JourneyLucky
[考研] 315求调剂 +9 小羊小羊_ 2026-03-11 10/500 2026-03-13 21:13 by SXNU李老师
[考研] 310求调剂 +3 【上上签】 2026-03-11 3/150 2026-03-13 16:16 by JourneyLucky
[考博] 26读博 +4 Rui135246 2026-03-12 10/500 2026-03-13 07:15 by gaobiao
[考研] 333求调剂 +3 152697 2026-03-12 4/200 2026-03-13 07:08 by Iveryant
[考研] 420求调剂 +4 莫向外求11 2026-03-10 6/300 2026-03-12 14:41 by ruiyingmiao
[考研] 哈工大材料324求调剂 +6 闫旭东 2026-03-10 8/400 2026-03-10 22:49 by 星空星月
[考博] 26申博求助 +3 跳跃饼干 2026-03-10 4/200 2026-03-10 21:15 by Tntcnn
信息提示
请填处理意见