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

文章来源:铁路计算机应用,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. 

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

基于SSM的手机商城管理系统+数据库+论文+免费远程调试

项目介绍: 基于SSM的手机商城管理系统。Javaee项目,采用M(model)V(view)C(controller)三层体系结构,通过Spring SpringMvc Mybatis JspBootstrapLayui来实现。MySQL数据库作为系统…

【vue3.0】实现导出的PDF文件内容是红头文件格式

效果图: 编写文件里面的主要内容 <main><div id"report-box"><p>线索描述</p><p class"label"><span>线索发现时间:</span> <span>{{ detailInfoVal?.problem.createdDate }}</span></p><…

Springboot+vue的四川美食分享网站+数据库+报告+免费远程调试

项目介绍: Springbootvue的四川美食分享网站。Javaee项目&#xff0c;springboot vue前后端分离项目 本文设计了一个基于Springbootvue的前后端分离的四川美食分享网站&#xff0c;采用M&#xff08;model&#xff09;V&#xff08;view&#xff09;C&#xff08;controller&am…

WORD某一段格式调整,其他段落也调整

在编辑WORD文字格式时&#xff0c;有时候会出现WORD某一段格式调整&#xff0c;其他段落的格式直接就乱了&#xff0c;该如何修复&#xff1f; 答&#xff1a;问题的根源在于格式的自动更新&#xff0c;把自动更新前面的勾选框取消即可。

同步服务器操作系统公网仓库到本地02--搭建http内网仓库源 _ 麒麟KOS _ 统信UOS _ 中科方德 NFSCNS

原文链接&#xff1a;同步服务器操作系统公网仓库到本地02 —搭建http内网仓库源| 麒麟KOS | 统信UOS | 中科方德 NFSCNS Hello&#xff0c;大家好啊&#xff01;继之前我们讨论了如何同步服务器公网仓库到本地服务器之后&#xff0c;今天我们将进入这个系列的第二篇文章——通…

编程出现bug?怎么用Python打印异常

在 Python 编程中&#xff0c;异常是指程序执行过程中出现的错误或异常情况。当程序遇到异常时&#xff0c;为了更好地调试和定位问题&#xff0c;我们需要打印异常信息。本文将详细介绍如何在 Python 中打印异常&#xff0c;并提供一些示例和注意事项。 一、try-except 语句捕…

Ubuntu 安装 Carla仿真环境

1、系统要求 Ubuntu 16.04/18.04/20.04 CARLA 为 16.04 之前的 Ubuntu 版本提供支持。然而&#xff0c;Unreal Engine需要合适的编译器才能正常工作。 CARLA 服务器至少需要 6 GB GPU&#xff0c;但建议使用 8 GB。 2、安装NIVDIA驱动 BISO设置 开机F12&#xff0c;进入BIOS…

如何让电脑定时开机?这个方法你一定要学会

前言 前段时间小白在上班的时候&#xff0c;个人使用一台台式机和一台笔记本电脑。台式机并不是经常使用&#xff0c;但整个公司的数据中心是建立在小白所使用的那台台式机上。 如果台式机没有开机&#xff0c;同事们就没办法访问数据中心获取自己想要的资料。领导也没办法链…

python的OA公文发文管理系统flask-django-php-nodejs

采用结构化的分析设计&#xff0c;该方法要求结合一定的图表&#xff0c;在模块化的基础上进行系统的开发工作。在设计中采用“自下而上”的思想&#xff0c;在OA公文发文管理系统实现了用户、公文分类、公文信息、待办提醒等的功能性。系统根据现有的管理模块进行开发和扩展&a…

【python】python3基础

文章目录 一、安装pycharm 二、输入输出输出 print()文件输出&#xff1a;格式化输出&#xff1a; 输入input注释 三、编码规范四、变量保留字变量 五、数据类型数字类型整数浮点数复数 字符串类型布尔类型序列结构序列属性列表list &#xff0c;有序多维列表列表推导式 元组tu…

python爬虫使用代理ip的好处是什么?

