naoki-mizuno/ds4_driver

ds4_twist_node crashes on foxy-devel

3mrrrx opened this issue · 10 comments

I am having trouble running the "ds4_twist_node.py " on the "foxy-devel" branch.

the python script crashes on line 73:

val = eval(expr, {}, input_vals)

as the expr is allways of type None!

thanks for the support

Thanks for reporting! ds4_twist_node.py seems to be working in my environment. Could you elaborate more about your environment and what you tried so far?

thank you for the quick reply.

I just setup every thing two days ago, so i might have newer versions of some code. but i am not sure about this.

but everything is pretty much standard. i am using the "foxy-devel" branch.

when i echo the /status topic, and the output seams normal.

i also check if the ds4_twist.py is subscribing to the topic and getting the data, which seam to be the case.

i think the error happens in the part where the data from the /status topic is beaing mapped to the twist topic.

this is the error:

`
ros2 run ds4_driver ds4_twist_node.py

Traceback (most recent call last):
File "/home/ubuntu/ros2_example_ws/install/ds4_driver/lib/ds4_driver/ds4_twist_node.py", line 101, in
main()
File "/home/ubuntu/ros2_example_ws/install/ds4_driver/lib/ds4_driver/ds4_twist_node.py", line 95, in main
rclpy.spin(node)
File "/opt/ros/foxy/lib/python3.8/site-packages/rclpy/init.py", line 191, in spin
executor.spin_once()
File "/opt/ros/foxy/lib/python3.8/site-packages/rclpy/executors.py", line 714, in spin_once
raise handler.exception()
File "/opt/ros/foxy/lib/python3.8/site-packages/rclpy/task.py", line 239, in call
self._handler.send(None)
File "/opt/ros/foxy/lib/python3.8/site-packages/rclpy/executors.py", line 429, in handler
await call_coroutine(entity, arg)
File "/opt/ros/foxy/lib/python3.8/site-packages/rclpy/executors.py", line 354, in _execute_subscription
await await_or_execute(sub.callback, msg)
File "/opt/ros/foxy/lib/python3.8/site-packages/rclpy/executors.py", line 118, in await_or_execute
return callback(*args)
File "/home/ubuntu/ros2_example_ws/install/ds4_driver/lib/ds4_driver/ds4_twist_node.py", line 80, in cb_status
val = eval(expr, None, input_vals)
TypeError: eval() arg 1 must be a string, bytes or code object
`

Okay, I was able to reproduce the problem. It happens when you don't have the inputs parameter defined. You must either specify it via command line arguments or use ros2 launch ds4_driver ds4_twist.launch.xml.

Although, I did update the code so it doesn't crash when no parameter is defined, so please try out the latest commit.

great!!! thank you....

i am still in the early stages of my project... that is why i was starting the nodes directly....

would be great to add the start/launch cmd to the read me!

No problem! The README was indeed outdated so I updated it with the correct instructions.

Hallo Again,

so basically to get the ds4_twist node to work with turtlesim i had to fix another bug.

the basic turtelsim node required a "none-stamped" type for the /cmd_vel topic, but the stamped argument is not passed when set in the launch.xml file.

furthermore the line 74 of ds4_twist.py gives an error:

'AttributeError: 'Twist' object has no attribute 'twist''

and thus has to be changed to something like :

twist = to_pub #.twist

with this quick fix i was able to get turtlesim to work with this node.

the bigger picture.... what i am trying to do with this node is to map the /status topic of this ds4_node to an arbitrary topic. thus making it possilble to control motors and other functions in ros2 using the ds4 controler.

how difficult would it be to add an arbitrary confi.yaml file that would do this kind of mapping?

thank you for the support!

The stamped parameter in ds4_twist node controls whether it should output a Twist or a TwistStamped.

Not quite sure what you mean by "mapping to an arbitrary topic."

The stamped parameter in ds4_twist node controls whether it should output a Twist or a TwistStamped.

yes... think I am a aware of this part.. but when using the "Twist" output the code using in the library didn't work for two reasons:

  1. the Stamped Var is not read from the python code...
  2. In case of a "Twist" output the "to_pub" variable does not need to be appended with a "twist" as it is it's self a Twist object. in the current implantation of the code this results in the error:

AttributeError: 'Twist' object has no attribute 'twist'

and thus has to be changed to something like :

twist = to_pub #.twist

Not quite sure what you mean by "mapping to an arbitrary topic."

the idea is to have generic topic that can be mapped with the input of the DS4 for example for topic:

/set_velocity
"id: 1, velocity: axis_left_y "