您好,欢迎访问一九零五行业门户网

读出S7-1500 CPU运行时间的四种方法

读出s7-1500 cpu的运行时间有多种方式,下面分别介绍这几种方式。
1.通过ob1的启动参数读出运行时间在非优化的ob1启动信息中带有ob1的运行时间,如图1所示。
图1.读出非优化的ob1中运行时间
将启动信息参数传递到全局变量中就可以读出cpu的上次扫描、最小、最大扫描时间,编程非常方便。
2.调用rd_sinfo函数读出运行时间
如果使用优化的ob1,启动信息简化而没有这些运行信息,如图2所示,则必须调用函数读出。
图2优化ob1的启动信息
例如在ob1中调用rd_sinfo函数读出运行时间,程序如图3所示。参数top_si为当前ob1的启动信息,数据类型为si_classic,需要手动键入,zi1为上次扫描时间,zi2_3包含最小、最大扫描时间,低字为最小扫描时间,高字为最大扫描时间,示例中分别传送到mw10和mw12中。start_up_si为暖启动ob的启动信息,示例中没有进行引用。
图3调用rd_sinfo函数
3.调用rt_info函数读出运行时间
通过函数rt_info也可以读出cpu的运行时间,示例程序如图4所示。
图4调用rt_info函数
通过模式1、2、3可以读出cpu的上次扫描、最小、最大扫描时间,在这三种模式下,参数info的数据类型为ltime,可以直接读出。也可以通过其他模式读出运行时间的百分比。
4.调用runtime指令读出运行时间
通过指令runtime可以从参数ret_val直接读出cpu的运行时间,单位为秒,mem为中间保存程序运行的存储器,两个参数类型都是lreal,除此之外还可以读出一段程序的运行时间。如图5所示。
图5 runtime指令
其它类似信息

推荐信息