使用Scade实现神经网络算法

在ERTS2022中,ANSYS 发表了使用Scade实现神经网络AI算法的相关工作。论文题目为《Programming Neural Networks Inference in a Safety-Critical Simulation-based Framework》

背景与挑战

神经网络在安全关键系统中的应用:随着嵌入式系统中自主性的引入,神经网络(NN)在多个领域的成功应用引起了安全关键系统行业的关注。然而,现有标准化工作尚未完全覆盖机器学习(ML)在安全关键系统中的应用。
行业需求:标准化机构(如SAE和EUROCAE)已明确指出需要制定支持ML子系统集成到安全关键航空软件、硬件和系统开发的标准。

方法论

论文提出了一种端到端的工作流,用于在安全关键系统中开发基于神经网络的功能。该方法基于以下三个核心支柱:

  • Scade语言的形式化表示和代码生成:Scade是一种形式化语言,用于安全关键系统的软件设计,支持代码生成、测试执行和覆盖分析。
  • 操作设计域(ODD)的定义:ODD描述了系统的预期运行条件,并通过场景驱动的方式评估其适用性。
  • 基于仿真的强化学习(RL)和鲁棒性分析:通过仿真环境训练神经网络模型,并结合鲁棒性和可靠性分析,确保模型的安全实现。

神经网络的实现

  • Scade中的神经网络编程:Scade语言支持多维数组操作和线性代数运算,能够实现神经网络的线性层、激活层(如ReLU)和卷积层。
  • 模型导入与验证:训练好的神经网络模型被自动导入到Scade中,与传统软件功能结合,形成完整的嵌入式软件应用。通过仿真环境验证整个应用的安全性。

无人机避障案例

问题定义:无人机需要在未知环境中自主飞行,同时避开其他飞机、基础设施和地面障碍物。
强化学习训练:使用深度强化学习(DRL)框架(如minds.ai DeepSim)训练神经网络,输入包括无人机状态、目标信息和入侵者信息,输出为飞行控制指令(如俯仰、横滚、偏航率和推力)。
训练结果:经过100万步训练,神经网络成功学习了避障策略,并通过敏感性分析验证了输入与输出之间的逻辑关系。
验证与分析
鲁棒性分析:验证了无人机在各种场景下的性能,结果显示大部分场景符合安全要求。
可靠性分析:通过概率模型和闭环仿真,量化了失败概率,并识别了特定失败场景(如目标高度过低或入侵者距离过近)。

结论与未来工作

成果:论文成功展示了如何在安全关键系统中开发和验证基于神经网络的车辆功能,并通过无人机避障案例验证了方法的有效性。
未来工作
进一步优化神经网络的训练过程,提高其泛化能力。
深入研究目标平台与主机平台之间的数值差异对系统性能的影响。
推进工具认证工作,确保仿真和分析方法的准确性。

总结

这篇论文为安全关键系统中神经网络的应用提供了一种系统化的工作流,并通过无人机避障案例展示了其可行性。该方法结合了形式化语言、强化学习和鲁棒性分析,为未来安全关键系统的开发提供了重要参考。

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

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

相关文章

Next.js + SQLite 项目 Docker 生产环境部署方案

以下是完整的 Next.js SQLite 项目 Docker 生产环境部署方案: 1. 项目结构准备 your-project/ ├── prisma/ │ ├── schema.prisma │ └── migrations/ ├── app/ ├── lib/ ├── Dockerfile ├── docker-compose.yml ├── .dockerignore └…

MCU软件开发使用指针有哪些坑?

目录 1、空指针访问 2、野指针(未初始化的指针) 3、指针越界 4、内存泄漏 5、悬空指针 6、指针类型不匹配 7、多任务环境中的指针访问 8、对齐问题 在MCU软件开发中,使用指针虽然可以提高程序的灵活性和性能,但也存在许多…

【SPSS/EXCEl】主成分分析构建__综合评价指数

学习过程中实验操作的记录 1.数据准备和标准化: (1)区分正负相关性:判断每个因子是正向指标还是负向指标,计算每个的最大值和最小值 (2) 标准化: Min-Max标准化 Min-Max标准化(最大最小值法): 将数据映射到指定的区间&#xff…

selenium安装,以及浏览器驱动下载详细步骤

1.下载谷歌浏览器Chromedriver 查看谷歌浏览器版本 2.去官网下载Chromedriver 114之前的版本链接chromedriver.storage.googleapis.com/index.html 选择和浏览器版本较接近的点击进行下载 125之后的版本链接Chrome for Testing availability (googlechromelabs.github.io)&a…

LabVIEW 油井动液面在线监测系统​

项目背景 传统油井动液面测量依赖人工现场操作,面临成本高、效率低、安全风险大等问题。尤其在偏远地区或复杂工况下,测量准确性与时效性难以保障。本系统通过LabVIEW虚拟仪器技术实现硬件与软件深度融合,为油田智能化转型提供实时连续监测解…

C++标准库 —— round 函数用法详解

round 是 C/C 标准库中的一个数学函数,用于对浮点数进行四舍五入取整。以下是它的详细用法说明: 目录 1. 基本语法 2. 功能描述 3. 使用示例 示例1:基本用法 示例2:保留小数位 4. 相关函数对比 5. 注意事项 6. 实际应用场景…

嵌入式C语言11(宏/程序的编译过程)

