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

Visualize arm reach during drive mode #14

Open
mayacakmak opened this issue Jun 24, 2021 · 7 comments · Fixed by #31
Open

Visualize arm reach during drive mode #14

mayacakmak opened this issue Jun 24, 2021 · 7 comments · Fixed by #31
Assignees

Comments

@mayacakmak
Copy link

Add a visualization to give the user a sense of the robot's arm's reach while driving. Initial idea is to overlay a transparent circle on top of the drive mode video stream on the floor plane. Since we know the head camera viewpoint parameters relative to the ground plane (height of the camera and tilt angle), we can compute how the circle would be skewed for the visualization. We should also be able to figure out the circle diameter based on the robot arm max extension (we probably want this to be where the fingers would end up. Here's a rough sketch.

Screen Shot 2021-06-24 at 1 50 42 PM

This issue is motivated in the problem description in Issue #11.

@kavidey
Copy link
Collaborator

kavidey commented Jun 28, 2021

I'm using three.js on the operator side to render the circle on the ground
three.js may be a bit overkill for just a circle, but if we want to do a full 3d gimbal overlayed onto the gripper in a future version, it will come in handy

I also updated sensors.js to send the camera position/rotation from the robot browser to the operator.
The axes in three.js are not aligned with the ROS axes, so I'm working on remapping them.

The circle seems to be lined up when the camera is pointing straight down, as the camera moves it becomes less aligned.
https://youtu.be/cbiql28Ijb4
The green box is supposed to be rendered over the tip of the gripper. I think the delay between the overlay updating and the video feed updating is partly because its in simulation, but it may also be the bandwidth issue described in Issue #30, because I am now sending camera and gripper position data in addition to the torque.

@mayacakmak
Copy link
Author

I wonder if there is a simplification of the problem because of the object being rendered is a circle.. assuming the camera rotation axis center is also the center of the robot base that it rotates around: if the camera is pointing straight down, it should see a perfect circle (though might not fit into the frame), as it looks higher and higher (increased tilt) the circle will get skewed on the y axis (vertical) and less of it will be visible (eventually none of it). The pan movement should have no effect (again if the assumption is correct). So it feels like we just need a few parameters: the arm reach-radius to pixel ratio (i.e. how big is the circle you draw in the straight down case), tilt-angle change to skew ratio (i.e. how much to skew the circle into an ellipse when the head tilts up by a certain amount), tilt-angle change to pixel movement ratio (how much to move the circle center downwards in the image when the head tilts up by a certain amount). Does that make sense? Might be worth trying if you're stuck with the other path. But I completely agree that it would be great to get threejs working at some point for other geometric overlay based interfaces.

@kavidey
Copy link
Collaborator

kavidey commented Jul 3, 2021

Yeah I think that does. I'm working on some more advanced camera math that takes into account the position provided from ROS, as well as the physical rotation point and position of the camera sensor (I'll post some more details on the math if it ends up working). If that doesn't work I definitely try the other method.

@kavidey
Copy link
Collaborator

kavidey commented Jul 4, 2021

I fixed a mathematical error in how the Euler rotations were being processed in the mapping from the ros reference frame to the threejs reference frame, which made a big improvement in how accurate the virtual camera angles are.

There is still some small error, but I think I know the root cause and am working on a fix. The camera frame I'm currently using ,link_head_tilt, is not actually the position of the camera sensor, but where the camera mount attaches to the servo. It provides correct rotation data but incorrect position data. I'm looking into other frames (specifically camera_color_frame) to get the exact position of the camera sensor.

Which interface views should the circle be visible in? Currently, it is visible in all of them. I also saw that the master branch now has the split-screen/two-mode interface, so maybe would just always be visible in one of those two.

Everything is in #11-decrease-manipulation-burden, let me know how I can help when we are ready to merge into master. The biggest difference from master will probably be in operator_ui_regions.js where three.js is setup (The render canvas needs to be created in the correct location in the DOM to line up with the camera feed). The code to update the camera position once everything is setup should work without too much modification.

@mayacakmak
Copy link
Author

Oh nice!

Yes I think having the visualization only on the navigation view make sense, since it will be useful for navigating close enough to a target before rotating.

For merging, how about you create a pull request, see if it will merge automatically? if not perhaps you merge master onto your branch first to handle conflicts then create the pull request? just to keep master functioning.

@kavidey kavidey linked a pull request Jul 5, 2021 that will close this issue
@mayacakmak mayacakmak reopened this Jul 11, 2021
@mayacakmak
Copy link
Author

@kaviMD I tested this feature on the real robot and it's really cool! I works quite well in the front part of the robot but there seems to be an issue when looking towards the side, described a bit more below.

I tested it with a bottle on the floor. I tried moving the robot to a point where I'd be able to grasp the bottle from as far as possible. This is how it looked in the default view for navigation mode.

Screen Shot 2021-07-09 at 12 51 05 PM

So it is just within the reach surface. When I moved the camera around, the object seemed to nicely stay at that edge of reachability.

Screen Shot 2021-07-09 at 12 51 23 PM
Screen Shot 2021-07-09 at 12 51 39 PM

However, when I rotated the robot base in place and looked towards the arm, the visualization seemed to go off. The object appeared to be quite a bit outside of reach, even though the distance to the robot center axis had not changed.

Screen Shot 2021-07-09 at 12 54 49 PM

And when I tried to reach towards the object it was able to reach it:

stretch_reach

  • It seems the reach threshold is set based on the wrist--let's change that to the fingertips since the robot can grasp things further than the wrist due to the additional link.
  • Fix the visualization towards the sides of the robot. Even though it is already useful without this fix (as long as the user is aware about the issue), it can be confusing to see the object go out of reach when the robot rotates and would be great to fit it.

@mayacakmak
Copy link
Author

Haha, actually this reminded me that the robot arm raise axis is not at the robot's base rotation center, it is shifted backwards in the direction of extension--perhaps that's the issue here? We still need to visualize what can be reached with the arm, while we are in the navigation mode even though it cannot reach it withouth moving the base (i.e. assuming the robot would rotate in place to reach that direction, but would not be able to translate in that direction any more).

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging a pull request may close this issue.

2 participants