-
Notifications
You must be signed in to change notification settings - Fork 118
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
Safe Setup for UR10e Hardware with Cartesian Controllers? #210
Comments
Thanks @zirogravity Any new insights? |
Perhaps a single new insight but not yet fully understood on my end yet. If I set the speed slider on the URSim/UR10e below 40% I can get the controllers to work painfully slow. This seems to be true no matter how small the error_scale is set to. I have the setup working with the teleoperation spacenav launch with cartesian force controller but NumPy versions break the Cartesian Pose launch. Was hoping to use the spacenav to log data with rosbag but I am still sorting through what topics are important to investigating the problem. |
Perhaps this video will help better describe the behavior I am seeing? https://youtu.be/P5t74CZsDwE Also, if I am not mistaken moving the robot via Polyscope UI seems to cause the controller to lose track of the robot states. Reactivating external control works only if the robot is not moved via the Polyscope UI otherwise, the Cartesian controllers immediately fault the robot as seen in the video in between a Polyscope move and a replay of the external control program.
|
I am unsure if this is a related clue or a different issue somewhere else. With an active compliance controller this screen shot shows:
RQT values do not update, plotjuggler shows added Euler angles?, ros2 cli mismatches with plotjuggler albeit corresponding pose and orientation values are correct i.e. ros2 topic echo does not show Euler angles but matches RQT. Update: I noticed "frame_id" is blank in the screen shot below. It seems like this "base_link" part of the header gets dropped maybe? Not sure why or when but I see that on a fresh start I get the frame_id populated with the base_link part in the header. When the frame ID is blank the controller is reporting something like " Received command in wrong frame expected "base_link but received _____" |
EDIT: My bad, you can maybe ignore this, it was happening when using the Joint Based Controller from UR ROS Driver and restarting URSim solved the problem. Hello, I observe the same error with my UR10e using the Compliance Controller with the ROS1 Noetic version. However, it doesn't seem to be link with a controller switching (I don't do any) but rather with the controller or the position of the robot. It worked till few minutes ago. Hard to tell exactly what happened in between, I just jogged the robot around using URSim. I also observed a similar behavior on the issue mentioned above using a Pose based Cartesian controller, however I don't know if the Universal Robots ROS Driver uses your controller implementation or another one. Let me know if you need more details or what I can do to help. |
@LAYERED-pierrechass Should i use a URSIM ?
My work environment with UR5e is below.
|
Hello, I do not know why I did not think of checking the full Polyscope logs earlier but today I did just that. These logs are from URSim using Polyscope 5.17 which is the same as we have on the robot and I have been witnessing consistent behavior between URSim and UR10e robot/hw.
Please note the last several lines here where the received (computed) velocity/ target messages are unrealistic in values. Any reccomendations on a troubleshooting approach through the software stacks? i.e. Is this coming from the UR ROS2 Driver or the Cartesian controller code base? EDIT: As I read through @LAYERED-pierrechass link above to the ROS1 git issues and the possible relationship between the two I am also wondering if it is possible for this to be rooted in the urcap/external control or the ur controller code base itself? Help isolating which part of the code I should be setting eyes on would be appreciated. It appears as if switching controllers does not handle initial conditions perhaps? I would imagine no command should be sent or lingering in the command queue during a controller switch no? For example why does the controller try to command to [-1.594235, -1.715054, -2.231413, -0.802429, 1.595039, -0.024669] when nothing has asked it to go there? |
Hello all, Just attempting to share or document more findings here. This is a link to a screen cast that shows moving the speed slider seems to induce some kind of command. In the video I show polyscope along side plotjuggler for pose variables. The jump seems to be related to PI but I would expect that moving the speed slider should not cause any command or motion. |
Hello @stefanscherzinger Please close this issue and please consider the following. Mainly on the UR ROS2 Driver and ROS2 Control "user experience" side of the house for error reporting and logging.
Polyscope:
Velocity 1079061265960517780674978211771199010412960408001592546096313184391289769924262625280 required to reach the received target [-2158122531921035460250156421727498790824614239679570066053334784255432735709986816, -40188274169231131068414796569196668
UR ROS2 / ROS2 Driver None of these errors suggest that such behavior is coming from a "default" update rate. In my case I setup the launch and config files to point to the latest ones from UR ROS2 drivers. Compared to referencing the minimal UR ROS2 example linked on this repo. The minimal example does not emphasize the update rate in which my case it needed to be 500Hz rather than the default 100Hz. |
Problem description:
Erratic robot motion before immediate faulting when switching from default STC to Cartesian Controller
Software versions:
Commit: dc80337
OS: Linux 6.2.0-39-generic #40~22.04.1-Ubuntu SMP PREEMPT_DYNAMIC Thu Nov 16 10:53:04 UTC 2 x86_64
ROS Version: ROS2 Humble
Reproduce: Please see this post:
UR Forum Post
Expected behavior: Robot not to fault when switching controllers and ready for testing Cartesian Controllers via RQT
Update:
I am not exactly clear what I did differently so far but I managed to get "a reaction" from URSim but unclear what the messages mean if anything. I will report back as I learn more.
The text was updated successfully, but these errors were encountered: