加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
PTtuningParams.m 7.81 KB
一键复制 编辑 原始数据 按行查看 历史
Brian White 提交于 2020-05-19 11:05 . Add files via upload
%% PTtuningParams - scripts for plotting tune-related parameters
% ----------------------------------------------------------------------------------
% "THE BEER-WARE LICENSE" (Revision 42):
% <brian.white@queensu.ca> wrote this file. As long as you retain this notice you
% can do whatever you want with this stuff. If we meet some day, and you think
% this stuff is worth it, you can buy me a beer in return. -Brian White
% ----------------------------------------------------------------------------------
if ~isempty(filenameA) || ~isempty(filenameB)
PTtunefig=figure(4);
prop_max_screen=(max([PTtunefig.Position(3) PTtunefig.Position(4)]));
fontsz4=round(screensz_multiplier*prop_max_screen);
guiHandlesTune.saveFig4.FontSize=fontsz4;
guiHandlesTune.run4.FontSize=fontsz4;
guiHandlesTune.subsampFactor.FontSize=fontsz4;
guiHandlesTune.checkboxrateHigh.FontSize=fontsz4;
guiHandlesTune.minDegMove.FontSize=fontsz4;
guiHandlesTune.maxDegMove.FontSize=fontsz4;
guiHandlesTune.minDegMove_text.FontSize=fontsz4;
guiHandlesTune.maxDegMove_text.FontSize=fontsz4;
%% step resp computed directly from set point and gyro
ylab={'R';'P';'Y'};
ylab2={'roll';'pitch';'yaw'};
%%%%%%%%%%%%% step resp A %%%%%%%%%%%%%
if ~isempty(filenameA)
for p=1:3
% try
if ~updateStep
[stepresp_A{p} tA rateHigh_A{p}] = PTstepcalc(DATtmpA.RCRate(p,:), DATtmpA.GyroFilt(p,:), A_lograte, guiHandlesTune.subsampFactor.Value*3, str2num(guiHandlesTune.minDegMove.String), str2num(guiHandlesTune.maxDegMove.String));
end
% catch
% stepresp_A{p}=[];
% rateHigh_A{p}=[];
% end
figure(PTtunefig)
h1=subplot('position',posInfo.TparamsPos(p,:)); cla
hold on
if guiHandlesTune.checkboxrateHigh.Value==1,
rA=find(rateHigh_A{p}==1);
else
rA=find(rateHigh_A{p}==0);
end
if ~isempty(rA) && size(stepresp_A{p}(rA,:),1)>1
m=nanmean(stepresp_A{p}(rA,:));
sd=std(stepresp_A{p}(rA,:));%/sqrt(size(stepresp_A,1));
h2=fill([tA fliplr(tA)],[m+sd fliplr(m-sd)],colorA);
set(h2, 'FaceAlpha',.2,'EdgeColor',colorA,'EdgeAlpha',.2)
hold on
h1=plot(tA,m); set(h1, 'color',[colorA],'linewidth',2.5);
stepnfo=stepinfo(m,tA,1);
latencyHalfHeight=(find(m>.5,1) / A_lograte) - 1;
eval(['PID=' ylab2{p} 'PIDF_A;'])
h=text(320, .7, ['N=' int2str(size(stepresp_A{p}(rA,:),1)) ]);set(h,'fontsize',fontsz4);
h=text(320, .6, ['P,I,D,Dmin,F: ' char(string(PID(:,2)))]);set(h,'fontsize',fontsz4);
h=text(320, .5, ['Peak: ' num2str(stepnfo.Peak)]);set(h,'fontsize',fontsz4);
h=text(320, .4, ['PeakTime: ' num2str(stepnfo.PeakTime) 'ms']);set(h,'fontsize',fontsz4);
h=text(320, .3, ['Latency: ' num2str(latencyHalfHeight) 'ms']);set(h,'fontsize',fontsz4);
h=text(320, .2, ['SettlingMin: ' num2str(stepnfo.SettlingMin)]);set(h,'fontsize',fontsz4);
h=text(320, .1, ['SettlingMax: ' num2str(stepnfo.SettlingMax)]);set(h,'fontsize',fontsz4);
else
h=text(180, 1.1, ['insufficient data']);
set(h,'fontsize',fontsz4,'fontweight','bold')
end
if p==3
set(gca,'fontsize',fontsz4,'xminortick','on','yminortick','on','xtick',[0 100 200 300 400 500],'xticklabel',{'0' '100' '200' '300' '400' '500'},'ytick',[0 .2 .4 .6 .8 1 1.2 1.4 1.6],'tickdir','out')
else
set(gca,'fontsize',fontsz4,'xminortick','on','yminortick','on','xtick',[0 100 200 300 400 500],'xticklabel',{'' '' '' '' '' ''},'ytick',[0 .2 .4 .6 .8 1 1.2 1.4 1.6],'tickdir','out','ygrid','on')
end
box off
h=ylabel({'mean response {\pm}sd'}, 'fontweight','bold');
set(h,'fontsize',fontsz4)
if p==3, xlabel('time (ms)', 'fontweight','bold');end
if p==1, title('Step response [A]');end
h=text(5,1.5,ylab2{p});
set(h,'fontsize',fontsz4,'fontweight','bold')
h=plot([0 500],[1 1],'k--');
set(h,'linewidth',.5)
% h=plot([0 latencyHalfHeight],[.5 .5],'k:');
% set(h,'linewidth',1)
% h=plot([latencyHalfHeight latencyHalfHeight],[0 .5],'k:');
% set(h,'linewidth',1)
% h=text(latencyHalfHeight,.51,[int2str(latencyHalfHeight) 'ms']);
% set(h,'fontsize',fontsz4)
axis([0 500 0 1.6])
grid on
end
end
%%%%%%%%%%%%% step resp B %%%%%%%%%%%%%
if ~isempty(filenameB)
for p=1:3
try
if ~updateStep
[stepresp_B{p} tB rateHigh_B{p}] = PTstepcalc(DATtmpB.RCRate(p,:), DATtmpB.GyroFilt(p,:), B_lograte, guiHandlesTune.subsampFactor.Value*3, str2num(guiHandlesTune.minDegMove.String), str2num(guiHandlesTune.maxDegMove.String));
end
catch
stepresp_B{p}=[];
rateHigh_B{p}=[];
end
figure(PTtunefig)
h1=subplot('position',posInfo.TparamsPos(p+3,:)); cla
hold on
if guiHandlesTune.checkboxrateHigh.Value==1,
rB=find(rateHigh_B{p}==1);
else
rB=find(rateHigh_B{p}==0);
end
if ~isempty(rB) && size(stepresp_B{p}(rB,:),1)>1
m=nanmean(stepresp_B{p}(rB,:));
sd=std(stepresp_B{p}(rB,:));%/sqrt(size(stepresp_B,1));
h5=fill([tB fliplr(tB)],[m+sd fliplr(m-sd)],colorB);
set(h5, 'FaceAlpha',.25,'EdgeColor',colorB,'EdgeAlpha',.25)
hold on
h4=plot(tB,m); set(h4, 'color',[colorB],'linewidth',2.5)
stepnfo=stepinfo(m,tB,1);
latencyHalfHeight=(find(m>.5,1) / B_lograte) - 1;
eval(['PID=' ylab2{p} 'PIDF_B;'])
h=text(320, .7, ['N=' int2str(size(stepresp_B{p}(rB,:),1)) ]);set(h,'fontsize',fontsz4);
h=text(320, .6, ['P,I,D,Dmin,F: ' char(string(PID(:,2)))]);set(h,'fontsize',fontsz4);
h=text(320, .5, ['Peak: ' num2str(stepnfo.Peak)]);set(h,'fontsize',fontsz4);
h=text(320, .4, ['PeakTime: ' num2str(stepnfo.PeakTime) 'ms']);set(h,'fontsize',fontsz4);
h=text(320, .3, ['Latency: ' num2str(latencyHalfHeight) 'ms']);set(h,'fontsize',fontsz4);
h=text(320, .2, ['SettlingMin: ' num2str(stepnfo.SettlingMin)]);set(h,'fontsize',fontsz4);
h=text(320, .1, ['SettlingMax: ' num2str(stepnfo.SettlingMax)]);set(h,'fontsize',fontsz4);
else
h=text(180, 1.1, ['insufficient data']);
set(h,'fontsize',fontsz4,'fontweight','bold')
end
if p==3
set(gca,'fontsize',fontsz4,'xminortick','on','yminortick','on','xtick',[0 100 200 300 400 500],'xticklabel',{'0' '100' '200' '300' '400' '500'},'ytick',[0 .2 .4 .6 .8 1 1.2 1.4 1.6],'tickdir','out')
else
set(gca,'fontsize',fontsz4,'xminortick','on','yminortick','on','xtick',[0 100 200 300 400 500],'xticklabel',{'' '' '' '' '' ''},'ytick',[0 .2 .4 .6 .8 1 1.2 1.4 1.6],'tickdir','out')
end
box off
h=ylabel({'mean response {\pm}sd'}, 'fontweight','bold');
set(h,'fontsize',fontsz4)
if p==3, xlabel('time (ms)', 'fontweight','bold');end
if p==1, title('Step response [B]');end
h=text(5,1.5,ylab2{p});
set(h,'fontsize',fontsz4,'fontweight','bold')
h=plot([0 500],[1 1],'k--');
set(h,'linewidth',.5)
% h=plot([0 latencyHalfHeight],[.5 .5],'k:');
% set(h,'linewidth',1)
% h=plot([latencyHalfHeight latencyHalfHeight],[0 .5],'k:');
% set(h,'linewidth',1)
axis([0 500 0 1.6])
grid on
end
end
updateStep=0;
end
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化