-
Notifications
You must be signed in to change notification settings - Fork 16
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
Camera-projector calibration #25
Comments
I'm not following the full, complex sequence, but on a high-level, it seems like it should mostly work. If you are able, I would simplify: do you really need the 3 separate steps? Why can't you do it in one step? If the opencv chessboard detector sucks (it does!), then don't use it. mrgingham works great. Or boofcv. Past that, you just need to debug. After each step, pick an arbitrary point, and manually transform and project it through your calibration to see if it makes sense. If there's a bug somewhere (there probably is), this will find it. |
Thanks. I will try to simplify the sequence to try and find any bugs. The corner detections I think are okay given the poor resolution of the IR camera:
Just to confirm, can I use |
I tried
How can I compensate for this? Would multiplying the X,Y by the width/height of |
If you have a low-res camera, bring the object it's looking at closer to make things appear bigger. The way you're doing it won't make anything fail catastrophically, but your accuracy will suffer. When debugging, you want to trust nothing (since you don't know what's broken), and use as simple and as core things as you can. In this case, don't use
And then you can compare the q1 you get this way with a q1 you know (from looking at your image, or something). At each step, find some correspondence you can validate like this. If you have a transform, then you need a distance also, and the |
I don't know what I'm supposed to do with those images. But don't show them to me; this is for your own sanity checking, since you have a logic bug somewhere. As for the distance, think about what you are trying to do. Draw a diagram of your two cameras, and draw a ray in space that represents one of your pixels, and the point in space that corresponds to it and the reprojection to the other camera. Does the reprojection depend on distance? What if there's no translation? If you are trying to reproject a known-geometry object from one camera to another, you can use that object geometry to compute the distances. In the special case of a plane in space, whose pose you know, you can use |
Ah I think I see where I am getting confused wrt distance. if I want to accurately reproject a given camera pixel coordinate to hit it with the projector, I think that projector pixel coordinate will depend on the given distance/depth and I'm not giving that. I only have estimates of that when passing in checkerboards at calibration time. However, the IR cam is a depth sensor and I could sample THAT depth coordinate and that's what most solutions do. I was hoping not to do that because it is noisy but it seems like it's the only solution here. A simple test of this theory would be to get the world coordinate of a chessboard corner using |
I think my original plan wouldve worked if I was just working on a flat plane. |
Hi. Sorry, I don't have the cycles right now to really think about this. But it sounds like you're on the right track, and hopefully will figure it out. Good luck! |
I am trying to accomplish a fairly niche task, but overlaps with computer vision/camera calibration. I have a IR camera (kinect) (
cam1
) mounted on top of a projector (cam2
). The idea is to be able to re-project the scene in the projector and have it accurately align to the viewer. The applications for this are augmented reality/tracking/etc.I have made good progress, but likely missing a piece of the puzzle which is why I am asking for help.
cam1
/IR camera is 1024x848 [upscaled from 512 x 424 - I wasn't getting opencv corners at the native resolution] and is wide anglecam2
is 1920 x 1080 - short throw projector and seems basically pinhole.My steps are
--skip-intrinsics-solve
and use the previous cameramodels as input to--seed
. Results in ~0.5 RMS err.I then transform an input (distorted) IR image of the current scene to the PINHOLE variant of the projector/
cam2
cameramodel, NOT the actual one (because the projector will then "distort" it again)When I transform
cam1
tocam2-pinhole
, and then reproject the 1920x1080 image to the projector [it's native resolution], it doesn't line up. What gives me hope though, is that the "shapes" look correct. I can manually scale x,y and offset x,y and get them to align pretty well. So the distortion seems to be removed. This is apparent in the below image where the projected cardboard at least seems to be the same shape as the real cardboard.I was hoping though to have it magically align well. Is there anything I'm missing in this process? Maybe some sort of zoom or scale factor because I'm using different resolutions?
For the third step of extrinsics solving, do I need to cover the entire region where the projector FoV and IR camera FoV overlap?
The text was updated successfully, but these errors were encountered: