西门子PLC结构化编程_线性插值算法功能块

文章目录


前言

在之前的文章中,我们详细分析了PID算法的原理和推导过程,同时给出了各种各样的PID功能块及仿真块程序。

见文章:

  1. 《西门子PLC结构化编程_基于线性回归模型的过程值预测》
  2. 《西门子PLC结构化编程_通用型PID过程仿真模型》
  3. 《西门子PLC结构化编程_基于一阶惯性加纯滞后环节的过程仿真模型》
  4. 《西门子PLC结构化编程_带前馈控制功能的增量式PID控制器》
  5. 《西门子PLC结构化编程_带前馈控制功能的位置式PID控制器》
  6. 《西门子PLC结构化编程_增量式PID功能块》
  7. 《SIMATIC S7-1200 PID串级控制(以巧克力加热炉温度控制为例)》

在某些工控场景下,不需要PID这种精确的控制算法,可使用线性插值法等低精度低运算量的算法。本文对线性插值法做简要介绍,并给出程序实现方法。


一、算法原理

线性插值基于两点确定一条直线的思想。已知输入量(温度)在两个边界点(低温度、高温度)对应输出量(频率)的两个边界值(低频率、高频率),则对于任意介于两者之间的输入量,其输出量可通过直线方程计算得出。公式如下:

二、功能概述

  1. 分为手动、自动模式;
  2. 手动模式下,手动给定输出值,自动模式下,根据线性插值法自动计算出输出值;
  3. 手自动无扰切换,当模式切换为手动时,当前时刻的输出值传递给手动设定输出值,以防止手自动切换时产生输出值震荡;
  4. 采用分段控制,过程值小于某个值时,以最小输出值输出,过程值大于某个值时,以最大输出值输出,过程值在此之间时,根据线性插值法计算出的输出值输出;
  5. 可选择正作用控制器,还是反作用控制器。

三、程序编写

1. 新建数据类型"1_LerpType"

图1

2. 新建FB块"FB615_Lerp"

建立如下引脚变量:

图2

3. 编程

程序段4:

c 复制代码
REGION 手自动无扰切换
    
    IF #Lerp.HMI.HMIManual THEN
        #Lerp.HMI.ManualSetpoint := #Lerp.OutPut.Output;
    END_IF;
    
END_REGION

