电子产业一站式赋能平台

PCB联盟网

搜索
查看: 1331|回复: 3
收起左侧

求助~为什么我按书上编的模糊pid程序,还报错呀?跪求高手!

[复制链接]

600

主题

954

帖子

5061

积分

四级会员

Rank: 4

积分
5061
发表于 2022-11-2 10:50:33 | 显示全部楼层 |阅读模式
%fuzzy tunning PID control
clear all;
close all;
a=newfis('fuzzpid');
%parameter e
a=addvar(a,'input','e',[-3,3]);
a=addmf(a,'input',1,'NB','zmf',[-3,-1]);
a=addmf(a,'input',1,'NM','trimf',[-3,-2,0]);
a=addmf(a,'input',1,'NS','trimf',[-3,-1,1]);
a=addmf(a,'input',1,'Z','trimf',[-2,0,-2]);
a=addmf(a,'input',1,'PS','trimf',[-1,1,3]);
a=addmf(a,'input',1,'PM','trimf',[0,2,3]);
a=addmf(a,'input',1,'PB','smf',[1,3]);
%parameter ec
a=addvar(a,'input','ec',[-3,3]);
a=addmf(a,'input',2,'NB','zmf',[-3,-1]);
a=addmf(a,'input',2,'NM','trimf',[-3,-2,0]);
a=addmf(a,'input',2,'NS','trimf',[-3,-1,1]);
a=addmf(a,'input',2,'Z','trimf',[-2,0,-2]);
a=addmf(a,'input',2,'PS','trimf',[-1,1,3]);
a=addmf(a,'input',2,'PM','trimf',[0,2,3]);
a=addmf(a,'input',2,'PB','smf',[1,3]);
%parameter kp
a=addvar(a,'output','kp',[-0.3,0.3]);
a=addmf(a,'output',1,'NB','zmf',[-0.3,-0.1]);
a=addmf(a,'output',1,'NM','trimf',[-0.3,-0.2,0]);
a=addmf(a,'output',1,'NS','trimf',[-0.3,-0.1,0.1]);
a=addmf(a,'output',1,'Z','trimf',[-0.2,0,-0.2]);
a=addmf(a,'output',1,'PS','trimf',[-0.1,0.1,0.3]);
a=addmf(a,'output',1,'PM','trimf',[0,0.2,0.3]);
a=addmf(a,'output',1,'PB','smf',[0.1,0.3]);
%parameter ki
a=addvar(a,'output','ki',[-0.06,0.06]);
a=addmf(a,'output',2,'NB','zmf',[-0.06,-0.02]);
a=addmf(a,'output',2,'NM','trimf',[-0.06,-0.04,0]);
a=addmf(a,'output',2,'NS','trimf',[-0.06,-0.02,0.02]);
a=addmf(a,'output',2,'Z','trimf',[-0.04,0,-0.04]);
a=addmf(a,'output',2,'PS','trimf',[-0.02,0.02,0.06]);
a=addmf(a,'output',2,'PM','trimf',[0,0.04,0.06]);
a=addmf(a,'output',2,'PB','smf',[0.02,0.06]);
%parameter kd
a=addvar(a,'output','kd',[-3,3]);
a=addmf(a,'output',3,'NB','zmf',[-3,-1]);
a=addmf(a,'output',3,'NM','trimf',[-3,-2,0]);
a=addmf(a,'output',3,'NS','trimf',[-3,-1,1]);
a=addmf(a,'output',3,'Z','trimf',[-2,0,-2]);
a=addmf(a,'output',3,'PS','trimf',[-1,1,3]);
a=addmf(a,'output',3,'PM','trimf',[0,2,3]);
a=addmf(a,'output',3,'PB','smf',[1,3]);
rulelist=[1 1 7 1 5 1 1;
     1 2 7 1 3 1 1;
     1 3 6 2 1 1 1;
     1 4 6 2 1 1 1;
     1 5 5 3 1 1 1;
     1 6 4 4 2 1 1;
     1 7 4 4 5 1 1;
   
     2 1 7 1 5 1 1;
     2 2 7 1 3 1 1;
     2 3 6 2 1 1 1;
     2 4 5 3 2 1 1;
     2 5 5 3 2 1 1;
     2 6 4 4 3 1 1;
     2 7 3 4 4 1 1;
   
     3 1 6 1 4 1 1;
     3 2 6 2 3 1 1;
     3 3 6 3 2 1 1;
     3 4 5 3 2 1 1;
     3 5 4 4 3 1 1;
     3 6 3 5 3 1 1;
     3 7 3 5 4 1 1;
   
     4 1 6 2 4 1 1;
     4 2 6 2 3 1 1;
     4 3 5 3 3 1 1;
     4 4 4 4 3 1 1;
     4 5 3 5 3 1 1;
     4 6 2 6 3 1 1;
     4 7 2 6 4 1 1;
   
     5 1 5 2 4 1 1;
     5 2 5 3 4 1 1;
     5 3 4 4 4 1 1;
     5 4 3 5 4 1 1;
     5 5 3 5 4 1 1;
     5 6 2 6 4 1 1;
     5 7 2 7 4 1 1;
   
     6 1 5 4 7 1 1;
     6 2 4 4 5 1 1;
     6 3 3 5 5 1 1;
     6 3 3 5 5 1 1;
     6 4 2 5 5 1 1;
     6 5 2 6 5 1 1;
     6 6 2 7 5 1 1;
     6 7 1 7 7 1 1;
   
     7 1 4 4 7 1 1;
     7 2 4 4 6 1 1;
     7 3 2 5 6 1 1;
     7 4 2 6 6 1 1;
     7 5 2 6 5 1 1;
     7 6 1 7 5 1 1;
     7 7 1 7 7 1 1];
a=addrule(a,rulelist);
a=setfis(a,'DefuzzMethod','centroid');

a=readfis('fuzzpid');

figure(1);
plotmf(a,'input',1);
figure(2);
plotmf(a,'input',2);
figure(3);
plotmf(a,'output',1);
figure(4);
plotmf(a,'output',2);
figure(5);
plotmf(a,'output',3);
figure(6);
plotfis(a);

fuzzy fuzzpid;
showrule(a);
ruleview fuzzpid;
报错:??? Error using ==> readfis at 52
No such file or directory

Error in ==> pid at 109
a=readfis('fuzzpid');

回复

使用道具 举报

591

主题

1772

帖子

5770

积分

四级会员

Rank: 4

积分
5770
发表于 2022-11-2 10:51:24 | 显示全部楼层
你确信a=addrule(a,rulelist);
a=setfis(a,'DefuzzMethod','centroid');

a=readfis('fuzzpid');

这几个没有写错么。
回复 支持 反对

使用道具 举报

578

主题

858

帖子

4821

积分

四级会员

Rank: 4

积分
4821
发表于 2022-11-2 10:52:09 | 显示全部楼层
回复:2楼没有写错,我已经调出来了,错误原因是fuzzpid名字没有命名好,中间有空格,所以调用不了!谢谢你!!
回复 支持 反对

使用道具 举报

600

主题

954

帖子

5061

积分

四级会员

Rank: 4

积分
5061
发表于 2022-11-2 10:53:27 | 显示全部楼层
你是什么书哇.推荐下呗
回复 支持 反对

使用道具 举报

发表回复

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

本版积分规则


联系客服 关注微信 下载APP 返回顶部 返回列表