diff --git a/astrobee/config/communications/comms_bridge.config b/astrobee/config/communications/comms_bridge.config index 3c0f86a4b3..0261712519 100644 --- a/astrobee/config/communications/comms_bridge.config +++ b/astrobee/config/communications/comms_bridge.config @@ -15,18 +15,11 @@ -- License for the specific language governing permissions and limitations -- under the License. --- param for each bridge component use the following params -- --- ABREV = First Letters of Component Ex: ros_string_rapid_text_msg = RSRTM -- --- use_ABREV bool: turn this component on? -- --- sub_topic_ABREV string: [ROS: subscribe topic] or [RAPID: subscribe topic suffix] -- --- pub_topic_ABREV string: [ROS: publish topic] or [RAPID: publish topic suffix] -- --- queue_size_ABREV int: queue size -- - require "context" -- Enable DDS communications on start -- -- If false, a trigger call will be needed to start communications -- -started = false; +started = false -- Rapid subscribers -- rapid_sub_names = {"Bumble", "Honey", "Queen", "Bsharp", "Wannabee"} @@ -57,4 +50,4 @@ links = { } verbose = 2 -ad2pub_delay = 3.0 \ No newline at end of file +ad2pub_delay = 3.0 diff --git a/communications/comms_bridge/README.md b/communications/comms_bridge/README.md index 43ec478cef..d13d6f3803 100644 --- a/communications/comms_bridge/README.md +++ b/communications/comms_bridge/README.md @@ -1,26 +1,13 @@ -\page coms_bridge Modular Polymorphic ROS Relay +\page comms_bridge DDS Generic Comms Bridge -See that dir for architecture info. - -This is unidirectional, supporting an arbitrary number of in-out topics. -For bi-directional, an additional paired set of flipped subscribers/publishers can be run. - -This is a demonstration of unidirectional relaying of ROS messages from one topic to another, without any specification of the message types, nor even the requirement that the types be available to the nodes at compile-time. - -This is a demonstration insofar as the metadata backchannel is itself just ROS topics on the same ROS master, but this can be replaced with other conduits. +This is bidirectional bridge to communicate between different astrobees or ros clients using DDS to relay the topics. Supporting an arbitrary number of in-out topics, relaying of ROS messages from one topic to another, without any specification of the message types, nor even the requirement that the types be available to the nodes at compile-time. ## Basic architecture -- The subscriber node (A) subscribes to a specified list of topics +- The subscriber class (A) subscribes to a specified list of topics - Upon receipt of the first message on a given forwarded topic, A sends an advertisement message to a metadata "advertisement" topic -- Receiving the metadata advertisement, the republisher node (B) itself advertises the output (republished) topic +- Receiving the metadata advertisement, the republisher class (B) itself advertises the output (republished) topic - The first and all subsequent messages A receives are serialized and published to a metadata "content" topic - A delay is implemented in B between its advertising and subsequent republishing of any messages to practically avoid the potential race condition of a subscriber on that end missing the first message as it connects to B only upon seeing the advertisement - Otherwise, B deserializes all messages received on the "content" metadata topic, looks up the topic in previously received "advertisement" metadata, and republishes the message on the output topic - -## Reverse channel - -To account for situations in which the republisher node may be restarted after the subscriber node has already been running, or to handle implementations in which advertisement metadata could be lost (eg if the metadata channels were implemented on a lossy medium), the republisher can request retransmission of "advertisement" metadata for any topic. It does this by publishing a message to a "reset" metadata channel, specifying the topic name, to which the the subscriber node listens and retransmits the advertisement. - -