宏 ⦁ 基本概念 C语言中可以利用宏定义实现文本的快速替换,注意:宏定义是单纯的文本替换,不检查语法是否合法。 C语言标准中提供了很多的预处理指令,比如#include、#pragma…以#开头的都属于预处理指令。 预处理指令指的是在…

【湖南大学】2025我们该如何看待DeepSeek

大家好,我是樱木。 DeepSeek 官方网站:https://www.deepseek.com/ 一、DeepSeek 到底是什么? TA 到底厉害在哪里? 故事从 ChatGPT 说起 去年我们看到 Open AI 发布ChatGPT 后,全球的注意力到了 AI 身上。 我们来拆…

【区块链安全 | 第三十三篇】备忘单

文章目录 备忘单操作符优先级备忘单ABI 编码和解码函数bytes 和 string 的成员Address 的成员区块与交易属性校验和断言数学和加密函数合约相关类型信息函数可见性说明符修饰符备忘单 操作符优先级备忘单 以下是操作符的优先级顺序,按评估顺序列出: 优先级描述操作符1后缀递…

Python----计算机视觉处理(Opencv:道路检测之车道线显示)

完整版:Python----计算机视觉处理(Opencv:道路检测完整版:透视变换,提取车道线,车道线拟合,车道线显示) 一、透视变换 将透视变换之后的图像再继续透视变换为原图像 可参考Python----计算机视…

26届Java暑期实习面经,腾讯视频一面

短链接的生成原理 如何解决短链接生成的哈希冲突问题 如何加快从短链接到原链接的重定向过程 TCP 和 UDP 协议 如何理解 TCP 是面向连接的 为什么 TCP 的握手是 3 次 IO 模式 是否有真正写过一个底层的 Socket 通信 MySQL 的事务隔离级别 MVCC 机制 什么叫服务的并行 为什么能基…

Windows注册鼠标钩子,获取用户选中的文本

注册鼠标钩子 // 注册鼠标钩子 HHOOK hMouseHook; hMouseHook SetWindowsHookEx(WH_MOUSE_LL, MouseProc, GetModuleHandle(NULL), 0);// 取消鼠标钩子 UnhookWindowsHookEx(hMouseHook); hMouseHook nullptr; 上述代码中MouseProc方法用于处理系统的鼠标消息 处理鼠标消息…

flink cdc的source数据流如何配置事件时间,如何设置时间语义,分配时间戳并生成水位线

在 Flink CDC 中为 Source 数据流配置事件时间需要结合时间语义设置、时间戳分配和水位线生成三个核心步骤。以下是具体配置方法及注意事项: 1. 设置时间语义 Flink 默认使用处理时间(Processing Time),需显式指定事件时间语义&a…

C++ 指针类型转换全面解析与最佳实践

文章目录 C 指针类型转换全面解析与最佳实践1. 隐式转换基类和派生类指针 2. 显式转换(1) static_cast(2) dynamic_cast(3) reinterpret_cast(4) const_cast 3. C 风格转换4. 常见问题与注意事项5. 总结最佳实践 C 指针类型转换全面解析与最佳实践 在 C 中,指针类型…

批量将 txt/html/json/xml/csv 等文本拆分成多个文件

我们的文本文件太大的时候,我们通常需要对文本文件进行拆分,比如按多少行一个文件将一个大的文本文件拆分成多个小的文本文件。这样我们在打开或者传输的时候都比较方便。今天就给大家介绍一种同时对多个文本文件进行批量拆分的方法,可以快速…

ARM 汇编启动代码详解:从中断向量表到中断处理

ARM 汇编启动代码详解:从中断向量表到中断处理 引言 在嵌入式系统开发中,ARM 处理器(如 Cortex-A 系列)的启动代码是系统初始化和运行的基础。启动代码通常包括中断向量表的创建、初始化硬件状态(如关闭缓存和 MMU&a…

4.7学习总结 可变参数+集合工具类Collections+不可变集合

可变参数: 示例: public class test {public static void main(String[] args) {int sumgetSum(1,2,3,4,5,6,7,8,9,10);System.out.println(sum);}public static int getSum(int...arr){int sum0;for(int i:arr){sumi;}return sum;} } 细节&#xff1a…

2023年蓝桥杯第十四届CC++大学B组真题及代码

目录 1A:日期统计 解析代码_暴力_正解 2B:01串的熵 解析代码_暴力_正解 3C:冶炼金属 解析代码_暴力_正解 4D:飞机降落 解析代码_暴力dfs_正解 5E:接龙数列 解析代码_dp_正解 6F:岛屿个数 解析代…

rom定制系列------小米10pro机型定制解锁固件 原生安卓15批量线刷固件 操作解析与界面预览

注意;固件用于自己机型忘记密码或者手机号注销等出现设备锁 过保修期 售后无视的机型,勿用于非法途径 目前有粉丝联系,自己的机型由于手机号注销导致手机更新系统后出现设备锁界面。另外也没有解锁bl。目前无法使用手机。经过询问是小米10pro机型。根据…

信息学奥赛一本通 1861:【10NOIP提高组】关押罪犯 | 洛谷 P1525 [NOIP 2010 提高组] 关押罪犯

【题目链接】 ybt 1861:【10NOIP提高组】关押罪犯 洛谷 P1525 [NOIP 2010 提高组] 关押罪犯 【题目考点】 1. 图论:二分图 2. 二分答案 3. 种类并查集 【解题思路】 解法1:种类并查集 一个囚犯是一个顶点,一个囚犯对可以看…