三角化:Triangulation: Why Optimize?

news2024/9/22 15:26:00

三角化:Triangulation: Why Optimize?

  • 1. 预备知识
    • 1.1 评估 3D 点准确性
  • 2. 提出的方法
    • 2.1 广义加权中点法
    • 2.2 可选的中点法
    • 2.3 Cheirality(多视图几何中代表着3D点的正景深约束)
    • 2.4 逆深度加权中点-Inverse Depth Weighted(IDW) Midpoint
  • 3. 实现代码

Reference:

  1. GitHub:openMVG

1. 预备知识

在这里插入图片描述

  • 向量 v \mathbf{v} v 的欧几里得范数: ∥ v ∥ \| \mathbf{v}\| v
  • 单位向量: v ^ = v / ∥ v ∥ \hat{\mathbf{v}} =\mathbf{v}/ \| \mathbf{v}\| v^=v/∥v
  • 两条线 L 0 \mathbf{L_0} L0 L 1 \mathbf{L_1} L1 间角度: ∠ ( L 0 , L 1 ) ∈ [ 0 , π / 2 ] \angle(\mathbf{L}_0,\mathbf{L}_1)\in[0,\pi/2] (L0,L1)[0,π/2]
  • 定义 x 0 = [ x 0 , y 0 , z 0 ] T \mathbf{x_0}=[x_0, y_0, z_0]^T x0=[x0,y0,z0]T x 1 = [ x 1 , y 1 , z 1 ] T \mathbf{x_1}=[x_1, y_1, z_1]^T x1=[x1,y1,z1]T 分别为相机参考系 C 0 C_0 C0 C 1 C_1 C1 的三维坐标;
  • R \mathbf{R} R t \mathbf{t} t 为两相机间的旋转和位移,则 x 1 = R x 0 + t \mathbf{x}_1=\mathbf{R}\mathbf{x}_0+\mathbf{t} x1=Rx0+t
  • 相机标定矩阵: K \mathbf{K} K
  • 每帧点观测到的其次像素坐标: u 0 = ( u 0 , v 0 , 1 ) ⊺ \mathbf{u}_{0}=(u_{0},v_{0},1)^{\intercal} u0=(u0,v0,1) u 1 = ( u 1 , v 1 , 1 ) ⊺ \mathbf{u}_{1}=(u_{1},v_{1},1)^{\intercal} u1=(u1,v1,1)
  • 归一化图像坐标: f 0 = [ x 0 / z 0 , y 0 / z 0 , 1 ] T \mathbf{f_{0}}=\left[x_{0}/z_{0},y_{0}/z_{0},1\right]^{T} f0=[x0/z0,y0/z0,1]T f 1 = [ x 1 / z 1 , y 1 / z 1 , 1 ] T \mathbf{f_{1}}=\left[x_{1}/z_{1},y_{1}/z_{1},1\right]^{T} f1=[x1/z1,y1/z1,1]T,分别由 f 0 = K − 1 u 0 \mathbf{f}_0=\mathbf{K}^{-1}\mathbf{u}_0 f0=K1u0 f 1 = K − 1 u 1 \mathbf{f}_1=\mathbf{K}^{-1}\mathbf{u}_1 f1=K1u1 得到;
  • 在 Fig.1a 的理想情况下,两个反向投影的光线相交,满足对极约束: f 1 ⋅ ( t × R f 0 ) = 0 \mathbf{f}_1\cdot(\mathbf{t}\times\mathbf{Rf}_0)=0 f1(t×Rf0)=0(SLAM十四讲 P167, x 2 T t ∧ R x 1 = 0 \mathbf{x_2}^Tt^{\wedge}\mathbf{R}\mathbf{x_1}=0 x2TtRx1=0);
  • 给定上图的深度标量 λ 0 \lambda_0 λ0 λ 1 \lambda_1 λ1,交点 x 1 \mathbf{x_1} x1 的公式为: x 1 = λ 0 R f 0 ^ + t \begin{aligned}\mathbf{x}_{1}& =\lambda_0\mathbf{R}\mathbf{\hat{f_0}}+\mathbf{t} \end{aligned} x1=λ0Rf0^+t x 1 = λ 1 f 1 ^ \begin{aligned}\mathbf{x}_{1}& =\lambda_1\mathbf{\hat{f_1}}\end{aligned} x1=λ1f1^。( f 0 ^ \mathbf{\hat{f_0}} f0^ f 1 ^ \mathbf{\hat{f_1}} f1^ 为理想值,由于图像测量和相机模型的不准确,这种情况很少发生。要从两条倾斜的光线推断三维点,就引出了下面的方法);

