当前位置:首页 > 嵌入式 > 嵌入式教程
[导读]利用多目标建模技术降低ECU软件成本

多目标建模是一种电子控制单元(ECU)开发技术,它采用了基于模型的设计方法和自动嵌入式代码生成技术。利用多目标建模技术可以为各种嵌入式DSP、微处理器和微控制器建立算术模型,并实现代码的自动生成。软件开发人员也因此可以节省许多时间和精力,因为他们不再需要为每个嵌入式目标器件编写、测试和重编代码。 

在这方面,Visteon公司正在使用多目标建模技术开发动力控制系统。他们的方法以数据字典的创建为基础,而数据字典用来控制模型仿真和嵌入式代码生成时使用的数据类型。利用这种方法可以仿真设计思路,并根据各种嵌入式处理器选项试验各种处理器的算法功能。仿真环境有助于设计师在软件实现前就确定数据分辨率和量化对系统性能的影响。一旦选好了合适的嵌入式处理器,代码就能自动生成和创建,并被集成进产品ECU。仿真和代码生成环境由MathWorks公司的Simulink及Real-Time Workshop Embedded Coder提供。本文将介绍使用多目标建模方法开发动力ECU的技术、工具以及因此带来的好处。 

人工的多目标实现方法 

支持各种硬件架构的传统方法是人工开发代码。这些代码接口方便,并且很容易从一种架构改成另一种架构。这种方法的挑战是,工程师很难将他们的浮点算法转换成定点设计。转换过程要求提供各种变量和参数的换算系数和其它定点信息。另外,也很难创建和维持这样一种软件层,它能以一种易用的方式提供高层算法和定点软件实现之间的足够的抽象(abstraction)。

从浮点到定点架构的软件设计和接口会给开发过程带来其它问题,包括:

1. 建立换算信息要花很长时间;

2. 测试定点上溢和下溢是一件很繁琐的工作。每次数学运算都要求用最小和最大值进行分析和测试,才能满足上溢和下溢检查的需求;

3. 人工设计和编码技术很容易出错。

 图1:Visteon公司动力系统的多目标建模架构。

基于模型的多目标实现方法

在20世纪90年代,Visteon公司开始研究模型和自动代码生成在动力传动系统中的应用。调查结果使Visteon公司决定从人工开发方法转向模型设计方法。这种方法的转换在过去六年中一直在进行,因为已有的手工编码生产模块需要根据要求逐步转换成Simulink模型。在这段时间内也引入了Real-Time Workshop Embedded Coder的自动代码生成功能。该功能已在产品ECU实现中用来从模型中自动产生代码。

目前模型设计方法已在汽车产业中得到广泛使用,使用建模、仿真和自动代码生成的好处也已众所周知。Visteon公司建立了完整的建模环境,可以帮助设计师使用多目标、自动代码生成方法快速部署不同的硬件架构。该方法需要利用外部数据字典来约束从模型架构生成的代码的格式和结构。

模型设计环境

多目标模型与数据类型无关。最初模型使用的数据类型是主机执行仿真时可用的最大字长度(例如双精度实数)。这样就提供了被建议算法的理想行为。如果行为能令人满意,就可以再增加特定的目标实现,使模型适合产品ECU的要求。

图2:数据字典例子。

为了使模型符合特定目标要求,需要将数据字典和特定硬件信息装载进MATLAB工作区。同时提供数据字典和基准通用模型的链接机制。自动化换算工具可以使转换和验证过程更加便利。自动化代码生成就是将定点设计翻译成产品代码的过程。接着Visteon公司工程师将软硬件组件集成进最终的产品ECU中,以便今后进一步的验证和确认操作。

图1给出了Visteon公司动力系统使用的通用模型架构,并说明了如何使用多个数据字典实现特定目标细节。

一旦行为令人满意,通用模型就被纳入Visteon公司的配置管理系统中,并作为动力算法库中的一个组件放置在知识架上。工程师可以随时通过复用存储在算法库中的模型组件创建新的算法。

模型设计工具

Simulink公司通过使用信号和参数数据对象支持面向数据字典的数据规范。可以利用加载进MATLAB工作区的外部数据字典确定数据对象。一旦开始仿真或代码生成,Simulink或Real-Time Workshop Embedded Coder就开始检查模型中已被命名的信号或参数在工作区中是否有对应的数据对象。如果工作区中存在对象,就可以在仿真和代码生成过程中使用数据对象的属性。

图3:通用模型例子。

图2就是具有数据对象的工作区例子。可以赋于数据对象的数据属性包括了初始值、数据类型、存储类、描述、最小和最大值等。除此之外,还可以赋于定点属性,如字长度、小数长度或二进制小数点、有符号或无符号等等。使用数据对象进行仿真和代码生成的通用模型如图3所示。这些例子描述的技术并不代表Visteon公司专有的产品数据或模型。