近年来&#xff0c;随着信息时代的不断发展&#xff0c;网络数据的获取和分析变得愈发重要。而Python作为一种强大的编程语言&#xff0c;其爬虫技术在数据采集领域得到了广泛应用。然而&#xff0c;在使用Python爬虫时&#xff0c;为何要考虑使用代理服务器呢?这和python爬虫…

HarmonyOS实战开发-编写一个分布式邮件系统

概述 本篇Codelab是基于TS扩展的声明式开发范式编程语言编写的一个分布式邮件系统&#xff0c;可以由一台设备拉起另一台设备&#xff0c;每次改动邮件内容&#xff0c;都会同步更新两台设备的信息。效果图如下&#xff1a; 说明&#xff1a; 本示例涉及使用系统接口&#xff…

Python 基于 OpenCV 视觉图像处理实战 之 OpenCV 简单实战案例 之五 简单局部/整体马赛克效果

Python 基于 OpenCV 视觉图像处理实战 之 OpenCV 简单实战案例 之五 简单局部/整体马赛克效果 目录 Python 基于 OpenCV 视觉图像处理实战 之 OpenCV 简单实战案例 之五 简单局部/整体马赛克效果 一、简单介绍 二、简单局部/整体马赛克效果实现原理 三、简单局部/整体马赛克…

Maven发布开源框架到远程仓库

1.背景 当你写了一个自我感觉良好的开源工具希望给他人分享&#xff0c;如果只是在github等网站进行公布之外&#xff0c;用户使用起来还不是很方便&#xff0c;特别是当你提供是特定领域的基础工具。你还可以把它部署到中央仓库&#xff0c;这样别人使用就会方便很多。接下来…

Csharp学习Linq

Linq的学习 这里继续使用之前文章创建的学生类&#xff0c;首先简单介绍一下linq的使用。 Student.cs public class Student{public int Id { get; set; }public int ClassId { get; set; }public string Name { get; set; }public int Age { get; set; }public string Descr…

欧科云链:2024将聚焦发展与安全,用技术助力链上数据安全和合规

近期&#xff0c;OpenAI和Web3.0两大新技术发展势头迅猛。OpenAI 再次引领AI领域的新浪潮&#xff0c;推出了创新的文本转视频模型——Sora&#xff0c;Sora 可以创建长达60 秒的视频&#xff0c;包含高度详细的场景、複杂的摄像机运动以及情感丰富角色&#xff0c;再次将AI 的…

网络基础「HTTP」

&#x1f52d;个人主页&#xff1a; 北 海 &#x1f6dc;所属专栏&#xff1a; Linux学习之旅、神奇的网络世界 &#x1f4bb;操作环境&#xff1a; CentOS 7.6 阿里云远程服务器 文章目录 1.再谈协议1.1.认识URL1.2.Encode 和 Decode 2.HTTP 协议2.1.协议格式2.2.见一见请求2.…

【OpenCV C++Python】(五)图像平滑(模糊)

文章目录 图像平滑均值滤波高斯滤波中值滤波双边滤波(Bilateral Filtering ) PythonC 图像线性平滑空间滤波&#xff08;加权均值滤波器&#xff0c;几何均值滤波&#xff0c;谐波均值滤波&#xff0c;逆谐波均值滤波&#xff09;&#xff0c;非线性平滑空间滤波&#xff08;中…

2024 年 5 个 Linux 开源数字化学习平台

与其他行业一样&#xff0c;教育界多年来一直在经历数字化转型的过程。随着数字化学习平台的建立&#xff0c;目前只要能上网&#xff0c;任何人都可以接受教育。 “e-learning”一词的意思是“数字化学习”&#xff0c;是当今最常用的词之一。 它指的是通常在互联网上进行的培…

unity Mirror网络同步

我们直接来剖析&#xff0c;上干货 在github上的主页代码&#xff0c;稍微修改了下&#xff1a; using System.Collections; using System.Collections.Generic; using Mirror; using UnityEngine;public class Player : NetworkBehaviour {// Synced automatically //自动同…