1.1 评估 3D 点准确性

一旦使用某种三角测量方法获得 3D 点 x 1 ′ \mathbf{x}_{1}' x1 的估计,就可以以多种方式评估其准确性:

  1. 计算 3D 误差,即: e 3 D = ∥ x 1 ′ − x t r u e ∥ e_{3D}=\|\mathbf{x}_1^\prime-\mathbf{x}_{\mathrm{true}}\| e3D=x1xtrue(见 Fig.1b);
  2. 计算 2D 误差,也就是重投影误差:
    d i = ∥ K ( f i − f i ′ ) ∥ = ∥ K ( f i − ( [ 0   0   1 ] x i ′ ) − 1 x i ′ ) ∥ for i = 0 , 1 ( 1 ) d_i=\|\mathbf{K}\left(\mathbf{f}_i-\mathbf{f}_i'\right)\|=\left\|\mathbf{K}\left(\mathbf{f}_i-\left(\left[\mathbf{0}\text{ }\mathbf{0}\text{ }\mathbf{1}\right]\mathbf{x}_i'\right)^{-1}\mathbf{x}_i'\right)\right\|\quad\text{for}\quad i=0,1 \quad(1) di=K(fifi)= K(fi([0 0 1]xi)1xi) fori=0,1(1)其中 x 0 ′ = R ⊺ ( x 1 ′ − t ) \mathbf{x}'_0=\mathbf{R}^\intercal(\mathbf{x}'_1-\mathbf{t}) x0=R(x1t)。这里 ( [ 0   0   1 ] x i ′ ) − 1 \left(\left[\mathbf{0}\text{ }\mathbf{0}\text{ }\mathbf{1}\right]\mathbf{x}_i'\right)^{-1} ([0 0 1]xi)1 求的是 z z z 轴坐标的逆,再乘上 x 1 ′ \mathbf{x}'_1 x1 可得归一化平面坐标(见 Fig.1b);
    2D 误差表示与测量的偏差,而 3D 误差表示与真实值的偏差。与 3D 误差不同,3D 点的 2D 误差可以在不同范数下评估,如:
    • L 1 L_1 L1 范数: d 0 + d 1 d_0+d_1 d0+d1
    • L 2 L_2 L2 范数: d 0 2 + d 1 2 \sqrt{d_0^2+d_1^2} d02+d12
    • L ∞ L_\infty L 范数: max ⁡ ( d 0 , d 1 ) \max(d_0,d_1) max(d0,d1)
  3. 除了 2D 和 3D 精度外,还可以评估得到的视差角精度(见 Fig.1c),视差误差定义如下(这里的表示感觉有点迷, x t r u e \mathbf{x}_{\mathrm{true}} xtrue 说的应该是 C 1 C_1 C1 x t r u e \mathbf{x}_{\mathrm{true}} xtrue 的直线,而 x t r u e − t \mathbf{x}_{\mathrm{true}}-\mathbf{t} xtruet C 0 C_0 C0 x t r u e \mathbf{x}_{\mathrm{true}} xtrue 的直线):
    e β = ∣ β t r u e − β ′ ∣ = ∣ ∠ ( x t r u e , x t r u e − t ) − ∠ ( x 1 ′ , x 1 ′ − t ) ∣ ( 2 ) e_{\beta}=|\beta_{\mathrm{true}}-\beta'|=|\angle\left(\mathbf{x}_{\mathrm{true}},\mathbf{x}_{\mathrm{true}}-\mathbf{t}\right)-\angle\left(\mathbf{x}'_1,\mathbf{x}'_1-\mathbf{t}\right)| \quad(2) eβ=βtrueβ=∣∠(xtrue,xtruet)(x1,x1t)(2)将“原始视差”定义为原始反投影光线之间的角度:
    β r a w = ∠ ( R f 0 , f 1 ) . ( 3 ) \beta_{\mathrm{raw}}=\angle\left(\mathbf{Rf}_0,\mathbf{f}_1\right). \quad(3) βraw=(Rf0,f1).(3)这给出了独立于平移和三角化方法的视差角粗略估计。

