MATLAB-S-function实现PID

1 建立模型

2 模型参数设置

注意设置0.001s的延时,因为s-fun中是0.01的步长

 

 3 s-function代码

%函数的总入口,收到信号后,首先进入这个函数.这个函数包含一个switch语句,根据情况进入不同的子函数
function [sys,x0,str,ts] = exp_pidf(t,x,u,flag)
switch flag, 
  case 0,
    [sys,x0,str,ts]=mdlInitializeSizes; 
  case 1,
    sys=mdlDerivatives(t,x,u); 
  case 2,
    sys=mdlUpdate(t,x,u); 
  case 3,
    sys=mdlOutputs(t,x,u); 
  case 4,
    sys=mdlGetTimeOfNextVarHit(t,x,u);  
  case 9,
    sys=mdlTerminate(t,x,u);
 
  otherwise
    DAStudio.error('Simulink:blocks:unhandledFlag', num2str(flag));
 
end
 
%S-function进行基本的设置,相当于构造函数,定义S函数的基本特性,包括采样时间、连续或者离散状态的初始条件和Sizes数组
function [sys,x0,str,ts]=mdlInitializeSizes
sizes = simsizes;              %调用构造函数,生成一个默认类
sizes.NumContStates  = 0;      %设置系统连续状态的数量,如果是2个输出,则设为2
sizes.NumDiscStates  = 3;      %设置系统离散状态的数量
sizes.NumOutputs     = 1;      %设置系统输出的数量,如果是2个输出,则设为2
sizes.NumInputs      = 2;      %设置系统输入的数量
sizes.DirFeedthrough = 1;      %设置系统直接通过量的数量,一般为1
sizes.NumSampleTimes = 1;      % At least one sample time is needed
                               % 采样时间个数,1表示只有一个采样周期.
                               % 猜测为如果为n,则下一时刻的状态需要知道前n个状态的系统状态
sys = simsizes(sizes);         %将sizes结构体中的信息传递给sys
x0  = [0;0;0];                   % 系统初始状态
str = [];                      % 保留变量,保持为空
ts  = [-1 0];                   % 采样时间
 
%该函数仅在连续系统中被调用,计算连续状态变量的微分方程,求所给表达式的等号左边状态变量的积分值的过程
function sys=mdlDerivatives(t,x,u)   %Time-varying model
sys = [];
 
%sys=mdlUpdate(t,x,u); 该函数仅在离散系统中被调用,用于产生控制系统的下一个状态;更新离散状态、采样时间和主时间步的要求
function sys=mdlUpdate(t,x,u)   %更新离散状态
T=0.001;
sys=[u(1); %P部分-本次偏差
    x(2)+u(1)*T;%I部分,偏差的累加
    (u(1)-u(2))/T];%D部分,偏差的变化

%产生(传递)系统输出
function sys=mdlOutputs(t,x,u)
kp=20;
ki=0.0;
kd=0.5;
sys=kp*x(1)+ki*x(2)+kd*x(3);

% sys=mdlGetTimeOfNextVarHit(t,x,u) 获得下一次系统执行(next hit)的时间,该时间为绝对时间 此函数仅在采样时间数组中指定变量离散时间采样时间[-2 0]时会被调用。
function sys=mdlGetTimeOfNextVarHit(t,x,u) 
% sampleTime = 1;   %设置下一个采样时间在1s之后
% sys = t + sampleTime;
 sys = [];
 
% sys=mdlTerminate(t,x,u) 相当于构析函数,结束该仿真模块时被调用
function sys=mdlTerminate(t,x,u) 
sys = [];

4 仿真结果

参考材料《MATLAB_SIMULINK系统仿真》

  • 8
    点赞
  • 59
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 在Matlab中,我们可以使用S函数实现一个PID控制。S函数是一种用于在Simulink模型中实现C或C++代码的模块。S函数的输入和输出可以与Simulink中的其他模块进行连接,例如传感、执行、仿真环境等。 编写一个PID S函数的方法如下: 1. 在MatlabSimulink Library Browser中,找到S-Function模块并添加至一个新建的模型当中。 2. 将S函数模块双击打开,然后在Parameters标签下设置PID控制的系数Kp、Ki和Kd。 3. 在Outputs标签下定义S函数的输出变量和数值类型。 4. 在mdlInitializeSizes()函数中定义S函数的输入和输出端口的数量、尺寸和数据类型等信息。 5. 在mdlStart()函数中初始化PID控制的各个参数。 6. 在mdlOutputs()函数实现PID控制的算法,根据当前的误差计算控制量并输出到Simulink模型中。 7. 最后,在mdlTerminate()函数中释放资源和清空内存。 需要注意的是,MATLABPID S函数只是一个简单的PID算法演示,因此在实际应用中需要根据具体需求修改参数和算法等细节,以达到更好的控制效果和稳定性。 总的来说,在Matlab中使用S函数实现PID控制是一种简便有效的方法,可用于学习、验证和仿真控制系统的设计和性能。 ### 回答2: 在MATLAB中,使用s函数可以实现PID控制PID控制是一种反馈控制,由比例、积分和微分三个控制项组成。具体实现过程如下: 首先,从MATLAB的工具栏中选择“新建” -> “模块” -> “S函数模块”,打开一个新的S函数编辑。 然后,在编辑中编写代码来实现PID控制。代码将包含PID控制的公式和需要的控制参数。其中,Kp表示比例控制增益、Ki表示积分控制增益、Kd表示微分控制增益。 在代码顶部,定义所需的输入和输出信号。这些信号包括输入信号、输出信号以及PID控制的三个参数。 接下来,在代码的主体部分,实现PID控制公式。使用输入信号、PID参数和PID控制公式来计算输出信号。 最后,保存S函数文件,并将其添加到MATLAB的工作路径中。从Simulink中,可以将PID S函数模块添加到模型中,以便在Simulink模型中使用。 总之,使用MATLAB的S函数实现PID控制是一种可靠和高效的方法,可用于控制许多工业过程和系统。 ### 回答3: MATLAB中使用s函数可以实现PID控制PID控制是一种经典的反馈控制,它可以通过测量反馈信号来调节输出信号,实现对系统的控制。 使用s函数可以方便地构建PID控制。首先,可以定义一个s函数模块,其中包含用于计算PID控制输出的代码。在这个模块中,需要定义PID控制的三个参数:比例系数、积分时间常数和微分时间常数。然后,在每个时刻,根据反馈信号和期望输出信号计算PID控制的输出,并更新控制参数。 具体实现时,可以使用MATLAB中的s函数库,根据PID控制的数学模型构建对应的传输函数。然后,在s函数中添加计算控制输出的代码,并将控制输出传递给系统。最后,将s函数与系统模型进行连接,即可实现PID控制。 使用s函数实现PID控制的方法简单易懂,可以快速构建PID控制模型并进行仿真实验。因此,在工程实践中,s函数常被使用来实现PID控制
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值