【单片机】温控系统参数辨识及单片机PID控制

温控系统参数辨识及单片机PID控制

  • [1. 温控系统组成](#1. 温控系统组成)
  • [2. matlab辨识系统参数](#2. matlab辨识系统参数)
  • PID控制

1. 温控系统组成

  • 半导体制冷片正向通电制冷,反向通电制热。系统采用半导体制冷片(帕尔贴)作为执行单元,帕尔贴下端连接水冷系统进行散热,上端为导热铜片,铜片上贴有热敏电阻用于测量系统的温度。
  • 控制系统采用4个MOS管组成的H桥驱动电路,通过PWM进行加热制冷温度控制。

2. matlab辨识系统参数

一般的加热系统的传递函数可以简化为一阶时滞系统,其传递函数如下:

W ( s ) = K e − τ s T 1 s + 1 W(s)=\frac{K e^{-\tau s}}{T_1 s+1} W(s)=T1s+1Ke−τs

2.1 采集阶跃响应信号

我们可以用一阶跃信号去激励系统,从而识别出系统的参数。

这里将温控系统的输出设定为100%,记录导热铜板上的温度变化曲线。

导入matlab系统辨识模块

将阶跃响应信号保存为 iddata 格式

cpp 复制代码
dataName=["P100","P80","P50","P20"]; %P100代表 PWM信号100%开度
dataAll=readtable('Row.xlsx');
dataAll=table2array(dataAll);
originalTemp=dataAll(1,:);%初始温度
dataAll=dataAll-originalTemp;%将所有信号变为0摄氏度开始
sampTime=0.06;%采样时间

for  i=1:length(dataName)
    tempData=dataAll(:,i);
    tempData=tempData(~isnan(tempData));
    tempTime=(sampTime:sampTime:(length(tempData))*sampTime)';
    tempDataTime=[tempTime,tempData];
    u=ones(length(tempDataTime),1);%阶跃信号
    eval("x_"+dataName(i)+"=iddata(tempData,u,sampTime);");
end

得到下面四组实验数据

打开matlab中 System Identifiction模块

导入数据点击【Data object】



PID控制

理论模型与实际模型比较

相关推荐
蓬荜生灰24 分钟前
永磁无刷电机旋转原理
单片机·嵌入式硬件
Ronin-Lotus5 小时前
嵌入式硬件与应用篇---寄存器GPIO控制
stm32·单片机·嵌入式硬件·微处理器原理与应用
星辰pid12 小时前
STM32控制四自由度机械臂(SG90舵机)(硬件篇)(简单易复刻)
stm32·单片机·嵌入式硬件·机械臂
威桑14 小时前
STM32 专有名词缩写整合
stm32·单片机·嵌入式硬件
星源~14 小时前
tree 命令集成到 Git Bash:可视化目录结构的指南
git·单片机·物联网·嵌入式·项目开发
SKYDROID云卓小助手16 小时前
无人设备遥控器之自动调整编码技术篇
人工智能·嵌入式硬件·算法·自动化·信号处理
所念皆星海91116 小时前
图灵完备之路(数电学习三分钟)----数据选择器与总线
嵌入式硬件·通信·数电
智者知已应修善业17 小时前
【51单片机节日彩灯控制器设计】2022-6-11
c语言·经验分享·笔记·单片机·嵌入式硬件·51单片机
开-悟18 小时前
嵌入式编程-使用AI查找BUG的启发
c语言·人工智能·嵌入式硬件·bug
许白掰20 小时前
【stm32】HAL库开发——CubeMX配置RTC,单片机工作模式和看门狗
stm32·单片机·嵌入式硬件·学习·实时音视频