2. 提出的方法

2.1 广义加权中点法

广义加权中点法 Generalized Weighted Midpoint (GWM) 包含以下三个步骤:

  1. 给定对应于同一点的两个反向投影光线,使用一些方法估计两条光线 ( λ 0 , λ 1 ) (\lambda_0, \lambda_1) (λ0,λ1) 的深度;
  2. 计算这两条深度为 λ 0 \lambda_0 λ0 λ 1 \lambda_1 λ1 的光线的 3D 点,也就是在 C 1 C_1 C1 帧的 t + λ 0 R f 0 ^ \mathbf{t} + \lambda_0\mathbf{R}\mathbf{\hat{f_0}} t+λ0Rf0^ λ 1 f 1 ^ \lambda_1\mathbf{\hat{f_1}} λ1f1^
  3. 通过计算它们的加权平均来获得 3D 点的最终估计。

以前经典的中点方法是,每条光线的两个点是有着相同权重的最接近点对。而下图展示了广义加权中点的另一个可能的示例:
在这里插入图片描述

2.2 可选的中点法

这里提出一种属于 GWM 的可选中点法。首先考虑两个反向投影碰巧相交的情况,如 Fig.1a。在这种情况下,最合理的解决方案是交点,可以使用正弦规则获得沿射线的对应深度:
λ 0 = sin ⁡ ( ∠ ( f 1 , t ) ) sin ⁡ ( ∠ ( R f 0 , f 1 , ) ) ∥ t ∥ = ∥ f ^ 1 × t ∥ ∥ R f ^ 0 × f ^ 1 ∥ , λ 1 = sin ⁡ ( ∠ ( R f 0 , t ) ) sin ⁡ ( ∠ ( R f 0 , f 1 , ) ) ∥ t ∥ = ∥ R f ^ 0 × t ∥ ∥ R f ^ 0 × f ^ 1 ∥ . ( 4 ) \lambda_0=\frac{\sin\left(\angle\left(\mathbf{f}_1,\mathbf{t}\right)\right)}{\sin\left(\angle\left(\mathbf{R}\mathbf{f}_0,\mathbf{f}_1,\right)\right)}\|\mathbf{t}\|=\frac{\|\hat{\mathbf{f}}_1\times\mathbf{t}\|}{\|\mathbf{R}\hat{\mathbf{f}}_0\times\hat{\mathbf{f}}_1\|},\quad\lambda_1=\frac{\sin\left(\angle\left(\mathbf{R}\mathbf{f}_0,\mathbf{t}\right)\right)}{\sin\left(\angle\left(\mathbf{R}\mathbf{f}_0,\mathbf{f}_1,\right)\right)}\|\mathbf{t}\|=\frac{\|\mathbf{R}\hat{\mathbf{f}}_0\times\mathbf{t}\|}{\|\mathbf{R}\hat{\mathbf{f}}_0\times\hat{\mathbf{f}}_1\|}. \quad(4) λ0=sin((Rf0,f1,))sin((f1,t))t=Rf^0×f^1f^1×t,λ1=sin((Rf0,f1,))sin((Rf0,t))t=Rf^0×f^1Rf^0×t.(4)在两条光线是倾斜的时候,也使用该公式估计深度。分别计算 3D 点在每条光线上的深度 λ 0 \lambda_0 λ0 λ 1 \lambda_1 λ1,得:
t + λ 0 R f ^ 0 = t + ∥ f 1 × t ∥ ∥ R f 0 × f 1 ∥ R f 0 and λ 1 f 1 ^ = ∥ R f 0 × t ∥ ∥ R f 0 × f 1 ∥ f 1 ( 5 ) \mathbf{t}+\lambda_0\mathbf{R}\hat{\mathbf{f}}_0=\mathbf{t}+\frac{\|\mathbf{f}_1\times\mathbf{t}\|}{\|\mathbf{Rf}_0\times\mathbf{f}_1\|}\mathbf{Rf}_0\quad\text{and}\quad\lambda_1\hat{\mathbf{f_1}}=\frac{\|\mathbf{Rf}_0\times\mathbf{t}\|}{\|\mathbf{Rf}_0\times\mathbf{f}_1\|}\mathbf{f}_1 \quad(5) t+λ0Rf^0=t+Rf0×f1f1×tRf0andλ1f1^=Rf0×f1Rf0×tf1(5)取这两个点的中点有:
x 1 ′ = 1 2 ( t + ∥ f 1 × t ∥ ∥ R f 0 × f 1 ∥ R f 0 + ∥ R f 0 × t ∥ ∥ R f 0 × f 1 ∥ f 1 ) . ( 6 ) \mathbf{x}_1'=\frac{1}{2}\left(\mathbf{t}+\frac{\|\mathbf{f}_1\times\mathbf{t}\|}{\|\mathbf{R}\mathbf{f}_0\times\mathbf{f}_1\|}\mathbf{R}\mathbf{f}_0+\frac{\|\mathbf{R}\mathbf{f}_0\times\mathbf{t}\|}{\|\mathbf{R}\mathbf{f}_0\times\mathbf{f}_1\|}\mathbf{f}_1\right). \quad(6) x1=21(t+Rf0×f1f1×tRf0+Rf0×f1Rf0×tf1).(6) p = R f ^ 0 × f ^ 1 \mathbf p=\mathbf R\hat{\mathbf f}_0\times\hat{\mathbf f}_1 p=Rf^0×f^1 q = R f ^ 0 × t \mathbf q=\mathbf R\hat{\mathbf f}_0\times\mathbf t q=Rf^0×t 以及 r = f ^ 1 × t \mathbf r=\hat{\mathbf f}_1\times\mathbf t r=f^1×t,深度公式可替换为:
λ 0 = ∣ ∣ r ∣ ∣ ∣ ∣ p ∣ ∣ , λ 1 = ∣ ∣ q ∣ ∣ ∣ ∣ p ∣ ∣ ( 7 ) \lambda_{0}={\frac{||\mathbf{r}||}{||\mathbf{p}||}},\quad\lambda_{1}={\frac{||\mathbf{q}||}{||\mathbf{p}||}} \quad(7) λ0=∣∣p∣∣∣∣r∣∣,λ1=∣∣p∣∣∣∣q∣∣(7)这些形式类似于以前经典的中点法给出的深度:
λ mid 0 = p ^ ⋅ r ∥ p ∥ , λ mid 1 = p ^ ⋅ q ∥ p ∥ . ( 8 ) \lambda_{\text{mid}0}=\frac{\hat{\mathbf{p}}\cdot\mathbf{r}}{\|\mathbf{p}\|},\quad\lambda_{\text{mid}1}=\frac{\hat{\mathbf{p}}\cdot\mathbf{q}}{\|\mathbf{p}\|}. \quad(8) λmid0=pp^r,λmid1=pp^q.(8)这两种公式的不同之处在于分子,equ.7 有大小 r \mathbf{r} r q \mathbf{q} q,而 equ.8 将它们投影到 p \mathbf{p} p 上。因此,我们总是得到 λ 0 ≥ λ mid 0 \lambda_0\geq \lambda_{\text{mid}0} λ0λmid0 λ 1 ≥ λ mid 1 \lambda_1\geq \lambda_{\text{mid}1} λ1λmid1。在大多数情况下,这意味着该方法得到的中点会比经典中点更远。在 Fig.2 描述的例子里,当我们估计一个远离相机的点时,通常(传统三角化方法)会导致估计的视差角较小。

