基于MBD的APSOA架构到代码生成的过程

原创 汽车电子与软件 2025-04-03 08:38

作者 | 不可说

出品 | 汽车电子与软件



#01

前  言


AUTOSAR AP平台通过提供高性能计算与通信能力、灵活性和可扩展性、OTA支持、实时性与安全性保障以及渐进部署与动态管理等功能,解决了CP平台在面对现代汽车电子系统快速发展时所面临的一系列问题。这些改进使得AP平台能够更好地满足汽车制造商和供应商对汽车电子系统开发的需求,推动汽车电子系统的不断升级和创新。


本文计划基于MBD方式,从零开始搭建一个AP模型,该模型能够清晰地表达AP架构服务通信架构、逻辑控制流程、输入输出关系以及各组件间的交互机制,实现简单的逻辑控制,并生成代码分析下这种方式对于AP的开发利弊,供参考讨论。




#02
Simulink对AP SOA的支持


AP AUTOSAR架构中,集成了多样化的接口与服务体系,涵盖通讯、日志记录、诊断等多个方面,共计十余个功能模块协同工作,共同构筑起一个功能完备的层级结构。这些接口与服务的核心价值在于赋能OTA的实施、促进运行时环境的动态配置调整与服务的发布/发现,并显著增强了对高性能车载软件在计算能力与数据处理速度上的支持能力。通讯模块(Com)设计基础在于两种主流的通讯标准:SOME/IPDDS


起初,DDS在除汽车行业外的多个领域内展现了广泛的应用潜力,而现如今,它也正逐渐吸引汽车行业内的瞩目。本质上,DDS作为一种中间件技术,其核心理念在于从复杂的网络架构、多样化的数据格式及操作系统细节中剥离应用逻辑,转而聚焦于数据本身,实现高度的数据中心化。它运作的核心机制是基于发布/订阅模式,确保数据能够在不同的网络节点间高效、灵活地传递,同时,该通讯方式同样有对动态服务发现的支持,进一步增强了其在复杂系统环境中的适应性和可扩展性。



DDS中间件


目前呢,几个较新版本的MATLABSOME/IPDDS通信方式都有一定的支持,并且对于软件架构和软件模型,可以自动生成对应的CC++代码。



Simulink如何来支持面向服务的架构?前面也提到了一个关键概念是面向服务的通讯。应用服务是通过中间件进行发送和接收来实现通讯的。通讯里面最基本的元素是消息,它包含了事件和数据,在Simulink中,可以使用消息对面向服务通讯进行建模。



服务中的消息通讯


可以使用消息和事件库中的一些特定块基础模块来发送和接收消息。以及配置和使用消息队列,也可以查看仿真过程中跨模型交换的一些消息序列。同时也可以为C/C++代码生成配置接口,以便你生成的代码可以集成到所选择的中间件中。



 

因此,可以继续使用Simulink模块对应用的算法进行建模,甚至为这些新的应用重用一些已有的模型。降低重复开发的工作量,提升开发效率。


现在较新的MATLAB版本可以在总线路由多条消息,也可以将列总线一起使用。可以使用消息和事件库中的合并功能将多消息进行合并,变成一条。



Simulink也支持事件的记录和动画功能,可以用来查看模型中函数调用子系统、Simulink消息函数模块的事件、还可以进行动画的设置因此这些功能是可以帮助我们更好的去理解复杂系统





#03
SOA服务设计内容


要搭建AP模型,首先要做下AP服务设计及SWC软件架构设计,本次计划实现一个氛围灯功能,分为两个SWC模块,首先是一个氛围灯原子模块,负责氛围灯开闭状态反馈及开闭、颜色控制,再一个是氛围灯基础模块,负责氛围灯的模式控制及反馈,对外部控制器提供这些能力,当然,他也需要调用氛围灯原子模块的功能来实现自身的功能;


因此计划设计两个SWC:氛围灯原子模块AmbiAtomicSWC与氛围灯基础模块AmbiBasicSWCAmbiAtomicSWC对外提供AmbiAtomic服务,AmbiBasicSWC对外提供AmbiBasic服务,自身也需要调用AmbiAtomic服务;


