OpenVINS 官方文档 第一部分

news2025/1/10 21:21:08

参考链接:OpenVINS https://docs.openvins.com/index.html


1. Getting Started

  欢迎来到OpenVIINS项目!以下指南将帮助新用户下载软件并在我们支持的数据集上运行。此外,我们还提供有关如何在我们的系统上运行您自己的传感器的信息,并提供有关我们如何标定的指南。如果您发现任何缺失或需要澄清的地方,请随时提出问题。

High-level overview
  从高层次来看,该系统建立在几个关键算法之上我们以 ov_core 为核心,其中包含许多任何人都可以使用的标准计算机视觉算法和实用程序。具体来说,它存储以下大型组件:

  • 稀疏特征视觉跟踪(基于 KLT 和描述符)
  • 用于表示状态的基本数学类型
  • 初始化过程
  • 生成合成测量值的多传感器模拟器

  这个 ov_core 库由包含我们基于过滤器的估计器的 ov_msckf 系统使用。其中我们有状态、管理器、类型系统、预测和更新算法。我们鼓励用户查看特定文档,详细了解我们提供的内容。ov_eval 库有一堆评估方法和脚本,可以用来生成研究成果以供发表。

1.5 传感器标定 — 如何标定您自己的视觉惯性传感器

视觉惯性传感器
  有人可能会问为什么要使用视觉惯性传感器?主要原因是因为两种不同传感方式的互补性。摄像头提供高密度的环境外部测量,而IMU测量传感器平台的内部自我运动。IMU对于为估算器提供鲁棒性至关重要,同时在单眼摄像头的情况下还提供系统尺度。
  但是,在估计中利用IMU时存在一些挑战。IMU 需要估计其他偏置项,并且需要在相机和 IMU 之间进行高精度标定。此外,传感器之间相对时间戳中的小误差也会在动态轨迹中非常迅速地降低性能。在这个 OpenVINS 项目中,我们通过倡导在线估计相机和IMU之间的这些外参和时间偏移参数来解决这些问题。

相机内参标定(离线)
  第一个任务是校准相机内参,例如焦距、相机中心和畸变参数。我们的团队经常使用 Kalibr 校准工具箱进行内参和外参离线标定,方法是执行以下步骤:

  1. 下载并构建 Kalibr 工具箱。
  2. 打印出要使用的标定板(我们通常使用 Aprilgrid 6x6 0.8x0.8米)。
  3. 确保传感器驱动程序使用正确的时间戳发布到 ROS 上。
  4. 传感器准备。
    ● 通过减少曝光时间来限制运动模糊;
    ● 以低帧率发布,以允许数据集中较大的差异 (2-5hz);
    ● 确保可以在图像中看到标定板;
    ● 确保您的传感器对焦(可以使用其 kalibr_camera_focus 或手动)
  5. 录制 ROS 数据包,并确保可以从图像平面的不同方向,距离和每个部分看到标定板。您可以移动标定板并保持相机静止,也可以移动相机并保持标定板静止。
  6. 最后运行校准。
    ● 将 kalibr_calibrate_cameras 与指定的话题一起使用
    ● 根据畸变程度,对鱼眼使用 pinhole-equi,或者如果畸变较低,则使用 pinhole-radtan
  7. 检查最终结果,密切关注最终重投影误差图,良好的标定小于<0.2-0.5像素重投影误差。

IMU Intrinsic Calibration (Offline)
  另一个内参标定是计算惯性传感器固有噪声特性,这是批量优化所必需的,以将相机校准为IMU变换和任何VINS估计器,以便我们可以正确地概率融合图像和惯性读数。不幸的是,没有成熟的开源工具箱来查找这些值,而可以尝试我们的kalibr_allan项目,尽管该项目没有优化。具体来说,我们估计了以下噪声参数:
加粗样式

在这里插入图片描述

  如上图所示,如果我们计算艾伦方差,我们可以看在在图的左侧 τ = 1 \tau=1 τ=1以及拟合-1/2斜率这条线,以获得传感器的白噪声。类似地,可以评估右侧 τ = 3 \tau=3 τ=3 以及1/2 斜率的这条线以获得随机游走噪声。我们有一个可以在 matlab 中做到这一点的包,但实际的验证和转换为C++代码库尚未完成。请参阅我们的 kalibr_allan github 项目,详细了解如何为传感器生成此图并计算值。请注意,可能需要将计算值膨胀 10-20 倍才能获得可用的传感器值。

