E=[T]×R 的证明

一、简介

最清晰、最短、最本质 的推导,解释为什么:

二、为什么 E = [T]× R?(严格数学推导)

给定两个相机:

  • 第一相机坐标系:C₁

  • 第二相机坐标系:C₂

  • 第二相机相对第一相机的姿态:

    • 旋转:R

    • 平移:T

3D 点 X在两个相机的成像点满足:

几何约束:点、极线、极平面

三、Matlab 测试

计算本质矩阵E

cpp 复制代码
%% 随机生成一个旋转矩阵 R
[U,~,V] = svd(randn(3,3));
R = U*V';

% 确保 det(R)=1
if det(R)<0
    U(:,3) = -U(:,3);
    R = U*V';
end

%% 随机平移 T(非零)
T = randn(3,1);
T = T / norm(T);

%% 构造叉乘矩阵 [T]×
Tx = [  0   -T(3)   T(2);
       T(3)   0    -T(1);
      -T(2)  T(1)    0 ];

%% 按理论构造本质矩阵 E
E = Tx * R;

disp('E = [T]x R =');
disp(E)
cpp 复制代码
%% ====== 数值验证:x2^T E x1 = 0 ======
% 随机生成空间 3D 点
X = randn(3,20);

% 第一相机投影
x1 = X ./ X(3,:);

% 第二相机投影:x2 = R*X + T
X2 = R * X + T;
x2 = X2 ./ X2(3,:);

% 验证 epipolar constraint
err = zeros(1,size(X,2));
for i = 1:size(X,2)
    err(i) = x2(:,i)' * E * x1(:,i);
end

disp('数值误差(应接近 0):');
disp(err);

fprintf('\n最大误差: %.3e\n', max(abs(err)));
E = [T]x R =
   -0.7750    0.5902   -0.1374
   -0.5141   -0.7866   -0.3197
    0.2064   -0.0104    0.0651

数值误差(应接近 0):
   1.0e-14 *

  列 1 至 11

   -0.0056   -0.0652         0   -0.3553    0.0333   -0.0444   -0.0111         0         0    0.0888   -0.0042

  列 12 至 20

   -0.0222   -0.0444    0.0444    0.0139   -0.1332         0   -0.0087         0   -0.1332


最大误差: 3.553e-15
相关推荐
无忧智库2 分钟前
低空经济新基建:构建低空飞行大数据中心与行业应用算法工厂的全景式蓝图(WORD)
算法
闻缺陷则喜何志丹1 小时前
【背包 组合】P7552 [COCI 2020/2021 #6] Anagramistica|普及+
c++·算法·背包·洛谷·组合
小章UPUP2 小时前
2026年第十六届MathorCup数学应用挑战赛D题国奖思路
算法
hssfscv2 小时前
软件设计师下午试题四——C语言(N皇后问题、分治、动态规划)
c语言·算法·动态规划
lolo大魔王2 小时前
Go语言的反射机制
开发语言·后端·算法·golang
白羊by2 小时前
Softmax 激活函数详解:从数学原理到应用场景
网络·人工智能·深度学习·算法·损失函数
故事和你912 小时前
洛谷-算法1-7-搜索3
数据结构·c++·算法·leetcode·动态规划
chipsense3 小时前
霍尔电流传感器选型方法论再升级:从800V平台到TMR竞争的全场景决策树
算法·决策树·机器学习·闭环霍尔·tmr传感
CoderYanger3 小时前
14届蓝桥杯省赛Java A 组Q1~Q3
java·开发语言·线性代数·算法·职场和发展·蓝桥杯
会编程的土豆4 小时前
【日常做题】 代码随想录(岛屿最大面积+寻宝)
数据结构·算法·图论