设计的服务/Interface以及服务内接口/Element元素如下表内容:


功能

服务

接口描述

接口

参数

参数类型描述

参数类型

参数范围

氛围灯

氛围灯原子服务

AmbiAtomic

开闭控制

setAmbLiOnOffReq

入参:switchSts

出参:result

开闭类型

Uint8

0:关

1:开

开闭通知

onAmbLiOnOffChange

返回类型:switchSts

开闭类型

Uint8

0:关

1:开

颜色控制

setAmbLiColorReq

入参:color

整型

Uint8

1:颜色1

2:颜色2

氛围灯基础服务

AmbiBasic

模式控制

setAmbLiModeReq

入参:mode

模式类型

Uint8

0:关闭

1:模式1

2:模式2

模式通知

onAmbLiModeChange

返回类型:mode

模式类型

Uint8

0:关闭

1:模式1

2:模式2




#04

模型搭建


首先要依据Autosar软件架构模板创建个AP模型画布,如下:



创建模板


模型默认是CP架构的,要切换到AP架构;



创建两个AP Component,按照上面设计的SWC进行重命名,构建并填充好端口名,暂时以SOA服务名作为端口名,注意端口是Client/Server类型;



SWC模块上,右键选择Creat Simulink Behavior,将其转换为Simulink元素;



转换为如下的模型,AmbiAtomic服务默认生成了一个函数调用子系统,AmbiBasic服务默认生成了一个函数调用子系统以及一个function caller



接下来需要进行服务数据的设计填充,打开Autosar字典分别对两个SWC进行配置;


1AmbiAtomicSWC配置


AmbiAtomic服务是根据外部创建的AmbiAtomic端口同名生成的,这里不做修改也可以,不过默认的ProvidedPorts里面的Instance Id并未配置,这里手动给配置为1


按照接口表手动修改默认生成的f1方法,最后变为两个Method方法,一个Event事件;



下一步就是在Simulink界面中配置与刚才设计的AUTOSAR元素对应的Simulink模块,这也是Simulink搭建AUTOSAR模型的硬性要求,所有元素都必须一一匹配;


首先修改原有的f1函数,修改后的函数名为AmbiAtomic服务中的一个Method方法名,修正对应的入参及出参,同时修改对应的bus element out的名称,格式为port.method,这里为:AmbiAtomic.setAmbLiOnOffReq



添加该服务里另一个Method setAmbLiColorReq



添加该服务里的Event onAmbLiOnOffChange


对于服务的Server端,提供Event事件需要使用message send模块,但是必须存在于函数子系统中,对于函数输入端口,也要勾选上“输出函数调用”



最后检查下Simulink元素和Autosar元素的映射关系,不能有未map的,如有可以补上;



到这里,相当于完成了AP架构设计部分,最后添加一点实现逻辑的软件单元:


客户端可以调用服务中setAmbLiOnOffReqsetAmbLiColorReq方法,存储(设置)氛围灯开闭及颜色,并且调用setAmbLiOnOffReq设置开闭时,调用成功时会回复1,同时,AmbiAtomicSWC作为AmbiAtomic服务的服务端,会把氛围灯开闭状态通过Event事件通知到客户端;最后这部分AP模型呈现如下:



2AmbiBasicSWC配置


首先也是要修改Autosar字典数据内容,AmbiBasicSWC一共包含两个服务:AmbiBasicAmbiAtomic,分别对应进行Server端和Client端的实例化,注意,simulink这里不允许具有一样的Instance Id,即便是不同服务的不同port,还不理解为什么不允许这样……


其余配置都按照服务设计的内容来就行;



AmbiBasicSWCAmbiAtomic服务配置



AmbiBasicSWCAmbiBasic服务配置


下一步同样在Simulink界面中配置与刚才设计的AUTOSAR元素对应的Simulink模块,首先配置AmbiBasic服务作为Server端的内容,这一部分与AmbiAtomicSWC配置方式基本一致,具体细节就不展开了;



对于AmbiAtomic服务的客户端配置展开说下,要实现对服务内的两个Method方法的调用,以及Event事件消息的接收;


