CN114143136A - 一种基于iros的can大消息通信方法、设备、存储介质 - Google Patents
一种基于iros的can大消息通信方法、设备、存储介质 Download PDFInfo
- Publication number
- CN114143136A CN114143136A CN202111408008.8A CN202111408008A CN114143136A CN 114143136 A CN114143136 A CN 114143136A CN 202111408008 A CN202111408008 A CN 202111408008A CN 114143136 A CN114143136 A CN 114143136A
- Authority
- CN
- China
- Prior art keywords
- message
- module
- sending
- interface
- topic
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Pending
Links
- 238000004891 communication Methods 0.000 title claims abstract description 63
- 238000000034 method Methods 0.000 title claims abstract description 52
- 238000004806 packaging method and process Methods 0.000 claims abstract description 10
- 230000006870 function Effects 0.000 claims description 14
- 239000000126 substance Substances 0.000 claims description 3
- 230000005540 biological transmission Effects 0.000 abstract description 19
- 238000011161 development Methods 0.000 description 4
- 230000008569 process Effects 0.000 description 4
- 238000010586 diagram Methods 0.000 description 3
- 238000005516 engineering process Methods 0.000 description 3
- 230000009286 beneficial effect Effects 0.000 description 2
- 238000012423 maintenance Methods 0.000 description 2
- 238000012986 modification Methods 0.000 description 2
- 230000004048 modification Effects 0.000 description 2
- 238000013461 design Methods 0.000 description 1
- 238000001514 detection method Methods 0.000 description 1
- 230000000694 effects Effects 0.000 description 1
- 230000006872 improvement Effects 0.000 description 1
- 230000000750 progressive effect Effects 0.000 description 1
- 238000012827 research and development Methods 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L12/00—Data switching networks
- H04L12/28—Data switching networks characterised by path configuration, e.g. LAN [Local Area Networks] or WAN [Wide Area Networks]
- H04L12/40—Bus networks
- H04L12/40006—Architecture of a communication node
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L41/00—Arrangements for maintenance, administration or management of data switching networks, e.g. of packet switching networks
- H04L41/08—Configuration management of networks or network elements
- H04L41/0803—Configuration setting
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L12/00—Data switching networks
- H04L12/28—Data switching networks characterised by path configuration, e.g. LAN [Local Area Networks] or WAN [Wide Area Networks]
- H04L12/40—Bus networks
- H04L2012/40208—Bus networks characterized by the use of a particular bus standard
- H04L2012/40215—Controller Area Network CAN
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L12/00—Data switching networks
- H04L12/28—Data switching networks characterised by path configuration, e.g. LAN [Local Area Networks] or WAN [Wide Area Networks]
- H04L12/40—Bus networks
- H04L2012/4026—Bus for use in automation systems
Abstract
本申请公开了一种基于IROS的CAN大消息通信方法、设备、存储介质,属于数据传输领域,该方法包括:在计算设备中建立CAN发送节点、第一CAN发送接口,并配置第一CAN模块;其中,所述第一CAN发送接口用于封装CAN通信协议;通过在所述计算设备中安装的应用程序将第一消息发送到话题中,然后由所述CAN发送节点从所述话题实时获取所述第一消息;将所述第一消息通过所述CAN发送节点调用所述第一CAN发送接口,发送至所述第一CAN模块;通过所述第一CAN模块与控制设备中的第二CAN模块建立的基于CAN协议的通信连接,向所述第二CAN模块发送所述第一消息。
Description
技术领域
本申请涉及数据传输领域,尤其涉及一种基于IROS的CAN大消息通信方法、设备、存储介质。
背景技术
随着科技的发展,机器人的出现是社会和经济发展的必然,机器人操作系统(Robot Operating System,ROS)是一个适用于机器人的开源的元操作系统。它提供了操作系统应有的服务,包括硬件抽象,底层设备控制,常用函数的实现,进程间消息传递,以及包管理。
智能机器人操作系统(Intelligent Robot Operating System,IROS),具备ROS类似的功能,替代了开源ROS的内核,提供了兼容ROS的接口,解决了ROS可靠性、性能、安全等相关的问题,并增加了新的功能,支持云化机器人开发、支持云边端通信、支持多机器人协作等。
控制器局域网络(Controller Area Network,CAN),是一种用于实时应用的串行通讯协议总线,它可以用双绞线来传输信号,作为一种现场总线技术,由于其可靠性高、稳定性好、抗干扰能力强、通讯速率高和维护成本低等特点,被普遍应用于工业控制领域。
目前,在ROS中进行CAN通信,要求开发人员必须熟知CAN协议,并且ROS支持传输的有效数据最多是8个字节,这不仅对开发人员的要求高而且数据传输效率低。基于此,需要能够降低开发人员的作业难度,提高数据传输效率的方案,以更好地实现机器人内部的数据传输。
发明内容
本申请提供了一种基于IROS的CAN大消息通信方法、设备、存储介质,解决了开发人员的工作难度大,机器人系统内部数据传输效率低的技术问题。
一种基于IROS的CAN大消息通信方法,应用于计算设备中,所述计算设备基于智能机器人操作系统IROS运行,包括:
在所述计算设备中建立CAN发送节点、第一CAN发送接口,并配置第一CAN模块;其中,所述第一CAN发送接口用于封装CAN通信协议;
通过在所述计算设备中安装的应用程序将第一消息发送到话题中,然后由所述CAN发送节点从所述话题实时获取所述第一消息;
将所述第一消息通过所述CAN发送节点调用所述第一CAN发送接口,发送至所述第一CAN模块;
通过所述第一CAN模块与控制设备中的第二CAN模块建立的基于CAN协议的通信连接,向所述第二CAN模块发送所述第一消息。
在本申请的一种实施例中,当所述计算设备接收来自所述控制设备的第二消息时,所述方法还包括:所述计算设备还包括CAN接收节点、第一CAN接收接口;通过所述第一CAN模块与所述第二CAN模块建立的基于CAN协议的通信连接,接收来自所述控制设备的第二消息;通过所述CAN接收节点调用所述第一CAN接收接口,将所述第二消息从所述第一CAN模块接收至对应的话题中存储;通过应用程序从所述对应的话题中获取所述第二消息。
在本申请的一种实施例中,所述方法还包括:根据IROS支持的话题实时订阅功能,建立多个话题类型,生成每个话题类型对应的话题名称;通过CAN发送节点进行配置,将每个所述话题名称与对应的CAN ID绑定,以使所述第一消息能够实时发送。
在本申请的一种实施例中,所述方法还包括:通过CAN接收节点进行配置,将每个所述话题名称与对应的CAN ID绑定,以实时接收来自所述控制单元的第二消息;将所述第二消息存储到对应的话题中。
一种基于CAN的大消息通信方法,其特征在于,应用于控制设备中,包括:
所述控制设备包括第二CAN接收接口、第二CAN模块;
通过第二CAN模块接收来自计算设备的第一消息;
由所述控制设备安装的嵌入式应用调用所述第二CAN接收接口从所述第二CAN模块获取接收到的所述第一消息。
在本申请的一种实施例中,所述控制设备还包括第二CAN发送接口;所述方法还包括:所述嵌入式应用通过调用所述第二CAN发送接口将第二消息发送到所述第二CAN模块;通过所述第二CAN模块与计算设备中的第一CAN模块建立的基于CAN协议的通信连接,将所述第二消息发送至所述第一CAN模块。
在本申请的一种实施例中,所述方法还包括:当计算设备的第一CAN发送接口或控制设备的第二CAN发送接口发送数据时,将待发送的大消息拆分成多个CAN协议能识别的小消息;其中,首个小消息表示消息数目和总消息大小;将拆分后的小消息根据设定的可配置的CAN ID发送到目的地。
在本申请的一种实施例中,所述方法还包括:当所述第一CAN接收接口接收到小消息时,通过对应的CAN ID通道向所述第二CAN发送接口发送消息回执,以确认成功接收所述小消息;当所述第二CAN接收接口接收到小消息时,通过对应的CAN ID通道向CAN ID向所述第一CAN发送接口发送消息回执,以确认成功接收所述小消息;根据所述首个小消息包括的消息数目和总消息大小,将所述小消息组合还原成大消息。
一种基于IROS的CAN大消息通信设备,包括:
至少一个处理器;以及,
与所述至少一个处理器通信连接的存储器;其中,
所述存储器存储有可被所述至少一个处理器执行的指令,所述指令被所述至少一个处理器执行,以使所述至少一个处理器能够:
在计算设备中建立CAN发送节点、第一CAN发送接口,并配置第一CAN模块;其中,所述第一CAN发送接口用于封装CAN通信协议;
通过在所述计算设备中安装的应用程序将第一消息发送到话题中,然后由所述CAN发送节点从所述话题实时获取所述第一消息;
将所述第一消息通过所述CAN发送节点调用所述第一CAN发送接口,发送至所述第一CAN模块;
通过所述第一CAN模块与控制设备中的第二CAN模块建立的基于CAN协议的通信连接,向所述第二CAN模块发送所述第一消息。
一种非易失性存储介质,存储有计算机可执行指令,所述计算机可执行指令设置为:
在计算设备中建立CAN发送节点、第一CAN发送接口,并配置第一CAN模块;其中,所述第一CAN发送接口用于封装CAN通信协议;
通过在所述计算设备中安装的应用程序将第一消息发送到话题中,然后由所述CAN发送节点从所述话题实时获取所述第一消息;
将所述第一消息通过所述CAN发送节点调用所述第一CAN发送接口,发送至所述第一CAN模块;
通过所述第一CAN模块与控制设备中的第二CAN模块建立的基于CAN协议的通信连接,向所述第二CAN模块发送所述第一消息。
本申请提供了一种基于IROS的CAN大消息通信方法,至少包括以下有益效果:通过使用智能机器人操作系统IROS,支持CAN通信KB级别以上数据包的通信,相比机器人操作系统ROS,能更快的进行数据传输,极大地提高了数据的传输效率,且能保持CAN通信的可靠性和性能;通过建立在机器人的计算设备中建立多个话题,保证了大消息的实时发送;通过在计算设备和控制设备中建立CAN发送接口和CAN接收接口,将CAN协议进行封装,使开发人员在操作时直接调用接口即可使用,无需掌握底层CAN协议,降低了工作难度。
附图说明
此处所说明的附图用来提供对本申请的进一步理解,构成本申请的一部分,本申请的示意性实施例及其说明用于解释本申请,并不构成对本申请的不当限定。在附图中:
图1为本申请实施例提供的一种基于IROS的CAN大消息通信方法的步骤示意图;
图2为本申请实施例提供的从计算设备向控制设备发送消息的流程示意图;
图3为本申请实施例提供的计算设备和控制设备同时发送和接收大消息的流程示意图;
图4为本申请实施例提供的一种基于IROS的CAN大消息通信设备的组成结构示意图。
具体实施方式
为了使本申请的目的、技术方案和优点更加清楚,下面将结合本申请具体实施例对本申请进行清楚、完整的描述。显然,所描述的实施例仅是本申请一部分实施例,而不是全部的实施例。基于本申请中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本申请保护的范围。
在现有技术中,机器人操作系统(Robot Operating System,ROS)是一个适用于机器人的开源的元操作系统。它提供了操作系统应有的服务,包括硬件抽象,底层设备控制,常用函数的实现,进程间消息传递,以及包管理。它也提供用于获取、编译、编写、和跨计算机运行代码所需的工具和库函数。ROS的主要目标是为机器人研究和开发提供代码复用的支持。ROS是一个分布式的进程(也就是“节点”)框架,这些进程被封装在易于被分享和发布的程序包和功能包中。
智能机器人操作系统(Intelligent Robot Operating System,IROS),具备ROS类似的功能,替代了开源ROS的内核,提供了兼容ROS的接口,解决了ROS可靠性、性能、安全等相关的问题,并增加了新的功能,支持云化机器人开发、支持云边端通信、支持多机器人协作等。
控制器局域网络(Controller Area Network,CAN),是一种用于实时应用的串行通讯协议总线,它可以用双绞线来传输信号,作为一种现场总线技术,由于其可靠性高、稳定性好、抗干扰能力强、通讯速率高和维护成本低等特点,被普遍应用于工业控制领域。鉴于其良好的性能及独特的设计,机器人、汽车领域也广泛地使用CAN总线来实现内部控制器、执行器和各检测设备间的数据通信。
目前,在ROS中进行CAN通信,要求开发人员必须熟知CAN协议,并且ROS支持CAN传输的有效数据最多是8个字节,这样不仅使开发人员的工作难度高,而且数据传输效率低。基于此,需要能够降低开发人员的作业难度,提高数据传输效率的方案,以更好地实现机器人内部的数据传输。
通过使用智能机器人操作系统IROS,支持CAN通信KB级别以上数据包的通信,相比机器人操作系统ROS,能更快的进行数据传输,极大地提高了数据的传输效率,且能保持CAN通信的可靠性和性能;通过建立在机器人的计算设备中建立多个话题,保证了大消息的实时发送;通过在计算设备和控制设备中建立CAN发送接口和CAN接收接口,将CAN协议进行封装,使开发人员在操作时直接调用接口即可使用,无需掌握底层CAN协议,降低了工作难度。下面进行具体说明。
智能机器人的组成中包括计算设备和控制设备,计算设备安装智能机器人操作系统(Intelligent Robot Operating System,IROS),配置第一CAN模块,基于IROS运行的系统能够支持CAN通信KB级别以上的数据包通信,能够保持CAN通信的可靠性和性能。控制设备运行嵌入式应用,配置有第二CAN模块,计算设备和控制设备通过两个CAN模块进行通信。
为了能够流畅的发送数据,基于IROS的计算设备建立话题(存储单元)、CAN发送节点、CAN接收节点、第一CAN发送接口、第一CAN接收接口,控制设备运行第二CAN发送接口、第二CAN接收接口。
图1为本申请实施例提供的一种基于IROS的CAN大消息通信方法的步骤示意图,可以包括以下步骤:
S101:在计算设备中建立CAN发送节点、第一CAN发送接口,并配置第一CAN模块;其中,第一CAN发送接口用于封装CAN通信协议。
S102:通过在计算设备中安装的应用程序将第一消息发送到话题中,然后由CAN发送节点从话题实时获取第一消息。
S103:将第一消息通过CAN发送节点调用第一CAN发送接口,发送至第一CAN模块。
S104:通过第一CAN模块与控制设备中的第二CAN模块建立的基于CAN协议的通信连接,向第二CAN模块发送第一消息。
具体地,如图2为机器人中从计算设备向控制设备发送消息的流程示意图。由机器人应用程序将第一消息(由计算设备发送到控制设备)发送到话题中,CAN发送节点从话题订阅并实时获取第一消息,调用第一CAN发送接口将第一消息发送到第一CAN模块,通过第一CAN模块与控制设备进行通信。计算设备的第一CAN模块与控制设备的第二CAN模块通过双绞线相连,二者通过CAN协议进行通信。
在本申请的一种实施例中,计算设备还包括CAN接收节点、第一CAN接收接口;当计算设备接收来自控制设备的第二消息(由控制设备发送到计算设备)时,通过第一CAN模块与第二CAN模块建立的基于CAN协议的通信连接,接收来自控制设备的第二消息;通过CAN接收节点调用第一CAN接收接口,将第二消息从第一CAN模块接收至对应的话题中存储;通过应用程序从对应的话题中获取第二消息。
具体地,机器人计算设备接收来自控制设备发送的第二消息时,首先由第一CAN模块接收来自控制设备的CAN嵌入式应用通过第二CAN发送接口发送到第二CAN模块的第二消息;控制设备的第二CAN模块与计算设备的第一CAN模块通过双绞线相连,二者通过CAN协议进行通信;第一CAN接收节点调用第一CAN接收接口从第一CAN模块获取消息并将消息发布到话题中,机器人应用程序从话题订阅消息,进而实时接收到CAN嵌入式应用程序发送的第二消息。
在本申请的一种实施例中,根据IROS支持的话题实时订阅功能,建立多个话题类型,生成每个话题类型对应的话题名称;通过CAN发送节点进行配置,将每个话题名称与一个CAN ID对应绑定,以使第一消息能够实时发送。
具体地,根据IROS支持的话题实时订阅功能,可以同时支持多个话题,针对不同类型的消息建立多个话题类型,例如机器人中不同的应用程序可以建立不同的话题类型,每个话题类型对应一个话题名称,建立与该话题名称对应的CAN ID,通过CAN发送节点将话题名称和其对应的CAN ID绑定,通过第一CAN模块可以将消息发送到控制设备。
在本申请的一种实施例中,通过CAN接收节点进行配置,将每个话题类型与一个CAN ID对应绑定,以实时接收来自控制单元的第二消息;将第二消息存储到对应的话题中。
具体地,通过CAN接收节点的配置,将话题名称及对应的CAN ID绑定,可以同时支持多个话题消息的接收,能够实时接收来自控制设备中的消息并实时存储到对应的话题中,机器人应用程序利用IROS话题的实时订阅功能可实时获取消息并且不用关心底层的CAN协议。
本申请实施例提供的另一种基于CAN的大消息通信方法,应用于控制设备中,包括:
控制设备包括第二CAN接收接口、第二CAN模块;
通过第二CAN模块接收来自计算设备的第一消息;也就是接收来自第一CAN模块的第一消息,然后由控制设备安装的嵌入式应用调用第二CAN接收接口从第二CAN模块获取接收到的第一消息。
具体地,控制设备的CAN嵌入式应用通过第二CAN接收接口接收第二CAN模块的信息,进而实时收到应用程序发送的第一消息。
在本申请的一种实施例中,控制设备还包括第二CAN发送接口;嵌入式应用通过调用第二CAN发送接口将第二消息发送到第二CAN模块;通过第二CAN模块与计算设备中的第一CAN模块建立的基于CAN协议的通信连接,将第二消息发送至第一CAN模块。
具体地,控制设备的嵌入式应用通过调用第二CAN发送接口将第二消息发送到第二CAN模块。然后第二CAN模块通过双绞线发送到第一CAN模块。计算设备中的CAN发送节点利用IROS话题的实时订阅功能,保证了能够实时接收机器人应用程序发送的消息并通过第一CAN模块实时发送出去,由于CAN协议封装在了第一CAN发送接口中,所以保证发送的可靠性且开发人员无需掌握底层的CAN协议即可操作,降低了开发人员的工作难度。
如图3所示,机器人应用程序通过一个话题实时发送第一消息到话题1中,也可通过另一个话题2实时接收第二消息,同样控制设备上的嵌入式应用也能同时发送第二消息和接收第一消息,计算设备和控制设备通过IROS实现了CAN的大消息的可靠发送。
在本申请的一种实施例中,当计算设备的第一CAN发送接口发送第一消息或控制设备的第二CAN发送接口发送第二消息时,此时待发送的第一消息和第二消息都属于大消息,为了提高消息传输的高效性,将待发送的大消息拆分成多个CAN协议能识别的小消息;其中,首个小消息表示消息数目和总消息大小;将拆分后的小消息根据设定的可配置的CANID发送到目的地。
具体地,第一CAN发送接口与第二CAN发送接口用于将待发送的大消息拆分成多个CAN协议能识别的小消息,首个小消息为拆分后的消息数目及总消息大小,假设通过设定的CAN ID1通道进行发送;第一CAN接收接口与第二CAN接收接口通过标准CAN协议接收小消息,并根据首个小消息中包含的消息数目及总消息大小信息,将接收到小消息组合还原为一个大消息。
在本申请的一种实施例中,当第一CAN接收接口接收到小消息时,通过对应的CANID通道向第二CAN发送接口发送消息回执,以确认成功接收小消息;当第二CAN接收接口接收到小消息时,通过对应的CAN ID通道向第一CAN发送接口发送消息回执,以确认成功接收小消息;根据首个小消息包括的消息数目和总消息大小,将小消息组合还原成大消息。
具体地,第一CAN接收接口或第二CAN接收接口每收到一个小消息同时通过另一个CAN ID2通道发送该小消息的回执消息,第一CAN发送接口与第二CAN发送接口通过CAN ID2通道接收到回执消息就确认该次发送成功,否则会重发,该方案解决了因CAN缓冲区小或因接收端故障消息丢失的问题,提高了消息发送的可靠性,同时也会使数据传输的性能较好。第一CAN发送接口与第二CAN接收接口是成对配套的,第二CAN发送接口与第一CAN接收接口是成对配套的。
以上为本申请实施例提供的一种基于IROS的CAN大消息通信方法,基于同样的发明思路,本申请实施例还提供了相应的一种基于IROS的CAN大消息通信设备,如图4所示。
本实施例提供了一种基于IROS的CAN大消息通信设备,包括:
至少一个处理器;以及,
与至少一个处理器通信连接的存储器;其中,
存储器存储有可被至少一个处理器执行的指令,指令被至少一个处理器执行,以使至少一个处理器能够:
在计算设备中建立CAN发送节点、第一CAN发送接口,并配置第一CAN模块;其中,第一CAN发送接口用于封装CAN通信协议;
通过在计算设备中安装的应用程序将第一消息发送到话题中,然后由CAN发送节点从话题实时获取第一消息;
将第一消息通过CAN发送节点调用第一CAN发送接口,发送至第一CAN模块;
通过第一CAN模块与控制设备中的第二CAN模块建立的基于CAN协议的通信连接,向第二CAN模块发送第一消息。
基于同样的思路,本申请的一些实施例还提供了上述方法对应的介质。
本申请的一些实施例提供的一种基于IROS的CAN大消息通信存储介质,存储有计算机可执行指令,计算机可执行指令设置为:
在计算设备中建立CAN发送节点、第一CAN发送接口,并配置第一CAN模块;其中,第一CAN发送接口用于封装CAN通信协议;
通过在计算设备中安装的应用程序将第一消息发送到话题中,然后由CAN发送节点从话题实时获取第一消息;
将第一消息通过CAN发送节点调用第一CAN发送接口,发送至第一CAN模块;
通过第一CAN模块与控制设备中的第二CAN模块建立的基于CAN协议的通信连接,向第二CAN模块发送第一消息。
本申请中的各个实施例均采用递进的方式描述,各个实施例之间相同相似的部分互相参见即可,每个实施例重点说明的都是与其他实施例的不同之处。尤其,对于方法和介质实施例而言,由于其基本相似于方法实施例,所以描述的比较简单,相关之处参见方法实施例的部分说明即可。
本申请实施例提供的方法和介质与方法是一一对应的,因此,方法和介质也具有与其对应的方法类似的有益技术效果,由于上面已经对方法的有益技术效果进行了详细说明,因此,这里不再赘述方法和介质的有益技术效果。
还需要说明的是,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程方法商品或者方法不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程方法商品或者方法所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括要素的过程方法商品或者方法中还存在另外的相同要素。
以上仅为本申请的实施例而已,并不用于限制本申请。对于本领域技术人员来说,本申请可以有各种更改和变化。凡在本申请的精神和原理之内所作的任何修改、等同替换、改进等,均应包含在本申请的权利要求范围之内。
Claims (10)
1.一种基于IROS的CAN大消息通信方法,其特征在于,应用于计算设备中,所述计算设备基于智能机器人操作系统IROS运行,包括:
在所述计算设备中建立CAN发送节点、第一CAN发送接口,并配置第一CAN模块;其中,所述第一CAN发送接口用于封装CAN通信协议;
通过在所述计算设备中安装的应用程序将第一消息发送到话题中,然后由所述CAN发送节点从所述话题实时获取所述第一消息;
将所述第一消息通过所述CAN发送节点调用所述第一CAN发送接口,发送至所述第一CAN模块;
通过所述第一CAN模块与控制设备中的第二CAN模块建立的基于CAN协议的通信连接,向所述第二CAN模块发送所述第一消息。
2.根据权利要求1所述的方法,其特征在于,当所述计算设备接收来自所述控制设备的第二消息时,所述方法还包括:
所述计算设备还包括CAN接收节点、第一CAN接收接口;
通过所述第一CAN模块与所述第二CAN模块建立的基于CAN协议的通信连接,接收来自所述控制设备的第二消息;
通过所述CAN接收节点调用所述第一CAN接收接口,将所述第二消息从所述第一CAN模块接收至对应的话题中存储;
通过应用程序从所述对应的话题中获取所述第二消息。
3.根据权利要求1所述的方法,其特征在于,所述方法还包括:
根据IROS支持的话题实时订阅功能,建立多个话题类型,生成每个话题类型对应的话题名称;
通过CAN发送节点进行配置,将每个所述话题名称与对应的CAN ID绑定,以使所述第一消息能够实时发送。
4.根据权利要求3所述的方法,其特征在于,所述方法还包括:
通过CAN接收节点进行配置,将每个所述话题名称与对应的CAN ID绑定,以实时接收来自所述控制单元的第二消息;
将所述第二消息存储到对应的话题中。
5.一种基于CAN的大消息通信方法,其特征在于,应用于控制设备中,包括:
所述控制设备包括第二CAN接收接口、第二CAN模块;
通过第二CAN模块接收来自计算设备的第一消息;
由所述控制设备安装的嵌入式应用调用所述第二CAN接收接口从所述第二CAN模块获取接收到的所述第一消息。
6.根据权利要求5所述的方法,其特征在于,所述控制设备还包括第二CAN发送接口;
所述方法还包括:
所述嵌入式应用通过调用所述第二CAN发送接口将第二消息发送到所述第二CAN模块;
通过所述第二CAN模块与计算设备中的第一CAN模块建立的基于CAN协议的通信连接,将所述第二消息发送至所述第一CAN模块。
7.根据权利要求1或5所述的方法,其特征在于,所述方法还包括:
当计算设备的第一CAN发送接口或控制设备的第二CAN发送接口发送数据时,将待发送的大消息拆分成多个CAN协议能识别的小消息;
其中,首个小消息表示消息数目和总消息大小;
将拆分后的小消息根据设定的可配置的CAN ID发送到目的地。
8.根据权利要求7所述的方法,其特征在于,所述方法还包括:
当所述第一CAN接收接口接收到小消息时,通过对应的CAN ID通道向所述第二CAN发送接口发送消息回执,以确认成功接收所述小消息;
当所述第二CAN接收接口接收到小消息时,通过对应的CAN ID通道向所述第一CAN发送接口发送消息回执,以确认成功接收所述小消息;
根据所述首个小消息包括的消息数目和总消息大小,将所述小消息组合还原成大消息。
9.一种基于IROS的CAN大消息通信设备,其特征在于,包括:
至少一个处理器;以及,
与所述至少一个处理器通信连接的存储器;其中,
所述存储器存储有可被所述至少一个处理器执行的指令,所述指令被所述至少一个处理器执行,以使所述至少一个处理器能够:
在计算设备中建立CAN发送节点、第一CAN发送接口,并配置第一CAN模块;其中,所述第一CAN发送接口用于封装CAN通信协议;
通过在所述计算设备中安装的应用程序将第一消息发送到话题中,然后由所述CAN发送节点从所述话题实时获取所述第一消息;
将所述第一消息通过所述CAN发送节点调用所述第一CAN发送接口,发送至所述第一CAN模块;
通过所述第一CAN模块与控制设备中的第二CAN模块建立的基于CAN协议的通信连接,向所述第二CAN模块发送所述第一消息。
10.一种非易失性存储介质,存储有计算机可执行指令,其特征在于,所述计算机可执行指令设置为:
在计算设备中建立CAN发送节点、第一CAN发送接口,并配置第一CAN模块;其中,所述第一CAN发送接口用于封装CAN通信协议;
通过在所述计算设备中安装的应用程序将第一消息发送到话题中,然后由所述CAN发送节点从所述话题实时获取所述第一消息;
将所述第一消息通过所述CAN发送节点调用所述第一CAN发送接口,发送至所述第一CAN模块;
通过所述第一CAN模块与控制设备中的第二CAN模块建立的基于CAN协议的通信连接,向所述第二CAN模块发送所述第一消息。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202111408008.8A CN114143136A (zh) | 2021-11-19 | 2021-11-19 | 一种基于iros的can大消息通信方法、设备、存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202111408008.8A CN114143136A (zh) | 2021-11-19 | 2021-11-19 | 一种基于iros的can大消息通信方法、设备、存储介质 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN114143136A true CN114143136A (zh) | 2022-03-04 |
Family
ID=80391476
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202111408008.8A Pending CN114143136A (zh) | 2021-11-19 | 2021-11-19 | 一种基于iros的can大消息通信方法、设备、存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN114143136A (zh) |
Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101552785A (zh) * | 2009-05-07 | 2009-10-07 | 浙江大学 | 基于消息机制的用于海量数据传输的can总线通信协议 |
US20170203436A1 (en) * | 2014-07-08 | 2017-07-20 | Hongxing Wei | Robotic hybrid system application framework based on multi-core processor architecture |
CN108927808A (zh) * | 2018-08-15 | 2018-12-04 | 京东方科技集团股份有限公司 | 一种ros节点的通信方法、认证方法及装置 |
-
2021
- 2021-11-19 CN CN202111408008.8A patent/CN114143136A/zh active Pending
Patent Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101552785A (zh) * | 2009-05-07 | 2009-10-07 | 浙江大学 | 基于消息机制的用于海量数据传输的can总线通信协议 |
US20170203436A1 (en) * | 2014-07-08 | 2017-07-20 | Hongxing Wei | Robotic hybrid system application framework based on multi-core processor architecture |
CN108927808A (zh) * | 2018-08-15 | 2018-12-04 | 京东方科技集团股份有限公司 | 一种ros节点的通信方法、认证方法及装置 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN102457442A (zh) | 一种消息发送和读取方法、装置及中间件系统 | |
CN107741884B (zh) | 一种分层状态机实现消息推送的方法和装置 | |
CN101014019B (zh) | 一种系统间消息转发的通讯方法 | |
US20230080588A1 (en) | Mqtt protocol simulation method and simulation device | |
CN101567861B (zh) | 异构应用系统之间的数据同步方法及应用系统 | |
CN112532673B (zh) | 消息发送方法及装置、计算机可读存储介质、电子设备 | |
US20230388148A1 (en) | Data communication method and device | |
CN101145052B (zh) | 设备间实时信息交互系统和设备间实时信息交互方法 | |
CN110768840A (zh) | 通信设备的控制方法、装置、设备及存储介质 | |
CN114205183A (zh) | 基于实时操作系统的at指令协议栈的通信方法及系统 | |
CN114143136A (zh) | 一种基于iros的can大消息通信方法、设备、存储介质 | |
CN115022424B (zh) | 水电lcu控制器网卡虚拟控制方法、系统、设备及其介质 | |
CN114157997B (zh) | 一种iros话题桥接方法、设备及介质 | |
CN113254097A (zh) | 配置信息的下发方法和装置、电子设备和存储介质 | |
CN111682978A (zh) | 一种网络通信增强方法及系统 | |
CN115134361B (zh) | 一种自动驾驶软件平台的跨平台通信方法及装置 | |
US20200401446A1 (en) | Intermediary system for data streams | |
CN111711581A (zh) | 一种通信方法、载波代理模块及台区融合终端 | |
CN113301121B (zh) | 一种机器人遥操作中指令的传输方法及系统 | |
CN110602245B (zh) | 提高应用软件吞吐量的方法、存储介质 | |
CN114710755B (zh) | 一种消息处理方法、车载通讯装置、电子设备及存储介质 | |
CN107707492A (zh) | 一种上报和下发报文的方法及装置 | |
CN114615187B (zh) | 一种逻辑接口数据通信方法及装置 | |
CN117692493A (zh) | 一种非实时域iros与实时域应用交互通信方法和系统 | |
JP2001243202A (ja) | 2つのソフトウェアエージェント間の通信に使用される通信手段を動的に変更するためのシステム |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
RJ01 | Rejection of invention patent application after publication | ||
RJ01 | Rejection of invention patent application after publication |
Application publication date: 20220304 |