西门子模块6ES7216-2BD23-0XB8正规授权
- 供应商
- 浔之漫智控技术-西门子PLC代理商
- 认证
- 手机号
- 15221406036
- 经理
- 聂航
- 所在地
- 上海市松江区石湖荡镇塔汇路755弄29号1幢一层A区213室
- 更新时间
- 2024-05-08 07:10
西门子模块6es7216-2bd23-0xb8正规授权
自1969年世界上诞生了台可编程逻辑控制器(plc)以来,可编程控制技术在工业控制领域便一路高歌,取得了极为广泛的应用。但是在这过去的30多年里,计算机技术、电子技术、网络通信技术以及自动控制技术的飞速发展,使得工程师们在工业应用中对于控制器的功能需求也远远超越了当初的“顺序逻辑控制”的简单期望。
来自于奥地利的贝加莱(b&r)工业自动化公司便是敏锐地捕捉到这一技术需求的变化,早在1994年便在全球个推出了基于定性实时多任务操作系统(realtime multi-tasking operation system)的可编程计算机控制器(pcc—programmablecomputer controller),时至,仍然代表了这一创新技术的发展趋势,成为新一代自控工程师的新宠。
我们知道,常规的plc大多依赖于单任务的时钟扫描或监控程序,来处理程序本身的逻辑运算指令以及外部的i/o通道的状态采集与刷新,整个应用程序采用一个循环周期,但事实上在一个控制系统中,虽然往往有一些数据量是实时性要求很高的,但也有很多大惯性的模拟量是没有太高实时要求的,如果采用同样的刷新速度其实是对资源的浪费,而且循环顺序扫描的运行机制也直接导致了系统的控制速度严重依赖于应用程序的大小,应用程序一旦复杂庞大,控制速度就必然降低。这无疑是与i/o通道高实时性控制的要求相违背的。
而贝加莱pcc系统的设计方案则完美地解决了这一问题,与常规plc相比较,pcc大的特点就在于其引入了类大型计算机的分时多任务操作系统理念,并辅以多样化的应用软件设计手段,由于分时多任务的运行机制,使得应用任务的循环周期与程序长短无关,而是由设计人员根据工艺需要自由设定,从而将应用程序的扫描周期同真正外部的控制周期区别开来,满足了真正实时控制的要求,而且这种控制周期是可以在cpu运算能力允许的前提下,按照用户的实际要求而做相应设定。
传统plc运行模式
贝加莱pcc-定性分时多任务操作系统的运行模式
基于这样的运行平台,pcc的应用程序可分为多个独立的任务模块,这样给便应用软件的开发带来了极大的便利,因为工程师可以方便地根据控制项目中各子系统的不同功能要求,如数据采集,报警,pid调节运算,通信控制等,开发相应的控制程序模块(任务),在分别编制和调试之后,可一同下载至pcc的用户程序存储器中,在多任务操作系统的调度管理下,并行协同运行,因为这些模块既相互独立运行,而数据间又保持一定的相互关联,由他们共同实现项目的控制要求。在这多个任务中,根据不同任务对实时性能的不同需求,设计人员可以指定不同的优先等级即确定的循环周期,从而实现确定的分时多任务控制。即便某个任务处于等待状态,别的任务也可继续执行。
这种多任务的运行机制,采用大型应用软件的模块化设计思想,还带来了项目开发效率上的提高,有着常规plc无法比拟的灵活性。因为多任务的思想使得各个任务模块的功能描述更趋清晰简洁,用户可以自行开发自己独有的而又同时具有通用性的独立功能模块,并将其封装以便于日后在其他应用项目中重新使用。而且各个不同的任务甚至可以由开发小组的不同成员分别编制,不同的开发人员基于共同的约定,可以灵活选用不同编程语言,这就意味着不仅在常规plc上一直为人们所熟悉的梯形图,指令表等符合iec6113-3规范的通用语言可以在pcc上继续沿用,而且用户还可采用更为高效直观的语言,比如ansic 和automationbasic,从而实现复杂的数学运算功能和过程控制算法。而且所有这些编程语言,pcc都采用“符号变量”来标识外部i/o通道及内部寄存器单元(例如用户可用motor_run来代表某开关量输出通道,button_down代表某开关量输入通道)。这样,软件开发人员毋需熟知pcc内部的硬件资源分布,而只须集中精力于项目本身的工艺要求,即可迅速编制出结构清晰功能明确的控制程序来。
pcc在硬件上的特点,还体现在它为工业现场的各种信号和应用设计了许多专用的接口模块和功能模块,如温度、张力、步进电机驱动、示波器、鼓序列发生、脉冲编码,称重、超声波信号等等。它们将各种形式的现场信号十分方便的接入以pcc为核心的数字控制系统中,用户可按需要对i/o通道进行数十点、数百点至数千点的扩展与联网。在pcc模块内部,cpu的数据总线与io总线分离,并配置有独立的i/o处理器,特有的时间处理单元(tpu)在不增加cpu负荷的前提下,高速处理无论简单或复杂的定时任务,其基准计时频率可高达6.29mhz,因此目前被广泛应用于测频测相及pwm等极高精度的时间处理场合中。而其所有数字量输入端都经过了光电耦合隔离,模拟量输入端也都经过了rc滤波处理,因此具有很好的抗干扰能力,其整体硬件平均无故障时间mtbf高达50万小时。
pcc在远程通信方面的灵活性,是区别于常规plc的另一显著标志,作为构成现场分布式控制的主要供应商之一,贝加莱pcc为此提供了十分灵活多样的解决方案。除开放式现场总线的网络方案之外,pcc还提供了多种网络协议,用户不仅可以采用贝加莱的独有网络协议,也可以方便的与其他厂家的plc或其他工控设备联网通信(如siemens,ab,modicon等),在一些特殊情况下,pcc还为用户提供了创建自定义协议的帧驱动(framedrive)工具。特别值得一提是ethernetpowerbbbb网络协议,这是2001年贝加莱公司在竞争对手还在讨论实时工业以太网概念的时候,便在全球次推出并实用化了真正意义的实时工业以太网络,这也是全球个开放的安全级(sil3)实时工业以太网。2007年初该公司又已经发布其实现了千兆级实时工业以太网ethernetpowerbbbb的消息。由于具备这样的技术优势,pcc常常能解决许多常规plc所望尘莫及的通信难题,轻松实现与各种不同产品,不同通信协议的高效互联。
pcc作为一种可编程计算机控制器,它是专为在工业环境下应用而设计的,是一种新型的定性分时多任务plc,它不但具备传统plc的所有功能,同时融合了新的it网络技术和可选的语言编程环境,具有更强大的数学运算能力、网络通信能力、抗干扰能力和控制能力,从而代表了plc今后发展的方向,具有更高的可靠性、更丰富的功能和更广泛的适应性。
s7300系列cpu可以处理符合ieee标准的32位浮点数。可以完成32位浮点数的加、减、乘、除运算,以及取值、平方、开平方、指数、对数、三角函数、反三角函数等指令。
l 基本的浮点数算术运算指令
stl 指令 | fbd符号 | 说 明
|
+r | <[if !vml]><[endif]> | 将累加器1,2中的32位浮点数相加,32位结果保存在果加器1中。 |
-r | <[if !vml]><[endif]> | 用累加器2中的32位浮点数减去累加器1中的浮点数,结果保存在累加器1中。 |
*r | <[if !vml]><[endif]> | 将累加器l,2中的32位浮点数相乘,32位乘积保存在累加器1中。 |
/r | <[if !vml]><[endif]> | 用累加器2中的32位浮点数除以累加器1中的浮点数,32位商保存在累加器1中。 |
abs | <[if !vml]><[endif]> | 对累加器l中的32位浮点数取值。 |
l 扩展的浮点数算术运算指令
stl指令 | fbd符号 | 说 明 |
sqr | <[if !vml]><[endif]> | 求累加器1中的32位浮点数的平方值。 |
sqrt | <[if !vml]><[endif]> | 求累加器1中的32位浮点数的开平方值 |
exp | <[if !vml]><[endif]> | 求累加器1中的32位浮点数以e为底的指数 |
ln | <[if !vml]><[endif]> | 求累加器1中的32位浮点数的自然对数 |
sin | <[if !vml]><[endif]> | 求累加器1中的32位浮点数的正弦值 |
cos | <[if !vml]><[endif]> | 求累加器1中的32位浮点数的余弦值 |
tan | <[if !vml]><[endif]> | 求累加器1中的32位浮点数的正切值 |
asin | <[if !vml]><[endif]> | 求累加器1中的32位浮点数的反正弦值 |
acos | <[if !vml]><[endif]> | 求累加器1中的32位浮点数的反余弦值 |
atan | <[if !vml]><[endif]> | 求累加器1中的32位浮点数的反正切值 |
指令 | 说 明 |
rnd | 将实数化整为接近的整数。 |
rnd+ | 将实数化整为大于或等于该实数的小整数 |
rnd- | 将实数化整为小于或等于该实数的大整数 |
trunc | 取实数的整数部分(截尾取整) |
因为实数的数值范围远大于32位整数,所以有的实数不能成功地转换为32位整数。如果被转换的实数格式非法或超出了32位整数的表示范围,则在累加器1中得不到有效结果,而且状态字中的ov和os被置1。
上面的指令都是将累加器1中的实数化整为32位整数,因化整的规则不同,所以在累加器1中得到的结果也不一致,如下表
执行的 指令 | 累加器l内容 | 说 明 | |
化整前 | 化整结果 | ||
rnd | +99.5 | +100 | 将实数化整为接近的整数 |
rnd+ | +99.5 | +100 | 将实数化整为大于或等于该实数的小整数 |
rnd- | +99.5 | +99 | 将实数化整为小于或等于该实数的大整数 |
trunc | +99.5 | +99 | 只取实数的整数部分(截尾取整) |
指令 | 说 明 |
= =r | 比较累加器2中的32位实数是否等于累加器l中的实数 |
<>r | 比较累加器2中的32位实数是否不等于累加器l中的实数 |
>r | 比较累加器2中的32位实数是否大于累加器1中的实数 |
<r | 比较累加器2中的32位实数是否小于累加器1中的实数 |
>=r | 比较累加器2中的32位实数是否大于等于累加器1中的数 |
<=r | 比较累加器2中的32位实数是否小于等于累加器l中的数 |
例3.5.2:
如果存储双字md 24中的实数大于1.0,则输出q 4.1为1;若小于1.0则输出q 4.2为1。
l md 24
l +1.359e+02
>r
= q 4.1 https://若(md24)>+1.359e+02,q 4.1为1,否则为0
<r
= q 4.2 https://若(md24)<+1.359e+02,q 4.2为l,否则为0
例3.5.3
这是一个限值监测程序,当数据字dbwl5的值大于l05时,输出q 4.0为1;当数据字dbwl5的值小于77时,输出q4.1为1;数值在77到105范围内时,输出q 4.0和q 4.1均为0。下面是与其对应的语句表程序:
l dbw15
l +l05
>i
= q 4.0
l +77
<i
= q 4.1