matlab实现PID参数功能的简单仿真_gif

复制代码
clc 
clear
close all

% 定义系统传递函数
G = tf(2,[6 5 1]);                    % 二阶系统传递函数

% 合并后的GIF文件名
filename_all = 'PID_All.gif';  

% 创建单个图窗
figure(1); clf;
set(gcf, 'Position', [100, 100, 800, 600]);  % 设置图窗大小,保证帧捕获完整

%% 1. 比例系数Kp的动态过程
Kp_list = 0:0.1:5;
for idx = 1:length(Kp_list)
    Kp = Kp_list(idx);
    G1 = Kp;                          % 比例控制
    sys = feedback(G1 * G, 1);        % 单位负反馈系统
    
    % 绘制阶跃响应
    step(sys);                       
    axis([0 14 0 1.6]);
    title(['比例控制: Kp = ', num2str(Kp, '%.1f')], 'FontSize', 12);
    xlabel('时间 (s)', 'FontSize', 10);
    ylabel('输出', 'FontSize', 10);
    grid on;
    pause(0.05);
    
    % 捕获帧并写入GIF
    frame = getframe(1);    
    im = frame2im(frame);    
    [imind, cm] = rgb2ind(im, 256);  
    if idx == 1 && length(Kp_list) == 1  % 处理单帧情况
        imwrite(imind, cm, filename_all, 'gif', 'Loopcount', inf, 'DelayTime', 0.1);
    else
        if idx == 1  % 第一帧(比例阶段起始)
            imwrite(imind, cm, filename_all, 'gif', 'Loopcount', inf, 'DelayTime', 0.1);
        else
            imwrite(imind, cm, filename_all, 'gif', 'WriteMode', 'append', 'DelayTime', 0.1);
        end
    end
end

%% 2. 积分系数Ki的动态过程
Kp = 5;
Ki_list = 0:0.02:1;
for idx = 1:length(Ki_list)
    Ki = Ki_list(idx);
    G1 = tf([Kp Ki], [1 0]);          % PI控制
    sys = feedback(G1 * G, 1);        % 单位负反馈系统
    
    % 绘制阶跃响应
    step(sys);                       
    axis([0 14 0 1.6]);
    title(['PI控制: Kp = ', num2str(Kp), ', Ki = ', num2str(Ki, '%.2f')], 'FontSize', 12);
    xlabel('时间 (s)', 'FontSize', 10);
    ylabel('输出', 'FontSize', 10);
    grid on;
    pause(0.05);
    
    % 捕获帧并写入GIF
    frame = getframe(1);    
    im = frame2im(frame);    
    [imind, cm] = rgb2ind(im, 256);  
    imwrite(imind, cm, filename_all, 'gif', 'WriteMode', 'append', 'DelayTime', 0.1);
end

%% 3. 微分系数Kd的动态过程
Kp = 5;
Ki = 1;
Kd_list = 0:0.1:5.5;
for idx = 1:length(Kd_list)
    Kd = Kd_list(idx);
    G1 = tf([Kd, Kp, Ki], [1,0]);     % PID控制
    sys = feedback(G1 * G, 1);        % 单位负反馈系统
    
    % 绘制阶跃响应
    step(sys);                       
    axis([0 14 0 1.6]);
    title(['PID控制: Kp = ', num2str(Kp), ', Ki = ', num2str(Ki), ', Kd = ', num2str(Kd, '%.1f')], 'FontSize', 12);
    xlabel('时间 (s)', 'FontSize', 10);
    ylabel('输出', 'FontSize', 10);
    grid on;
    pause(0.05);
    
    % 捕获帧并写入GIF
    frame = getframe(1);    
    im = frame2im(frame);    
    [imind, cm] = rgb2ind(im, 256);  
    imwrite(imind, cm, filename_all, 'gif', 'WriteMode', 'append', 'DelayTime', 0.1);
end

disp(['GIF文件已生成:', fullfile(pwd(), filename_all)]);
复制代码
clc 
clear
close all

% 定义系统传递函数
G = tf(2,[6 5 1]);                    % 二阶系统传递函数

%% 1. 比例系数Kp的功能展示(图窗1,生成Kp_GIF.gif)
filename_kp = 'Kp_Function.gif';
figure(1); clf;
set(gcf, 'Position', [100, 100, 800, 600]);  % 设置图窗位置和大小
Kp_list = 0:0.1:5;

for idx = 1:length(Kp_list)
    Kp = Kp_list(idx);
    G1 = Kp;                          % 比例控制
    sys = feedback(G1 * G, 1);        % 单位负反馈系统
    
    % 绘制阶跃响应
    step(sys);                       
    axis([0 14 0 1.6]);
    title(['比例系数Kp的功能展示', newline, '当前Kp = ', num2str(Kp, '%.1f')], 'FontSize', 12);
    xlabel('时间 (s)', 'FontSize', 10);
    ylabel('系统输出', 'FontSize', 10);
    grid on;
    pause(0.05);
    
    % 捕获帧并写入GIF
    frame = getframe(1);    
    im = frame2im(frame);    
    [imind, cm] = rgb2ind(im, 256);  
    if idx == 1
        imwrite(imind, cm, filename_kp, 'gif', 'Loopcount', inf, 'DelayTime', 0.1);
    else
        imwrite(imind, cm, filename_kp, 'gif', 'WriteMode', 'append', 'DelayTime', 0.1);
    end
