一种残膜回收机防缠绕挑膜装置的制 一种秧草收获机用电力驱动行走机构

一种智能控制系统代码自动生成方法及装置

2022-07-16 23:31:52 来源:中国专利 TAG:


1.本发明涉及软件研发技术领域,尤其涉及一种智能控制系统代码自动生成方法及装置。


背景技术:

2.智能控制安全关键实时系统(safety-critical real-time system)广泛应用于无人机、航空电子、航天器、武器装备、核能、汽车控制等关键信息领域,智能控制安全关键实时系统是一种智能控制系统。由于功能和非功能要求不断提高,智能控制系统的复杂度急剧增加,如何设计与实现高质量的智能控制系统,并有效控制开发时间和成本,是学术界和工业界共同面临的难题。近年来,模型驱动开发方法(model-driven development, mdd)逐渐成为智能控制系统设计与开发的重要手段,而作为复杂嵌入式实时系统的体系结构设计与分析语言标准,aadl(architecture analysis and design language, aadl)日益受到关注,并逐渐发展成为一个新的研究热点。
3.aadl,体系结构分析与设计语言,广泛应用于基于模型的系统工程,进行系统体系结构的建模和模型转换,并进而借助系统设计模型实现系统的软件验证。
4.aadl是一种半形式化建模语言,有确定的语义和严格语法的语言表达规范。aadl主要用于各类安全系统中,这类系统规模庞大、逻辑复杂并且经常处于高强度的运行状态,一旦出现非正常状态将造成不可估量的损失。例如航空电子、航空航天、医疗、机器人、汽车和过程控制等领域。aadl模型到代码的自动生成,在提供代码质量,缓解软件危机是不可或缺的手段。它能够有助于提高嵌入式实时系统的软件开发的自动化水平,缩短软件开发周期,减少人工写代码的工作量和编码过程中出错的可能性。使用aadl实现智能控制系统的代码自动生成,具有重大的应用价值。
5.在智能控制系统代码自动生成技术方面,simulink自带了种类繁多、功能强大的模块库,在基于模型设计的开发流程下,simulink不仅通过仿真可以进行早期设计的验证,还可以生成c/c 、plc等代码直接应用于pc、mcu、dsp等平台,在嵌入式软件开发中发挥着重要的作用。
6.现有技术如图1所示,通过simulink模块库设计simulink系统模型,然后使用build model将已经通过仿真检验的系统ing模型转换为rtw文件,然后通过simulink coder中的目标语言编译器使用tlc模板将rtw文件转换为一系列的源文件,这个过程中tlc所使用的文件包括3类:系统目标文件、模块的目标文件和支持代码生成的tlc函数库等文件。模型的源代码全部生成之后,导入到目标硬件中进行实机运行。
7.现有技术中,simulink代码生成是商业化的软件,无法保证软件的有效性,在开发过程中,功能固化,无法满足自定义功能的需求,尤其是不支持采用智能算法作为系统模块的智能控制系统;同时在针对特定的平台开发时,比如pixhawk平台开发实现代码,需要购买单独的px4硬件支持包,价格相对昂贵,同时开发难度比较大。


技术实现要素:

