-
Notifications
You must be signed in to change notification settings - Fork 91
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
Laser line / profilometer extrinsic calibration #95
Comments
Consider sweeping the laser across a 3-sphere calibration target. Spherical models can be fit to the resulting point cloud yielding the three sphere centers which can be used to uniquely define a frame. For example: http://www.precisionballs.com/all_ball_bar.php#b3km Note that you would likely have to paint the spheres to get decent returns. The SICK Ranger products use methods similar to the referenced paper: http://spectronet.de/story_docs/vortraege_2009/091103_vision/091104_1530_nilsson_sick.pdf |
Awesome information Clay thank you! The three sphere method really looks good; however I don't think we wan't equally spaced spheres otherwise we cannot determine from which point of view the set of sphere was observed. With a non isosceles triangle there should be no ambiguity. |
I believe the Keyence sensor returns both range and intensity. If that is the case, I see no reason one could not obtain an excellent extrinsic calibration from a planar target (possibly checkerboard, with slight modifications). It is a straight forward exercise given the relative pose between the target and the laser to predict the locations of the transitions from white to black. If one collected a sufficient number of different relative poses, the pose of the target relative to the base of the robot holding the Keyence and the pose between the wrist and the Keyence should be fully constrained. I would design a relatively small checkerboard target with a unique border on each of the four sides such that all observations of the target included at least one border. Each intensity transition has an (x,y,z) coordinate where y=0 in every measurement and every prediction. The cost would be the differences between x_predict-x_observed and z_predict-z_observed. We could simulate the process to make sure it worked prior to implementation. There is the slight possibility that no matter how inventive we are in diversifying our observations that the optimization is under-constrained. This would be evident in the Jacobian which Ceres-solver computes. I do not have enough geometric intuition to be confident that this would not be the case, but it seems unlikely to me. Every measurement set has an inherent degree of freedom about the axis where the plane of the laser meets the plane of the target. Additional measurements along different planes should tie that axis down. |
@VictorLamoine please see my last comment |
@VictorLamoine We have a slack for these awesome detailed technical discussions. I find that github issues are not the best place for them. Can you email me your preferred email address and i will send you an invite. my email is [email protected]. you too @gavanderhoorn! |
We will be trying with a ping pong ball today and tomorrow and see what we can get. |
Hey @VictorLamoine, it's been forever but I'm finally at a place where I want to start helping out with this laser calibration issue. Can you give me a feel for any progress that you've managed to make? |
Hey, we have a procedure that has given us great results 👍 The procedure uses a calibrated ball (we also tested with a ping pong ball). One has to know precisely the diameter of the object, and it has to be as round as possible. I'm now familiar with the ROS Keyence driver. We need to write a ROS package to:
I want to keep these three modules independent to allow easy simulation of the process. I suggest creating a new package first and see what we can get. Have a nice week-end! |
I'm absolutely on board, especially with respect to the separate modules. I wrote a simple touch-point calibration routine for TCP teaching here: https://github.com/Jmeyer1292/tool_point_calibration I tried to follow a similar model. Is it possible for you to share this Matlab code? |
ping @VictorLamoine |
I'll send you an email with the code and some details in a few hours! |
Hi @VictorLamoine, we are interested in this issue as well. Is the matlab code mentioned in #95 (comment) available in a public repository? Thanks! |
I have sent you an email with the code (at your GitHub profile email), you should be looking at these repos first:
I've not worked on this topic since a (very) long time but I still hope I will get the time someday to finish what I have started :) |
Got it! Thanks :) |
Dear @VictorLamoine, could you please either share with me your Matlab code for 2D profile laser? You mentioned about it in #95 (comment). I try to calibrate by means of a sphere, but I have some trouble. Thank you in advance |
Adding another point of interest in this topic. Thanks guys! |
Hi @VictorLamoine, I'm also working with a laserscanner and face the same problem as you with calibration. Could you please share the code with me via Email/Repo? Thanks |
@udopa I've sent an email at the one publicly available on your GitHub account! |
@VictorLamoine, would you be open to sharing your procedure? I too put together a non-production version that works well, but is not as accurate as I'd like. Mine is essentially a standard touch-point calibration procedure where the point of my "tool" is the estimated center of the sphere when the diameter of the sphere ~ equals the actual sphere diameter. There is some error though that I'm not accounting for. |
Sorry, I changed work and I cannot share this data anymore! |
We have found this paper:
http://www.mdpi.com/1424-8220/9/9/7374
I tried to test the Keyence experimental driver but the TCP/UDP ports filtered in our network, I'm waiting for them to be open. I should be able to use the driver next week.
I'm waiting for a 3D printed interface to mount the sensor on the robot. I should get this next week.
We are thinking about the target geometry, we're not sure what to use.
From what I have understood we need to be able to build a (3D) frame consistently and precisely on the calibration target whatever the point of view. Given the fact that we only have a line this is quite difficult to think of.
Rather than using a single line acquisition, I thought we might get a bunch of them with a linear sweeping movement. This way we can get a point cloud that we would store in the first frame user frame and built a 3D user frame from here.
We could for example scan 3 faces of a cube, the problem would be that because the dimensions are the same everywhere we cannot determine the orientation of the cube; we would need markers on the faces to determine which face is which face.
@AustinDeric @drchrislewis your opinion would be much appreciated
The text was updated successfully, but these errors were encountered: