在自動(dòng)駕駛與機(jī)器人仿真領(lǐng)域,傳感器數(shù)據(jù)的高效交互是連接虛擬仿真與實(shí)際系統(tǒng)的關(guān)鍵紐帶。ROS(Robot Operating System) 作為行業(yè)通用的機(jī)器人操作系統(tǒng),其傳感器數(shù)據(jù)交互機(jī)制直接影響仿真的真實(shí)性與系統(tǒng)集成的便捷性。
本文基于對(duì)aiSim 中各類 ROS 傳感器(時(shí)鐘、GPS、IMU、激光雷達(dá)、車輛、相機(jī))模塊的源碼學(xué)習(xí),梳理了它們的共性架構(gòu)與實(shí)現(xiàn)要點(diǎn),并結(jié)合 aiSim?SDK 中相機(jī)模塊的通用設(shè)計(jì),對(duì)跨中間件擴(kuò)展性提出思考。
通用架構(gòu)與設(shè)計(jì)模式
aiSim 中 ROS 傳感器模塊的設(shè)計(jì)遵循了一系列通用原則,這些原則構(gòu)成了整個(gè)系統(tǒng)的 “骨架”,確保了不同傳感器在交互方式、數(shù)據(jù)處理等方面的一致性。
雙層分離:職責(zé)清晰的架構(gòu)基礎(chǔ)
aiSim 的 ROS 傳感器模塊采用雙層分離架構(gòu),將與仿真引擎的交互和與 ROS 的橋接功能明確分開(kāi):
實(shí)現(xiàn)層(xxx_ros_sensor.cpp/.h):專注于與仿真引擎的交互,負(fù)責(zé)從仿真中采集數(shù)據(jù)、進(jìn)行時(shí)間同步處理,并將仿真數(shù)據(jù)封裝成 ROS 消息;
代理層(xxx_ros_sensor_proxy.h):作為 ROS 節(jié)點(diǎn)與仿真系統(tǒng)的連接樞紐,承擔(dān)節(jié)點(diǎn)延遲初始化、ROS 回調(diào)函數(shù)注冊(cè)及話題消息篩選等核心功能。通過(guò)封裝標(biāo)準(zhǔn)化的 ROS 通信接口(如自定義消息類型、服務(wù)接口),實(shí)現(xiàn)了對(duì)實(shí)現(xiàn)層與應(yīng)用層模塊的有效解耦,避免了實(shí)現(xiàn)層內(nèi)部接口直接暴露給應(yīng)用層節(jié)點(diǎn)。
這種架構(gòu)使得模塊的維護(hù)和擴(kuò)展更加便捷,當(dāng) ROS 版本更新或中間件更換時(shí),主要修改代理層即可,對(duì)實(shí)現(xiàn)層的影響較小。
發(fā)布者創(chuàng)建流程與消息發(fā)布機(jī)制
發(fā)布者的創(chuàng)建和消息發(fā)布是傳感器與 ROS 進(jìn)行數(shù)據(jù)交互的核心流程:
發(fā)布者創(chuàng)建:首先通過(guò)單例模式獲取 ROS 節(jié)點(diǎn),auto& ros_bridge = RosBridge::Instance(true); auto node = ros_bridge.GetNode();,然后在構(gòu)造函數(shù)中創(chuàng)建發(fā)布者并綁定話題,m_publisher = node->create_publisher("/topic_name", qos);,確保了發(fā)布者與特定話題的關(guān)聯(lián);
消息發(fā)布機(jī)制:在SendMsg函數(shù)中,將仿真輸出的數(shù)據(jù)轉(zhuǎn)換為 ROS 消息格式,設(shè)置消息頭的時(shí)間戳為當(dāng)前節(jié)點(diǎn)時(shí)間,msg.header.stamp = node->now();,然后填充數(shù)據(jù)并發(fā)布,m_publisher->publish(msg);,保證了數(shù)據(jù)的及時(shí)傳遞。
動(dòng)態(tài)注冊(cè)與QoS
通過(guò)動(dòng)態(tài)注冊(cè)和QoS 與時(shí)間同步兩大機(jī)制,分別實(shí)現(xiàn)了部署靈活性的提升與數(shù)據(jù)處理可靠性的保障:
動(dòng)態(tài)注冊(cè):借助 SensorFactory 和 ConfiguratorApplication,從 JSON 配置文件中動(dòng)態(tài)創(chuàng)建傳感器實(shí)例,擺脫了對(duì)硬編碼的依賴。這意味著在不修改代碼的情況下,通過(guò)修改配置文件就能添加或修改傳感器,極大地提高了系統(tǒng)的靈活性。
QoS 及時(shí)間同步:QoS 的隊(duì)列長(zhǎng)度設(shè)置保證了未處理消息的緩存,防止高頻數(shù)據(jù)丟失;而 ClockRosSensor 發(fā)布的/clock話題,為各節(jié)點(diǎn)提供了統(tǒng)一的仿真時(shí)間基準(zhǔn),確保了整個(gè)系統(tǒng)時(shí)鐘的一致性,避免了因時(shí)間不同步導(dǎo)致的數(shù)據(jù)處理錯(cuò)誤。
各傳感器模塊要點(diǎn)
在通用架構(gòu)的基礎(chǔ)上,不同類型的傳感器根據(jù)其功能特點(diǎn),有著各自獨(dú)特的實(shí)現(xiàn)要點(diǎn),共同構(gòu)成了整個(gè)傳感器系統(tǒng)。
aiSim?SDK 傳感器模塊:通用化示例
雖然上面的內(nèi)容聚焦在 ROS 中間件上,aiSim?SDK 的傳感器模塊(以camera為例)設(shè)計(jì)卻不依賴 ROS,可直接擴(kuò)展至其他通信框架,為跨中間件擴(kuò)展提供了可能,其相機(jī)模塊的通用化設(shè)計(jì)具有代表性。
消息定義(camera_sensor_messages.h)
MessageType 枚舉:列舉了傳感器初始化、訂閱、配置查詢及各種相機(jī)輸出(顏色、深度、分割、邊界框、車道、元數(shù)據(jù)等)的一致化消息類型。
Config與請(qǐng)求/響應(yīng)機(jī)制:通過(guò) InitRequest/InitResponse、SubscribeRequest、GetConfigRequest/GetConfigResponse 等消息,實(shí)現(xiàn)對(duì)更新間隔、時(shí)間偏移和可選功能的動(dòng)態(tài)配置管理。
統(tǒng)一消息封裝:以 CameraMessage 為基類衍生多種具體數(shù)據(jù)消息,并使用std::variant 將它們封裝為單一類型以簡(jiǎn)化處理。
代理層(camera_sensor_proxy.h)
初始化與配置:構(gòu)造函數(shù)通過(guò) InitRequest 向底層傳感器發(fā)送配置并校驗(yàn)響應(yīng)錯(cuò)誤,以確保代理層與模擬傳感器的對(duì)接正確。
統(tǒng)一回調(diào)訂閱:模板化的 SubscribeToNotification 方法為所有 CameraMessageTypes 注冊(cè)同一回調(diào),且對(duì)高頻大數(shù)據(jù)的 ColorImageMessage 采用零拷貝以降低性能開(kāi)銷。
可插拔通信接口:依賴 BinarySerializerClient 抽象,代理層僅需替換該序列化/傳輸實(shí)現(xiàn),便可對(duì)接不同中間件或網(wǎng)絡(luò)協(xié)議。
核心處理(camera_sensor.cpp)
異步捕獲與處理:使用 CaptureNonBlocking 非阻塞地獲取圖像幀,并在 ProcessDataAsync 中按需生成多種消息(如彩色圖、深度圖、分割圖等)。
功能插件化:通過(guò)可選的 BoundingBoxCalculator 和 LaneCalculator 模塊,動(dòng)態(tài)啟用目標(biāo)邊界框計(jì)算和車道線檢測(cè),無(wú)需修改核心流程即可擴(kuò)展新算法。
統(tǒng)一消息發(fā)布:FillCommonMessageFields 在所有消息中注入車輛名、傳感器名、時(shí)間戳與序列號(hào),并通過(guò)零拷貝或常規(guī)方式一次性發(fā)布所有可用數(shù)據(jù)。
模塊化與可擴(kuò)展性總結(jié)
aiSim中ROS傳感器模塊的設(shè)計(jì)充分體現(xiàn)了模塊化和可擴(kuò)展性的理念。通過(guò)通用架構(gòu)的搭建,確保了不同傳感器在交互方式上的一致性;各傳感器模塊根據(jù)自身特點(diǎn)進(jìn)行個(gè)性化實(shí)現(xiàn),滿足了不同的數(shù)據(jù)采集需求;而 aiSim-SDK 的通用化設(shè)計(jì),則突破了 ROS 中間件的限制,為系統(tǒng)向更多通信框架擴(kuò)展奠定了基礎(chǔ)。
這種設(shè)計(jì)不僅提高了仿真系統(tǒng)的開(kāi)發(fā)效率和維護(hù)便捷性,也使得仿真數(shù)據(jù)能夠更順暢地與實(shí)際自動(dòng)駕駛系統(tǒng)進(jìn)行集成,為自動(dòng)駕駛技術(shù)的研發(fā)提供了有力的支撐。在未來(lái),隨著技術(shù)的不斷發(fā)展,這種模塊化、可擴(kuò)展的設(shè)計(jì)思路將在更多領(lǐng)域發(fā)揮重要作用。
-
傳感器
+關(guān)注
關(guān)注
2573文章
53900瀏覽量
780920 -
自動(dòng)駕駛
+關(guān)注
關(guān)注
791文章
14551瀏覽量
174276 -
ROS
+關(guān)注
關(guān)注
1文章
290瀏覽量
18301
發(fā)布評(píng)論請(qǐng)先 登錄
基于SOA的數(shù)字電視中間件系統(tǒng)的研究與實(shí)現(xiàn)
將集群技術(shù)引入到RFID中間件的設(shè)計(jì)討論
一個(gè)基于漏洞掃描的安全中間件架構(gòu)設(shè)計(jì)
基于JMS的RFID中間件設(shè)計(jì)與實(shí)現(xiàn)
NGB中間件標(biāo)準(zhǔn)考慮因素

基于通用中間件接口服務(wù)器的遠(yuǎn)程醫(yī)療信息系統(tǒng)

基于ARM的RFID中間件系統(tǒng)設(shè)計(jì)
常見(jiàn)的中間件有哪些?匯總解析
RFID系統(tǒng)中間件平臺(tái)架構(gòu)研究
物聯(lián)網(wǎng)軟件系統(tǒng)中的RFID中間件介紹

RFID中間件是什么東西
基于SOA的RFID中間件如何來(lái)設(shè)計(jì)

評(píng)論