Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: aimrt_py support ros2 protocol interface #95

Merged
merged 55 commits into from
Nov 21, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
55 commits
Select commit Hold shift + click to select a range
5a79b74
feat: add checks for ROS 2 message type support
zhangyi1357 Nov 7, 2024
11ac735
build: update file globbing to include configure dependencies
zhangyi1357 Nov 7, 2024
455a2fc
feat: add ROS2 message support and enhance publishing functionality
Nov 8, 2024
67e98c8
feat: add HTTP and ROS2 example configurations and applications
Nov 8, 2024
cdb8924
chore: disable unimplemented copy and move functions
Nov 8, 2024
0650f44
feat: enhance message publishing with iteration and logging
Nov 8, 2024
f7691c8
refactor: reorganize and encapsulate ROS2 message handling functionality
Nov 8, 2024
6aa08bb
refactor: streamline protobuf and ROS2 message publishing
Nov 11, 2024
3751ed1
refactor: streamline messaging functions
Nov 11, 2024
079306b
refactor: simplify message subscription handling and reduce publish f…
Nov 11, 2024
219a300
fix: remove unnecessary error message for ROS 1 type detection
Nov 11, 2024
ab6521e
docs: update README and add ros2 channel examples
Nov 11, 2024
605cf09
feat: support ros2 message types in aimrt_py channel
Nov 11, 2024
78a4425
fix: improve error handling during ROS2 message serialization and des…
Nov 11, 2024
f53d338
fix: correct argument validation and formatting
Nov 11, 2024
ccc44ba
refactor: streamline message conversion logic
Nov 11, 2024
39aa0ab
feat: add ROS2 support to Python runtime
Nov 12, 2024
b9a0016
feat: enhance message type handling for publishers and subscribers
Nov 12, 2024
ae64f1c
feat: update message types to use RosTestMsg for better compatibility
Nov 12, 2024
780864c
chore: consolidate pybind11 includes
Nov 12, 2024
8a67e4b
docs: add ROS2 message support details and example links
Nov 12, 2024
c794cf4
chore: update copyright information to reflect new authorship
Nov 12, 2024
60011e4
feat: add ROS2 RPC client and server examples with configurations
zhangyi1357 Nov 14, 2024
e75460d
feat: update RPC request and response handling
zhangyi1357 Nov 14, 2024
95ad436
refactor: simplify RPC response handling
zhangyi1357 Nov 14, 2024
95d26b8
refactor: streamline publisher and subscriber method names
zhangyi1357 Nov 14, 2024
475b6af
chore: update configuration file paths for gRPC client and server exa…
zhangyi1357 Nov 14, 2024
31cb039
refactor: rename internal methods for clarity
zhangyi1357 Nov 14, 2024
7076dd3
feat: add service type validation and improve bash scripts
zhangyi1357 Nov 15, 2024
4585e11
feat: extend RPC response data structure and improve logging
zhangyi1357 Nov 15, 2024
14274d9
feat: add support for static and dynamic arrays in RPC service
zhangyi1357 Nov 18, 2024
aa85968
feat: add support for new ROS message types
zhangyi1357 Nov 18, 2024
6ad0e57
refactor: improve type mapping and message copy functions
zhangyi1357 Nov 18, 2024
f97f3c0
refactor: improve message copying and moving functions
zhangyi1357 Nov 19, 2024
068716e
refactor: simplify message type support functions
zhangyi1357 Nov 19, 2024
b76018f
refactor: streamline ROS message handling and improve introspection s…
zhangyi1357 Nov 19, 2024
5e6ae7f
fix: ensure pointers for ROS message creation and destruction are valid
zhangyi1357 Nov 19, 2024
b8fd122
feat: enhance RosTestRpc method signature for better type safety
zhangyi1357 Nov 19, 2024
97e362e
refactor: simplify parameter naming in RPC proxy function
zhangyi1357 Nov 19, 2024
5542a83
fix: restrict static array sizes in RosTestRpc service
zhangyi1357 Nov 19, 2024
079c0c1
feat: enhance python runtime generation for ROS2 services
zhangyi1357 Nov 19, 2024
bb37ded
refactor: update RPC service and client implementations to use ROS2 n…
zhangyi1357 Nov 19, 2024
a5372b6
chore: update .gitignore to exclude generated files
zhangyi1357 Nov 19, 2024
f250378
refactor: streamline response structure for RosTestRpc
zhangyi1357 Nov 19, 2024
42811d0
chore: update log level to INFO for consistency
zhangyi1357 Nov 19, 2024
bcfa9c0
docs: add README for ros2 rpc examples
zhangyi1357 Nov 19, 2024
b5625ec
feat: enhance aimrt_py channel with rpc support for ros2 message types
zhangyi1357 Nov 19, 2024
059d5e7
docs: add ros2_rpc example to Python interface section
zhangyi1357 Nov 19, 2024
116dc13
chore: add spacing for improved readability in service proxy class
zhangyi1357 Nov 19, 2024
d107f4f
chore: standardize argument names for RPC generator
zhangyi1357 Nov 19, 2024
3cb5d3f
docs: update RPC documentation to include ROS2 Srv support
zhangyi1357 Nov 19, 2024
f341fc0
style: standardize whitespace in RosTestRpc.srv
zhangyi1357 Nov 19, 2024
a5cea2c
build: exclude ROS2 specific files from the build if not using ROS2
zhangyi1357 Nov 19, 2024
1fd6b4c
style: add missing newline at end of file for consistency
zhangyi1357 Nov 19, 2024
9bf6eb8
refactor: rename copy function to improve clarity
zhangyi1357 Nov 19, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
refactor: streamline messaging functions
Enhance message publishing by consolidating function calls and improving clarity. Update context handling to better support message serialization types, allowing for a more flexible interaction with both protobuf and ROS2 messages.
  • Loading branch information