2.3 Cheirality(多视图几何中代表着3D点的正景深约束)

在这里插入图片描述当三角化的点有负深度时,违反了 3D 点的正景深约束。这可能有很多原因产生,如点对的关联错了或极点附近的图像点有噪声。通常它不会造成严重的问题,因为可以很轻易检查每个点的正景深并抛弃坏点。对于经典的中点方法,可以通过检查 equ.8 给出的深度符号确认。但对于该文中给出的方法是不能这样确认的,因为给出的深度总为正。上图说明了两种方法间的差异。因此在该方法中,仅靠深度不能说明三角测量的结果是否可靠。

这时需要使用其他方法来测试该点是否为坏点(满足以下不等式即为坏点):如果将至少一个深度的符号改为负会导致光线上两点间距变小,则抛弃这个点的对应关系:
∥ t + λ 0 R f 0 ^ − λ 1 f ^ 1 ∥ 2 ≥ min ⁡ ( ∥ t + λ 0 R f 0 ^ + λ 1 f 1 ^ ∥ 2 , ∥ t − λ 0 R f 0 ^ − λ 1 f ^ 1 ∥ 2 , ∥ t − λ 0 R f 0 ^ + λ 1 f 1 ^ ∥ 2 ) ( 9 ) \|\mathbf{t}+\lambda_0\mathbf{R}\hat{\mathbf{f_0}}-\lambda_1\hat{\mathbf{f}}_1\|^2\geq\min\left(\|\mathbf{t}+\lambda_0\mathbf{R}\hat{\mathbf{f_0}}+\lambda_1\hat{\mathbf{f_1}}\|^2,\|\mathbf{t}-\lambda_0\mathbf{R}\hat{\mathbf{f_0}}-\lambda_1\hat{\mathbf{f}}_1\|^2,\|\mathbf{t}-\lambda_0\mathbf{R}\hat{\mathbf{f_0}}+\lambda_1\hat{\mathbf{f_1}}\|^2\right)\quad(9) t+λ0Rf0^λ1f^12min(t+λ0Rf0^+λ1f1^2,tλ0Rf0^λ1f^12,tλ0Rf0^+λ1f1^2)(9)对于经典的中点法,令 λ 0 = ∣ λ m i d 0 ∣ \lambda_0=|\lambda_{mid0}| λ0=λmid0 λ 1 = ∣ λ m i d 1 ∣ \lambda_1=|\lambda_{mid1}| λ1=λmid1 可以有效得到与检验正景深约束相同的结果(显而易见,都是验证这个数是不是大于零的)。而现方法在 equ.9 在 Fig.3a 成立,是因为当 λ 0 = − ∣ λ m i d 0 ∣ \lambda_0=-|\lambda_{mid0}| λ0=λmid0 λ 1 = − ∣ λ m i d 1 ∣ \lambda_1=-|\lambda_{mid1}| λ1=λmid1 时两点最接近。