动态 IMU 摄像头标定(离线)
  在获得相机和IMU的内参后,我们现在可以对两个传感器之间的变换进行动态校准。为此,我们再次利用 Kalibr 标定工具箱。对于这些收集的数据集,重要的是尽量减少相机中的运动模糊,同时确保激励IMU的所有轴。需要至少有一个平移运动以及两个方向变化才能观察到这些标定参数(请参阅我们最近的论文:使用在线空间和时间传感器标定的辅助INS的简并运动分析)。我们建议尽可能多地改变方向,以确保收敛。

  1. 下载并构建 Kalibr 工具箱。
  2. 打印出要使用的标定板(我们通常使用 Aprilgrid 6x6 0.8x0.8米)。
  3. 确保传感器驱动程序使用正确的时间戳发布到 ROS 上。
  4. 传感器准备。
    ● 通过减少曝光时间来限制运动模糊;
    ● 以高帧率 (20-30hz) 发布;
    ● 以合理的速率(200-500hz)发布惯性读数;
  5. 录制 ROS 数据包,并确保可以从不同的方向,距离看到标定板,并且大部分在图像的中心。您应该以平滑的非生涩运动移动,其轨迹可以同时激发尽可能多的方向和平移方向。30-60秒的数据集通常足以进行标定。
  6. 最后运行校准。
    ● 使用kalibr_calibrate_imu_camera
    ● 输入您的静态标定文件,其中将包含相机话题
    ● 您需要使用噪声参数创建一个 imu.yaml 文件。
    ● 根据数据集中的帧数,这可能需要半天以上的时间。
  7. 检查最终结果。您需要确保拟合到惯性读数的样条已正确拟合。确保您的估计偏差不会超出您的 3-sigma 界限。否则说明你的轨迹太动态了,或者你的噪声值不好。使用手动测量值检查您的最终旋转和平移。

2. IMU Propagation Derivations

2.1 IMU Measurements
  我们使用 6 轴惯性测量单元 (IMU) 来传播惯性导航系统 (INS),该系统提供局部旋转速度(角速率) ω m \omega_m ωm和局部平移加速度 α m \alpha_m αm的测量:
ω m ( t ) = ω ( t ) + b g ( t ) + n g ( t ) \omega_m(t) = \omega(t) + b_g(t) + n_g(t) ωm(t)=ω(t)+bg(t)+ng(t) α m ( t ) = α ( t ) + G I R ( t ) g G + b a ( t ) + n a ( t ) \alpha_m(t) = \alpha(t) + {_G^I}R(t)^G_g + b_a(t) + n_a(t) αm(t)=α(t)+GIR(t)gG+ba(t)+na(t)
其中 ω \omega ω α \alpha α 是 IMU 本地坐标系 { I } \{I\} {I}中的真实旋转速度和平移加速度, b g b_g bg b a b_a ba 是陀螺仪和加速度计偏差, n g n_g ng n a n_a na 是白高斯噪声, G g = [ 0 0 9.81 ] ⊤ {^G}g =\left[ \begin{array}{ccc} 0 & 0 & 9.81\\ \end{array} \right]^{\top} Gg=[009.81] 是全局坐标系 { G } \{G\} {G}中表示的重力(注意重力在地球的不同位置略有不同), G I R {_G^I}R GIR是从全局坐标系到 IMU 本地坐标系的旋转矩阵。

2.2 State Vector
  我们将 INS 在时间 t t t 的状态向量 X I X_I XI 定义为:
X I ( t ) = [ G I q ˉ ( t ) G p I ( t ) G v I ( t ) b g ( t ) b a ( t ) ] X_I(t) = \left[ \begin{array}{ccc} {_G^I} \bar q(t) \\ {^G} p_I(t) \\ {^G} v_I(t)\\ b_g (t) \\ b_a(t)\\ \end{array} \right] XI(t)= GIqˉ(t)GpI(t)GvI(t)bg(t)ba(t)