Method的调用需要使用FunctionCaller模块,对Event事件的接收需要使用到Message Receive模块,该模块是从收到的消息中提取数据并写入输出信号端口。如果模块执行时没有新消息,则模块或者写入默认数据,或者保留从最后一条消息中读取的数据。



检查下Simulink元素和Autosar元素的映射关系,不能有未map的,如有可以补上;



到这里,相当于完成了这部分的AP架构设计部分,最后添加一点实现逻辑的软件单元:


允许有AmbiBasic的客户端,调用AmbiBasicSWC中的AmbiBasic服务端,进行氛围灯模式的设置,并且把模式状态返回回去;同时,再通过AmbiAtomic客户端解析氛围灯模式,调用服务中setAmbLiOnOffReqsetAmbLiColorReq方法,对服务端设置氛围灯开闭及颜色,并且接收关闭状态消息,完成简单的逻辑闭环控制。


最后这部分AP模型呈现如下:



 


#05
代码生成与分析


最后模型呈现如下;



1AmbiAtomicSWC代码生成


生成的文件如下:



ambiatomic_skeleton.h 内部定义了SOA服务的服务端行为,比如服务发布、停止发布、Event事件,Method行为等。



AmbiAtomicSWC.cpp内则是服务内EventMethod行为模型对应的代码;



AmbiAtomicSWC.cpp内的初始化动作也可以关注下:



2AmbiBasicSWC代码生成


AmbiBasicSWC生成的代码文件稍微多一些,因为他既有服务的客户端(Proxy),也有服务的服务端(Skeleton);



Proxy内容大致如下:



AmbiBasicSWC.cpp初始化函数中也加入了服务发现的find部分代码;



 


#06
小  结


本文设计了含有两个SWC、两个SOA服务的AUTOSAR AP软件架构,建立了AP模型对应的Simulink模型,分析了模型中的AUTOSAR AP元素,最后也成了AP平台的C++代码。


但是,也存在着不少信息是在当前Simulink环境下没办法进行配置,比如SOA服务的服务ID,服务MethodEvent等接口的通信ID、没有办法去选择AP平台的通信方式,是SOME/IP还是DDS等,服务的部署信息等也没有相应模块可以配置,因此该Simulink工具箱还有蛮大的上升空间;目前来说,还是Vector系列的AP工具更为常用些,当然,如今不少Tire1也都自己的AP工具,欢迎大家交流讨论AP的开发方法论、流程及工具等。


/ END /


