关于opencv::triangulatePoints()函数的注意事项

void cv::triangulatePoints(

InputArray projMatr1, // 左相机投影矩阵 3×4

InputArray projMatr2, // 右相机投影矩阵 3×4

InputArray projPoints1, // 左相机图像点 (2×N)

InputArray projPoints2, // 右相机图像点 (2×N)

OutputArray points4D // 输出的齐次坐标 (4×N)

);

该函数的输入要求:

  1. 投影矩阵 projMatr1projMatr2 必须是 3×4K * [R | T] 矩阵。

  2. 输入点 projPoints1projPoints2 必须是 2×N 形状的 归一化相机坐标 (Normalized Image Coordinates)。

  3. 输出点 points4D齐次坐标 ,即 X, Y, Z, W,需要手动转换为非齐次坐标: X′=X/W,Y′=Y/W,Z′=Z/WX' = X / W, \quad Y' = Y / W, \quad Z' = Z / WX′=X/W,Y′=Y/W,Z′=Z/W

    常见错误

    错误原因:未正确处理 undistortPoints() 的结果

    当我们使用 cv::undistortPoints() 进行畸变矫正后,它返回的点坐标是 归一化相机坐标 (单位焦距 f=1 的坐标系),而不是像素坐标。因此:

  4. 如果 triangulatePoints() 的投影矩阵 包含了相机内参 K ,则输入的点必须是 像素坐标 (未除去 K)。

  5. 如果输入的是 归一化坐标 (已除 K),那么投影矩阵就不应该包含 K
    正确方法 1:使用归一化坐标

    // 1. 去畸变,得到归一化坐标
    cv::undistortPoints(projPoints_left, projPoints_left, K_left, dist_left);
    cv::undistortPoints(projPoints_right, projPoints_right, K_right, dist_right);

    // 2. 只使用 [R | T] 作为投影矩阵
    cv::Mat P1 = RT_left;
    cv::Mat P2 = RT_right;

    // 3. 三角化
    cv::triangulatePoints(P1, P2, projPoints_left, projPoints_right, Final_points3D);

    正确方法 2:保持像素坐标

    如果希望直接在像素坐标下进行三角化,可以在 cv::undistortPoints() 中传入 新的投影矩阵 P=K,让输出点保持在像素坐标系:

    复制代码
    // 1. 去畸变,但保持像素坐标
    cv::undistortPoints(projPoints_left, projPoints_left, K_left, dist_left, cv::noArray(), K_left);
    cv::undistortPoints(projPoints_right, projPoints_right, K_right, dist_right, cv::noArray(), K_right);
    
    // 2. 计算投影矩阵 (带K)
    cv::Mat P1 = K_left * RT_left;
    cv::Mat P2 = K_right * RT_right;
    
    // 3. 三角化
    cv::triangulatePoints(P1, P2, projPoints_left, projPoints_right, Final_points3D);
相关推荐
爱上珍珠的贝壳3 小时前
ESP32-S3-CAM:豆包语音识别文字后控制小车(五)——认识L298N驱动模块
人工智能·语音识别·智能硬件·esp32-s3·l298n·减速电机
俊哥V3 小时前
每日 AI 研究简报 · 2026-04-14
人工智能·ai
紧固视界3 小时前
汽车紧固件最新技术趋势解析:2026上海紧固件专业展有哪些看点
大数据·人工智能·汽车·紧固件·上海紧固件展·上海紧固件专业展
刘佬GEO3 小时前
本地门店做 GEO 的起步顺序:第一步先做什么?
大数据·网络·人工智能·搜索引擎·ai
kcuwu.3 小时前
AI完整发展史内容
人工智能·提示词工程
人工智能AI技术3 小时前
智能体边界控制:禁止越权、防止危险操作
人工智能
东离与糖宝3 小时前
智能体评测基础:能力、稳定性、安全性评估标准
人工智能
莱昂纳多迪卡普利奥3 小时前
LLM工程化实践——Prompt Engineering(一)
人工智能·prompt
Satellite-GNSS3 小时前
AI Agent(智能体)全知识体系详解(从入门到精通,彻底理清脉络)
人工智能·agent
一叶知秋yyds3 小时前
大语言模型LLM完整技术解析从训练到应用
人工智能·语言模型·自然语言处理