使用 'RUNTIME' 指令测量运行时间 使用 'RUNTIME' 指令可以测量整个程序、单个块或者命令序列的运行时间。该指令在 SCL (S7-1200/S7-1500) 语言和 STL (S7-1500) 语言中调用。下面的例子展示了如何测量一个程序块的运行时间。 ......
描述
使用 "RUNTIME" 指令测量运行时间
使用 "RUNTIME" 指令可以测量整个程序、单个块或者命令序列的运行时间。该指令在 SCL (S7-1200/S7-1500) 语言和 STL (S7-1500) 语言中调用。下面的例子展示了如何测量一个程序块的运行时间。
例 1:在 S7-1500 中使用 STL 语言测量运行时间
第一次调用指令(调用 RUNTIME)时设置时间测量的起始点。这个起始点信息缓存在 DB 数据块的 "DB1".Mem 中,并作为第二次调用此命令的参考点。执行完 "TimeDelay" [FC2] 功能后,再次执行 "RUNTIME" 指令,然后计算出了功能的运行时间。结果存储在 DB 变量的 "DB1".Res (输出 "RET_VAL") 中。

图 01
例 2:在 S7-1500 中使用 SCL 语言测量运行时间
- 第一次调用 "RUNTIME" 指令设置时间测量的起始点并且存储在 "Memory" 中,并且作为第二次调用的参考点。
- 然后调用程序块 "Module_FC"。
- 当程序块执行完后,"RUNTIME" 指令被再次调用,此次调用计算出程序块 "Module_FC" 的运行时间并将其作为结果输出到 "RT_Measure" 中。

图 02
关于此方法的详细描述和示例,参考如下 STEP 7 (TIA 博途) 的在线帮助:
- 针对 SCL 语言的 "RUNTIME:测量程序运行时间 (S7-1200, S7-1500)"
- 针对 STL 语言的 "RUNTIME:测量程序运行时间 (S7-1500)"
例 3:使用主程序 [OB1] 的临时变量测量循环时间
对于 S7-1500 的“程序循环 OB ”,可以将其从“优化的块访问”改成“标准兼容模式”。然后与在 STEP 7 V5.x 中类似,通过访问临时变量来得到测量出的循环时间。
- 右键单击主程序 [OB1] ,在弹出的菜单中选择“属性...”。
- 进入“属性”标签并且取消“优化的块访问”属性(去掉钩选)。
- 点击确定,然后在下一消息框中再点击确定。

图 03
现在,就像在 STEP 7 V5.x 中一样,可以使用临时变量得到系统信息,这些信息包括这个块的进入系统时的起始时间数据、故障原因和故障点。可以在块中评估这些数据。现在可以通过主程序 [OB1] 的临时变量确定循环时间。

图 04
改变块的访问方式后,这些参数已经被保存在声明的临时变量里了。这些 OB 块的临时变量名称都可以被修改,但是其内容不会改变。下面给出了测量循环时间的编程例子。
1、输出前一个循环时间:#PREV_CYCLE

2、输出最小循环时间:#MIN_CYCLE

3、输出最长循环时间:#MAX_CYCLE

注意
如果没有修改 S7-1500 的块访问方式(图. 03),或者使用的是 S7-1200,那么上述方法是无法实现的。