汽车电子与软件 主要介绍汽车电子软件设计相关内容,每天分享一篇技术文章!
评论 (0)
  • 引言:POPO声的成因与影响在语音芯片应用中,WT588F08A作为一款支持DAC+功放输出的高集成方案,常因电路设计或信号处理不当,在音频播放结束后出现POPO声(瞬态噪声)。这种噪声不仅影响用户体验,还可能暴露电路设计缺陷。本文将基于实际案例,解析POPO声的成因并提供系统化的解决方案。一、POPO声的根源分析1. 功放电路状态切换的瞬态冲击当DAC输出的音频信号突然停止时,功放芯片的输入端若处于高阻态或无信号状态,其内部放大电路会因电源电压突变产生瞬态电流,通过喇叭表现为POPO声。关键因
    广州唯创电子 2025-04-07 09:01 107浏览
  • 医疗影像设备(如CT、MRI、超声诊断仪等)对PCB的精度、可靠性和信号完整性要求极高。这类设备需要处理微伏级信号、高频数据传输,同时需通过严格的EMC/EMI测试。制造此类PCB需从材料选择、层叠设计、工艺控制等多维度优化。以下是关键技术与经验分享。 1. 材料选择:高频与生物兼容性优先医疗影像设备PCB常采用 Rogers RO4000系列 或 Isola FR4高速材料,以降低介电损耗并保证信号稳定性。例如,捷多邦在客户案例中曾为某超声探头厂商推荐 Rogers RO4350B
    捷多邦 2025-04-07 10:22 101浏览
  •     在研究Corona现象时发现:临界电压与介电材料表面的清洁程度有关。表面越清洁的介电材料,临界电压越高;表面污染物越多的地方,越容易“爬电”。关于Corona现象,另见基础理论第007篇。    这里说的“污染物”,定义为——可能影响介电强度或表面电阻率的固体、液体或气体(电离气体)的任何情况。    IEC 60664-1 (对应GB/T 16935.1-2023) 定义了 Pollution Degree,中文术语是“污染等
    电子知识打边炉 2025-04-07 22:06 74浏览
  •     根据 IEC术语,瞬态过电压是指持续时间几个毫秒及以下的过高电压,通常是以高阻尼(快速衰减)形式出现,波形可以是振荡的,也可以是非振荡的。    瞬态过电压的成因和机理,IEC 60664-1给出了以下四种:    1. 自然放电,最典型的例子是雷击,感应到电力线路上,并通过电网配电系统传输,抵达用户端;        2. 电网中非特定感性负载通断。例如热处理工厂、机加工工厂对
    电子知识打边炉 2025-04-07 22:59 90浏览
  • 及时生产 JIT(Just In Time)的起源JIT 起源于 20 世纪 70 年代爆发的全球石油危机和由此引发的自然资源短缺,这对仰赖进口原物料发展经济的日本冲击最大。当时日本的生产企业为了增强竞争力、提高产品利润,在原物料成本难以降低的情况下,只能从生产和流通过程中寻找利润源,降低库存、库存和运输等方面的生产性费用。根据这种思想,日本丰田汽车公司创立的一种具有特色的现代化生产方式,即 JIT,并由此取得了意想不到的成果。由于它不断地用于汽车生产,随后被越来越多的许多行业和企业所采用,为日
    优思学院 2025-04-07 11:56 103浏览
  • 贞光科技作为三星电机车规电容代理商,针对电动汽车领域日益复杂的电容选型难题,提供全方位一站式解决方案。面对高温稳定性、高可靠性、高纹波电流和小型化等严苛要求,三星车规电容凭借完整产品矩阵和卓越技术优势,完美满足BMS、电机控制器和OBC等核心系统需求。无论技术选型、供应链保障、样品测试还是成本优化,贞光科技助力客户在电动汽车产业高速发展中占据技术先机。在电动汽车技术高速发展的今天,作为汽车电子系统中不可或缺的关键元器件,电容的选型已成为困扰许多工程师和采购人员的难题。如何在众多参数和型号中找到最
    贞光科技 2025-04-07 17:06 59浏览
  • 在万物互联时代,智能化安防需求持续升级,传统报警系统已难以满足实时性、可靠性与安全性并重的要求。WT2003H-16S低功耗语音芯片方案,以4G实时音频传输、超低功耗设计、端云加密交互为核心,重新定义智能报警设备的性能边界,为家庭、工业、公共安防等领域提供高效、稳定的安全守护。一、技术内核:五大核心突破,构建全场景安防基座1. 双模音频传输,灵活应对复杂场景实时音频流传输:内置高灵敏度MIC,支持环境音实时采集,通过4G模块直接上传至云端服务器,响应速度低至毫秒级,适用于火灾警报、紧急呼救等需即
    广州唯创电子 2025-04-08 08:59 108浏览
  • 文/Leon编辑/cc孙聪颖‍转手绢、跳舞、骑车、后空翻,就在宇树、智元等独角兽企业率领“机器人大军”入侵短视频时,却有资本和科技大佬向此产业泼了一盆冷水。金沙江创投管理合伙人朱啸虎近日突然对人形机器人发难,他表示“最近几个月正在批量退出人形机器人公司”。“只是买回去做研究的,或者买回去做展示的,这种都不是我们意义上的商业化,谁会花十几万买一个机器人去干这些活?”朱啸虎吐槽。不过,朱啸虎的观点很快就遭到驳斥,众擎机器人的创始人、董事长赵同阳回怼道:“(朱啸虎)甚至问出了人形机器人在这个阶段有什么
    华尔街科技眼 2025-04-07 19:24 118浏览
  •   工业自动化领域电磁兼容与接地系统深度剖析   一、电磁兼容(EMC)基础认知   定义及关键意义   电磁兼容性(EMC),指的是设备或者系统在既定的电磁环境里,不但能按预期功能正常运转,而且不会对周边其他设备或系统造成难以承受的电磁干扰。在工业自动化不断发展的当下,大功率电机、变频器等设备被大量应用,现场总线、工业网络等技术也日益普及,致使工业自动化系统所处的电磁环境变得愈发复杂,电磁兼容(EMC)问题也越发严峻。   ​电磁兼容三大核心要素   屏蔽:屏蔽旨在切断电磁波的传播路
    北京华盛恒辉软件开发 2025-04-07 22:55 142浏览
  • 在全球电子产业面临供应链波动、技术迭代和市场需求变化等多重挑战的背景下,安博电子始终秉持“让合作伙伴赢得更多一点”的核心理念,致力于打造稳健、高效、可持续的全球供应链体系。依托覆盖供应商管理、品质检测、智能交付的全链路品控体系,安博电子不仅能确保电子元器件的高可靠性与一致性,更以高透明的供应链管理模式,助力客户降低风险、提升运营效率,推动行业标准升级,与全球合作伙伴共同塑造更具前瞻性的产业生态。动态优选机制:构建纯净供应链生态安博电子将供应商管理视为供应链安全的根基。打造动态优选管控体系,以严格
    电子资讯报 2025-04-07 17:06 72浏览
  • 在追求环境质量升级与产业效能突破的当下,温湿度控制正成为横跨多个行业领域的核心命题。作为环境参数中的关键指标,温湿度的精准调控不仅承载着人们对舒适人居环境的期待,更深度关联着工业生产、科研实验及仓储物流等场景的运营效率与安全标准。从应用场景上看,智能家居领域要求温湿度系统实现与人体节律的协同调节,半导体洁净车间要求控制温湿度范围及其波动以保障良品率,而现代化仓储物流体系则依赖温湿度的实时监测预防各种产品的腐损与锈化。温湿度传感器作为实现温湿度监测的关键元器件,其重要性正在各行各业中凸显而出。温湿
    华普微HOPERF 2025-04-07 10:05 121浏览
  • HDMI从2.1版本开始采用FRL传输模式,和2.0及之前的版本不同。两者在物理层信号上有所区别,这就需要在一些2.1版本的电路设计上增加匹配电路,使得2.1版本的电路能够向下兼容2.0及之前版本。2.1版本的信号特性下面截取自2.1版本规范定义,可以看到2.1版本支持直流耦合和交流耦合,其共模电压和AVCC相关,信号摆幅在400mV-1200mV2.0及之前版本的信号特性HDMI2.0及之前版本采用TMDS信号物理层,其结构和参数如下:兼容设计根据以上规范定义,可以看出TMDS信号的共模电压范
    durid 2025-04-08 19:01 86浏览
  • 在人工智能技术飞速发展的今天,语音交互正以颠覆性的方式重塑我们的生活体验。WTK6900系列语音识别芯片凭借其离线高性能、抗噪远场识别、毫秒级响应的核心优势,为智能家居领域注入全新活力。以智能风扇为起点,我们开启一场“解放双手”的科技革命,让每一缕凉风都随“声”而至。一、核心技术:精准识别,无惧环境挑战自适应降噪,听懂你的每一句话WTK6900系列芯片搭载前沿信号处理技术,通过自适应降噪算法,可智能过滤环境噪声干扰。无论是家中电视声、户外虫鸣声,还是厨房烹饪的嘈杂声,芯片均能精准提取有效指令,识
    广州唯创电子 2025-04-08 08:40 126浏览
  • 曾几何时,汽车之家可是汽车资讯平台领域响当当的“扛把子”。2005 年成立之初,它就像一位贴心的汽车小助手,一下子就抓住了大家的心。它不仅吸引了海量用户,更是成为汽车厂商和经销商眼中的“香饽饽”,广告投放、合作推广不断,营收和利润一路高歌猛进,2013年成功在纽交所上市,风光无限。2021年更是在香港二次上市,达到了发展的巅峰,当年3月15日上市首日,港股股价一度高达184.6港元,市值可观。然而,如今的汽车之家却陷入了困境,业务下滑明显。业务增长瓶颈从近年来汽车之家公布的财报数据来看,情况不容
    用户1742991715177 2025-04-07 21:48 80浏览
我要评论
0
0
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