EPICS database练习

2024-05-13 11:12
文章标签 练习 database epics

本文主要是介绍EPICS database练习,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

给定一个以下的数据库:

# 指定Limit的上限,初始为10,可以通过通道访问进行设置,上限为100
record(ao, "$(P)Limit")
{
field(DRVH, "100")
field(DOL, "10")
field(PINI, "YES")
}# 一个从0到'Limit'的渐变,这个Limit可以通过一个单独的记录进行配置
# 此记录1秒钟运行一次,每次运行时将自身值和Limit值进行比较,如果小于,则自增1,否则设为0
record(calc, "$(P)Ramp")
{
field(SCAN, "1 second")
field(INPA, "$(P)Ramp")
field(INPB, "$(P)Limit")
field(CALC, "A<B ? A+1 : 0")
}

根据以下要求对其进行扩展:

1、添加一个"$(P)Step"记录并且在CALC中使用它,使得渐变中步长增量能够在0.1和5之间。

2、为所有三个记录创建一个显示窗口。

3、让"$(P)Ramp"显示"a.u."的单位,并且使得它在十进制点后显示2位数字。

4、添加一个小组件到显示窗口,使得能够控制这个逻辑过程用什么速率。

5、配置"$(P)Ramp"在其值大于8时产生一个警报。

6、配置"$(P)Ramp"仅在其值变化2或更多时才发送值到一个存档程序。

7、添加一个模拟输出记录,当运行时,重置"$(P)Limit"为10。添加一个触发这个重置的按钮到显示窗口。

数据库设计如下:

$(P)Step记录用作输出,范围为0.1~5,其默认输出为1;calc通过INPC读取$(P)Step的值,并且存入C中并作为计算中使用的自增步长。

$(P)Reset记录运行时,将其值通过OUT字段写入到$(P)Step记录中。

$(P)Ramp记录字段设置如下:

  • PREC=2:小数点后取2位。
  • EGU=a.u.:设置记录的显示单位。
  • HIGH=8:当记录值超过8时,触发HSV设置的MINOR警报。
  • ADEL=2:变化超过2时,发送给存档程序。

文本数据库:

record(ao, "$(P)Limit") {field(SCAN, "Passive")field(PINI, "YES")field(DOL, "10")field(DRVH, "100")field(DRVL, "0")
}record(calc, "$(P)Ramp") {field(SCAN, "1 second")field(CALC, "A<B ? A+C : 0")field(INPA, "$(P)Ramp")field(INPB, "$(P)Limit")field(INPC, "$(P)Step")field(EGU, "a.u.")field(PREC, "2")field(HIGH, "8")field(HSV, "MINOR")field(ADEL, "2")
}record(ao, "$(P)Step") {field(SCAN, "Passive")field(PINI, "YES")field(DOL, "1")field(DRVH, "5")field(DRVL, "0.1")
}record(ao, "$(P)Reset") {field(SCAN, "Passive")field(PINI, "YES")field(DTYP, "Soft Channel")field(OUT, "$(P)Limit PP")field(DOL, "10")
}

测试:

运行数据库:

root@orangepi5:/usr/local/EPICS/program/softdb# softIoc -m P=Test: -d ramp_with_limit.db
Starting iocInit
############################################################################
## EPICS R7.0.7
## Rev. 2023-05-18T10:40+0800
## Rev. Date build date/time:
############################################################################
iocRun: All initialization complete
epics> dbl
Test:Limit
Test:Step
Test:Reset
Test:Ramp

用CSS创建显示窗口:

  • Limit输入框用于设置Test:Limit记录。
  • Step输入框用于设置Test:Step记录,设置范围0.1~5,用作Ramp记录渐变的步长。
  • Ramp显示文本框用于显示Test:Ramp记录。 
  • Reset按钮用于设置Test:Limit记录为10。

二进制记录

1)创建一个值为"Normal"和"Doubled"的BO记录,并将其添加到显示窗口。

2)在$(P)Ramp中使用来加倍有效的步长大小。

3)配置这个BO使其在设置成"Doubled"时,有效步长翻倍,在5秒钟后,它将恢复成"Normal"。

设计数据库如下:

添加的Bo记录名为$(P)Accel

文本数据库为:

