Взаимодействие собственной системы DDS с ROS2
Чтобы общаться с издателем на основе ROS2 и подписчиком на основе RTI Connext, им обоим необходимо иметь совместимые настройки QoS.
Я использую RTI Connector для python и использую XML Application Creation для запуска подписчика.
Я бегу talker_py
в ROS2, который имеет QoS по умолчанию и подписаться на эти сообщения в RTI Connext Pro.
ROS2 IDL выглядит так:
{
module msg
{
module dds_ {
struct String_ {
String data_;
};
};
};
};
Я использую rtiddsgen
утилита для преобразования его в файл XML. Вот преобразованный XML:
<?xml version="1.0" encoding="UTF-8"?>
<types xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="/path/to/RTIInstall/rti_connext_dds-5.3.1/bin/../resource/app/app_support/rtiddsgen/schema/rti_dds_topic_types.xsd">
<module name="std_msgs">
<module name="msg">
<module name="dds_">
<struct name="String_">
<member name="data_" type="string"/>
</struct>
</module>
</module>
</module>
</types>
Я добавил <types>
к моему USER_QoS.xml
и это выглядит так:
<dds xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:noNamespaceSchemaLocation="http://community.rti.com/schema/5.1.0/rti_dds_profiles.xsd" version="5.1.0">
<!-- Qos Library -->
<qos_library name="QosLibrary">
<qos_profile name="DefaultProfile" is_default_qos="true">
<datawriter_qos>
<history>
<kind>KEEP_LAST_HISTORY_QOS</kind>
<depth>1000</depth>
</history>
<reliability>
<kind>RELIABLE_RELIABILITY_QOS</kind>
</reliability>
<durablitiy>
<kind>VOLATILE_DURABILITY_QOS</kind>
</durablitiy>
</datawriter_qos>
<participant_qos>
<transport_builtin>
<mask>UDPV4 | SHMEM</mask>
</transport_builtin>
<!-- Turn on monitoring -->
<!-- Begin Monitoring
<property>
<value>
<element>
<name>rti.monitor.library</name>
<value>rtimonitoring</value>
</element>
<element>
<name>rti.monitor.create_function_ptr</name>
<value>$(NDDS_MONITOR)</value>
</element>
</value>
</property>
End Monitoring -->
</participant_qos>
</qos_profile>
</qos_library>
<!-- types -->
<types>
<module name="std_msgs">
<module name="msg">
<module name="dds_">
<struct name="String_" extensibility="extensible">
<member name="data_" type="std_msgs::msg::dds_::string" "/>
</struct>
</module>
</module>
</module>
</types>
<!-- Domain Library -->
<domain_library name="MyDomainLibrary">
<domain name="MyDomain" domain_id="0">
<register_type name="std_msgs::msg::dds_::String_" type_ref="std_msgs::msg::dds_::String_" />
<topic name="chatter" register_type_ref="std_msgs::msg::dds_::String_"/>
</domain>
</domain_library>
<!-- Participant library -->
<domain_participant_library name="MyParticipantLibrary">
<domain_participant name="Zero" domain_ref="MyDomainLibrary::MyDomain">
<subscriber name="MySubscriber">
<data_reader name="MyChatterReader" topic_ref="chatter" />
</subscriber>
</domain_participant>
</domain_participant_library>
</dds>
Теперь, когда я использую Соединитель RTI для Python, первый шаг здесь пытается загрузить USER_QoS.xml
файл и всегда выдает ошибку Unable to parse the .xml file
, Я сильно чувствую, что это из-за наличия ключевого слова module
в <types>
определение.
Вот скрипт на Python для Коннектора RTI:
from __future__ import print_function
from sys import path as sysPath
from os import path as osPath
from time import sleep
filepath = osPath.dirname(osPath.realpath(__file__))
sysPath.append(filepath + "/../../../")
import rticonnextdds_connector as rti
connector = rti.Connector("MyParticipantLibrary::Zero",
filepath + "/../User_QoS.xml")
inputDDS = connector.getInput("MySubscriber::MyChatterReader")
for i in range(1, 500):
inputDDS.take()
numOfSamples = inputDDS.samples.getLength()
for j in range(1, numOfSamples+1):
if inputDDS.infos.isValid(j):
# This gives you a dictionary
sample = inputDDS.samples.getDictionary(j)
x = sample['x']
# Or you can just access the field directly
toPrint = "Received x: " + repr(x)
print(toPrint)
sleep(2)
Я чувствую, что разъем не может разобрать это module
ключевое слово. Может ли это быть так?
1 ответ
Когда я пытаюсь выполнить настройку, Connector предоставляет больше выходных данных, чем вы указали. Среди прочего:
RTIXMLParser_validateOnStartTag:Parse error at line 15: Unexpected tag 'durablitiy'
Это ошибка в вашем XML, в соответствии со схемой имя тега должно быть durability
,
Тогда вы, кажется, сделали ошибки копирования-вставки при копировании сгенерированного <types>
тег и его содержимое в ваш XML. Для этого соединитель выдает следующую ошибку:
RTIXMLParser_parseFromFile_ex:Parse error at line 50: not well-formed (invalid token)
Действительно, в конце вашей строки 50 есть лишняя цитата:
<member name="data_" type="std_msgs::msg::dds_::string" "/>
Кроме того, значение type
атрибут отличается от сгенерированного XML, который вы пытались вставить здесь, который имеет:
<member name="data_" type="string"/>
После исправления этих ошибок Connector создает правильные экземпляры.
Чтобы проверить ваш XML-файл на соответствие его схеме, вы можете / должны использовать соответствующее определение схемы XSD.