其中,单位四元数 G I q ˉ {_G^I} \bar q GIqˉ 表示 IMU 帧的旋转全局, G p I {^G}p_I GpI 是 IMU 在全局帧中的位置, G v I {^G} v_I GvI 是 IMU 在全局帧中的速度。为了表示清晰起见,我们通常会将时间写成描述当时 IMU 状态的下标(例如 G I t q ˉ = G I q ˉ ( t ) {_G^{I_t}} \bar q = {_G^I} \bar q(t) GItqˉ=GIqˉ(t))。为了定义 IMU 误差状态,对位置、速度和偏差采用标准的加性误差定义,而我们使用具有左四元数乘法误差 ⊗ \otimes 的四元数误差状态 δ q ˉ \delta \bar q δqˉ:
G I q ˉ = δ q ˉ ⊗ G I q ˉ ^ {_G^I} \bar q = \delta \bar q \otimes {_G^I} \hat{\bar q} GIqˉ=δqˉGIqˉ^ δ q ˉ = [ k ^ s i n ( 1 2 θ ~ ) c o s ( 1 2 θ ~ ) ] ≈ [ 1 2 ^ θ ~ 1 ] \delta \bar q = \begin{bmatrix} \hat ksin({1\over 2} \tilde \theta) \\ cos({1\over 2 }\tilde \theta) \\ \end{bmatrix} \approx \begin{bmatrix} \hat {1\over 2} \tilde \theta \\ 1 \\ \end{bmatrix} δqˉ=[k^sin(21θ~)cos(21θ~)][21^θ~1]
其中 k ^ \hat k k^ 是旋转轴, θ ~ \tilde \theta θ~ 是旋转角度,对于小旋转,误差角度矢量近似为 θ ~ = θ ~ k ^ \tilde \theta = \tilde \theta \hat k θ~=θ~k^,作为关于三个方向轴的误差向量。因此,全部 IMU 误差状态定义为以下 15x1(非 16x1)矢量:
X ~ I ( t ) = [ G I θ ~ ( t ) G p ~ I ( t ) G v ~ I ( t ) b ~ g ( t ) b ~ a ( t ) ] \tilde X_I(t) = \left[ \begin{array}{ccc} {_G^I} \tilde \theta(t) \\ {^G} \tilde p_I(t) \\ {^G} \tilde v_I(t)\\ \tilde b_g (t) \\ \tilde b_a(t)\\ \end{array} \right] X~I(t)= GIθ~(t)Gp~I(t)Gv~I(t)b~g(t)b~a(t)

2.3 IMU Kinematics
IMU 状态随时间演变如下(参见用于 3D 姿态估计的间接卡尔曼滤波)。
G I q ˉ ˙ ( t ) = 1 2 [ − ω ( t ) × ω ( t ) − ω ⊤ ( t ) 0 ] G I t q ˉ {_G^I} \dot{ \bar q}(t) = {1 \over 2} \left[ \begin{array}{ccc} -\omega(t)\times & \omega(t)\\ -\omega^\top(t) & 0 \\ \end{array} \right] {_G^{I_t}} \bar q GIqˉ˙(t)=21[ω(t)×ω(t)ω(t)0]GItqˉ = : 1 2 Ω ( ω ( t ) ) G I t q ˉ =:{1\over 2}\Omega(\omega (t)){_G^{I_t}} \bar q =:21Ω(ω(t))GItqˉ G p ˙ I ( t ) = G v I ( t ) {^G} \dot p_I(t) = {^G}v_I(t) Gp˙I(t)=GvI(t) G v ˙ I ( t ) = G I t R ⊤ a ( t ) {^G} \dot v_I(t) = {_G^{I_t}} R^{\top}a(t) Gv˙I(t)=GItRa(t) b ˙ g ( t ) = n ω g \dot b_g(t) = n_{\omega g} b˙g(t)=nωg b ˙ a ( t ) = n ω a \dot b_a(t) = n_{\omega a} b˙a(t)=nωa

  我们将陀螺仪和加速度计偏差建模为随机游走,因此它们的时间导数是高斯白噪声(高斯白噪声中的高斯是指概率分布是正态函数,而白噪声是指它的二阶矩不相关,一阶矩为常数,是指先后信号在时间上的相关性。)。请注意,上述运动学是根据真实加速度和角速度定义的。


3. First-Estimate Jacobian Estimators

3.1 EKF 线性化误差状态系统
  在开发扩展卡尔曼滤波器(EKF)时,需要围绕某个线性化点对非线性运动和测量模型进行线性化。这种线性化是导致估计误差不准确的误差来源之一(除了模型误差和测量噪声之外)。让我们考虑以下线性化误差状态视觉惯性系统:
