eclipse中没有runtime environments_在 S7-1200/S7-1500 中,如何测量一个程序完整的循环时间?...

使用 '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") 中。

4b1c1b9a25060a52eb80c70f5b6656e4.png

图 01

例 2:在 S7-1500 中使用 SCL 语言测量运行时间

  • 第一次调用 "RUNTIME" 指令设置时间测量的起始点并且存储在 "Memory" 中,并且作为第二次调用的参考点。
  • 然后调用程序块 "Module_FC"。
  • 当程序块执行完后,"RUNTIME" 指令被再次调用,此次调用计算出程序块 "Module_FC" 的运行时间并将其作为结果输出到 "RT_Measure" 中。
1db02f85a7b068eb4aef741bfa18ffed.png

图 02

关于此方法的详细描述和示例,参考如下 STEP 7 (TIA 博途) 的在线帮助:

  • 针对 SCL 语言的 "RUNTIME:测量程序运行时间 (S7-1200, S7-1500)"
  • 针对 STL 语言的 "RUNTIME:测量程序运行时间 (S7-1500)"

例 3:使用主程序 [OB1] 的临时变量测量循环时间

对于 S7-1500 的“程序循环 OB ”,可以将其从“优化的块访问”改成“标准兼容模式”。然后与在 STEP 7 V5.x 中类似,通过访问临时变量来得到测量出的循环时间。

  1. 右键单击主程序 [OB1] ,在弹出的菜单中选择“属性...”。
  2. 进入“属性”标签并且取消“优化的块访问”属性(去掉钩选)。
  3. 点击确定,然后在下一消息框中再点击确定。
7f2d29ffc3a541a67315529e39cee273.png

图 03

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

777e9acac6bec2bb692c94e7e58daef8.png

图 04

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

1、输出前一个循环时间:#PREV_CYCLE

7d3ff9261113cae4a0b6463a6fdae8b7.png

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

2806a00c7a8623db9168e7b0d1ac918e.png

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

19f10367c67d712bd7034db28268f754.png

注意

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
# Byte-compiled / optimized / DLL files __pycache__/ *.py[cod] *$py.class # C extensions *.so # Distribution / packaging .Python build/ develop-eggs/ dist/ downloads/ eggs/ .eggs/ lib/ lib64/ parts/ sdist/ var/ wheels/ pip-wheel-metadata/ share/python-wheels/ *.egg-info/ .installed.cfg *.egg MANIFEST # PyInstaller # Usually these files are written by a python script from a template # before PyInstaller builds the exe, so as to inject date/other infos into it. *.manifest *.spec # Installer logs pip-log.txt pip-delete-this-directory.txt # Unit test / coverage reports htmlcov/ .tox/ .nox/ .coverage .coverage.* .cache nosetests.xml coverage.xml *.cover *.py,cover .hypothesis/ .pytest_cache/ # Translations *.mo *.pot # Django stuff: *.log local_settings.py db.sqlite3 db.sqlite3-journal # Flask stuff: instance/ .webassets-cache # Scrapy stuff: .scrapy # Sphinx documentation docs/_build/ # PyBuilder target/ # Jupyter Notebook .ipynb_checkpoints # IPython profile_default/ ipython_config.py # pyenv .python-version # pipenv # According to pypa/pipenv#598, it is recommended to include Pipfile.lock in version control. # However, in case of collaboration, if having platform-specific dependencies or dependencies # having no cross-platform support, pipenv may install dependencies that don't work, or not # install all needed dependencies. #Pipfile.lock # PEP 582; used by e.g. github.com/David-OConnor/pyflow __pypackages__/ # Celery stuff celerybeat-schedule celerybeat.pid # SageMath parsed files *.sage.py # Environments .env .venv env/ venv/ ENV/ env.bak/ venv.bak/ # Spyder project settings .spyderproject .spyproject # Rope project settings .ropeproject # mkdocs documentation /site # mypy .mypy_cache/ .dmypy.json dmypy.json # Pyre type checker .pyre/
06-02

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值