2.4 逆深度加权中点-Inverse Depth Weighted(IDW) Midpoint

equ.6 给出的为加权中点通常会导致两幅图像不成比例的重投影误差,Fig.3c 给出了一个例子。注意具有较小深度的光线往往会产生较大的重投影误差。为了补偿这种不平衡,文中建议使用逆深度作为权重:
x 1 ′ = λ 0 − 1 ( t + λ 0 R f 0 ^ ) + λ 1 − 1 ( λ 1 k 1 ^ ) λ 0 − 1 + λ 1 − 1 = ∥ q ∥ ∥ q ∥ + ∥ r ∥ ( t + ∥ r ∥ ∥ p ∥ ( k f 0 ^ + f 1 ^ ) ) . \mathbf{x}_1'=\frac{\lambda_0^{-1}\left(\mathbf{t}+\lambda_0\mathbf{R}\hat{\mathbf{f_0}}\right)+\lambda_1^{-1}\left(\lambda_1\hat{\mathbf{k_1}}\right)}{\lambda_0^{-1}+\lambda_1^{-1}}=\frac{\|\mathbf{q}\|}{\|\mathbf{q}\|+\|\mathbf{r}\|}\left(\mathbf{t}+\frac{\|\mathbf{r}\|}{\|\mathbf{p}\|}\left(\mathbf{k}\hat{\mathbf{f_0}}+\hat{\mathbf{f_1}}\right)\right). x1=λ01+λ11λ01(t+λ0Rf0^)+λ11(λ1k1^)=q+rq(t+pr(kf0^+f1^)).

