本文最后更新于:2024年5月7日 下午
光度立体法,可以利用多张不同光照的相同机位相机拍摄的图像建模计算出物体表面深度、法向量,本文记录基础理论。
光度立体法
光度立体法,即Photometric Stereo, 最早是由当时在MIT的人工智能实验室的Robert J. Woodham教授在1978年左右提出。他在1979年的论文《Photometric stereo: A reflectance map technique for determining surface orientation from image intensity》,以及1980年的论文《Photometric Method for Determining Surface Orientation from Multiple Images》中比较系统的阐述了整套理论框架。
实现思路
当相机和目标物体相对位置固定不变时,使用不同方向的光源照射同一目标物体,相机可以拍摄到目标物体带有不同明暗分布的图像,再通过求解基于朗伯反射原理的反射方程组,求解目标表面的法向分布或者深度图。
为图中像素值产生的过程建立和物体表面属性精确的假设模型,求解低秩矩阵解得物体属性。
基本假设
基础的光度立体法对成像提出三个基本假设
正交投影
图像的 $u,v$ 坐标直接对应物体的 $x,y $ 坐标值
入射光由远处的单一点光源发出
物体表面具有朗伯(lambertian)反射特性
相机接收到的光线(像素值)与物体表面属性、表面法向量、入射光角度和强度维持一种特定的关系
$$
t_{ij}=\rho_i(N_i·L_i)l_j
$$
其中各变量含义:
求解物体表面深度
$$
I_{x,y}^i=\rho_{x,y} L_{i} \mathbf{L_i} \cdot \mathbf{N}_{x,y}
$$
$i$ 表示第 $ i $ 个光源,将$L_i$合并入$\rho$,用 $k_{x,y}$ 表示($k_{x,y}=\rho L_i$),因此可以假设$L_i$为1,当前公式为:
$$
I_{x,y}^i=k_{x,y} \mathbf{N}_{x,y} · \mathbf{L_i}
$$
$$
\begin{array}{c}
I_{x,y}^1=k_{x,y} \mathbf{N}_{x,y} · \mathbf{L_1}\\
I_{x,y}^2=k_{x,y} \mathbf{N}_{x,y} · \mathbf{L_2}\\
...\\
I_{x,y}^n=k_{x,y} \mathbf{N}_{x,y} · \mathbf{L_n}
\end{array}
$$
将 $k$ 合并入 $\mathbf{N}$,用 $\mathbf{G}$ 表示,$\mathbf{G}=k\mathbf{N}$,对于第 $i$ 个光源 $(x,y)$像素:
$$
I_{x,y}^i = \mathbf{G}_{x,y}\mathbf{L}_i\
$$
$$
\begin{array}{c}
I_{x,y}^1= \mathbf{G}_{x,y} \mathbf{L_1}\\
I_{x,y}^2= \mathbf{G}_{x,y} \mathbf{L_2}\\
...\\
I_{x,y}^n= \mathbf{G}_{x,y} \mathbf{L_n}
\end{array}
$$
$$
\begin{aligned} {[L] G } &=[I] \\ L^{T} L G &=L^{T} I \\ G &=\left(L^{T} L\right)^{-1} L^{T} I \end{aligned}
$$
$$
\begin{aligned}
k_{d} &=\|G\| \\
N &=G / k_{d}
\end{aligned}
$$
物体表面沿着 ${x, y}$ 方向的导数与法线方向正交
$$
V_{1}=\left(x+1, y, z_{x+1, y})-\left(x, y, z_{x, y}\right) =\left(1,0, z_{x+1, y}-z_{x, y}\right) \right.
$$
$$
\begin{aligned} N . V_{1} &=0 \\\left(n_{x}, n_{y}, n_{z}\right) \cdot\left(1,0, z_{x+1, y}-z_{x, y}\right) &=0 \\ n_{x}+n_{z}\left(z_{x+1, y}-z_{x, y}\right) &=0 \end{aligned}
$$
$$
\begin{aligned} V_{2} &=\left(x, y+1, z_{x, y+1})-\left(x, y, z_{x, y}\right)\right.\\ &=\left(0,1, z_{x, y+1}-z_{x, y}\right) \end{aligned}
$$
$$
\begin{aligned} N . V_{2} &=0 \\\left(n_{x}, n_{y}, n_{z}\right) \cdot\left(0,1, z_{x, y+1}-z_{x, y}\right) &=0 \\ n_{y}+n_{z}\left(z_{x, y+1}-z_{x, y}\right) &=0 \end{aligned}
$$
如果有像素由于边界问题,有些像素需要使用其他方向的梯度:
$$
\begin{aligned}-n_{x}+n_{z}\left(z_{x-1, y}-z_{x, y}\right) &=0 \\-n_{y}+n_{z}\left(z_{x, y-1}-z_{x, y}\right) &=0 \end{aligned}
$$
$$
\begin{aligned}
z_{x+1, y}-z_{x, y}=-\frac{\boldsymbol{n}^{x, y}_x}{\boldsymbol{n}^{x, y}_z} \\
z_{x, y+1}-z_{x, y}=-\frac{\boldsymbol{n}^{x, y}_y}{\boldsymbol{n}^{x, y}_z}
\end{aligned}
$$
假设求解的点有 $M$ 个点,那么需要求解的 $z$ 有 $M$ 个,$n$ 的比值 $M$ 个,那么可以列出 $2M*M$ 维系数矩阵,并有等式:
$$
\left[\begin{array}{cccccc}\vdots & \vdots & \vdots & \vdots & \vdots & \vdots \\ \cdots & -1 & 1 & \cdots & \cdots & \cdots \\ \vdots & \vdots & \vdots & \vdots & \vdots & \vdots \\ \vdots & \vdots & \vdots & \vdots & \vdots & \vdots \\ \cdots & -1 & \cdots & \cdots & 1 & \cdots \\ \vdots & \vdots & \vdots & \vdots & \vdots & \vdots\end{array}\right] \left[\begin{array}{cccccc}\vdots \\ z_{a,b}\\ z_{a,b+1}\\ \vdots \\z_{a+1,b} \\ \vdots \end{array}\right]=\left[\begin{array}{cccccc}\vdots \\ -\frac{\boldsymbol{n}^{a, b}_x}{\boldsymbol{n}^{a, b}_z}\\ -\frac{\boldsymbol{n}^{a, b+1}_x}{\boldsymbol{n}^{a, b+1}_z}\\ \vdots \\-\frac{\boldsymbol{n}^{a+1, b}_x}{\boldsymbol{n}^{a+1, b}_z} \\ \vdots \end{array}\right]
$$
相关项目
参考资料
文章链接:
https://www.zywvvd.com/notes/study/image-processing/photometric-stereo/basic/