当前位置: 首页 > wzjs >正文

网站开发人员的岗位有短视频seo推广隐迅推专业

网站开发人员的岗位有,短视频seo推广隐迅推专业,莱芜金点子电子版最新招聘信息,网站客服模板目录 cv2.projectPoints 投影 矩阵计算投影 cv2.projectPoints 投影 cv2.projectPoints() 是 OpenCV 中的一个函数,用于将三维空间中的点(3D points)投影到二维图像平面上。这在计算机视觉中经常用于相机标定、物体姿态估计、3D物体与2D图…

目录

cv2.projectPoints 投影

矩阵计算投影


cv2.projectPoints 投影

cv2.projectPoints() 是 OpenCV 中的一个函数,用于将三维空间中的点(3D points)投影到二维图像平面上。这在计算机视觉中经常用于相机标定、物体姿态估计、3D物体与2D图像之间的映射等场景。

函数原型:
cv2.projectPoints(objectPoints, rvec, tvec, cameraMatrix, distCoeffs)
objectPoints:3D点的集合,通常是物体的真实世界坐标。
rvec:旋转向量,表示物体相对于相机的旋转。
tvec:平移向量,表示物体相对于相机的位置。
cameraMatrix:相机的内参矩阵,通常通过相机标定得到。
distCoeffs:相机的畸变系数,通常是由相机标定得到的。

import cv2
import numpy as np# 定义 3D 点(假设这些点在一个立方体的表面上)
object_points = np.array([[0, 0, 0], [1, 0, 0], [1, 1, 0], [0, 1, 0], [0, 0, -1], [1, 0, -1], [1, 1, -1], [0, 1, -1]], dtype=np.float32)# 定义相机内参矩阵
camera_matrix = np.array([[1000, 0, 320],  # fx, 0, cx[0, 1000, 240],  # 0, fy, cy[0, 0, 1]  # 0, 0, 1
], dtype=np.float32)# 定义畸变系数(假设无畸变)
dist_coeffs = np.zeros((5, 1), dtype=np.float32)# 定义相机外参(旋转向量和平移向量)
rvec = np.array([0, 0, 0], dtype=np.float32)  # 无旋转
tvec = np.array([0, 0, -10], dtype=np.float32)  # 相机在 Z 轴正方向 5 个单位处# 将 3D 点投影到 2D 图像平面
image_points, _ = cv2.projectPoints(object_points, rvec, tvec, camera_matrix, dist_coeffs)# 创建一个空白图像(用于可视化)
image = np.zeros((480, 640, 3), dtype=np.uint8)image_points=np.squeeze(image_points,axis=1)
print(image_points)
# 在图像上绘制投影点
for point in image_points:x, y = point.ravel()cv2.circle(image, (int(x), int(y)), 3, (0, 255, 0), -1)  # 绘制绿色圆点# 显示图像
cv2.imshow("Projected Points", image)
cv2.waitKey(0)
cv2.destroyAllWindows()

矩阵计算投影

内参,外参用的左乘

import numpy as np
import cv2# 定义相机内参矩阵 (3x3)
K = np.array([[1000, 0, 320],  # fx, 0, cx[0, 1000, 240],  # 0, fy, cy[0, 0, 1]])  # 0, 0, 1# 定义相机外参:旋转矩阵 (3x3) 和平移向量 (3x1)
R = np.eye(3)  # 假设相机没有旋转
t = np.array([[0], [0], [-10]])  # 相机在Z轴负方向平移10个单位# 生成随机3D点云 (Nx3)
num_points = 100
# points_3d = np.random.rand(num_points, 3) * 10  # 生成100个3D点,范围在[0, 10)points_3d = np.array([[0, 0, 0], [1, 0, 0], [1, 1, 0], [0, 1, 0], [0, 0, -1], [1, 0, -1], [1, 1, -1], [0, 1, -1]], dtype=np.float32)# 将3D点云从世界坐标系转换到相机坐标系
points_3d_cam = R @ points_3d.T + t  # 3xN
points_3d_cam = points_3d_cam.T  # 转置为Nx3# 将3D点云投影到2D图像平面
points_2d_homogeneous = K @ points_3d_cam.T  # 3xN
points_2d = points_2d_homogeneous[:2, :] / points_2d_homogeneous[2, :]  # 归一化
points_2d = points_2d.T  # 转置为Nx2# 创建空白图像
image_size = (640, 480)  # 图像尺寸
image = np.zeros((image_size[1], image_size[0], 3), dtype=np.uint8)print(points_2d)
# 将2D点绘制到图像上
for point in points_2d:x, y = int(point[0]), int(point[1])if 0 <= x < image_size[0] and 0 <= y < image_size[1]:  # 确保点在图像范围内cv2.circle(image, (x, y), 3, (0, 255, 0), -1)  # 绘制绿色圆点# 显示图像
cv2.imshow("2D Projection of Point Cloud", image)
cv2.waitKey(0)
cv2.destroyAllWindows()

总结,两种方法的结果是一样的。

http://www.dtcms.com/wzjs/219465.html

相关文章:

  • app开发公司选择技巧秦皇岛网站seo
  • 推广网站的广告怎样做博客是哪个软件
  • 如何自己开网站利用搜索引擎营销成功的案例
  • 城市建设法规考试网站电商运营培训机构哪家好
  • 上班自己花钱做的网站营销宝
  • 微信服务商平台官网seo是付费还是免费推广
  • 什么摄像头做直播网站怎么制作网页里面的内容
  • 营销网站定位微信群免费推广平台
  • 我要素材网网页设计素材上海优化排名网站
  • 做设计在哪个网站接单高端网站优化公司
  • 一般做网站销售提成做网络推广怎么收费
  • 怎么做代理深圳百度seo公司
  • php网站开发建设百度大数据分析
  • 怎么制作网站维护公告效果seo是做什么工作内容
  • 广东网站建设有限公司中国国家人才培训网官网
  • 营销型网站建设个人天津放心站内优化seo
  • 简历模板免费下载电子版seo自动发布外链工具
  • 免费行情软件app网站红色网络营销的特点有
  • 服务器做两个网站合肥网站设计
  • 做亚马逊网站的公司建议seo咨询推广找推推蛙
  • 济南专门做网站的公司有哪些给网站做seo的价格
  • 网站建设制作设计培训网登录入口
  • 本地服务器如何做网站谷歌浏览器官网下载手机版
  • 网站建设 发展历程建立网站需要多少钱
  • wordpress时间插件seo代码优化有哪些方法
  • 中央人民政府网站的seo是什么意思
  • 梵美传媒网站是谁做的国内好的seo
  • 渭南企业网站建设在线搜索引擎
  • 网站建设图市场监督管理局官网入口
  • 中小学校园网站开发技术百度推广助手官方下载