3. 实现代码

// Helper function
// Compute Relative motion between two absolute poses parameterized by Rt
// Rotate one bearing vector according to the relative motion
inline void AbsoluteToRelative(const Mat3 &R0, const Vec3 &t0, const Mat3 &R1, const Vec3 &t1, const Vec3 &x0, Mat3 &R, Vec3 &t, Vec3 &Rx0)
{
  R = R1 * R0.transpose();
  t = t1 - R * t0;
  Rx0 = R * x0;
}

bool TriangulateIDWMidpoint(const Mat3 & R0, const Vec3 & t0, const Vec3 & x0, const Mat3 & R1, const Vec3 & t1, const Vec3 & x1, Vec3* X_euclidean)
{
  // absolute to relative
  Mat3 R;
  Vec3 t, Rx0;
  AbsoluteToRelative(R0, t0, R1, t1, x0, R, t, Rx0);

  const double p_norm = Rx0.cross(x1).norm();
  const double q_norm = Rx0.cross(t).norm();
  const double r_norm = x1.cross(t).norm();

  // Eq. (10)
  const auto xprime1 = ( q_norm / (q_norm + r_norm) )
    * ( t + (r_norm / p_norm) * (Rx0 + x1) );

  // relative to absolute
  *X_euclidean = R1.transpose() * (xprime1 - t1);

  // Eq. (7)
  const Vec3 lambda0_Rx0 = (r_norm / p_norm) * Rx0;
  const Vec3 lambda1_x1 = (q_norm / p_norm) * x1;

  // Eq. (9) - test adequation
  return (t + lambda0_Rx0 - lambda1_x1).squaredNorm()
    <
    std::min(std::min(
      (t + lambda0_Rx0 + lambda1_x1).squaredNorm(),
      (t - lambda0_Rx0 - lambda1_x1).squaredNorm()),
      (t - lambda0_Rx0 + lambda1_x1).squaredNorm());
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/564280.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

塞尔达工业革命卷到数字电路了!网友:怕不是要在Switch里造Switch

量子位 | 公众号 QbitAI 《塞尔达传说&#xff1a;王国之泪》发布一周多&#xff0c;懂物理的和不懂物理的都沉默了。 如果说&#xff0c;一个打怪靠冷兵器的救公主游戏&#xff0c;主角开上带悬挂的摩托车&#xff0c;还不算稀奇&#xff1a; △B站up主&#xff1a;天舐鱼XQ…

springboot项目部署到宝塔

网上查找资料要么是细节不够失败要么是根本没用也不需要这么复杂&#xff0c;在这里总结一下本人在宝塔部署前端和后端的方法。 1.在宝塔上添加站点 ↑部署项目当然需要一个站点 2.在该站点的根目录下放打包好的jar文件和前端文件 ↑此时可以访问站点链接&#xff0c;无法请求数…

和月薪5W的京东程序员聊过后,才知道自己一直在打杂...

前几天和一个朋友聊面试&#xff0c;他说上个月同时拿到了腾讯和京东的offer&#xff0c;最后选择了京东。 京东内部将员工一共分为了14个等级&#xff0c;P6是资深工程师&#xff0c;P7是技术专家。 其中P6和P7就是一个分水岭了&#xff0c;P6是最接近P7的不持股员工&#x…

ES Elasticsearch 五 、文档入门****

目录 文档document介绍 手动生成id 自动生成id _source //定制查询字段 全量替换 put 强制创建-只创建不覆盖 增加/_create 延迟删除 该状态防止磁盘写入消耗 局部更新 脚本 并发问题 文档document介绍 默认字段&#xff1a;_index 索引 _type 类型 _id 可…

分享个自用的提升效率的ahk脚本

在草稿中新建笔记 有时遇到灵感想要快速记录&#xff0c;只要按winw快捷键&#xff0c;即可在指定文件夹中新建md文档&#xff0c;后期也可以再做一个收集并上传文档的脚本。 #w::Gui DestroyGui, Add, Edit, vMyEditGui, Add, Button, default xm, OKGui, Show ReturnButtonO…

小米手机系列的演进:从小米1到小米13

1. 小米1&#xff08;2011年&#xff09;&#xff1a;小米1是小米公司的首款旗舰手机&#xff0c;以超低的售价提供出色的硬件配置和流畅的用户体验。它打破了传统手机市场的价格壁垒&#xff0c;受到广大用户的欢迎。 2. 小米2&#xff08;2012年&#xff09;&#xff1a;小米…

Dubbo源码篇06---SPI神秘的面纱---原理篇---上

Dubbo源码篇06---SPI神秘的面纱---原理篇---上 引言核心思想SPI模块架构设计源码追踪Dubbo的分层模型获取扩展加载器对象创建ExtensionLoaderExtensionLoader自适应扩展对象创建Extension Instance创建生命周期SPI机制获取扩展对象实现类型获取扩展类型使用不同的加载策略加载不…

傅利叶变换在图像处理的应用

傅利叶变换在图像处理的应用 1.傅利叶变换在图像处理的应用1.1 图像函数化1.2 幅度谱1.3 相位谱1.4 图像处理的底层原理 1.傅利叶变换在图像处理的应用 之前本人的相关博客&#xff1a;傅里叶变换与图像处理 笔记来源&#xff1a;傅里叶变换从零到一 03集 从爱因斯坦和梦露讲起…

智慧档案馆一体化环境管控平台格式内容

第一章建设背景 第二章建设依据 1、 设计遵循规范 2、 方案设计原则 3、 成熟性 4、 开放性 5、 标准化 6、 可扩展性 7、 安全性 8、 可靠性 9、 高效、系统易用、互操作性 10、 经济性 11、 可管理性 第三章建设内容 1、管理总平台建设 2、档案库房环境建设 …

QT课程 UI设计

目录 1.面板的划分 2.组件对象和继承关系 3.QWidget类 注&#xff1a;学习布局前先知道这点 4.Layout 布局 5.Spacers 间隔器 6.基础组件对象 6.1 QLabel便签组件 6.2 QAbstractButton 按钮类 6.3 QLineEdit 单行文本输入框 6.4 QSpinBox&#xff08;数字选择器&…

java面试项目三:在线教育

1、项目简介 项目规模&#xff1a;15人 项目周期&#xff1a;2021.5-至今 开发环境&#xff1a;Intellij IDEA、Maven、JDK1.8、GIT 所用框架&#xff1a;Spring、SpringBoot、Mybatis-Plus、SpringCloud、Shiro、XXL-Job、 其他技术&#xff1a;RocketMQ、Redis、Mysql、Mongo…

梦x西游H5页面搭建教程Centos

梦x西游H5页面搭建教程Centos 大家好&#xff0c;我是艾西&#xff0c;今天给大家分享一款H5页面的游戏搭建教程。版本分为三种族、四种族、五种族&#xff0c;大家可以自己喜欢哪个版本自己尝试开服架设等&#xff0c;今天我们以三种族的为演示。 那么让我们直接进入正题开…

9. Linux下实现简单的socket通讯

本文简单介绍了UDP传输层协议&#xff0c;并在Linux下实现简单的socket通讯 一、UDP UDP&#xff08;User Datagram Protocol&#xff0c;用户数据报协议&#xff09;是一种无连接的传输层协议&#xff0c;它不保证数据包的可靠性和顺序。UDP在IP协议的基础上增加了简单的差错…

es 四 快速入门****

目录 查看集群状态 **颜色&#xff1a; 查看集群索引 **简单的索引操作 kibana 创建索引模式 Es 存储 文档 json数据 查看集群状态 get /_cat/health 带上表头 get /_cat/health?v **颜色&#xff1a; 绿色: 主分片副本分片可用 黄色: 主分片可用、副本分片不可用 红…

Java 与数据结构(6):快速排序

ChatGPT 中文指南(大全) 内容包含&#xff1a;如何开通chatgpt、chatgpt的同类站点、prompts 、AI绘图、ChatGPT 工具、相关报告论文、ChatGPT应用项目等 链接&#xff1a;ChatGPT 中文指南(大全) 指令指南&#xff0c;精选资源清单&#xff0c;更好的使用 chatGPT 让你的生产力…

C++线程池介绍和C++代码实现

1、介绍 1.1 线程池应用场景 在进行创建线程任务时&#xff0c;如果需要频繁的创建线程、销毁线程&#xff0c;这样会极大地降低效率&#xff0c;因为创建线程也是需要时间的&#xff0c;一个完整的线程处理运行时间包括&#xff1a;线程的创建时间、线程运作时间、线程的销毁…

【C++】-string的介绍以及使用(迭代器的介绍和使用)

&#x1f496;作者&#xff1a;小树苗渴望变成参天大树 ❤️‍&#x1fa79;作者宣言&#xff1a;认真写好每一篇博客 &#x1f4a8;作者gitee:gitee &#x1f49e;作者专栏&#xff1a;C语言,数据结构初阶,Linux,C 如 果 你 喜 欢 作 者 的 文 章 &#xff0c;就 给 作 者 点…

谈谈国产化CRM系统市场前景与发展趋势

随着数字化时代的到来&#xff0c;CRM系统已经成为企业管理中不可或缺的一部分。在过去&#xff0c;大多数企业都选择使用海外CRM系统&#xff0c;比如Salesforce、SAP等&#xff0c;但随着国内CRM系统的逐渐发展&#xff0c;越来越多的企业开始将目光转向了国产CRM系统。 一、…

Qt--自定义控件

写在前面 Qt中提供了应用在各种场景的控件&#xff0c;使开发人员在实际工作中选择。但有些特定的场合中这些控件并不满足需要时&#xff0c;Qt允许使用自定义的控件。 例&#xff1a;我们在工作中有这样一种需求&#xff0c;点击按钮会根据一些其他状态来显示不同的图片&…

在外远程登录局域网下的象过河ERP管理系统,无需公网IP

文章目录 概述1.查看象过河服务端端口2.内网穿透3. 异地公网连接4. 固定公网地址4.1 保留一个固定TCP地址4.2 配置固定TCP地址 5. 使用固定地址连接 转发自CSDN远程穿透的文章&#xff1a;公网远程访问公司内网象过河ERP系统「内网穿透」 概述 ERP系统对于企业来说重要性不言而…