REGION 模式切换
    
    IF #Lerp.InPut.Running THEN
        IF #Lerp.HMI.Auto_DO THEN
            IF #Lerp.InPut.ProcessValue < #Lerp.HMI.PVLow THEN
                #Lerp.Static.Step := 0;
            END_IF;
            
            IF #Lerp.InPut.ProcessValue > #Lerp.HMI.PVHigh THEN
                #Lerp.Static.Step := 1;
            END_IF;
            
            IF (#Lerp.HMI.PVLow < #Lerp.InPut.ProcessValue) AND (#Lerp.InPut.ProcessValue < #Lerp.HMI.PVHigh) THEN
                #Lerp.Static.Step := 2;
            END_IF;
        ELSIF
            #Lerp.HMI.Manual_DO THEN
            #Lerp.Static.Step := 3;
        END_IF;
    ELSE
        #Lerp.Static.Step := 4;
    END_IF;
    
END_REGION

REGION 输出值计算
    
    CASE #Lerp.Static.Step OF
        0:
            IF #Lerp.HMI.Direction THEN
                #Lerp.Static.OutputTemp := #Lerp.HMI.LowSetpoint;
            ELSE
                #Lerp.Static.OutputTemp := #Lerp.HMI.HighSetpoint;
            END_IF;
        1:
            IF #Lerp.HMI.Direction THEN
                #Lerp.Static.OutputTemp := #Lerp.HMI.HighSetpoint;
            ELSE
                #Lerp.Static.OutputTemp := #Lerp.HMI.LowSetpoint;
            END_IF;
        2:
            #Lerp.Static.PV_Percent := (#Lerp.InPut.ProcessValue - #Lerp.HMI.PVLow) / (#Lerp.HMI.PVHigh - #Lerp.HMI.PVLow);
            IF #Lerp.HMI.Direction THEN
                #Lerp.Static.OutputTemp := #Lerp.HMI.LowSetpoint + #Lerp.Static.PV_Percent * (#Lerp.HMI.HighSetpoint - #Lerp.HMI.LowSetpoint);
            ELSE
                #Lerp.Static.OutputTemp := #Lerp.HMI.HighSetpoint - #Lerp.Static.PV_Percent * (#Lerp.HMI.HighSetpoint - #Lerp.HMI.LowSetpoint);
            END_IF;
        3:
            #Lerp.Static.OutputTemp := #Lerp.HMI.ManualSetpoint;
        4:
            #Lerp.Static.OutputTemp := #Lerp.OutPut.Output;
    END_CASE;
    
    IF #Lerp.HMI.Enable THEN
        // 频率输出限幅
        #Lerp.OutPut.Output := LIMIT(MN := #Lerp.Static.OutputMIN, IN := #Lerp.Static.OutputTemp, MX := #Lerp.Static.OutputMAX);
        
        // 频率输出转换
        "FC607_AnalogOutPutConver"(AO_IN := #Lerp.OutPut.Output,
                                   IN_MAX := #Lerp.Static.OutputMAX,
                                   IN_MIN := #Lerp.Static.OutputMIN,
                                   OUT_MAX := 27648,
                                   OUT_MIN := 0,
                                   AO_OUT => #Lerp.OutPut.Output_PER);
    END_IF;
    
END_REGION

REGION 按钮自复位
    
    #Lerp.HMI.HMIManual := #Lerp.HMI.HMIManual AND NOT #Lerp.Static.ReSet[0];
    #Lerp.HMI.HMIAuto := #Lerp.HMI.HMIAuto AND NOT #Lerp.Static.ReSet[1];
    
    #Lerp.Static.ReSet[0] := #Lerp.HMI.HMIManual;
    #Lerp.Static.ReSet[1] := #Lerp.HMI.HMIAuto;
    
END_REGION

其中,"FC607_AnalogOutPutConver"是指调用FC块"FC607_AnalogOutPutConver",该程序块可将工程量转换为模拟量。参考文章《西门子PLC常用底层逻辑块分享_模拟量写入》


总结

本文详细阐述了线性插值算法在西门子博途编程平台中的程序实现过程。在实际工业控制场景中,可代替PID用于简单的开环控制环节,以降低程序的复杂度。

相关推荐
爱喝水的鱼丶1 天前
SAP-ABAP:条件判断与循环控制语句(7篇)第七篇:性能优化:条件与循环代码的常见性能瓶颈与优化方案
学习·算法·性能优化·sap·abap
吃好睡好便好1 天前
提取矩阵某一行或某一列元素
开发语言·人工智能·线性代数·算法·matlab·矩阵
云泽8081 天前
笔试算法 -位运算篇(二):从唯一字符到消失数字
c++·算法·位运算
ʚ希希ɞ ྀ1 天前
不同路径|| -- dp
算法
IT 行者1 天前
SimHash 与 MinHash:相似性计算的双子星算法
算法·hash·比对
智者知已应修善业1 天前
【51单片机8位数码管动态显示日期小数点风格】2023-11-13
c++·经验分享·笔记·算法·51单片机
智者知已应修善业1 天前
【51单片机有三个LED 分别第一个灯闪三下 再到第二个灯又闪三下 再到第三个灯又闪三下 就这样循环程序】2023-11-16
c++·经验分享·笔记·算法·51单片机
小L~~~1 天前
基于贪心策略的混合遗传算法求解01背包问题
python·算法
洛水水1 天前
【力扣100题】53.最长回文子串
算法·leetcode·职场和发展