end

%% 2. 积分系数Ki的功能展示(图窗2,生成Ki_GIF.gif)
filename_ki = 'Ki_Function.gif';
figure(2); clf;
set(gcf, 'Position', [200, 200, 800, 600]);
Kp = 5;  % 固定Kp
Ki_list = 0:0.02:1;

for idx = 1:length(Ki_list)
    Ki = Ki_list(idx);
    G1 = tf([Kp Ki], [1 0]);          % PI控制
    sys = feedback(G1 * G, 1);        % 单位负反馈系统
    
    % 绘制阶跃响应
    step(sys);                       
    axis([0 14 0 1.6]);
    title(['积分系数Ki的功能展示(Kp固定为5)', newline, '当前Ki = ', num2str(Ki, '%.2f')], 'FontSize', 12);
    xlabel('时间 (s)', 'FontSize', 10);
    ylabel('系统输出', 'FontSize', 10);
    grid on;
    pause(0.05);
    
    % 捕获帧并写入GIF
    frame = getframe(2);    
    im = frame2im(frame);    
    [imind, cm] = rgb2ind(im, 256);  
    if idx == 1
        imwrite(imind, cm, filename_ki, 'gif', 'Loopcount', inf, 'DelayTime', 0.1);
    else
        imwrite(imind, cm, filename_ki, 'gif', 'WriteMode', 'append', 'DelayTime', 0.1);
    end
end

%% 3. 微分系数Kd的功能展示(图窗3,生成Kd_GIF.gif)
filename_kd = 'Kd_Function.gif';
figure(3); clf;
set(gcf, 'Position', [300, 300, 800, 600]);
Kp = 5;  % 固定Kp
Ki = 1;  % 固定Ki
Kd_list = 0:0.1:5.5;

for idx = 1:length(Kd_list)
    Kd = Kd_list(idx);
    G1 = tf([Kd, Kp, Ki], [1, 0]);     % PID控制
    sys = feedback(G1 * G, 1);        % 单位负反馈系统
    
    % 绘制阶跃响应
    step(sys);                       
    axis([0 14 0 1.6]);
    title(['微分系数Kd的功能展示(Kp=5, Ki=1)', newline, '当前Kd = ', num2str(Kd, '%.1f')], 'FontSize', 12);
    xlabel('时间 (s)', 'FontSize', 10);
    ylabel('系统输出', 'FontSize', 10);
    grid on;
    pause(0.05);
    
    % 捕获帧并写入GIF
    frame = getframe(3);    
    im = frame2im(frame);    
    [imind, cm] = rgb2ind(im, 256);  
    if idx == 1
        imwrite(imind, cm, filename_kd, 'gif', 'Loopcount', inf, 'DelayTime', 0.1);
    else
        imwrite(imind, cm, filename_kd, 'gif', 'WriteMode', 'append', 'DelayTime', 0.1);
    end
end

disp('三个参数的功能展示GIF已生成,保存在当前工作目录!');

大佬们的链接汇总(学习参考):

深入浅出PID控制算法(二)------------PID算法离散化和增量式PID算法原理及Matlab实现_离散pid-CSDN博客

matlab模糊控制工具箱使用和模糊控制pid实例参考_模糊控制调试参数-CSDN博客

PID控制算法详解及其在电机控制中的应用-CSDN博客

PID控制算法简介-CSDN博客

相关推荐
技术净胜6 小时前
MATLAB 基因表达数据处理与可视化全流程案例
开发语言·matlab
机器学习之心11 小时前
SSA-SVMD麻雀算法优化逐次变分模态分解(15种不同的适应度)MATLAB代码
matlab·ssa-svmd·麻雀算法优化逐次变分模态分解
三维空间11 小时前
在MATLAB中对基因表达数据进行数据预处理
matlab
88号技师12 小时前
2025年9月一区SCI-孤行尺蠖觅食优化算法Solitary Inchworm Foraging-附Matlab免费代码
开发语言·算法·数学建模·matlab·优化算法
RaLi和夕20 小时前
Matlab求传递函数的零极点及增益并绘制零极点图 2
matlab
wuk9981 天前
MATLAB双树复小波变换(DTCWT)工具包详解
人工智能·计算机视觉·matlab
机器学习之心1 天前
PINN预测圆形区域内的二维声场MATLAB实现
matlab·pinn·二维声场
tyatyatya2 天前
如何在MATLAB中进行数据可视化?
matlab·信息可视化·数据分析
软件算法开发2 天前
基于秃鹰搜索优化的LSTM深度学习网络模型(BES-LSTM)的一维时间序列预测算法matlab仿真
深度学习·算法·matlab·lstm·时间序列预测·秃鹰搜索优化·bes-lstm