8.为解决上述技术问题,本发明提出了一种智能控制系统代码自动生成方法及装置,用以解决智能控制系统的代码自动化实现的技术问题。
9.根据本发明的第一方面,提供一种智能控制系统代码自动生成方法,所述方法包括以下步骤:步骤s1:解析aadl模型文件,从所述aadl模型文件中提取所述aadl模型文件包括的各个组件及属性约束,所述组件包括系统组件、进程组件、线程组件、数据组件、以及子程序组件;解析提取的所述组件及属性约束;步骤s2:构建aadl模型文件到c 代码的转换规则,所述aadl模型文件到c 代码的转换规则包括系统组件转换规则、进程组件转换规则、线程组件转换规则、数据组件转换规则、以及子程序组件转换规则;基于所述转换规则,解析所述aadl模型文件包括的各个组件的属性;步骤s3:基于预设的c 代码模板及所述aadl模型文件包括的各个组件的解析结果,生成与所述aadl模型文件对应的c 代码;所述智能控制系统是指包含了智能算法的控制类系统。
10.进一步地,所述步骤s1,所述系统组件为所述aadl模型文件对应的aadl模型的最顶层组件;所述系统组件包含一个或者多个进程组件,每个进程组件表示受保护的地址空间;所述进程组件必须至少包含一个线程组件,每个线程组件包括类型声明和类型实现两部分;所述线程组件的实现包括子程序组件和数组组件,所述数组组件表示静态数据和数据类型;所述子程序组件表示能够被调用的代码单元,具有参数、操作数据或者能够为调用者提供服务功能。
11.进一步地,所述系统组件转换规则为:步骤s211:对系统组件,将所述系统组件转换为一个文件夹,该文件夹的名称与系统组件类型声明的系统组件名称一致;步骤s212:在所述系统组件转换的文件夹下,生成一个命名为modules的文件夹,用于存放系统组件包括的各个进程组件生成的代码。
12.进一步地,所述进程组件的转换规则为:步骤s221:在modules文件夹下,建立与当前系统组件所包含的进程组件一一对应的子文件夹,所述子文件夹的名称与所述进程组件的名称一致;modules文件夹下的子文件夹个数与所述系统组件包含的进程组件个数一致;步骤s222:解析所述进程组件,在所述进程组件对应的子文件夹中,生成两个文件,分别是“*.hpp”和“*.cpp”文件;所述*.hpp文件包括所述进程组件对应的进程内的线程所共享的数据和函数的声明、所述进程组件所包含的线程组件实现的主类、以及与所述进程组件相关的头文件引用;步骤s223:若所述进程组件中具有特征项,则在所述*.hpp文件中增加所述进程组件对外发布的消息函数的代码;步骤s224:若所述进程组件中具有属性项,则在所述*.hpp文件中增加所述进程组件的与属性处理相关的函数的代码;步骤s225:在文件*.cpp中生成*.hpp中定义的所有函数,每个函数的具体实现代
码设置为空;“*”为通配符,替换为其对应的进程组件的名称。
13.进一步地,所述线程组件的转换规则为:步骤s231:解析线程组件类型声明,为每个线程组件对应生成两个文件“*.hpp”和“*.cpp”,文件名与所述线程组件的名称相同,“*”为通配符,替换为其对应的线程组件的名称;将与所述线程组件对应的所述两个文件存储于所述线程组件对应的进程组件对应的子文件夹下;步骤s232:在该线程组件的*.hpp文件中,生成该线程组件对应的主类(class)定义,以及所述主类的构造函数和析构函数的定义;步骤s233:若所述线程组件的声明中具有特征(features)关键词定义的函数,则在该线程组件的*.hpp文件中,在该线程组件对应的公有函数中增加对应的静态函数定义;步骤s234:若所述线程组件中具有属性项,根据所述线程组件中的属性项设置该线程组件的*.hpp中主类的继承属性和命名空间的参数值;所述线程组件中的属性项能够标识所述线程组件的功能的实现方式;所述实现方式若为基于智能算法实现,则基于属性值获取实现所述智能算法的功能模块的引用,所述引用用于表征所述智能算法的功能模块的路径,并在生成与所述aadl模型文件对应的c 代码时,用于指示动态加载实现所述智能算法的功能模块;步骤s235:解析所述线程组件的实现,所述线程组件的实现包括子程序组件和数组组件;对所述线程组件包括的子程序组件,生成c 类的私有方法参数和返回值类型;对所述线程组件包括的数组组件,生成该线程组件的*.hpp头文件中的变量或者引用方法的实例;步骤s236:根据该线程组件的*.hpp文件中的函数定义,在该线程组件的*.cpp文件中生成对应的函数实现代码框架,函数体的实现为空;*为通配符,替换为其对应的线程组件的名称;步骤s237:确定并记录各个线程组件的依赖和调用关系,用于代码编译。
14.本实施例中,不为线程组件生成文件夹。所有线程组件对应的文件均存储于所述线程组件对应的进程组件的文件夹中,即所述进程组件对应的文件夹中,存储所述进程组件对应的全部线程组件对应的文件,通过文件名区分不同的线程组件。
15.进一步地,所述数据组件的转换规则为:步骤s241:若所述数据组件的数据类型为c 语言支持的预定义类型,则将所述数据组件直接转换成c 语言支持的内部数据类型;步骤s242:若所述数据组件的数据类型对应于c 语言的自定义类型,则根据所述数据组件的定义,生成c 语言支持的自定义数据类型。
16.进一步地,所述子程序组件的转换规则为:将线程组件内部的子程序组件的声明,转换为与所述子程序组件对应的线程组件对应的*.hpp文件中的一个静态函数,并且所述静态函数中包括所述子程序组件的变量和返回值;*为通配符,替换为其对应的线程组件的名称。
17.根据本发明的第二方面,提供一种智能控制系统代码自动生成装置,所述装置包括:解析模块:配置为解析aadl模型文件,从所述aadl模型文件中提取所述aadl模型
文件包括的各个组件及属性约束,所述组件包括系统组件、进程组件、线程组件、数据组件、以及子程序组件;解析提取的所述组件及属性约束;转换模块:配置为构建aadl模型文件到c 代码的转换规则,所述aadl模型文件到c 代码的转换规则包括系统组件转换规则、进程组件转换规则、线程组件转换规则、数据组件转换规则、以及子程序组件转换规则;基于所述转换规则,解析所述aadl模型文件包括的各个组件的属性;代码生成模块:配置为基于预设的c 代码模板及所述aadl模型文件包括的各个组件的解析结果,生成与所述aadl模型文件对应的c 代码;所述智能控制系统是指包含了智能算法的控制类系统。
18.根据本发明的上述方案,本发明从实际需求和应用角度出发,设计实现了一种智能控制系统代码自动生成方法及装置,该方法是基于aadl模型到c 代码框架的自动代码生成的方案,首先解析aadl模型文件,从中提取相关的组件信息,并进行解析;然后根据目标平台转换规则,构建代码模板,代码模板使用aadl模型和目标平台信息,对aadl模型的进程组件、线程组件、子程序以及数据组件进行转换,所述目标平台是转换后的c 代码运行的平台;最后,通过模板实现将aadl模型和已有代码整合,完成c 代码的生成。本发明从aadl模型到c 代码框架的自动代码生成方法,通过读取aadl实例文件,经过处理,最终生成了c 标准规范的代码,实现了将体系结构设计语言到面向对象语言之间的转换。
19.本发明通过aadl对目标硬件系统建模,并对所述目标硬件系统对应的软件系统进行处理,将aadl模型自动转换为c 代码的功能实现为相应的插件,实现从aadl模型到c 代码框架的代码自动生成,完成了从面向组件到面向对象转换。通过本方法实现的插件,既包括组件到c 转换规则,也包括aadl模型中各组件的属性的配置,最终可生成一套可编译的完整的系统代码。
20.本发明解决智能控制系统的代码实现问题,通过代码自动生成的方式,提高系统的开发效率,降低人力成本。本发明生成的代码适用于支持运行c 语言的平台,适用于c语言运行平台,因为c语言是c 语言的一个子集。本发明尤其适用于软件架构支持模块化设计、定制化需求强烈的智能控制系统,例如无人机、无人车等运行了智能算法的无人化平台。
21.上述说明仅是本发明技术方案的概述,为了能够更清楚了解本发明的技术手段,并可依照说明书的内容予以实施,以下以本发明的较佳实施例并配合附图详细说明如后。
附图说明
22.构成本发明的一部分的附图用来提供对本发明的进一步理解,本发明提供如下附图进行说明。在附图中:图1为现有技术的simulink代码自动生成方法流程图;图2为本发明一个实施方式的智能控制系统代码自动生成方法流程示意图;图3为本发明一个实施方式的智能控制系统代码自动生成方法基本流程图;图4为本发明一个实施方式的智能控制系统代码自动生成方法整体流程图;图5为本发明一个实施方式的进程组件解析流程示意图;图6为本发明一个实施方式的线程组件解析流程示意图;
图7为本发明一个实施方式的具体实施示意图;图8为本发明一个实施方式的智能控制系统代码自动生成装置结构示意图。
具体实施方式
23.名词解释:aadl:architecture analysis and design language,体系结构分析与设计语言,用于在模型基工程的分析实践中,进行系统体系结构的建模和模型转换,并进而借助系统设计模型实现系统的软件验证。
24.osate:基于eclipse的aadl开发环境,支持aadl语言最新标准,其支持核心语言、行为附件和错误模型附件。
25.mdd:model-driven development,模型驱动开发方法。
26.智能算法:是指以神经网络模型为代表的人工智能算法,包括机器学习、深度学习等。
27.lstm: 长短期记忆网络(lstm,long short-term memory)是一种时间循环神经网络,常用的智能算法。
28.智能控制系统:是指包含了智能算法的控制类系统,例如无人机、无人车等。
29.为使本发明的目的、技术方案和优点更加清楚,下面将结合本发明具体实施例及相应的附图对本发明技术方案进行清楚、完整地描述。显然,所描述的实施例仅是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
30.首先结合图2-图4说明为本发明一个实施方式的智能控制系统代码自动生成方法流程图。如图2-图4所示,所述方法包括以下步骤:步骤s1:解析aadl模型文件,从所述aadl模型文件中提取所述aadl模型文件包括的各个组件及属性约束,所述组件包括系统组件、进程组件、线程组件、数据组件、以及子程序组件;解析提取的所述组件及属性约束;步骤s2:构建aadl模型文件到c 代码的转换规则,所述aadl模型文件到c 代码的转换规则包括系统组件转换规则、进程组件转换规则、线程组件转换规则、数据组件转换规则、以及子程序组件转换规则;基于所述转换规则,解析所述aadl模型文件包括的各个组件的属性;步骤s3:基于预设的c 代码模板及所述aadl模型文件包括的各个组件的解析结果,生成与所述aadl模型文件对应的c 代码。
31.所述aadl模型文件能够通过直接获取的方式或基于第三方工具的方式进行获取。所述直接获取是指根据aadl语言的规范,直接编写的aadl模型文件。所述基于第三方工具的方式是指将构建完成的第一aadl模型文件导入第三方工具,例如osate工具,获取所述aadl模型,再基于osate平台的解析器,确定所述aadl模型中各组件和连接关系,对所述aadl模型进行解析。即将所述第一aadl模型文件通过osate开发环境实例化,将所述第一aadl模型文件转化为所述aadl模型文件。本实施例,通过直接获取aadl模型文件,或通过所述第三方工具将原始的aadl模型文件实例化,得到待转化的所述aadl模型文件。
32.进一步地,本实施例确定转化后的c 代码,即系统代码的存储根目录路径,在将
系统代码存储于相应的存储路径。以所述系统的工程名称为px4为例,确定的存储根目录为/home/gen/,则将px4工程生成的代码存储于/home/gen/px4/。所述工程根目录为后续转化后的c 代码文件的顶层目录。
33.所述步骤s1,其中,所述系统组件为所述aadl模型文件对应的aadl模型的最顶层组件;所述系统组件包含一个或者多个进程组件,每个进程组件表示受保护的地址空间;所述进程组件必须至少包含一个线程组件,每个线程包括类型声明和类型实现两部分;所述线程组件的实现包括子程序组件和数组组件,所述数组组件表示静态数据和数据类型;所述子程序组件表示能够被调用的代码单元,具有参数、操作数据或者能够为调用者提供服务。
34.所述步骤s2:构建aadl模型文件到c 代码的转换规则,所述aadl模型文件到c 代码的转换规则包括系统组件转换规则、进程组件转换规则、线程组件转换规则、数据组件转换规则、以及子程序组件转换规则;基于所述转换规则,解析所述aadl模型文件包括的各个组件的属性,其中:所述系统组件为所述aadl模型文件对应的aadl模型的最顶层组件。系统组件必须有一个类型声明和类型实现。系统组件的类型声明以aadl语言的关键字 system和end来定义;系统组件的类型实现以aadl语言的关键字 system implementation 和end来定义。每个系统组件类型声明的名称和类型实现的名称保持一致,并且所述系统组件类型实现的命名按照*.impl的形式,*为对应的组件类型声明的名称。
35.如下所示,声明了一个名称为systemtypeid的系统组件,并且实现了一个名称为systemtypeid.impl的系统组件。system systemtypeidend systemtypeid;system implementation systemtypeid.implend systemtypeid.impl;所述系统组件转换规则为:步骤s211:对系统组件,将所述系统组件转换为一个文件夹,该文件夹的名称与系统组件类型声明的名称一致。
36.即采用system关键字定义的组件声明的名称,例如systemtypeid。
37.步骤s212:在所述系统组件转换的文件夹下,生成一个命名为modules的文件夹,用于存放系统组件包括的各个进程组件生成的代码。
38.本实施例中,所述系统组件包含一个或者多个进程组件,每个进程组件表示受保护的地址空间。每个进程组件在代码生成时,对应modules的文件夹下的一个子文件夹,该文件夹的名称与进程组件的名称一致;modules的文件夹下面的子文件夹个数与该系统组件包含的进程个数一致。例如对于进程a,转换成的两个文件分别为/modules/a/process_a_main.hpp和/modules/a/process_a_main.cpp。
39.如图5所示,所述进程组件的转换规则为:步骤s221:在modules文件夹下,建立与进程组件一一对应的子文件夹,所述子文件夹的名称与所述进程组件的名称一致;modules文件夹下的子文件夹个数与所述系统组件包含的进程组件个数一致;步骤s222:解析所述进程组件,在所述进程组件对应的子文件夹中,生成两个文
件,分别是*.hpp和*.cpp文件;所述*.hpp文件包括所述进程组件对应的进程内的线程所共享的数据和函数的声明、所述进程组件所包含的线程组件实现的主类、以及与所述进程组件相关的头文件引用;步骤s223:若所述进程组件中具有特征(features)项,则在所述*.hpp文件中增加所述进程组件对外发布的消息函数的代码;步骤s224:若所述进程组件中具有属性(property)项,则在所述*.hpp文件中增加所述进程组件的与属性处理相关的函数的代码;本实施例中,所述属性包括内存运行时与保护相关、与源文件相关、与源代码加载时间相关、与调度协议相关、与绑定时间相关的属性。
40.步骤s225:在文件*.cpp中生成*.hpp中定义的所有函数,每个函数的具体实现代码设置为空;*为通配符,替换为其对应的进程组件的名称。
41.进程组件必须至少包含一个线程组件。每个线程包括类型声明和类型实现两部分。
42.如图6所示,所述线程组件的转换规则为:步骤s231:解析线程组件类型声明,为每个线程组件对应生成两个文件*.hpp和*.cpp,文件名与所述线程组件的名称相同;将与所述线程组件对应的所述两个文件存储于所述线程组件对应的进程组件对应的子文件夹下;步骤s232:在该线程组件的*.hpp文件中,生成该线程组件对应的主类(class)定义,以及所述主类的构造函数和析构函数的定义;步骤s233:若所述线程组件的声明中具有特征(features)关键词定义的函数,则在该线程组件的*.hpp文件中,在该线程组件对应的公有函数中增加对应的静态函数定义;步骤s234:若所述线程组件中具有属性项,根据所述线程组件中的属性项设置该线程组件的*.hpp中主类的继承属性和命名空间的参数值;所述线程组件中的属性项能够标识所述线程组件的功能的实现方式;所述实现方式若为基于智能算法实现,则基于属性值获取实现所述智能算法的功能模块的引用,所述引用用于表征所述智能算法的功能模块的路径,并在生成与所述aadl模型文件对应的c 代码时,用于指示动态加载实现所述智能算法的功能模块;智能控制系统的特点是该控制系统包含了深度学习算法等训练出来的模型,该模型可以作为代码生成的一部分,在线程组件中,通过插入引用的方式,基于定义好的接口,引用实现智能算法的功能模块。因此,本发明中,在将aadl模型中的线程组件进行转化时,获取标识所述线程组件的功能的实现方式的属性项,所述实现方式若为基于智能算法实现,则基于属性值获取实现所述智能算法的功能模块的引用,所述引用用于表征所述智能算法的功能模块的路径,并在生成与所述aadl模型文件对应的c 代码时,用于指示动态加载实现所述智能算法的功能模块。
43.例如,本实施例中,所述线程组件中的属性项可以描述该线程组件的功能通过智能算法实现,该功能模块通过模型插入引用的方式,即px4::class_inherit(“control:: pos_control”,“pos_control_lstm”),px4飞控软件的姿态控制功能pos_control,采用lstm网络训练的智能算法模型pos_control_lstm实现。
44.本实施例中,所述线程组件中的属性项包括初始状态设定和计算状态设定。
45.步骤s235:解析所述线程组件的实现,所述线程组件的实现包括子程序组件和数组组件;对所述线程组件包括的子程序组件,生成c 类的私有方法参数和返回值类型;对所述线程组件包括的数组组件,生成该线程组件的*.hpp头文件中的变量或者引用方法的实例;步骤s236:根据该线程组件的*.hpp文件中的函数定义,在该线程组件的*.cpp文件中生成对应的函数实现代码框架,函数体的实现为空;*为通配符,替换为其对应的线程组件的名称;步骤s237:确定并记录各个线程组件的依赖和调用关系,用于代码编译。
46.数组组件表示系统中的静态数据和数据类型。复杂的数据结构可以采用数据组件的实现和层次化设计实现。
47.所述数据组件的转换规则为:步骤s241:若所述数据组件的数据类型为c 语言支持的预定义类型,则将所述数据组件直接转换成c 语言支持的内部数据类型,例如int等。
48.步骤s242:若所述数据组件的数据类型对应于c 语言的自定义类型,则根据所述数据组件的定义,生成c 语言支持的自定义数据类型。
49.子程序组件表示可被调用的代码单元,可以带参数、操作数据或者为调用者提供服务。子程序通过calls关键字被调用。
50.所述子程序组件的转换规则为:将线程组件内部的子程序组件的声明,转换为与所述子程序组件对应的线程组件对应的*.hpp文件中的一个静态函数(static),并且所述静态函数中包括所述子程序组件的变量和返回值;*为通配符,替换为其对应的线程组件的名称。
51.本实施例中,依次确定所述aadl模型文件中是否包括系统组件、进程组件、线程组件、数据组件、以及子程序组件,在确定包括某种类型的组件后,对该类型的组件按与该类型的组件对应的转换规则进行处理。本实施例中,基于系统组件转换规则、进程组件转换规则、线程组件转换规则、数据组件转换规则、以及子程序组件转换规则,能够解析所述aadl模型文件包括的各个组件的属性。
52.所述步骤s3:基于预设的c 代码模板及所述aadl模型文件包括的各个组件的解析结果,生成与所述aadl模型文件对应的c 代码,其中:所述c 代码模板包括多种类型,即包括:系统组件代码模板、进程组件代码模板、线程组件代码模板、数据组件代码模板、以及子程序组件代码模板,分别用于融合解析后的各系统组件、各进程组件、各线程组件、各数据组件、以及各子程序组件的属性,以生成对应的c 代码。
53.所述c 代码模板是由静态文本和占位符组成的文件,所述静态文本是直接输出到c 代码文件中的文本;所述点位符的格式与各类型模板表征的组件类型相对应,所述占位符由所述addl模型中解析出的内容进行替换;替换后的内容输出到c 代码文件中。所述c 代码模板实际上是各种转换规则的载体。
54.进一步地,配置目标平台参数,所述目标平台为转化后的c 代码运行的硬件平台,在所述目标平台上配置参数,目的在于确定转化后的c 代码与所述目标平台兼容。基于生成的c 代码,将所述c 代码保存于指定文件,在所述根目录下生成所有的c 代码文
件。
55.以下结合图7,说明本发明的实施方式。
56.根据本发明实施例所述的一种智能控制系统代码自动生成方法及装置,本实施例的目标平台为pixhawk平台,基于pixhawk平台的硬件系统,以及对应的px4开源软件架构,以aadl模型构建运行于pixhawk平台的硬件系统之上的px4软件系统,为了后续使用需要,需要将所述aadl模型转化为c 代码。包括步骤:步骤1:导入pixhawk系统模型。
57.导入pixhawk系统模型,对pixhawk系统模型进行软硬件一体化建模,明确系统的软硬件需求。其中,硬件模型是与pixhawk平台对应的硬件相关参数和链接关系;软件模型是运行在该平台的px4软件系统,也是自动生成代码的aadl模型。
58.步骤2:设计软件组件模型。
59.根据映射规则,需要对模型的软件组件进行详细设计,以生成c 代码,主要对进程组件、线程组件、数据组件以及子程序组件进行详细设计,并根据设计需求,对组件的映射规则属性进行设置,同时设置组件的引用文件,其中aadl模型生成c 代码的框架,通过引用文件,填充模型的实现,例如指定子程序入口,引用安全的c 实现,来自动生成c 代码。
60.步骤3:实例化模型。
61.通过aadl描述系统模型后,需要对模型进行实例化,将实例化模型提供给code_gen插件去做代码生成。实例化模型为后缀名为aaxl2的文件,该方法通过解析aaxl2文件,提取模型信息,并提供给代码转换模板。
62.步骤4:调用code_gen插件,生成c 代码。
63.所述code_gen插件实现将aadl模型文件自动转换到c 代码,即将aadl模型解析后,根据提供的c 转换规则,生成转换模板,输入到模板引擎,最终输出c 代码。
64.调用code_gen插件,先确定工程根路径,判断要生成的软件的系统组件是否存在,并根据系统组件中的属性约束,生成工程目录的一二级目录,分别存储工程的底层驱动文件和自定义的进程模块文件。
65.分析完系统组件后,查看系统组件内部的进程组件,进程组件主要用于生成工程的进程模块文件夹,通过解析进程组件,确定工程所包含的所有进程模块,用于实现软件的全部功能。
66.判断进程组件的实现是否包含线程组件,并根据线程名,转换为进程的主类,线程组件内部可转换为主类的公有和私有的方法和变量,通过转换规则,对详细设计的aadl模型进行一致性的转换,判断线程组件内部的子程序和数据组件,并根据转换规则,实现aadl到c 代码的生成。
67.在处理完一个进程的类型和实现后,判断是否包含其他的进程,并按照逻辑对所有的进程组件做处理。
68.最终生成c 代码。最终生成的工程和进程模块内相关的文件,包括*.hpp和*.cpp,以及cmakelists.txt文件。
69.步骤5:执行make指令,最终生成可执行文件。
70.生成的px4工程文件,支持调用px4的工具链执行编译,并最终生成可执行文件。
71.图8为本发明一个实施方式的智能控制系统代码自动生成装置的结构示意图,如图8所示,所述装置包括:所述装置包括:解析模块:配置为解析aadl模型文件,从所述aadl模型文件中提取所述aadl模型文件包括的各个组件及属性约束,所述组件包括系统组件、进程组件、线程组件、数据组件、以及子程序组件;解析提取的所述组件及属性约束;转换模块:配置为构建aadl模型文件到c 代码的转换规则,所述aadl模型文件到c 代码的转换规则包括系统组件转换规则、进程组件转换规则、线程组件转换规则、数据组件转换规则、以及子程序组件转换规则;基于所述转换规则,解析所述aadl模型文件包括的各个组件的属性;代码生成模块:配置为基于预设的c 代码模板及所述aadl模型文件包括的各个组件的解析结果,生成与所述aadl模型文件对应的c 代码;所述智能控制系统是指包含了智能算法的控制类系统。
72.本发明实施例进一步给出一种系统,包括:处理器,用于执行多条指令;存储器,用于存储多条指令;其中,所述多条指令,用于由所述存储器存储,并由所述处理器加载并执行如前所述的方法。
73.本发明实施例进一步给出一种计算机可读存储介质,所述存储介质中存储有多条指令;所述多条指令,用于由处理器加载并执行如前所述的方法。
74.需要说明的是,在不冲突的情况下,本发明中的实施例及实施例中的特征可以相互组合。
75.在本发明所提供的几个实施例中,应该理解到,所揭露的系统,装置和方法,可以通过其它的方式实现。例如,以上所描述的装置实施例仅仅是示意性的,例如,所述单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如,多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通信连接可以是通过一些接口,装置或单元的间接耦合或通信连接,可以是电性,机械或其它的形式。
76.所述作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。
77.另外,在本发明各个实施例中的各功能单元可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。上述集成的单元既可以采用硬件的形式实现,也可以采用硬件加软件功能单元的形式实现。
78.上述以软件功能单元的形式实现的集成的单元,可以存储在一个计算机可读取存储介质中。上述软件功能单元存储在一个存储介质中,包括若干指令用以使得一台计算机装置(可以是个人计算机,实体机服务器,或者网络云服务器等,需安装windows或者windows server操作系统)执行本发明各个实施例所述方法的部分步骤。而前述的存储介
质包括:u盘、移动硬盘、只读存储器(read-only memory,rom)、随机存取存储器(random access memory,ram)、磁碟或者光盘等各种可以存储程序代码的介质。
79.以上所述,仅是本发明的较佳实施例而已,并非对本发明作任何形式上的限制,依据本发明的技术实质对以上实施例所作的任何简单修改、等同变化与修饰,均仍属于本发明技术方案的范围内。
再多了解一些

本文用于企业家、创业者技术爱好者查询,结果仅供参考。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

相关文献