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查询JSON数组字段包含特定字符串的方法

《MySQL查询JSON数组字段包含特定字符串的方法》在MySQL数据库中,当某个字段存储的是JSON数组,需要查询数组中包含特定字符串的记录时传统的LIKE语句无法直接使用,下面小编就为大家介绍两种... 目录问题背景解决方案对比1. 精确匹配方案(推荐)2. 模糊匹配方案参数化查询示例使用场景建议性能优

mysql表操作与查询功能详解

《mysql表操作与查询功能详解》本文系统讲解MySQL表操作与查询,涵盖创建、修改、复制表语法,基本查询结构及WHERE、GROUPBY等子句,本文结合实例代码给大家介绍的非常详细,感兴趣的朋友跟随... 目录01.表的操作1.1表操作概览1.2创建表1.3修改表1.4复制表02.基本查询操作2.1 SE

MySQL中的锁机制详解之全局锁,表级锁,行级锁

《MySQL中的锁机制详解之全局锁,表级锁,行级锁》MySQL锁机制通过全局、表级、行级锁控制并发,保障数据一致性与隔离性,全局锁适用于全库备份,表级锁适合读多写少场景,行级锁(InnoDB)实现高并... 目录一、锁机制基础:从并发问题到锁分类1.1 并发访问的三大问题1.2 锁的核心作用1.3 锁粒度分

MySQL数据库中ENUM的用法是什么详解

《MySQL数据库中ENUM的用法是什么详解》ENUM是一个字符串对象,用于指定一组预定义的值,并可在创建表时使用,下面:本文主要介绍MySQL数据库中ENUM的用法是什么的相关资料,文中通过代码... 目录mysql 中 ENUM 的用法一、ENUM 的定义与语法二、ENUM 的特点三、ENUM 的用法1

MySQL count()聚合函数详解

《MySQLcount()聚合函数详解》MySQL中的COUNT()函数,它是SQL中最常用的聚合函数之一,用于计算表中符合特定条件的行数,本文给大家介绍MySQLcount()聚合函数,感兴趣的朋... 目录核心功能语法形式重要特性与行为如何选择使用哪种形式?总结深入剖析一下 mysql 中的 COUNT

mysql中的服务器架构详解

《mysql中的服务器架构详解》:本文主要介绍mysql中的服务器架构,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、mysql服务器架构解释3、总结1、背景简单理解一下mysqphpl的服务器架构。2、mysjsql服务器架构解释mysql的架

MySQL之InnoDB存储引擎中的索引用法及说明

《MySQL之InnoDB存储引擎中的索引用法及说明》:本文主要介绍MySQL之InnoDB存储引擎中的索引用法及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录1、背景2、准备3、正篇【1】存储用户记录的数据页【2】存储目录项记录的数据页【3】聚簇索引【4】二

mysql中的数据目录用法及说明

《mysql中的数据目录用法及说明》:本文主要介绍mysql中的数据目录用法及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、版本3、数据目录4、总结1、背景安装mysql之后,在安装目录下会有一个data目录,我们创建的数据库、创建的表、插入的

MySQL中的InnoDB单表访问过程

《MySQL中的InnoDB单表访问过程》:本文主要介绍MySQL中的InnoDB单表访问过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、环境3、访问类型【1】const【2】ref【3】ref_or_null【4】range【5】index【6】

MySQL 中 ROW_NUMBER() 函数最佳实践

《MySQL中ROW_NUMBER()函数最佳实践》MySQL中ROW_NUMBER()函数,作为窗口函数为每行分配唯一连续序号,区别于RANK()和DENSE_RANK(),特别适合分页、去重... 目录mysql 中 ROW_NUMBER() 函数详解一、基础语法二、核心特点三、典型应用场景1. 数据分