record(ao, "$(P)Limit") {field(SCAN, "Passive")field(PINI, "YES")field(DOL, "10")field(DRVH, "100")field(DRVL, "0")
}record(calc, "$(P)Ramp") {field(SCAN, "1 second")field(CALC, "A<B ? A+C*(D? 2 : 1) : 0")field(INPA, "$(P)Ramp")field(INPB, "$(P)Limit")field(INPC, "$(P)Step")field(INPD, "$(P)Accel")field(EGU, "a.u.")field(PREC, "2")field(HIGH, "8")field(HSV, "MINOR")field(ADEL, "2")
}record(ao, "$(P)Step") {field(SCAN, "Passive")field(PINI, "YES")field(DOL, "1")field(DRVH, "5")field(DRVL, "0.1")
}record(ao, "$(P)Reset") {field(SCAN, "Passive")field(PINI, "YES")field(DTYP, "Soft Channel")field(OUT, "$(P)Limit PP")field(DOL, "10")
}record(bo, "$(P)Accel") {field(SCAN, "Passive")field(PINI, "YES")field(DTYP, "Soft Channel")field(OMSL, "supervisory")field(HIGH, "5")field(ZNAM, "Normal")field(ONAM, "Doubled")
}

加载数据库进行测试:

root@orangepi5:/usr/local/EPICS/program/softdb# softIoc -m P=Test: -d ramp_with_limit2.db
Starting iocInit
############################################################################
## EPICS R7.0.7
## Rev. 2023-05-18T10:40+0800
## Rev. Date build date/time:
############################################################################
iocRun: All initialization complete
epics> dbl
Test:Limit
Test:Step
Test:Reset
Test:Accel
Test:Ramp

CSS显示界面修改如下:

测试如下:

当按下Double时,渐变的步长在Step执行步长基础上翻倍,在点击Double的5秒钟后,恢复成Normal,并且步长变为Step指定的步长。

这篇关于EPICS database练习的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/985536

相关文章

MySQL的JDBC编程详解

《MySQL的JDBC编程详解》:本文主要介绍MySQL的JDBC编程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言一、前置知识1. 引入依赖2. 认识 url二、JDBC 操作流程1. JDBC 的写操作2. JDBC 的读操作总结前言本文介绍了mysq

java.sql.SQLTransientConnectionException连接超时异常原因及解决方案

《java.sql.SQLTransientConnectionException连接超时异常原因及解决方案》:本文主要介绍java.sql.SQLTransientConnectionExcep... 目录一、引言二、异常信息分析三、可能的原因3.1 连接池配置不合理3.2 数据库负载过高3.3 连接泄漏

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

MySQL中On duplicate key update的实现示例

《MySQL中Onduplicatekeyupdate的实现示例》ONDUPLICATEKEYUPDATE是一种MySQL的语法,它在插入新数据时,如果遇到唯一键冲突,则会执行更新操作,而不是抛... 目录1/ ON DUPLICATE KEY UPDATE的简介2/ ON DUPLICATE KEY UP

MySQL分库分表的实践示例

《MySQL分库分表的实践示例》MySQL分库分表适用于数据量大或并发压力高的场景,核心技术包括水平/垂直分片和分库,需应对分布式事务、跨库查询等挑战,通过中间件和解决方案实现,最佳实践为合理策略、备... 目录一、分库分表的触发条件1.1 数据量阈值1.2 并发压力二、分库分表的核心技术模块2.1 水平分

Python与MySQL实现数据库实时同步的详细步骤

《Python与MySQL实现数据库实时同步的详细步骤》在日常开发中,数据同步是一项常见的需求,本篇文章将使用Python和MySQL来实现数据库实时同步,我们将围绕数据变更捕获、数据处理和数据写入这... 目录前言摘要概述:数据同步方案1. 基本思路2. mysql Binlog 简介实现步骤与代码示例1

使用shardingsphere实现mysql数据库分片方式

《使用shardingsphere实现mysql数据库分片方式》本文介绍如何使用ShardingSphere-JDBC在SpringBoot中实现MySQL水平分库,涵盖分片策略、路由算法及零侵入配置... 目录一、ShardingSphere 简介1.1 对比1.2 核心概念1.3 Sharding-Sp

MySQL 表空却 ibd 文件过大的问题及解决方法

《MySQL表空却ibd文件过大的问题及解决方法》本文给大家介绍MySQL表空却ibd文件过大的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录一、问题背景:表空却 “吃满” 磁盘的怪事二、问题复现:一步步编程还原异常场景1. 准备测试源表与数据

Mac电脑如何通过 IntelliJ IDEA 远程连接 MySQL

《Mac电脑如何通过IntelliJIDEA远程连接MySQL》本文详解Mac通过IntelliJIDEA远程连接MySQL的步骤,本文通过图文并茂的形式给大家介绍的非常详细,感兴趣的朋友跟... 目录MAC电脑通过 IntelliJ IDEA 远程连接 mysql 的详细教程一、前缀条件确认二、打开 ID

MySQL的配置文件详解及实例代码

《MySQL的配置文件详解及实例代码》MySQL的配置文件是服务器运行的重要组成部分,用于设置服务器操作的各种参数,下面:本文主要介绍MySQL配置文件的相关资料,文中通过代码介绍的非常详细,需要... 目录前言一、配置文件结构1.[mysqld]2.[client]3.[mysql]4.[mysqldum