X ~ k ∣ k − 1 = Φ ( k . k − 1 ) X ~ k − 1 ∣ k − 1 + G k w k \tilde X_{k|k-1} = \Phi_{(k.k-1)} \tilde X_{k-1|k-1} + G_kw_k X~kk1=Φ(k.k1)X~k1∣k1+Gkwk Z ~ k = H k X ~ k ∣ k − 1 + n k \tilde Z_k = H_k\tilde X_{k|k-1}+n_k Z~k=HkX~kk1+nk
其中状态包含惯性导航状态和单个环境特征(请注意,我们不包括偏差以简化推导):
X k = [ G I k q ˉ ⊤ G p I k ⊤ G v I k ⊤ G p f ⊤ ] ⊤ X_k=\left[ \begin{array}{ccc} {_G^{I_k}} \bar q^{\top} & {^G} p^{\top}_{I_k} & {^G} v^{\top}_{I_k} & {^G} p^{\top}_{f} \\ \end{array} \right]^\top Xk=[GIkqˉGpIkGvIkGpf]
  请注意,我们使用左四元数误差状态(有关详细信息,请参见用于3D姿态估计的间接卡尔曼滤波器)。为简单起见,我们假设相机和 IMU 帧相同的转换。我们可以根据第 k k k 个时间步长的透视投影相机模型计算给定特征的雅可比测量值,如下所示:
H k = H p r o j , k H s t a t e , k H_k = H_{proj,k}H_{state,k} Hk=Hproj,kHstate,k = [ 1 I Z 0 _ I x ( I z ) 2 0 1 I z _ I y ( I z ) 2 ] [ ⌊ G I k R ( G p f − G p I k ) × ⌋ − G I k R 0 3 × 3 G I K R ] =\left[ \begin{array}{ccc} {1\over I_Z} & 0& {{^{\_I}}x \over ({^I}z)^2} \\ 0 & {1\over {^I}z} & {{^{\_I}y}\over ({^I}z)^2}\\ \end{array} \right]\left[ \begin{array}{ccc} \lfloor {^{I_k}_G}R({^G}p_f-{^G}p_{I_k})\times \rfloor& -{^{I_k}_G}R & 0_{3\times3} & {^{I_K}_G}R\\ \end{array} \right] =[IZ100Iz1(Iz)2_Ix(Iz)2_Iy][GIkR(GpfGpIk)×GIkR03×3GIKR] = H p r o j , k G I k R [ ⌊ ( G p f − G p I k ) × ⌋ G I k R ⊤ − I 3 × 3 0 3 × 3 I 3 × 3 ] =H_{proj,k} {^{I_k}_G}R \left[ \begin{array}{ccc} \lfloor ({^G}p_f-{^G}p_{I_k})\times \rfloor {^{I_k}_G}R^{\top}& -I_{3\times3} & 0_{3\times3} & I_{3\times3} \\ \end{array} \right] =Hproj,kGIkR[⌊(GpfGpIk)×GIkRI3×303×3I3×3]
  从时间步长 k − 1 k-1 k1 k k k 的状态转换(或系统雅可比矩阵)作为(有关更多详细信息,请参阅 IMU 传播推导):