zhangyi committed Nov 11, 2024
commit 3751ed1fc5e8ed45086c59feb642cb25d1f4dc35
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,7 @@ def main():
msg = String()
for i in range(1000):
msg.data = f"Hello, AimRT! {i}"
aimrt_py.PublishRos2Message(publisher, msg)
aimrt_py.Publish(publisher, msg)

# Sleep for seconds
time.sleep(1)
Expand Down
4 changes: 2 additions & 2 deletions src/runtime/python_runtime/__init__.py
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
# Copyright (c) 2023, AgiBot Inc.
# All rights reserved.

from .aimrt_py_chn import (Publish, PublishRos2Message, RegisterPublishType,
Subscribe, SubscribeRos2Message)
from .aimrt_py_chn import (Publish, RegisterPublishType, Subscribe,
SubscribeRos2Message)
from .aimrt_py_log import *
from .aimrt_python_runtime import *
62 changes: 35 additions & 27 deletions src/runtime/python_runtime/aimrt_py_chn.py
Original file line number Diff line number Diff line change
Expand Up @@ -36,19 +36,19 @@ def _DeserializeProtobufMessage(msg_buf: bytes,
return msg


def _CreateContextRef(ctx_or_type) -> aimrt_python_runtime.ContextRef:
def _CreateContextRef(ctx_or_type, default_serialization_type: str) -> aimrt_python_runtime.ContextRef:
if isinstance(ctx_or_type, aimrt_python_runtime.Context):
ctx_ref = aimrt_python_runtime.ContextRef(ctx_or_type)
elif isinstance(ctx_or_type, aimrt_python_runtime.ContextRef):
ctx_ref = ctx_or_type
else:
serialization_type = ctx_or_type if isinstance(ctx_or_type, str) else "pb"
serialization_type = ctx_or_type if isinstance(ctx_or_type, str) else default_serialization_type
ctx = aimrt_python_runtime.Context()
ctx.SetSerializationType(serialization_type)
ctx_ref = aimrt_python_runtime.ContextRef(ctx)

if ctx_ref.GetSerializationType() == "":
ctx_ref.SetSerializationType("pb")
ctx_ref.SetSerializationType(default_serialization_type)

return ctx_ref

Expand Down Expand Up @@ -82,48 +82,56 @@ def Publish(publisher: aimrt_python_runtime.PublisherRef, second, third=None):
"""Publish a message to a channel.

This function can be called in following ways:
- Publish(publisher, pb_msg)
- Publish(publisher, pb_msg, ctx)
- Publish(publisher, pb_msg, serialization_type)
- Publish(publisher, ctx, pb_msg)
- Publish(publisher, serialization_type, pb_msg)
- Publish(publisher, msg)
- Publish(publisher, msg, ctx)
- Publish(publisher, msg, serialization_type)
- Publish(publisher, ctx, msg)
- Publish(publisher, serialization_type, msg)

pb_msg: google.protobuf.message.Message
msg: google.protobuf.message.Message | Ros2MsgType
ctx: aimrt_python_runtime.Context or aimrt_python_runtime.ContextRef
serialization_type: str

Args:
publisher (aimrt_python_runtime.PublisherRef): channel publisher
second: pb_msg or ctx or serialization_type
third: pb_msg or ctx or serialization_type or None
second: msg or ctx or serialization_type
third: msg or ctx or serialization_type or None
Raises:
TypeError: if the arguments are invalid
"""
if isinstance(second, google.protobuf.message.Message):
pb_msg = second
msg = second
ctx_or_type = third
message_type = "pb"
elif isinstance(third, google.protobuf.message.Message):
pb_msg = third
msg = third
ctx_or_type = second
message_type = "pb"
elif check_is_valid_ros2_msg_type(second):
msg = second
ctx_or_type = third
message_type = "ros2"
elif check_is_valid_ros2_msg_type(third):
msg = third
ctx_or_type = second
message_type = "ros2"
else:
raise TypeError("Invalid arguments, no protobuf message found")
raise TypeError("Invalid arguments, no protobuf message or ROS2 message found")

if isinstance(ctx_or_type, (aimrt_python_runtime.Context, aimrt_python_runtime.ContextRef, str)) or \
ctx_or_type is None:
ctx_ref = _CreateContextRef(ctx_or_type)
serialized_msg = _SerializeProtobufMessage(pb_msg, ctx_ref.GetSerializationType())
publisher.PublishPbMessageWithCtx(f"pb:{pb_msg.DESCRIPTOR.full_name}", ctx_ref, serialized_msg)
else:

if not isinstance(ctx_or_type, (aimrt_python_runtime.Context, aimrt_python_runtime.ContextRef, str)) and \
ctx_or_type is not None:
raise TypeError(
f"Invalid context type: {type(ctx_or_type)}, "
f"only 'aimrt_python_runtime.Context' or 'aimrt_python_runtime.ContextRef' or 'str' is supported")


def PublishRos2Message(publisher: aimrt_python_runtime.PublisherRef, msg: Ros2MsgType):
ctx = aimrt_python_runtime.Context()
ctx.SetSerializationType("ros2")
ctx_ref = aimrt_python_runtime.ContextRef(ctx)
publisher.PublishPbMessageWithCtx("ros2:" + msg.__class__.__name__, ctx_ref, msg)
if message_type == "pb":
ctx_ref = _CreateContextRef(ctx_or_type, default_serialization_type="pb")
serialized_msg = _SerializeProtobufMessage(msg, ctx_ref.GetSerializationType())
publisher.PublishPbMessageWithCtx(f"pb:{msg.DESCRIPTOR.full_name}", ctx_ref, serialized_msg)
elif message_type == "ros2":
ctx_ref = _CreateContextRef(ctx_or_type, default_serialization_type="ros2")
publisher.PublishRos2MessageWithCtx("ros2:" + msg.__class__.__name__, ctx_ref, msg)


def Subscribe(subscriber: aimrt_python_runtime.SubscriberRef,
Expand Down Expand Up @@ -163,7 +171,7 @@ def handle_callback(ctx_ref: aimrt_python_runtime.ContextRef, msg_buf: bytes):
except Exception as e:
print(f"AimRT channel handle get exception, {e}")

subscriber.SubscribeWithCtx(aimrt_ts, handle_callback)
subscriber.SubscribePbMessageWithCtx(aimrt_ts, handle_callback)


def SubscribeRos2Message(subscriber: aimrt_python_runtime.SubscriberRef,
Expand Down