- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我找到了一个关于 getting a depth map from stereo images 的教程其中包含这段代码:
import numpy as np
import cv2
from matplotlib import pyplot as plt
imgL = cv2.imread('tsukuba_l.png',0)
imgR = cv2.imread('tsukuba_r.png',0)
stereo = cv2.createStereoBM(numDisparities=16, blockSize=15)
disparity = stereo.compute(imgL,imgR)
plt.imshow(disparity,'gray')
plt.show()
简短问题:
极线必须平行才能使该算法发挥作用吗?我有两个相机,它们充当立体系统,但它们之间有一个小的旋转和平移,因为我只是将它们放在 table 上。所以我的轮廓线到目前为止并不平行。
最佳答案
是的,createStereoBM
需要使极线平行才能工作。
为此,您需要估计两个相机之间的外部校准(旋转和平移)。它的工作原理与单相机校准基本相同。那里有一些立体校准教程,但我现在还没有找到一个好的 python 教程。看看ROS camera calibration tool .
接下来您需要校正相机图像。这意味着您使用从立体校准获得的映射并扭曲图像,使极线平行。查看 OpenCV 的 stereoRectify
文档:here .
当您使用我链接的文档中建议的校准参数调用 initUn DistortifyMap
时,您的图像会扭曲,以便极线平行,现在您应该能够使用 createStereoBM
创建视差图。
关于python - 具有非平行外线的立体图像的 OpenCV 深度图,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58321848/
这个问题在这里已经有了答案: Can I get `cabal install` to use multiple cores? (3 个回答) 关闭 7 年前。 在使用类似于 GNU make 的 -
我正在尝试通过 akeeba backup 在 parallels plesk 面板中安装一个 joomla 站点。我在哪里面临文件权限问题。 An error occured Could not o
我在 MATLAB 中使用箱线图函数。我需要为 6 个“XTicks”绘制 6 个不同数据集的箱线图,即 x 轴上的每个刻度线应包含 6 个相应的框、晶须、中线和其域内的异常值集。我尝试通过为每个变量
我需要在 Kaplan Meier 图上呈现 at_risk 数字。 最终结果应该与此类似: 我在渲染时遇到的问题是 No。处于危险中的患者数量位于图表底部。此处显示的值对应于 x 轴上的值。因此本质
我想知道你们中的任何一个人为什么知道我的表现糟透了吗? 我正在努力实现的目标; 生成220万个文件。要创建每个文件,平均需要2-5个数据库调用。 我正在使用的服务器具有24个内核和190GB的RAM。
请帮忙。我正在研究具有此要求的算法。 给定 4 个“右”矩形(右矩形的边平行于 x 或 y),找出它们中的任何一个覆盖的区域 例如,灰色区域被下图中的 4 个矩形中的任何一个覆盖。 enter ima
我是一名优秀的程序员,十分优秀!