Φ ( k , k − 1 ) = [ I k − 1 I k R 0 3 × 3 0 3 × 3 0 3 × 3 − G I k − 1 R ⊤ ⌊ α ( k , k − 1 ) × ⌋ I 3 × 3 ( t k − t k − 1 I 3 × 3 0 3 × 3 ) − G I k − 1 R ⊤ ⌊ β ( k , k − 1 ) × ⌋ 0 3 × 3 I 3 × 3 0 3 × 3 0 3 × 3 0 3 × 3 0 3 × 3 I 3 × 3 ] \Phi_{(k,k-1)}=\left[ \begin{array}{ccc} {^{I_k}_{I_{k-1}}R} & 0_{3 \times 3} & 0_{3 \times 3} & 0_{3 \times 3} \\ -{^{I_{k-1}}_G}R^{\top}\lfloor \alpha(k,k-1)\times \rfloor & I_{3 \times 3} & (t_k-t_{k-1}I_{3 \times 3} & 0_{3 \times 3})\\ -{^{I_{k-1}}_G}R^{\top}\lfloor \beta(k,k-1)\times \rfloor & 0_{3 \times 3} & I_{3 \times 3} & 0_{3\times 3} \\ 0_{3\times 3} & 0_{3\times 3} & 0_{3\times 3} & I_{3\times 3} \\ \end{array} \right] Φ(k,k1)= Ik1IkRGIk1Rα(k,k1)×GIk1Rβ(k,k1)×03×303×3I3×303×303×303×3(tktk1I3×3I3×303×303×303×3)03×3I3×3 α ( k , k − 1 ) = ∫ t k − 1 k ∫ t k − 1 s τ I k − 1 R ( α ( τ ) − b a − w a ) d τ d s \alpha(k,k-1)=\int^k_{t_{k-1}}\int^s_{t_{k-1}} {^{I_{k-1}}_\tau}R(\alpha(\tau)-b_a-w_a)d\tau ds α(k,k1)=tk1ktk1sτIk1R(α(τ)bawa)dτds β ( k , k − 1 ) = ∫ t k − 1 t k τ I k − 1 R ( α ( τ ) − b a − w a ) d τ \beta(k,k-1)=\int^{t_k}_{t_{k-1}}{^{I_{k-1}}_\tau}R(\alpha(\tau)-b_a-w_a)d\tau β(k,k1)=tk1tkτIk1R(α(τ)bawa)dτ

  其中, α ( τ ) \alpha(\tau) α(τ)是时间 τ \tau τ 的真实加速度, I k − 1 I k R {^{I_k}_{I_{k-1}}R} Ik1IkR使用陀螺仪角速度测量计算,并且 G g ^Gg Gg 是全局参考系中的重力。在传播过程中,需要使用解析积分或数值积分来解决这些积分,而我们在这里对状态如何演变感兴趣,以便检查其可观测性。

3.2 线性化系统可观测性
  该线性化系统的可观测性矩阵由下式定义:
O = [ H 0 Φ ( 0 , 0 ) H 1 Φ ( 1 , 0 ) H 2 Φ ( 2 , 0 ) ⋮ H k Φ ( k , 0 ) ] \mathcal{O} = \left[ \begin{array}{ccc} H_0\Phi_{(0,0)} \\ H_1\Phi_{(1,0)} \\ H_2\Phi_{(2,0)}\\ \vdots\\ H_k\Phi_{(k,0)} \\ \end{array} \right] O= H0Φ(0,0)H1Φ(1,0)H2Φ(2,0)HkΦ(k,0)

  其中, H k H_k Hk是时间步长 k k k 处的雅可比测量值, Φ ( k , 0 ) \Phi_{(k,0)} Φ(k,0)是从时间步长 0 0 0 k k k 的复合状态转换(系统雅可比矩阵)。对于此矩阵的给定块行,我们有:
H k Φ ( k , 0 ) = H p r o j , k G I k R [ Γ 1 Γ 2 Γ 3 Γ 4 ] H_k\Phi_{(k,0)} = H_{proj,k} {^{I_k}_G}R \left[ \begin{array}{ccc} \Gamma_1 & \Gamma_2 & \Gamma_3 & \Gamma_4\\ \end{array} \right] HkΦ(k,0)=Hproj,kGIkR[Γ1Γ2Γ3Γ4]
Γ 1 = ⌊ ( G p f − G p I k + G I 0 R ⊤ α ( k , 0 ) ) × ⌋ G I 0 R ⊤ \Gamma_1= \lfloor(^Gp_f-^Gp_{I_k}+^{I_0}_GR^{\top}\alpha(k,0))\times\rfloor^{I_0}_GR^{\top} Γ1=(GpfGpIk+GI0Rα(k,0))×GI0R Γ 2 = − I 3 × 3 \Gamma_2 = -I_{3 \times 3} Γ2=I3×3 Γ 3 = − ( t k − t 0 ) I 3 × 3 \Gamma_3 = -(t_k-t_0)I_{3 \times 3} Γ3=(tkt0)I3×3 Γ 4 = I 3 × 3 \Gamma_4 = I_{3 \times 3} Γ4=I3×3

  我们现在验证以下零空间,它对应于关于重力和全局 IMU 和特征位置的全局偏航:
