目标控制器数字孪生系统的研究与设计

文章来源:铁路计算机应用,2023,32(10):36-41.

作者:许婧,杨硕,季志均

摘要:随着目标控制器(OC,Object Controller)系统在轨道交通领域的推广应用,其硬件投入较高、研发周期较长、环境搭建较为复杂的问题逐渐显现。文章根据OC系统的架构和特点,基于模块化设计,研究开发了OC数字孪生系统,利用SkyEye进行OC数字孪生系统的开发构建,对OC系统进行软硬件功能仿真,实现对OC系统的虚拟化。OC数字孪生系统已在上海地铁3号及4号线改造工程中上线试运行,运行效果良好,可有效缓解开发调试工作和测试工作形成的资源冲突问题,节省硬件资源和时间成本。

关键词:数字孪生;目标控制器;嵌入式系统;模块化设计;SkyEye

DOI:10.3969/j.issn.1005-8451.2023.10.08

目标控制器(OC,Object Controller)系统可取代传统计算机联锁系统中的继电电路和监测电路,实现对转辙机、信号机、电码化设备等轨旁设备的驱动和采集[1]。OC系统目前被集成于第二代智能安全型全电子计算机联锁系统[2]、列车自主运行系统[3]、列控联锁一体化系统[4-5]中,具有广阔的应用前景。

由于OC系统是在定制的母板上运行嵌入式软件,研发成本高、定制周期长,若其存在硬件设计问题,需要耗费较长时间进行修正。此外,OC系统具备分布式系统和二乘二取二系统的特点,配置灵活多变,负载种类繁多,为验证多种应用场景,需要搭建复杂的实验环境、投入大量的硬件资源;OC系统的研发和测试团队受限于硬件资源和实验室空间,能搭建的真实环境数量较少,开发调试工作和测试工作易形成资源冲突,导致项目进度滞后。

数字孪生技术是指通过数据的交互融合,设计虚拟模型并建立虚拟系统与真实系统的映射关系,进而“镜像”实体的技术[6-7]。数字孪生技术最早被应用于飞机的故障预测[8],目前,已广泛应用于卫星[9]、电力[10]、智慧城市[11]等多个领域。

针对OC系统面临的问题,本文研究和设计一种OC数字孪生系统,通过分析虚拟实体的运行状态,预测真实OC设备的运行结果,及时修正研发方向,从而降低研发成本、提升研发效率。

01.OC系统组成

OC系统的主要功能是根据联锁控制系统主控计算机(MCC,Master Control Computer)的驱动命令,控制室外的信号设备,并将室外设备的状态返回给MCC。OC系统采用模块化设计理念,每种控制模块完成一个独立的功能。其系统组成如图1所示。

▲图1  OC系统组成

OC系统采用二乘二取二架构。二取二是指每个控制模块内部采用双通道架构,每个通道各有1个运算单元,独立得出2个运算结果,结果一样则输出,不一样则不输出。控制模块中的某些关键电路采用双通道差异化设计,能够有效减少共因失效产生的几率。二乘二取二是指系统中相同的2个控制模块互为冗余、相互独立,即使出现了交叉故障,只要互为冗余的2个控制模块不同时失效,系统仍能保持正常功能。

1.1 安全通信模块

用于执行OC系统与MCC间的通信,通过L1安全红网和L2安全蓝网接收来自MCC的命令,根据铁路信号安全协议-I(RSSP-I,Railway Signal Safety Protocol-I)和FSFB/2(Fail Safe Field Bus second generation)协议控制GUEST模块,并且将OC系统的状态上传给MCC。同时,安全通信模块参与维护系统通信,通过L3维护网送出OC系统的维护和诊断信息,支持简单网络管理协议(SNMP,Simple Network Management Protocol)、简单文件传输协议(TFTP,Trivial File Transfer Protocol)、用户数据协议(UDP,User Datagram Protocol)、简单网络时间协议(SNTP,Simple Network Time Protocol)协议。互为冗余的安全通信模块A和B之间通过L7内网相连。

1.2 GUEST模块

GUEST模块是OC系统中负责控制各种信号设备的板卡(如状态采集板卡、道岔驱动板卡、信号机驱动板卡等),根据驱动命令控制室外的信号设备,并采集室外设备的状态。OC系统内2个相同种类的GUEST模块可互为冗余,例如:GUEST模块 Ai 与GUEST模块 Bi 两两配对使用,并通过L4电缆连接到轨道电路、转辙机、信号机、安全继电器、电码化设备、零散设备等室外设备。GUEST模块结构如图2所示。

▲图2  GUEST模块结构示意

各类GUEST模块的结构基本相同,主要由以下2部分组成。

(1)母板。其上集成了特定的硬件组件,例如采集电路、驱动电路、隔离电路、熔丝电路及与这些部件接口的部分现场可编程门阵列(FPGA,Field Programmable Gate Array);

(2)安全控制单元(VCU,Vital Control Unit)扣板。基于二取二架构的模块,其上集成了CPU_A、CPU_B、Flash存储器和随机存取存储器(RAM,Random Access Memory)。

1.3 背板

用于实现OC系统内部的连接和通信,提供电源接口、地址信息接口、配置数据接口、连接安全通信模块和各GUEST模块的控制器局域网(CAN,Controller Area Network)总线接口等。

1.4 CAN总线

每个GUEST模块具有2个独立的CAN通信接口,可以通过背板连接在2个独立冗余的CAN总线上。正常工作时,安全通信模块通过2个CAN总线(CAN_A、CAN_B)与GUEST模块通信。

02.OC数字孪生系统设计

2.1 系统架构

OC数字孪生系统架构包括分析与统计层、测试层、系统环境层、硬件仿真层等4层。各层相互独立、充分耦合,通过接口进行交互,实现物理隔离、逻辑相通,便于功能扩展和系统集成,根据不同使用场景的需求,实现多种运行模式。其系统架构如图3所示。

▲图3  OC数字孪生系统架构示意

(1)硬件仿真层可实现对OC数字孪生系统运行环境的快速构建和部署,根据应用场景的需要组成多配置项、多机测试环境。可在通用计算机中虚拟运行多片CPU及芯片外设,将要测试的嵌入式软件的二进制代码装载到不同的虚拟安全通信模块和虚拟GUEST模块中。

(2)系统环境层是整个OC数字孪生系统的核心层,可实现对真实OC系统各应用场景的全系统虚拟。系统环境层在OC数字孪生系统运行时,动态加载CPU模拟器、外设芯片构成虚拟实例,从而完成整个OC数字孪生系统的运行,包括运行操作系统和应用软件。虚拟实例可通过接口管理与其他相关测试系统进行互联,构成闭环运行环境。在系统环境层中,可根据场景需求,完成执行环境和通信协议的配置。

(3)测试层对测试用例进行管理,根据测试需要完成故障注入,并将需要运行的测试指令传输到系统环境层。

(4)在测试执行后,系统环境层将测试执行期间收集到的测试数据发送到分析统计层,在分析与统计层对故障相关数据进行故障原因分析和记录,最终由分析统计层输出测试结果。

2.2 关键模块的虚拟化

OC系统中的安全通信模块和GUEST模块均以VCU为核心处理单元,扩展不同外围功能电路。根据真实OC系统中的安全通信模块和GUEST模块的结构特点,可在OC数字孪生系统的系统环境层中搭建相应的虚拟模块。

2.2.1安全通信模块虚拟化

安全通信模块主要实现的功能如下。

(1)提供3个对外网口,实现OC系统对外的网络通信;提供1个对内网口,实现与另一个安全通信模块间的内部网络通信;

(2)对于二取二架构中的每个通道,安全通信模块的二进制代码和电子戳存储在虚拟VCU的Flash中;安全通信模块通过2个串行外设接口(SPI,Serial Peripheral Interface)通道,读取相关配置数据,并将数据存储在其他虚拟的Flash外设之中;

(3)通过2条虚拟的CAN总线与系统内的GUEST模块交互数据。

在OC数字孪生系统中,虚拟的VCU是双通道架构,每个通道以1个虚拟的MCF54418 CPU为核心处理器,双通道之间通过模拟的内部串口实现高频二取二交互通信。

2.2.2 GUEST模块虚拟化

GUEST模块的虚拟化架构与安全通信模块类似,但真实OC系统的GUEST模块中有众多继电器、自检电路、ADC数字采样和FPGA等硬件组件。系统环境层根据每类GUEST模块的构造,进行硬件功能的FPGA仿真,通过虚拟的通用输入/输出(GPIO,General Purpose Input/Output)和FPGA接口,与VCU模块进行交互,从而实现模块自检、驱动命令的执行与反馈、开关量的采集和模拟量的采集等功能,为OC数字孪生系统提供必要的自检和运行条件。

硬件仿真层根据应用场景搭建外围设备模块,对OC系统中GUEST模块的负载进行模拟,为OC数字孪生系统提供开关量、模拟量数据。

03.基于SkyEye的开发实例

SkyEye是基于可视化建模的硬件行为级仿真平台,支持用户通过拖拽的方式对硬件进行行为级别的仿真和建模。基于SkyEye搭建的嵌入式系统虚拟化运行环境,研发人员可不受物理硬件限制,随时访问目标系统,快速搭建虚拟硬件模型[12]。本文在Windows操作系统下,进行基于SkyEye平台的OC数字孪生系统的开发,完成对真实OC系统的虚拟化。

3.1 系统开发框架

OC数字孪生系统的开发框架如图4所示,由OC数字孪生系统构建、OC数字孪生运行环境和OC数字孪生配置管理工具构成。

▲图4  OC数字孪生系统开发框架示意

3.1.1 系统构建

本文通过设计通用模块和提供可配置的各类硬件外设接口,灵活构建OC数字孪生系统。构建思路如下:

(1)将通用API接口封装成核心动态库,支持其他模块的接口调用;

(2)采用模块化的设计思想,系统的处理器、内存总线、外围设备等均被设计为独立的模块;

(3)通过硬件配置脚本灵活搭建目标系统,根据硬件配置生成不同GUEST模块的面板显示,并根据程序运行情况点亮面板灯;

(4)实现二进制文件解析和加载功能。

3.1.2 运行环境

在真实OC系统中,最多包含2个安全通信模块和28个GUEST模块。与之对应的,在OC数字孪生系统中,最多虚拟30个VCU模块同时运行的状态,每个VCU包含2个CPU,并对OC系统的内部通信进行虚拟,还原真实系统的运行情况。为实现60个CPU的同时运行,本文设计了多VCU目标机集成方案:启动4个SkyEye进程,再通过时间同步工具进行统一的时钟推进,确保OC数字孪生系统的协同运行。

通过SkyEye集成MCF54418 CPU及芯片外设仿真、时间同步工具和二进制动态编译等组件,提供统一的OC数字孪生系统的部署验证。应用程序可直接在OC数字孪生系统中运行,在与真实OC系统的硬件输入条件相同、运行时间相同时,能得到与真实运行结果相同的输出。运行环境中的时间同步工具是OC数字孪生系统按时序运行的基础,主要有2个功能:

(1)实现单VCU模块内CPU_A和CPU_B的同步;

(2)实现模块之间的同步。

3.1.3 配置管理工具

配置管理工具基于运行环境,提供系统配置管理功能,包括虚拟硬件的设备管理、OC节点管理、节点间网络通信状态管理、日志管理、软件配置文件的加载、系统运行时间与数据同步的设置等。

3.2 VCU建模示例

通过SkyEye对VCU进行建模,虚拟VCU内部设计和多VCU间的通信,如图5所示。VCU_0模块描述VCU内部对双通道的规划,以core、ram、spi、uart、flash、net、gpio、can外设为基础搭建系统。VCU_1描述多个VCU之间通过can_linker的方式进行通信的机制。

▲图5  SkyEye环境下的VCU建模示意

04.试运行情况

本文设计的OC数字孪生系统是真实OC系统设备的数字映射,已于2023年2月,在上海地铁3号及4号线改造工程中上线试运行。研发人员使用OC数字孪生系统在真实OC硬件未制造时提前验证OC系统的硬件设计、软件功能和系统性能,在发现设计缺陷后及时优化,减少了产品研发的迭代次数,将研发时间从半年缩短至2个月左右,节约了研发成本。在排查OC系统的故障时,售后人员利用OC数字孪生系统还原了现场的复杂场景,快速复现了现场问题,及时定位了故障原因,减少了售后工作的人力消耗。

05.结束语

本文基于OC系统架构设计了OC数字孪生系统,介绍了关键模块的虚拟化方式,并基于SkyEye进行开发。该系统已在上海地铁3号及4号线改造工程中上线试运行,运行效果良好,可有效缓解开发调试工作和测试工作形成的资源冲突,缩短研发周期,同时,降低OC系统的维护成本,具有推广价值。

参考文献

[1]郭 阳. 全电子执行模块在信号计算机联锁工程设计中的应用[J]. 铁道标准设计,2010(4):116-118. 

[2]陈 亮. 全电子计算机联锁的发展与规模化应用[J]. 科技视界,2020(15):9-11. 

