CS231A Lecture 6:Stereo Systems
Reading:
[HZ] Chapter: 9 “Epip. Geom. and the Fundam. Matrix Transf.”
[HZ] Chapter: 18 “N view computational methods”
[FP] Chapters: 7 “Stereopsis”
[FP] Chapters: 8 “Structure from Motion”
Rectification
Epipolar geometry
data:image/s3,"s3://crabby-images/5b317/5b317fcf62f618e31fa113a64b8422e56b4e7b1a" alt=""
Epipolar Constraint
data:image/s3,"s3://crabby-images/22c13/22c13ea808633f5d7bb296499f57c5d36ec08163" alt=""
data:image/s3,"s3://crabby-images/28be4/28be4e94fe7b726c6e2f8f841a01323b81576019" alt=""
Parallel image planes
data:image/s3,"s3://crabby-images/a2522/a2522f0fc2dc9307878adfa1daa7c49bb0c7a487" alt=""
data:image/s3,"s3://crabby-images/8b070/8b0705016406333e2512e0f475513e4fc4223f57" alt=""
Essential matrix for parallel images
data:image/s3,"s3://crabby-images/75f8f/75f8fce2070c29c8721763a73e24f2a284cb8a90" alt=""
What are the directions of epipolar lines?
data:image/s3,"s3://crabby-images/7a5db/7a5db74e3bb0c6be889791f1e1b6fdc48d78a9ba" alt=""
How are p and p’ related?
data:image/s3,"s3://crabby-images/3a5b8/3a5b86fa3c4ec7792c36ce3e37e9e093916bdd97" alt=""
Rectification: making two images “parallel”
Rectification
data:image/s3,"s3://crabby-images/7f6e5/7f6e584763c4d7fc228257418cbc119a89e62a7f" alt=""
Example
data:image/s3,"s3://crabby-images/a8558/a85589a3a89f2ac56606882154b9e5c354ddaf6a" alt=""
Why it is useful?
- Epipolar constraint $\rightarrow v = v’$
- New views can be synthesized by linear interpolation
Why are parallel images useful?
Makes triangulation easy
这里有点类似双目相机的模型了。
Makes the correspondence problem easier
Correspondence problem
data:image/s3,"s3://crabby-images/25afb/25afb1260775df36c4898f471ff1bdd4fc739df4" alt=""
data:image/s3,"s3://crabby-images/f1c9b/f1c9b0ae74d8333e76072a4d943b20fd687b26cc" alt=""
Correlation Methods
A Simple Idea
data:image/s3,"s3://crabby-images/a4d52/a4d5266b148b89dd0ba2eff211fb19b78c96ac3d" alt=""
data:image/s3,"s3://crabby-images/be6d0/be6d01306c9dde888dfa8c95805682fda1a53505" alt=""
思考:
这里的问题是,只检查一个像素点,没有考虑到像素值相同的点可能比较多,很容易导致错误匹配。
Window-based correlation
data:image/s3,"s3://crabby-images/b9135/b9135cc6afa41ffd7afacf9be810b8ba8dda8136" alt=""
data:image/s3,"s3://crabby-images/6edf8/6edf8a2526af37b4abb254fe6514187c13775462" alt=""
思考:
这里的问题是,只计算两个矩阵的点乘,并且认为最大值是匹配的最好的。
这样处理很容易受到光照或者曝光的影响,如下所示。
Changes of brightness/exposure
data:image/s3,"s3://crabby-images/0a611/0a611ecfa21cb71d0f0ac1af375d4ef0b440803b" alt=""
Normalized cross-correlation
data:image/s3,"s3://crabby-images/0b55a/0b55a506603d82e39f64d36288564a65d765a433" alt=""
Effect of the window’s size
data:image/s3,"s3://crabby-images/35d31/35d31c2f92bf837e35dd1624d200118fe1303153" alt=""
Issues
Fore shortening effect
这个网站把Fore shortening effect介绍的非常清楚:Foreshortening – What It Means and How to Paint It
从上图中也可以看出,左边相机拍摄的物体很长,而右边因为距离较远就缩短了。前面几种算法在这里容易出问题,他们都是在一条水平线上查找固定大小的window,但是利用图像金字塔应该可以处理这种问题。
Occlusions
因为遮挡导致两个相机观察的内容不一样。
Base line trade-off
Homogeneous regions
Repetitive patterns
Correspondence problem is difficult!
data:image/s3,"s3://crabby-images/04d37/04d3723d4311e5aa06180dcdbf7702fe119e80b3" alt=""
Non-local constraints
data:image/s3,"s3://crabby-images/d4569/d4569fc0f134f942b90e2e9bed50f25e5659a15e" alt=""