N = [ G I 0 R G g 0 3 × 3 − ⌊ G p I 0 ⌋ G g I 3 × 3 − ⌊ G v I 0 ⌋ G g 0 3 × 3 − ⌊ G p f ⌋ G g I 3 × 3 ] \mathcal{N} = \left[ \begin{array}{ccc} ^{I_0}_GR{{^G}g} & 0_{3\times 3} \\ -\lfloor^Gp_{I_0}\rfloor ^Gg & I_{3\times 3} \\ -\lfloor^Gv_{I_0}\rfloor ^Gg & 0_{3\times 3} \\ -\lfloor^Gp_{f}\rfloor ^Gg & I_{3\times 3} \\ \end{array} \right] N= GI0RGgGpI0GgGvI0GgGpfGg03×3I3×303×3I3×3

  验证 H k Φ ( k , 0 ) N v i o = 0 H_k\Phi_{(k,0)} \mathcal{N}_{vio}=0 HkΦ(k,0)Nvio=0 这一点并不困难。因此,这是系统的零空间,这清楚地表明视觉惯性系统有四个不可观测的方向(全局偏航和位置)。

3.3 First Estimate Jacobians
  First-Estimate Jacobains(FEJ)方法的主要思想是确保在正确的线性化点评估状态转移和雅可比矩阵,以便上述可观测性分析成立。对于那些对技术细节感兴趣的人,请查看:8 和 13。让我们首先考虑一个关于标准卡尔曼滤波器如何计算其状态转移矩阵的小思想实验。从时间步长 0 0 0 1 1 1,它将使用从状态零向前移动的当前估计值。在它使用来自其他传感器的测量值更新状态后的下一个时间步长,它将使用更新的值计算状态转换,以将状态演变为时间步长 2。这会导致状态转移矩阵的“连续性”不匹配,当按顺序乘法时,应表示从时间 0 0 0 到时间 2 2 2 的演变。
Φ ( k + 1 , k − 1 ) ( x k + 1 ∣ k , x k − 1 ∣ k − 1 ) ≠ Φ ( k + 1 , k ) ( x k + 1 ∣ k , x k ∣ k ) Φ ( k , k − 1 ) ( x k ∣ k − 1 , x k − 1 ∣ k − 1 ) \Phi_{(k+1,k-1)}(x_{k+1|k},x_{k-1|k-1}) \neq \Phi_{(k+1,k)}(x_{k+1|k},x_{k|k}) \Phi_{(k,k-1)}(x_{k|k-1},x_{k-1|k-1}) Φ(k+1,k1)(xk+1∣k,xk1∣k1)=Φ(k+1,k)(xk+1∣k,xkk)Φ(k,k1)(xkk1,xk1∣k1)
  如上所示,我们希望计算从所有 k − 1 k-1 k1 时间处的 k − 1 k-1 k1的测量值 ,到当前传播时间 k + 1 k+1 k+1处的所有 k k k 的测量值的的状态转换矩阵。上述等式的右侧是人们通常在卡尔曼滤波器框架中执行此操作的方式。 Φ ( k , k − 1 ) ( x k ∣ k − 1 , x k − 1 ∣ k − 1 ) \Phi_{(k,k-1)}(x_{k|k-1},x_{k-1|k-1}) Φ(k,k1)(xkk1,xk1∣k1)对应于从 k − 1 k-1 k1 更新时间传播到 k k k 时间。然后,通常会对状态执行第 k k k 次更新,然后从此更新状态传播到最新的时间(即状态转换矩阵)。这显然与计算从时间 k − 1 k-1 k1 k + 1 k+1 k+1 时间的状态转换不同,因为第二个状态转换在不同的线性化点进行评估!为了解决这个问题,我们可以更改我们评估这些的线性化点:
Φ ( k + 1 , k − 1 ) ( x k + 1 ∣ k , x k − 1 ∣ k − 1 ) = Φ ( k + 1 , k ) ( x k + 1 ∣ k , x k ∣ k − 1 ) Φ ( k , k − 1 ) ( x k ∣ k − 1 , x k − 1 ∣ k − 1 ) \Phi_{(k+1,k-1)}(x_{k+1|k},x_{k-1|k-1}) = \Phi_{(k+1,k)}(x_{k+1|k},x_{k|k-1}) \Phi_{(k,k-1)}(x_{k|k-1},x_{k-1|k-1}) Φ(k+1,k1)(xk+1∣k,xk1∣k1)=Φ(k+1,k)(xk+1∣k,xkk1)Φ(k,k1)(xkk1,xk1∣k1)
  我们还需要确保我们的测量雅可比量与状态转移矩阵的线性化点相匹配。因此,它们也需要在 x k ∣ k − 1 x_{k|k-1} xkk1线性化点进行评估,而不是通常使用的 x k ∣ k x_{k|k} xkk线性化点。这种方式名为FEJ,因为我们将在同一线性化点评估雅可比矩阵,以确保零空间保持有效。


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

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

