Взаимодействие собственной системы 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.

Другие вопросы по тегам