发布于 2011-06-09 16:07:35
21楼
做了一下试验用SFC47加长了扫描周期发现对于:
A I 0.0
FP M 0.0
= Q 0.0
I0.0这个扫描周期出现了一个从0到1的变化,在下个扫描周期同时检查M0.0的状态,当M0.0为0则同时输出Q0.0一个周期的脉冲信号。如果M0.0为的状态为1,则无论I0.0是否有变化,Q0.0都不会有输出。
在《S7-300 和S7-400 梯形逻辑(LAD)编程参考手册》可以查到这个指令的说明:
---( P )---(RLO 上升沿检测指令)可以检测地址从“0”到“1”的信号变化,并在操作之后显示RLO =“1”。将RLO 的当前信号状态与“边沿存储位”地址的信号状态进行比较。如果操作之前地址的信号状态为“0”,并且RLO 为“1”,则在操作之后,RLO 将为“1”(脉冲),所有其它的情况为“0”。操作之前的RLO 存储在地址中。
从中可以看出讨论这个问题不能将“边沿存储位”这个信号的状态给忽略了。