相关文章

《500强高管谈VE价值工程》-对经营变革期下VE的期待

文章出处&#xff1a;日本VE协会杂志 文章翻译&#xff1a;泰泽项目部 关注泰泽&#xff1a;实现高利润企业 《500强高管谈VE价值工程》-对经营变革期下VE的期待 作者: 鹿岛建设常务董事小野馨喜 随着21世纪的到来&#xff0c;社会结构和经济环境正在发生重大转变&…

MobPush 创建推送

功能说明 MobPush提供遵循REST规范的HTTP接口&#xff0c;适用各开发语言环境调用。 IP绑定 工作台可以绑定服务器IP地址&#xff0c;未绑定之前所有IP均可进行REST API的调用&#xff0c;绑定后进仅绑定的IP才有调用权限。 调用地址 POSThttp://api.push.mob.com/v3/push/c…

东南亚开年大促必爆商品;2023Lazada家居家饰需求品类来袭

为持续提升商家体验&#xff0c;保障经营效率&#xff0c;2023年Lazada平台将调整Birthday sale生日大促的活动时间节奏 2023年6个国家站点&#xff08;印尼、马来西亚、菲律宾、新加坡、泰国、越南&#xff09;均会将生日大促提前至2023年3月3日开始。 家居家饰需求清单&…

什么是快速排序?

本文首发自「慕课网」&#xff0c;想了解更多IT干货内容&#xff0c;程序员圈内热闻&#xff0c;欢迎关注&#xff01; 作者| 慕课网精英讲师 JdreamZhang 快速排序&#xff08;Quick Sort&#xff09;&#xff0c;是计算机科学与技术领域中非常经典的一种排序算法&#xff0…

华为云工程师HCIA——桌面云解决方案概述

一、桌面云解决方案概述 瘦终端和胖终端 瘦终端&#xff1a;提供屏幕&#xff0c;和很小的计算能力胖终端&#xff1a;提供主要计算能力 桌面云架构VDI与IDV 华为桌面云解决方案逻辑架构 FusionCompute云平台架构 桌面云的优势 二、桌面云组件介绍 接入和访问控制层 WI&…

图像处理(2)——图像特征提取LBP

图像处理&#xff08;2&#xff09;——图像特征提取LBP 其实现在大家都说图像处理&#xff0c;其实计算机是不认识图片的&#xff0c;之所以可以处理图像&#xff0c;其实图像就是一个个矩阵&#xff0c;其实是数字&#xff0c;转而其实都是在处理数字。深度学习在图像上的建…

数字图像处理实验——数字图像处理初步

一、实验目的与要求 1.熟悉及掌握在MATLAB中能够处理哪些格式的图像&#xff1b; 2.熟练掌握在MATLAB中如何读取图像及图像的属性信息&#xff08;大小、颜色、亮度&#xff08;灰度&#xff09;、宽度、高度等&#xff09;&#xff1b; 3.掌握如何在MATLAB中按照指定要求存储一…

Windows 内核安全编程技术实践

《Windows 内核安全编程技术实践》&#xff0c;这是一本Windows 10内核安全开发系列丛书&#xff0c;探索 AntiRootKit 反内核工具核心原理与技术实现细节&#xff0c;揭开ARK工具的神秘面纱&#xff0c;本书以实战角度出发摒弃了大量无用的专业术语&#xff0c;欢迎阅读并提出…

在Qt中设置窗体背景颜色及透明度的方法介绍

本文主要介绍在 Qt 中设置窗体背景颜色及透明度的方法。 说明&#xff1a; 本文中的应用程序是面向 Windows 操作系统的&#xff1b;本文中使用的 Qt Creator 版本号为&#xff1a;7.0.0&#xff1b;本文中使用的 Qt 版本号为&#xff1a;5.14.2。 1 利用样式表&#xff08;S…

Github每日精选(第82期):还在用logging试试loguru