[3]欧阳玲萍,熊坤鹏,朱程辉,等. 城市轨道交通TACS系统测试探讨[J]. 电子技术与软件工程,2023(3):143-147.

[4]贾春肖,张宏韬,齐志华. 我国铁路列控联锁系统发展趋势研究[J]. 中国铁路,2020(2):1-5. 

[5]梁志国,卢佩玲,付 伟. 铁路列控联锁一体化系统研究[J]. 铁道通信信号,2019,55(S1):98-102. 

[6]陶 飞,刘蔚然,刘检华,等. 数字孪生及其应用探索[J]. 计算机集成制造系统,2018,24(1):1-18. 

[7]Boschert S, Rosen R. Digital twin—the simulation aspect[M]//Hehenberger P, Bradley D. Mechatronic Futures. Cham: Springer, 2016: 59-74.

[8]Grieves M, Vickers J. Digital Twin: Mitigating Unpredictable, Undesirable Emergent Behavior in Complex Systems[M]//Kahlen F J, Flumerfelt S, Alves A. Transdisciplinary Perspectives on Complex Systems. Cham: Springer, 2017: 85-113.

[9]刘蔚然,陶 飞,程江峰,等. 数字孪生卫星:概念、关键技术及应用[J]. 计算机集成制造系统,2020,26(3):565-588. 

[10]刘亚东,陈 思,丛子涵,等. 电力装备行业数字孪生关键技术与应用展望[J]. 高电压技术,2021,47(5):1539-1554. 

[11]王成山,董 博,于 浩,等. 智慧城市综合能源系统数字孪生技术及应用[J]. 中国电机工程学报,2021,41(5):1597-1608.

[12]杨兴伟. 基于SkyEye的SMDK2410硬件仿真平台设计[J]. 可编程控制器与工厂自动化,2009(10):87-90,105. 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/282867.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

VMware 15 中 Ubuntu与windows 10共享文件夹设置

wmware 15.5.7中安装ubuntu 22.04 物理机为windows 10 1.选中ubuntu中想要共享的文件夹右击,点属性 2.在Local network share中勾选share this folder,第一次会提示你安装samba,安装即可 3.window10的资源管理器中使用 虚拟机计算机名即可…

API调试管理工具Postman下载及操作介绍

1.下载安装postman地址:https://www.getpostman.com/downloads/ 2.创建项目 3.创建请求API 然后点击save保存api 4.用一个变量保存主域名,方便后续操作 就类似下面的baseurl 5.创建新环境 6.添加变量(如添加本地测试环境url——ba…

什么是单点登录?

单点登录(Single Sign On,简称 SSO)简单来说就是用户只需在一处登录,不用在其他多系统环境下重复登录。用户的一次登录就能得到其他所有系统的信任。 为什么需要单点登录 单点登录在大型网站应用频繁,比如阿里旗下有淘…

Spring常用设计模式-实战篇之单例模式

