Python中如何进行摄像头标定(云服务器、云主机、高防IP、高防服务器、香港服务器、美国服务器,编程语言)

时间:2024-05-08 09:15:45 作者 : 石家庄SEO 分类 : 编程语言
  • TAG :

    Python%E4%B8%AD%E5%A6%82%E4%BD%95%E8%BF%9B%E8%A1%8C%E6%91%84%E5%83%8F%E5%A4%B4%E6%A0%87%E5%AE%9A

  扭曲可以用下面的来解决:

  类似的,另一个切向畸变是因为成像的光线不是完全平行的到达镜像平面。所以有些区域比期望的要看上去离的近。可以用下面的方式解决:

  由于径向畸变,直线会显示成曲线,当直线离图像中心越远时越明显。比如下面显示的这张图,棋盘的两个用红色标出来的边缘,你可以看到棋盘不是直线,也不和红线匹配。所有的直线都凸了。

  除此之外,我们需要找到更多的信息,比如摄像头的内部和外部参数,内部参数是摄像头特定的参数。包括焦距(fx,fy)。光学中心(cx,cy)。也叫摄像机矩阵。它只依赖摄像头本身。一旦算出来就可以保存下来为以后使用,它应该是一个3x3的矩阵:

  要找到棋盘的模式,我们用函数cv2.findChessboardCorners()。我们也需要传我们要找的模式的类型,比如8x8网格,5x5网格等,在这个例子里,我们使用7x6网格(一般来说棋盘都是8x8的方块7x7的内角),它返回角点。这些角点会按照从左到右,从上到下的顺序放好。

  这个函数可能没法在所有图像里找到需要的模式,所以一个号的选择是写代码,启动摄像机,然后检查每帧,找需要的模式,当取得了模式,找到角点,并存在列表里。同时提供一些间隔,然后在读下面的帧的时候我们可以调整我们的棋盘的方向。不断进行这个过程知道需要的好的模式都获取到了。即使在这个例子里,我们也不知道多少是好的,所以我们读入所有的图像取里面好的。

  对于立体的应用,这些扭曲需要首先被矫正。要找到所有的这些参数,我们得做的是提供一些有良好定义模式的样例图像(比如棋盘)。我们找到特定的点(棋盘的四个角),我们知道他们的真实世界的坐标,我们知道他们在图像里的坐标。通过这些数据,后台就能解决一些数学问题以得到畸变参数。

本文:Python中如何进行摄像头标定的详细内容,希望对您有所帮助,信息来源于网络。
上一篇:什么是C++的堆栈指引下一篇:

2 人围观 / 0 条评论 ↓快速评论↓

(必须)

(必须,保密)

阿狸1 阿狸2 阿狸3 阿狸4 阿狸5 阿狸6 阿狸7 阿狸8 阿狸9 阿狸10 阿狸11 阿狸12 阿狸13 阿狸14 阿狸15 阿狸16 阿狸17 阿狸18