Loguru 如果你还在使用logging&#xff0c;不妨花点时间来看看Loguru&#xff0c;Loguru是一个Python日志记录的库。 您是否曾懒于配置记录器而使用print&#xff08;&#xff09;&#xff1f;。。。 我确实这样做了&#xff0c;但日志记录对于每个应用程序来说都是基本的&a…

Redis集群系列十二 —— 故障转移二

场景 模拟集群中有一个 master 宕机场景。 故障转移自动故障转移和手动故障转移。 自动故障转移 打开日志监控 为了更好折查看效果&#xff0c;通过 watch 命令实时查看集群的动态日志变化&#xff0c;如图&#xff1a; watch redis-cli -p 30001 cluster nodes 注意&#…

用SQL语句进行数据库查询(复杂查询)

前言 &#x1f388;个人主页:&#x1f388; :✨✨✨初阶牛✨✨✨ &#x1f43b;推荐专栏: &#x1f354;&#x1f35f;&#x1f32f; c语言初阶 &#x1f511;个人信条: &#x1f335;知行合一 &#x1f349;本篇简介:>:上一篇学习了如何使用SQL语句进行简单的数据查询,本篇…

C++ 简单工厂模式 与 工厂模式

简单工厂模式&#xff1a; 一个工厂&#xff0c;多个产品。产品需要有一个虚基类。通过传入参数&#xff0c;生成具体产品对象&#xff0c;并利用基类指针指向此对象。通过工厂获取此虚基类指针&#xff0c;通过运行时多态&#xff0c;调用子类实现。 注意&#xff1a;简单工厂…

S32K144—autoMBD是什么?

基于模型的设计&#xff08;Model-Based Design&#xff0c;MBD&#xff09;是一项非常具有发展潜力的技术&#xff0c;autoMBD 致力于分享和传播 MBD 相关技术&#xff0c;让更多人可以快速、高效地在项目开发中使用 MBD。 MBD能做什么&#xff1f; 从大的范围来说&#xff…

14 Python 办公自动化

目录 1、普通文件自动化管理 1.1 文件的复制 1.2 文件内容的复制 1.3 文件的裁剪 1.4 文件的删除 1.5 文件的压缩与解压缩 1.6 文件的查找 1.7 查找含有指定内容的文件 1.8 清理重复的文件 1.9 批量修改目录中的文件名称 2、文件夹的自动化管理 2.1 文件夹的复制 …

机器学习中的数学原理——线性可分问题

这个专栏主要是用来分享一下我在机器学习中的学习笔记及一些感悟&#xff0c;也希望对你的学习有帮助哦&#xff01;感兴趣的小伙伴欢迎私信或者评论区留言&#xff01;这一篇就更新一下《白话机器学习中的数学——线性可分问题》&#xff01; 一、什么是线性可分问题 线性可分…

kibana和elasticsearch-head安装手册

kibana和elasticsearch-head安装手册 0 安装包下载 组件安装包下载地址kibanakibana-8.5.2-linux-x86_64.tar.gzelastic官网&#xff1a;https://www.elastic.co/cn/downloads/past-releases#kibana elastic中文社区&#xff1a;https://elasticsearch.cn/download/nodenode-…

关键字:static

文章目录一、static关键字的使用static修饰属性实例变量静态变量&#xff08;类变量&#xff09;内存解析static修饰方法static注意点如何确定什么时候使用static&#xff1f;方法属性单例设计模式饿汉式懒汉式区分饿汉式和懒汉式一、static关键字的使用 1、可以用来修饰&…

回首满是自豪

写在前面hi朋友&#xff0c;我是几何心凉&#xff0c;感谢你能够点开这篇文章&#xff0c;看到这里我觉得我们是有缘分的&#xff0c;因着这份缘分&#xff0c;我希望你能够看完我的分享&#xff0c;因为下面的分享就是要汇报给你听的&#xff0c;这篇文章是在 2022 年 12 月 3…

【柔性数组与局部性原理】

柔性数组概念 柔性数组特点 局部性原理 柔性数组概念 对于柔性数组&#xff0c;也许你之前从未听说过&#xff0c;柔性数组&#xff0c;顾名思义&#xff0c;就是数组&#xff0c;它的柔性柔在元素个数可以动态变化&#xff0c; 即柔性数组是未知大小的&#xff0c;数组大小…