在建立通用模型后,Visteon公司的软件工程师就要为他们需要的目标架构创建并换成特定的数据字典,然后使用这个数据字典进行仿真和代码生成。然而,创建一个优秀的定点数据字典需要花很长的时间,这是因为在确定换算系数时需要做多方面的折衷考虑。工程师需要选择能够提供足够精度但在已知范围内的换算系数。如果换算系数的选择不够充分,那么当结果超过字长时可能发生数字上溢或下溢。

在选择换算系数时自动换算工具被证明是非常有用的。这些工具能够非常容易地确定仿真期间是否会发生上溢或下溢。图4是来自Simulink定点用户接口工具的输出例子。在这个例子中,数据记录显示了仿真过程中信号获得的最小和最大值。在这种情况下,所有信号都在范围之内。如果发生上溢或饱和,数据记录会标志这一事件,从而促使设计工程师调查问题原因,并选择新的正确的换算系数。

如果需要额外的保护,设计师可以使用由Simulink在模块参数对话框中提供的饱和设置在计算中增加上溢保护。饱和检查对生成代码的效率来说非常重要,下面的结论部分将提到这一点。

产品ECU程序的结果

Visteon动力系统实现了用于发动机管理系统的产品化浮点和定点的应用。对开发过程来说最大的好处是显著减少了时间和成本。在有个案例中,Visteon公司在三个月内就完成了ECU软件的开发,如果采用手工编码方案的话起码要6个月。

图4:自动换算工具和记录结果例子。

与人工编码相比,浮点自动代码的效率也有所提高,使用的RAM和ROM空间要少5%左右。定点自动代码效率几乎接近手工编码效率。在对导航程序中定点代码的初始分析过程中,Visteon公司将对前面讨论过的饱和检查进行确认,这将对定点代码效率起关键作用。如果每次定点计算都激活了饱和检查,那么代码长度会有显著增加。然而,如果象在手工编码中做的那样只在需要时做饱和检查,那么生成代码所需的RAM和ROM空间基本上等于手工编码所需的空间。

另外需要注意的是,为了确保获得高质量的代码,开发人员仍要使用静态分析工具和MISRA检查器对自动代码进行检查。

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

9月2日消息,不造车的华为或将催生出更大的独角兽公司,随着阿维塔和赛力斯的入局,华为引望愈发显得引人瞩目。

关键字: 阿维塔 塞力斯 华为

加利福尼亚州圣克拉拉县2024年8月30日 /美通社/ -- 数字化转型技术解决方案公司Trianz今天宣布,该公司与Amazon Web Services (AWS)签订了...

关键字: AWS AN BSP 数字化

伦敦2024年8月29日 /美通社/ -- 英国汽车技术公司SODA.Auto推出其旗舰产品SODA V,这是全球首款涵盖汽车工程师从创意到认证的所有需求的工具,可用于创建软件定义汽车。 SODA V工具的开发耗时1.5...

关键字: 汽车 人工智能 智能驱动 BSP

北京2024年8月28日 /美通社/ -- 越来越多用户希望企业业务能7×24不间断运行,同时企业却面临越来越多业务中断的风险,如企业系统复杂性的增加,频繁的功能更新和发布等。如何确保业务连续性,提升韧性,成...

关键字: 亚马逊 解密 控制平面 BSP

8月30日消息,据媒体报道,腾讯和网易近期正在缩减他们对日本游戏市场的投资。

关键字: 腾讯 编码器 CPU

8月28日消息,今天上午,2024中国国际大数据产业博览会开幕式在贵阳举行,华为董事、质量流程IT总裁陶景文发表了演讲。

关键字: 华为 12nm EDA 半导体

8月28日消息,在2024中国国际大数据产业博览会上,华为常务董事、华为云CEO张平安发表演讲称,数字世界的话语权最终是由生态的繁荣决定的。

关键字: 华为 12nm 手机 卫星通信

要点: 有效应对环境变化,经营业绩稳中有升 落实提质增效举措,毛利润率延续升势 战略布局成效显著,战新业务引领增长 以科技创新为引领,提升企业核心竞争力 坚持高质量发展策略,塑强核心竞争优势...

关键字: 通信 BSP 电信运营商 数字经济

北京2024年8月27日 /美通社/ -- 8月21日,由中央广播电视总台与中国电影电视技术学会联合牵头组建的NVI技术创新联盟在BIRTV2024超高清全产业链发展研讨会上宣布正式成立。 活动现场 NVI技术创新联...

关键字: VI 传输协议 音频 BSP

北京2024年8月27日 /美通社/ -- 在8月23日举办的2024年长三角生态绿色一体化发展示范区联合招商会上,软通动力信息技术(集团)股份有限公司(以下简称"软通动力")与长三角投资(上海)有限...

关键字: BSP 信息技术
关闭
关闭