实现案例,饿汉式 Double-Check机制 synchronized锁 /*** 以饿汉式为例* 使用Double-Check保证线程安全*/ public class Singleton {// 使用volatile保证多线程同一属性的可见性和指令重排序private static volatile Singleton instance;public static Singleton …

Git学习笔记之标签

Git 可以给仓库历史中的某一个提交打上标签,以示重要。 比较有代表性的 是人们会使用这个功能来标记发布结点( v1.0 、 v2.0 等等)。 1、列出标签 列出已有的标签: git tag按照通配符列出标签需要 -l 或 --list 选项。如果你只想要完整的标…

Codeforces Round #936 (Div. 2)D(拆位贪心)

思路:首先需要知道:如果某一位的数量为奇数,那么无论怎么分都会最终变成1. 整个问题转化成能有多少个隔断选取位置 先将所有数都拆位来看,首先观察那些比x的最高位还要高的位: 如果这些位的数量为奇数, 那么必然会使其位是1,不…

网络安全笔记-day6,NTFS安全权限

文章目录 NTFS安全权限常用文件系统文件安全权限打开文件安全属性修改文件安全权限1.取消父项继承权限2.添加用户访问权限3.修改用户权限4.验证文件权限5.总结权限 强制继承父项权限文件复制移动权限影响跨分区同分区 总结1.权限累加2.管理员最高权限2.管理员最高权限 NTFS安全…

使用npm创建一个全局的cli命令,就像vue-cli一样

我们用过vue-cli等工具包,全局安装之后,我们可以直接使用vue create等命令,实际上能够这样使用的原因,就是使用了package.json里面的bin字段注册命令。接下来就以一个脚本文件为例子为大家演示一下bin是如何发挥作用的。 创建项目…

vue.js+element-ui的基础表单

遇到原生的html小型单页应用时,是脱离了vue框架,而我们又想使用vue的语法和element的组件加快我们的开发速度,这个时候就需要引用他们的js了。技术栈即htmlvue.jselement-ui。而使用它们的方法也很简单,引入对应的js和css文件即可…

MySQL定时任务Event详解

文章目录 基本概念一、Event事件使用权限二、开启\关闭Event事件三、Event事件定义格式四、事件调度使用案例4.1 准备工作4.2 创建单次定时执行事件4.2.1 创建指定时间单次执行事件任务4.2.2 创建延迟时间单次执行事件任务4.2.3 创建单次执行事件任务[多SQ执行] 4.3 创建循环定…

数据仓库的数据处理架构Lambda和Kappa

1.数据仓库 数据仓库(Data Warehouse),简写DW。顾名思义,数据仓库是一个很大的数据存储集合,为企业分析性报告和决策支持而创建,是对多元业务数据的筛选与整合,具备一定的BI能力,主要用于企业的数据分析、数据挖掘、数据报表等方向,指导业务流程改进、监视时间、成本、…

从0到1实现RPC | 03 重载方法和参数类型转换

一、存在的问题 1.重载方法在当前的实现中还不支持,调用了会报错。 2.类型转换也还存在问题。 假设定义的接口如下,参数是float类型。 在Provider端接受到的是一个Double类型,这是因为web应用接收的请求后处理的类型。 在反射调用的时候就会…

前言:为什么C语言最适合编程入门?

前言:为什么C语言最适合编程入门? C语言被认为最适合编程入门的原因主要有以下几点: 基础且强大:C语言是一种基础且强大的编程语言。它提供了对底层硬件的直接访问,让初学者能够更好地理解计算机的工作原理&#xff0…

从零开始学Spring Boot系列-集成Kafka

Kafka简介 Apache Kafka是一个开源的分布式流处理平台,由LinkedIn公司开发和维护,后来捐赠给了Apache软件基金会。Kafka主要用于构建实时数据管道和流应用。它类似于一个分布式、高吞吐量的发布-订阅消息系统,可以处理消费者网站的所有动作流…

基于python+vue的O2O生鲜食品订购flask-django-nodejs-php

近年来互联网络的迅猛发展和电子终端设备的普及,赋予了各行业充足的发展空间。微信小程序的O2O生鲜食品订购相比于传统信息技术,时效性是它最大的特色,已经在电子娱乐、经济等中发挥着举足轻重的作用。短时间内迅速扩大了线上管理系统的规模。…

了解云原生

1、云原生学习路线 学习云原生(Cloud Native)技术涉及了解和掌握一系列的概念、技术和工具。云原生是一种构建和运行应用程序的方法,旨在充分利用云计算的灵活性、可伸缩性和弹性。以下是一个可以参考的学习路线: 了解云原生基础 学习云计算的基本概念&…

此站点正在尝试打开 ,chrome/edge 允许http网站打开url schema

正常https链接会有首次允许选项 但http没有,每次都会弹出,非常烦人。 Chrome / Edge 配置 地址栏输入 chrome://flags/搜索Insecure origins treated as secure, 配置允许网站,需要协议和端口再次跳转会显示始终允许选项

puppeteer使用示例云顶之弈官网

自己从0到1开发的,微信小程序【云顶宝藏】求求点个5星好评吧! 需求:拿到所有英雄的信息 思路:点击每个英雄,进入英雄详情页,拿信息,并返回,继续下一个英雄** 最终效果 本地环境 win…

docker进阶篇,docker集群介绍

docker swarm 官网:https://docs.docker.com/engine/swarm/how-swarm-mode-works/nodes/ 什么是 docker swarm docker swarm 是 docker 官方提供的容器编排和集群管理工具。它允许用户将多个 docker 主机组成一个虚拟的 docker 集群,以便更高效地管理…

云计算系统等保测评对象和指标选取

1、云计算服务模式与控制范围关系 参考GBT22239-2019《基本要求》附录D 云计算应用场景说明。简要理解下图,主要是云计算系统安全保护责任分担原则和云服务模式适用性原则,指导后续的测评对象和指标选取。 2、测评对象选择 测评对象 IaaS模式 PaaS模式…