当前位置: 首页 > news >正文

视觉SLAM十四讲|【四】误差Jacobian推导

视觉SLAM十四讲|【四】误差Jacobian推导

预积分误差递推公式

ω = 1 2 ( ( ω b k + n k g − b k g ) + ( w b k + 1 + n k + 1 g − b k + 1 g ) ) \omega = \frac{1}{2}((\omega_b^k+n_k^g-b_k^g)+(w_b^{k+1}+n_{k+1}^g-b_{k+1}^g)) ω=21((ωbk+nkgbkg)+(wbk+1+nk+1gbk+1g))
其中, w b k w_b^k wbk k k k时刻下body坐标系的角速度, n k g n_k^g nkg k k k时刻下陀螺仪白噪声, b k g b_k^g bkg k k k时刻下陀螺仪偏置量。 n k a n_k^a nka k k k时刻下加速度白噪声, b k a b_k^a bka k k k时刻下加速度偏置量。 k + 1 k+1 k+1时刻下记号同理。
q b i b k + 1 = q b i b k ⊗ [ 1 , 1 2 ω δ t ] T q_{b_i b_{k+1}} = q_{b_i b_k} \otimes [1, \frac{1}{2} \omega \delta t]^T qbibk+1=qbibk[1,21ωδt]T
a = 1 2 ( q b i b k ( a b k + n b k − b k a ) + q b i b k + 1 ( a b k + 1 + n b k + 1 − b k + 1 a ) ) a = \frac{1}{2}(q_{b_i b_{k}} (a_b^k + n_b^k -b_k^a) + q_{b_i b_{k+1}} (a_b^{k+1} + n_b^{k+1} - b_{k+1}^a)) a=21(qbibk(abk+nbkbka)+qbibk+1(abk+1+nbk+1bk+1a))
α b i b k + 1 = α b i b k + β b i b k δ t + 1 2 a δ t 2 \alpha_{b_i b_{k+1}} = \alpha_{b_i b_{k}} + \beta_{b_i b_k} \delta t + \frac{1}{2}a \delta t^2 αbibk+1=αbibk+βbibkδt+21aδt2
β b i b k + 1 = β b i b k + a δ t \beta_{b_i b_{k+1}} = \beta_{b_i b_{k}} + a\delta t βbibk+1=βbibk+aδt
b k + 1 a = b k a + n b k a δ t b_{k+1}^a = b_k^a + n_{b_k^a}\delta t bk+1a=bka+nbkaδt
b k + 1 g = b k g + n b k g δ t b_{k+1}^g = b_k^g + n_{b_k^g}\delta t bk+1g=bkg+nbkgδt

示例1

f 15 = δ α b i b k + 1 δ b k g f_{15} = \frac{\delta \alpha_{b_i b_{k+1}}}{\delta b_k^g} f15=δbkgδαbibk+1
由上面的递推公式可知
α b i b k + 1 = α b i b k + β b i b k δ t + 1 2 a δ t 2 \alpha_{b_i b_{k+1}} = \alpha_{b_i b_{k}} + \beta_{b_i b_k} \delta t + \frac{1}{2}a \delta t^2 αbibk+1=αbibk+βbibkδt+21aδt2
其中, α b i b k \alpha_{b_i b_{k}} αbibk β b i b k δ t \beta_{b_i b_k}\delta t βbibkδt都与 b k g b_k^g bkg无关,可以省略,而很容易看出 a a a中含有 q b i b k + 1 q_{b_i b_{k+1}} qbibk+1项,其中进一步含有对 b k g b_k^g bkg相关的元素,必须保留。因此进一步推得
f 15 = δ 1 2 a δ t 2 δ b k g f_{15} = \frac{\delta \frac{1}{2} a \delta t^2}{\delta b_k^g} f15=δbkgδ21aδt2
其中,
a = 1 2 ( q b i b k ( a b k + n b k − b k a ) + q b i b k + 1 ( a b k + 1 + n b k + 1 − b k + 1 a ) ) a = \frac{1}{2}(q_{b_i b_{k}} (a_b^k + n_b^k -b_k^a) + q_{b_i b_{k+1}} (a_b^{k+1} + n_b^{k+1} - b_{k+1}^a)) a=21(qbibk(abk+nbkbka)+qbibk+1(abk+1+nbk+1bk+1a))
q b i b k ( a b k + n b k − b k a ) q_{b_i b_{k}} (a_b^k + n_b^k -b_k^a) qbibk(abk+nbkbka)依然与 b k g b_k^g bkg无关,可以省略。
f 15 = δ 1 4 q b i b k + 1 ( a b k + 1 + n b k + 1 − b k + 1 a ) δ t 2 δ b k g f_{15}=\frac{\delta \frac{1}{4} q_{b_i b_{k+1}} (a_b^{k+1} + n_b^{k+1} - b_{k+1}^a) \delta t^2}{\delta b_k^g} f15=δbkgδ41qbibk+1(abk+1+nbk+1bk+1a)δt2
白噪声项不可知,拿掉
f 15 = δ 1 4 q b i b k + 1 ( a b k + 1 − b k + 1 a ) δ t 2 δ b k g f_{15}=\frac{\delta \frac{1}{4} q_{b_i b_{k+1}} (a_b^{k+1} - b_{k+1}^a) \delta t^2}{\delta b_k^g} f15=δbkgδ41qbibk+1(abk+1bk+1a)δt2
f 15 = δ 1 4 q b i b k + 1 ( a b k + 1 − b k + 1 a ) δ t 2 δ b k g f_{15}=\frac{\delta \frac{1}{4} q_{b_i b_{k+1}} (a_b^{k+1} - b_{k+1}^a) \delta t^2}{\delta b_k^g} f15=δbkgδ41qbibk+1(abk+1bk+1a)δt2
q b i b k + 1 = q b i b k ⊗ [ 1 , 1 2 ω δ t ] T q_{b_i b_{k+1}} = q_{b_i b_k} \otimes [1, \frac{1}{2} \omega \delta t]^T qbibk+1=qbibk[1,21ωδt]T
f 15 = δ 1 4 q b i b k ⊗ [ 1 , 1 2 ω δ t ] T ( a b k + 1 − b k + 1 a ) δ t 2 δ b k g f_{15}=\frac{\delta \frac{1}{4} q_{b_i b_k} \otimes [1, \frac{1}{2} \omega \delta t]^T (a_b^{k+1} - b_{k+1}^a) \delta t^2}{\delta b_k^g} f15=δbkgδ41qbibk[1,21ωδt]T(abk+1bk+1a)δt2
其中
ω = 1 2 ( ( ω b k + n k g − b k g ) + ( w b k + 1 + n k + 1 g − b k + 1 g ) ) \omega = \frac{1}{2}((\omega_b^k+n_k^g-b_k^g)+(w_b^{k+1}+n_{k+1}^g-b_{k+1}^g)) ω=21((ωbk+nkgbkg)+(wbk+1+nk+1gbk+1g))
去除不可知的白噪声项
ω = 1 2 ( ( ω b k − b k g ) + ( w b k + 1 − b k + 1 g ) ) \omega = \frac{1}{2}((\omega_b^k-b_k^g)+(w_b^{k+1}-b_{k+1}^g)) ω=21((ωbkbkg)+(wbk+1bk+1g))
由于 k + 1 k+1 k+1时刻的信息并不知道,在此处如果不使用中值积分,直接使用初始值,有
ω = ω b k − b k g \omega =\omega_b^k-b_k^g ω=ωbkbkg
f 15 = δ 1 4 q b i b k ⊗ [ 1 , 1 2 ( ω b k − b k g ) δ t ] T ( a b k + 1 − b k + 1 a ) δ t 2 δ b k g f_{15}=\frac{\delta \frac{1}{4} q_{b_i b_k} \otimes [1, \frac{1}{2} (\omega_b^k-b_k^g) \delta t]^T (a_b^{k+1} - b_{k+1}^a) \delta t^2}{\delta b_k^g} f15=δbkgδ41qbibk[1,21(ωbkbkg)δt]T(abk+1bk+1a)δt2
此时,为了便于计算,我们需要把四元数表示旋转转换为用旋转矩阵表示矩阵的旋转,得到
f 15 = 1 4 δ R b i b k exp ⁡ ( ( ( w b k − b k g ) δ t ) ∧ ) ( a b k + 1 − b k + 1 a ) δ t 2 δ b k g f_{15}=\frac{1}{4} \frac{\delta R_{b_i b_k} \exp(((w_b^k-b_k^g)\delta t)^{\wedge})(a_b^{k+1} - b_{k+1}^a)\delta t^2}{\delta b_k^g} f15=41δbkgδRbibkexp(((wbkbkg)δt))(abk+1bk+1a)δt2
观察式子,我们要想办法把 b k g b_k^g bkg拆出来。回顾上一章,李代数旋转有性质
l n ( R e x p ( ϕ ∧ ) ) ∨ = l n ( R ) ∨ + J r − 1 ϕ ln(Rexp(\phi^{\land}))^{\vee}=ln(R)^{\vee}+J_r^{-1}\phi ln(Rexp(ϕ))=ln(R)+Jr1ϕ
类似的,对于非对数情况,有
exp ⁡ ( ( ϕ + δ ϕ ) ∧ ) = exp ⁡ ( ϕ ∧ ) exp ⁡ ( ( J r ( ϕ ) δ ϕ ) ∧ ) \exp( (\phi + \delta\phi)^{\wedge} )= \exp(\phi^{\wedge})\exp((J_r(\phi)\delta\phi)^{\wedge}) exp((ϕ+δϕ))=exp(ϕ)exp((Jr(ϕ)δϕ))
lim ⁡ ϕ → 0 J r ( ϕ ) = I \lim_{\phi \rightarrow 0} J_r(\phi)=I ϕ0limJr(ϕ)=I
exp ⁡ ( ( ( w b k − b k g ) δ t ) ∧ = exp ⁡ ( ( w b k δ t ) ∧ ) exp ⁡ ( ( J r ( w b k δ t ) ( − b k g δ t ) ) ∧ ) \exp(((w_b^k-b_k^g)\delta t)^{\wedge}=\exp((w_b^k\delta t)^{\wedge})\exp((J_r(w_b^k\delta t)(-b_k^g \delta t))^{\wedge}) exp(((wbkbkg)δt)=exp((wbkδt))exp((Jr(wbkδt)(bkgδt)))
f 15 = 1 4 δ R b i b k exp ⁡ ( ( ( w b k − b k g ) δ t ) ∧ ) ( a b k + 1 − b k + 1 a ) δ t 2 δ b k g f_{15}=\frac{1}{4} \frac{\delta R_{b_i b_k} \exp(((w_b^k-b_k^g)\delta t)^{\wedge})(a_b^{k+1} - b_{k+1}^a)\delta t^2}{\delta b_k^g} f15=41δbkgδRbibkexp(((wbkbkg)δt))(abk+1bk+1a)δt2
f 15 = 1 4 δ R b i b k exp ⁡ ( ( w b k δ t ) ∧ ) exp ⁡ ( ( J r ( w b k δ t ) ( − b k g δ t ) ) ∧ ) ( a b k + 1 − b k + 1 a ) δ t 2 δ b k g f_{15}=\frac{1}{4} \frac{\delta R_{b_i b_k} \exp((w_b^k\delta t)^{\wedge})\exp((J_r(w_b^k\delta t)(-b_k^g \delta t))^{\wedge})(a_b^{k+1} - b_{k+1}^a)\delta t^2}{\delta b_k^g} f15=41δbkgδRbibkexp((wbkδt))exp((Jr(wbkδt)(bkgδt)))(abk+1bk+1a)δt2
w b k δ t → 0 w_b^k\delta t \rightarrow0 wbkδt0
f 15 = 1 4 δ R b i b k exp ⁡ ( ( J r ( w b k δ t ) ( − b k g δ t ) ) ∧ ) ( a b k + 1 − b k + 1 a ) δ t 2 δ b k g f_{15}=\frac{1}{4} \frac{\delta R_{b_i b_k} \exp((J_r(w_b^k\delta t)(-b_k^g \delta t))^{\wedge})(a_b^{k+1} - b_{k+1}^a)\delta t^2}{\delta b_k^g} f15=41δbkgδRbibkexp((Jr(wbkδt)(bkgδt)))(abk+1bk+1a)δt2
f 15 = 1 4 δ R b i b k exp ⁡ ( ( − b k g δ t ) ) ∧ ) ( a b k + 1 − b k + 1 a ) δ t 2 δ b k g f_{15}=\frac{1}{4} \frac{\delta R_{b_i b_k} \exp((-b_k^g \delta t))^{\wedge})(a_b^{k+1} - b_{k+1}^a)\delta t^2}{\delta b_k^g} f15=41δbkgδRbibkexp((bkgδt)))(abk+1bk+1a)δt2
f 15 = 1 4 δ R b i b k ( I + ( − b k g δ t ) ) ∧ ) ( a b k + 1 − b k + 1 a ) δ t 2 δ b k g f_{15}=\frac{1}{4} \frac{\delta R_{b_i b_k} (I+(-b_k^g \delta t))^{\wedge})(a_b^{k+1} - b_{k+1}^a)\delta t^2}{\delta b_k^g} f15=41δbkgδRbibk(I+(bkgδt)))(abk+1bk+1a)δt2
f 15 = 1 4 δ R b i b k ( − b k g δ t ) ∧ ( a b k + 1 − b k + 1 a ) δ t 2 δ b k g f_{15}=\frac{1}{4} \frac{\delta R_{b_i b_k} (-b_k^g \delta t)^{\wedge}(a_b^{k+1} - b_{k+1}^a)\delta t^2}{\delta b_k^g} f15=41δbkgδRbibk(bkgδt)(abk+1bk+1a)δt2
使用伴随性质,有
f 15 = 1 4 δ R b i b k ( a b k + 1 − b k + 1 a ) ∧ ( b k g δ t ) δ t 2 δ b k g f_{15}=\frac{1}{4} \frac{\delta R_{b_i b_k} (a_b^{k+1} - b_{k+1}^a)^{\wedge}(b_k^g \delta t)\delta t^2}{\delta b_k^g} f15=41δbkgδRbibk(abk+1bk+1a)(bkgδt)δt2
f 15 = 1 4 R b i b k ( a b k + 1 − b k + 1 a ) ∧ δ t 2 δ t f_{15}=\frac{1}{4} R_{b_i b_k} (a_b^{k+1} - b_{k+1}^a)^{\wedge} \delta t^2 \delta t f15=41Rbibk(abk+1bk+1a)δt2δt

示例2

g 12 = δ α b i b k + 1 δ n k g g_{12}=\frac{\delta \alpha_{b_i b_{k+1}}}{\delta n_k^g} g12=δnkgδαbibk+1
一看 n k g n_k^g nkg就知道又要找和旋转有关的量了。回顾递推公式,有
ω = 1 2 ( ( ω b k + n k g − b k g ) + ( w b k + 1 + n k + 1 g − b k + 1 g ) ) \omega = \frac{1}{2}((\omega_b^k+n_k^g-b_k^g)+(w_b^{k+1}+n_{k+1}^g-b_{k+1}^g)) ω=21((ωbk+nkgbkg)+(wbk+1+nk+1gbk+1g))
q b i b k + 1 = q b i b k ⊗ [ 1 , 1 2 ω δ t ] T q_{b_i b_{k+1}} = q_{b_i b_k} \otimes [1, \frac{1}{2} \omega \delta t]^T qbibk+1=qbibk[1,21ωδt]T
a = 1 2 ( q b i b k ( a b k + n b k − b k a ) + q b i b k + 1 ( a b k + 1 + n b k + 1 − b k + 1 a ) ) a = \frac{1}{2}(q_{b_i b_{k}} (a_b^k + n_b^k -b_k^a) + q_{b_i b_{k+1}} (a_b^{k+1} + n_b^{k+1} - b_{k+1}^a)) a=21(qbibk(abk+nbkbka)+qbibk+1(abk+1+nbk+1bk+1a))
α b i b k + 1 = α b i b k + β b i b k δ t + 1 2 a δ t 2 \alpha_{b_i b_{k+1}} = \alpha_{b_i b_{k}} + \beta_{b_i b_k} \delta t + \frac{1}{2}a \delta t^2 αbibk+1=αbibk+βbibkδt+21aδt2

g 12 = δ α b i b k + 1 δ n k g g_{12}=\frac{\delta \alpha_{b_i b_{k+1}}}{\delta n_k^g} g12=δnkgδαbibk+1
g 12 = δ 1 2 a δ t 2 δ n k g g_{12}=\frac{\delta \frac{1}{2}a \delta t^2}{\delta n_k^g} g12=δnkgδ21aδt2
a = 1 2 ( q b i b k ( a b k + n b k − b k a ) + q b i b k + 1 ( a b k + 1 + n b k + 1 − b k + 1 a ) ) a = \frac{1}{2}(q_{b_i b_{k}} (a_b^k + n_b^k -b_k^a) + q_{b_i b_{k+1}} (a_b^{k+1} + n_b^{k+1} - b_{k+1}^a)) a=21(qbibk(abk+nbkbka)+qbibk+1(abk+1+nbk+1bk+1a))
g 12 = δ 1 4 q b i b k + 1 ( a b k + 1 − b k + 1 a ) δ t 2 δ n k g g_{12}=\frac{\delta \frac{1}{4}q_{b_i b_{k+1}} (a_b^{k+1} - b_{k+1}^a) \delta t^2}{\delta n_k^g} g12=δnkgδ41qbibk+1(abk+1bk+1a)δt2
又因为
q b i b k + 1 = q b i b k ⊗ [ 1 , 1 2 ω δ t ] T q_{b_i b_{k+1}} = q_{b_i b_k} \otimes [1, \frac{1}{2} \omega \delta t]^T qbibk+1=qbibk[1,21ωδt]T
所以有
g 12 = δ 1 4 q b i b k ⊗ [ 1 , 1 2 ω δ t ] T ( a b k + 1 − b k + 1 a ) δ t 2 δ n k g g_{12}=\frac{\delta \frac{1}{4}q_{b_i b_k} \otimes [1, \frac{1}{2} \omega \delta t]^T (a_b^{k+1} - b_{k+1}^a) \delta t^2}{\delta n_k^g} g12=δnkgδ41qbibk[1,21ωδt]T(abk+1bk+1a)δt2
ω = 1 2 ( ( ω b k + n k g − b k g ) + ( w b k + 1 + n k + 1 g − b k + 1 g ) ) \omega = \frac{1}{2}((\omega_b^k+n_k^g-b_k^g)+(w_b^{k+1}+n_{k+1}^g-b_{k+1}^g)) ω=21((ωbk+nkgbkg)+(wbk+1+nk+1gbk+1g))
g 12 = δ 1 4 q b i b k ⊗ [ 1 , 1 2 ( ω b k + 1 2 n k g ) δ t ] T ( a b k + 1 − b k + 1 a ) δ t 2 δ n k g g_{12}=\frac{\delta \frac{1}{4}q_{b_i b_k} \otimes [1, \frac{1}{2} (\omega_b^k+\frac{1}{2}n_k^g)\delta t]^T (a_b^{k+1} - b_{k+1}^a) \delta t^2}{\delta n_k^g} g12=δnkgδ41qbibk[1,21(ωbk+21nkg)δt]T(abk+1bk+1a)δt2
g 12 = 1 4 δ R b i b k exp ⁡ ( ( ( ω b k + 1 2 n k g ) δ t ) ∧ ) ( a b k + 1 − b k + 1 a ) δ t 2 δ n k g g_{12}=\frac{1}{4} \frac{\delta R_{b_i b_k} \exp(((\omega_b^k+\frac{1}{2}n_k^g)\delta t)^{\wedge})(a_b^{k+1} - b_{k+1}^a) \delta t^2}{\delta n_k^g} g12=41δnkgδRbibkexp(((ωbk+21nkg)δt))(abk+1bk+1a)δt2
g 12 = 1 4 δ R b i b k ( exp ⁡ ( ( ω b k δ t ) ∧ ) ) ( exp ⁡ ( ( J r ( ω b k δ t ) 1 2 n k g δ t ) ∧ ) ) ( a b k + 1 − b k + 1 a ) δ t 2 δ n k g g_{12}=\frac{1}{4} \frac{\delta R_{b_i b_k} (\exp((\omega_b^k\delta t)^{\wedge}))(\exp((J_r(\omega_b^k\delta t)\frac{1}{2}n_k^g \delta t)^{\wedge}))(a_b^{k+1} - b_{k+1}^a) \delta t^2}{\delta n_k^g} g12=41δnkgδRbibk(exp((ωbkδt)))(exp((Jr(ωbkδt)21nkgδt)))(abk+1bk+1a)δt2
g 12 = 1 4 δ R b i b k ( exp ⁡ ( ( J r ( ω b k δ t ) 1 2 n k g δ t ) ∧ ) ) ( a b k + 1 − b k + 1 a ) δ t 2 δ n k g g_{12}=\frac{1}{4} \frac{\delta R_{b_i b_k}(\exp((J_r(\omega_b^k\delta t)\frac{1}{2}n_k^g \delta t)^{\wedge}))(a_b^{k+1} - b_{k+1}^a) \delta t^2}{\delta n_k^g} g12=41δnkgδRbibk(exp((Jr(ωbkδt)21nkgδt)))(abk+1bk+1a)δt2
g 12 = 1 4 δ R b i b k ( exp ⁡ ( ( 1 2 n k g δ t ) ∧ ) ) ( a b k + 1 − b k + 1 a ) δ t 2 δ n k g g_{12}=\frac{1}{4} \frac{\delta R_{b_i b_k}(\exp((\frac{1}{2}n_k^g \delta t)^{\wedge}))(a_b^{k+1} - b_{k+1}^a) \delta t^2}{\delta n_k^g} g12=41δnkgδRbibk(exp((21nkgδt)))(abk+1bk+1a)δt2
g 12 = 1 4 δ R b i b k ( ( 1 2 n k g δ t ) ∧ ) ( a b k + 1 − b k + 1 a ) δ t 2 δ n k g g_{12}=\frac{1}{4} \frac{\delta R_{b_i b_k}((\frac{1}{2}n_k^g \delta t)^{\wedge})(a_b^{k+1} - b_{k+1}^a) \delta t^2}{\delta n_k^g} g12=41δnkgδRbibk((21nkgδt))(abk+1bk+1a)δt2
g 12 = − 1 4 δ R b i b k ( a b k + 1 − b k + 1 a ) ∧ ( 1 2 n k g δ t ) δ t 2 δ n k g g_{12}=-\frac{1}{4} \frac{\delta R_{b_i b_k}(a_b^{k+1} - b_{k+1}^a)^{\wedge} (\frac{1}{2}n_k^g \delta t)\delta t^2}{\delta n_k^g} g12=41δnkgδRbibk(abk+1bk+1a)(21nkgδt)δt2
g 12 = − 1 4 R b i b k ( a b k + 1 − b k + 1 a ) ∧ ( 1 2 δ t ) δ t 2 g_{12}=-\frac{1}{4} R_{b_i b_k}(a_b^{k+1} - b_{k+1}^a)^{\wedge} (\frac{1}{2} \delta t)\delta t^2 g12=41Rbibk(abk+1bk+1a)(21δt)δt2
g 12 = − 1 8 R b i b k ( a b k + 1 − b k + 1 a ) ∧ ( δ t ) δ t 2 g_{12}=-\frac{1}{8} R_{b_i b_k}(a_b^{k+1} - b_{k+1}^a)^{\wedge} (\delta t)\delta t^2 g12=81Rbibk(abk+1bk+1a)(δt)δt2

Levenberg-Marquardt方法证明

Levenberg (1944) 和 Marquardt (1963) 先后对高斯牛顿法进行了改进,求解过程中引入了阻尼因子
( J T J + μ I ) Δ x l m = − J T f , μ > 0 (J^TJ+\mu I) \Delta x_{lm} = -J^Tf,\mu >0 (JTJ+μI)Δxlm=JTf,μ>0
J = δ F δ x J = \frac{\delta F}{\delta x} J=δxδF

相关文章:

视觉SLAM十四讲|【四】误差Jacobian推导

视觉SLAM十四讲|【四】误差Jacobian推导 预积分误差递推公式 ω 1 2 ( ( ω b k n k g − b k g ) ( w b k 1 n k 1 g − b k 1 g ) ) \omega \frac{1}{2}((\omega_b^kn_k^g-b_k^g)(w_b^{k1}n_{k1}^g-b_{k1}^g)) ω21​((ωbk​nkg​−bkg​)(wbk1​nk1g​−bk1g​)) …...

「实战应用」如何用DHTMLX Gantt构建类似JIRA式的项目路线图(一)

DHTMLX Gantt是用于跨浏览器和跨平台应用程序的功能齐全的Gantt图表。可满足项目管理应用程序的所有需求,是最完善的甘特图图表库。 在web项目中使用DHTMLX Gantt时,开发人员经常需要满足与UI外观相关的各种需求。因此他们必须确定JavaScript甘特图库的…...

【习题】应用程序框架

判断题 1. 一个应用只能有一个UIAbility。错误(False) 正确(True)错误(False) 2. 创建的Empty Ability模板工程,初始会生成一个UIAbility文件。正确(True) 正确(True)错误(False) 3. 每调用一次router.pushUrl()方法,页面路由栈数量均会加1。错误(Fal…...

java基于ssm的线上选课系统的设计与实现论文

摘 要 在如今社会上,关于信息上面的处理,没有任何一个企业或者个人会忽视,如何让信息急速传递,并且归档储存查询,采用之前的纸张记录模式已经不符合当前使用要求了。所以,对学生选课信息管理的提升&#x…...

汽车雷达:实时SAR成像的实现

摘要: 众所周知,点云成像是目前实现汽车雷达感知最流行的方案,尤其是采用多级联实现的4D点云成像雷达,这是目前最有希望实现产品落地的技术方案之一。 今天重点分享关于汽车雷达SAR成像相关技术内容,这也证实了4D点云成像雷达并不一定就是汽车雷达成像唯一的方案,在业内…...

《C++语言程序设计(第5版)》(清华大学出版社,郑莉 董渊编著)习题——第2章 C++语言简单程序设计

2-15 编写一个程序&#xff0c;运行时提示输入一个数字&#xff0c;再把这个数字显示出来。 #include <iostream>using namespace std;int main() {// 提示用户输入数字cout << "请输入一个数字: ";// 用于存储用户输入的数字的变量double number;// 从…...

2023年生成式AI全球使用报告

生成式人工智能工具正在迅速改变多个领域&#xff0c;从营销和新闻到教育和艺术。 这些工具使用算法从大量培训材料中获取新的文本、音频或图像。虽然 ChatGPT 和 Midjourney 之类的工具可以用来实现超出人类能力或想象力的艺术效果&#xff0c;但目前它们最常用于比人类更轻松…...

安全防御之漏洞扫描技术

每年都有数以千计的网络安全漏洞被发现和公布&#xff0c;加上攻击者手段的不断变化&#xff0c;网络安全状况也在随着安全漏洞的增加变得日益严峻。寻根溯源&#xff0c;绝大多数用户缺乏一套完整、有效的漏洞管理工作流程&#xff0c;未能落实定期评估与漏洞修补工作。只有比…...

SPON世邦 IP网络对讲广播系统 多处文件上传漏洞复现

0x01 产品简介 SPON世邦IP网络对讲广播系统是一种先进的通信解决方案,旨在提供高效的网络对讲和广播功能。 0x02 漏洞概述 SPON世邦IP网络对讲广播系统 addscenedata.php、uploadjson.php、my_parser.php等接口处存在任意文件上传漏洞,未经身份验证的攻击者可利用此漏洞上…...

Python综合数据分析_RFM用户分层模型

文章目录 1.数据加载2.查看数据情况3.数据合并及填充4.查看特征字段之间相关性5.聚合操作6.时间维度上看销售额7.计算用户RFM8.数据保存存储(1).to_csv(1).to_pickle 1.数据加载 import pandas as pd dataset pd.read_csv(SupplyChain.csv, encodingunicode_escape) dataset2…...

【C++进阶04】STL中map、set、multimap、multiset的介绍及使用

一、关联式容器 vector/list/deque… 这些容器统称为序列式容器 因为其底层为线性序列的数据结构 里面存储的是元素本身 map/set… 这些容器统称为关联式容器 关联式容器也是用来存储数据的 与序列式容器不同的是 其里面存储的是<key, value>结构的键值对 在数据检索时…...

在 Linux 中开启 Flask 项目持续运行

在 Linux 中开启 Flask 项目持续运行 在部署 Flask 项目时&#xff0c;情况往往并不是那么理想。默认情况下&#xff0c;关闭 SSH 终端后&#xff0c;Flask 服务就停止了。这时&#xff0c;您需要找到一种方法在 Linux 服务器上实现持续运行 Flask 项目&#xff0c;并在服务器…...

考研个人经验总结【心理向】

客官你好 首先&#xff0c;不管你是以何种原因来到这篇博客&#xff0c;以下内容或多或少可能带给你一些启发。如果你还是大二or大三学生&#xff0c;有考研的打算&#xff0c;不妨提前了解一些考研必备的心理战术&#xff0c;有时候并不是你知识学得不好&#xff0c;而是思维…...

如何在CentOS安装SQL Server数据库并通过内网穿透工具实现公网访问

文章目录 前言1. 安装sql server2. 局域网测试连接3. 安装cpolar内网穿透4. 将sqlserver映射到公网5. 公网远程连接6.固定连接公网地址7.使用固定公网地址连接 前言 简单几步实现在Linux centos环境下安装部署sql server数据库&#xff0c;并结合cpolar内网穿透工具&#xff0…...

jupyter内核错误

1、在dos窗口输入以下命令激活环境&#xff1a;anaconda activate 【py环境名&#xff0c;比如py37】&#xff08;目的是新家你一个虚拟环境&#xff09; 2、在虚拟环境py37下安装jupyter notebook&#xff0c;命令&#xff1a;pip install jupyter notebook 3、安装ipykerne…...

设计模式的艺术P1基础—2.3 类之间的关系

设计模式的艺术P1基础—2.3 类之间的关系 在软件系统中&#xff0c;类并不是孤立存在的&#xff0c;类与类之间存在各种关系。对于不同类型的关系&#xff0c;UML提供了不同的表示方式 1&#xff0e;关联关系 关联&#xff08;Association&#xff09;关系是类与类之间最常用…...

工业无人机行业研究:预计2025年将达到108.2亿美元

近年来&#xff0c;在技术进步和各行各业对无人驾驶飞行器 (UAV) 不断增长的需求的推动下&#xff0c;工业无人机市场一直在快速增长。该市场有望在未来几年继续其增长轨迹&#xff0c;许多关键趋势和因素推动其发展。 在全球范围内&#xff0c;工业无人机市场预计到 2025 年将…...

PCA主成分分析算法

在数据分析中&#xff0c;如果特征太多&#xff0c;或者特征之间的相关性太高&#xff0c;通常可以用PCA来进行降维。比如通过对原有10个特征的线性组合, 我们找出3个主成分&#xff0c;就足以解释绝大多数的方差&#xff0c;该算法在高维数据集中被广泛应用。 算法&#xff08…...

Hyperledger Fabric 权限策略和访问控制

访问控制是区块链网络十分重要的功能&#xff0c;负责控制某个身份在某个场景下是否允许采取某个操作&#xff08;如读写某个资源&#xff09;。 常见的访问控制模型包括强制访问控制&#xff08;Mandatory Access Control&#xff09;、自主访问控制&#xff08;Discretionar…...

Day28 回溯算法part04 93. 复原IP地址 78. 子集 90. 子集 II

回溯算法part04 93. 复原IP地址 78. 子集 90. 子集 II 93. 复原 IP 地址 class Solution { private:vector<string> result;bool isValid(string& s,int start,int end){if (start > end) return false;if (s[start] 0 && start ! end) { // 0开头的数…...

Linux系统常用的安全优化

环境&#xff1a;CentOS7.9 1、禁用SELinux SELinux是美国国家安全局对于强制访问控制的实现 1)永久禁用SELinux vim /etc/selinux/config SELINUXdisabled #必须重启系统才能生效2&#xff09;临时禁用SELInux getenforce #查看SELInux当前状态 setenforce 0 #数字…...

Vue-4、单向数据绑定与双向数据绑定

1、单向数据绑定 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>数据绑定</title><!--引入vue--><script type"text/javascript" src"https://cdn.jsdelivr.net/npm/…...

【Flutter 开发实战】Dart 基础篇:常用运算符

在Dart中&#xff0c;运算符是编写任何程序的基本构建块之一。本文将详细介绍Dart中常用的运算符&#xff0c;以帮助初学者更好地理解和运用这些概念。 1. 算术运算符 算术运算符用于执行基本的数学运算。Dart支持常见的加、减、乘、除、整除以及取余运算。常见的算数运算符如…...

C++:ifstream通过getline读取文件会忽略最后一行空行

getline是读取文件的常用函数,虽然使用简单,但是有一个较容易被忽视的问题,就是文件最后一行空行会被忽略。 #include <iostream> #include <fstream> #include <string> using namespace std;void readWholeFileWithGetline(string fileName) {string t…...

力扣123. 买卖股票的最佳时机 III

动态规划 思路&#xff1a; 最多可以完成两笔交易&#xff0c;因此任意一天结束后&#xff0c;会处于5种状态&#xff1a; 未进行任何操作&#xff1b;只进行了一次买操作&#xff1b;进行了一次买操作和一次卖操作&#xff1b;再完成了一次交易之后&#xff0c;进行了一次买操…...

Vue3:vue-cli项目创建

一、node.js检测或安装&#xff1a; node -v node.js官方 二、vue-cli安装&#xff1a; npm install -g vue/cli # OR yarn global add vue/cli/*如果安装的时候报错&#xff0c;可以尝试一下方法 删除C:\Users**\AppData\Roaming下的npm和npm-cache文件夹 删除项目下的node…...

C# .Net学习笔记—— 异步和多线程(Task)

一、概念 Task是DotNet3.0之后所推出的一种新的使用多线程的方式&#xff0c;它是基于ThreadPool线程进行封装的。 二、使用多线程的时机 任务能够并发运行的时候&#xff0c;提升速度&#xff1b;优化体验 三、基本使用方法 private void button5_Click(object sender, Ev…...

Python从入门到网络爬虫(读写Excel详解)

前言 Python操作Excel的模块有很多&#xff0c;并且各有优劣&#xff0c;不同模块支持的操作和文件类型也有不同。最常用的Excel处理库有xlrd、xlwt、xlutils、xlwings、openpyxl、pandas&#xff0c;下面是各个模块的支持情况&#xff1a; 工具名称.xls.xlsx获取文件内容写入…...

Mysql之子查询、连接查询(内外)以及分页查询

目录 一.案例&#xff08;接上篇博客&#xff09; 09&#xff09;查询学过「张三」老师授课的同学的信息 10&#xff09;查询没有学全所有课程的同学的信息 11&#xff09;查询没学过"张三"老师讲授的任一门课程的学生姓名 12&#xff09;查询两门及其以上不及格课程…...

计算机的存储单位

在计算机中&#xff0c;只能识别二进制。 byte是1个字节&#xff0c;是8个比特位&#xff0c;所以byte可以存储的最大值是&#xff1a;01111111&#xff0c;byte是 [-128 ~ 127] 共可以标识256个不同的数字。 1字节 8bit&#xff08;8比特&#xff09;--> 1byte 8bit 类…...

南阳商都网站做网站/网页平台做个业务推广

常见的浏览器内核主要有四种&#xff1a;Webkit内核、Presto内核、Trident内核、Gecko内核。HTML兼容CSS兼容JavaScript兼容1. HTML兼容对于HTML兼容&#xff0c;这是由于低版本浏览器不能识别一些高版本浏览器使用的标签&#xff0c;从而导致不能解析&#xff0c;比如Html5 新…...

彩票网站开发.极云/太原百度关键词排名

1 简介 推荐一篇文章&#xff0c;写的非常好https://blog.csdn.net/u014231646/article/details/79482195 2 下载安装及配置 官网&#xff1a; 2.1 下载安装 根据电脑配置选择32位或者64位进行安装。安装成功后解压到自己需要安装的目录。 tomcat的目录介绍 [外链图片转存失败…...

小说网站建设/推广免费

一、学习内容及要求 1. 内容&#xff1a;5.1 特征值与特征向量的概念与计算 线性代数学习笔记——第五十六讲——特征值及特征向量的定义 线性代数学习笔记——第五十七讲——特征子空间 线性代数学习笔记——第五十八讲——特征值与特征向量的判定 线性代数学习笔记——第…...

wordpress域名后缀/数据分析培训

我们知道在构造最小生成树的时候有可能会选择不同的边&#xff0c;这样构造的最小生成树不相同&#xff0c;但是最小生成树的权是唯一的&#xff01; 毫无疑问&#xff0c;无向图中存在相同权值的边是最小生成树不唯一的必要条件&#xff08;但不是充分条件&#xff09;。正因为…...

wordpress回复后可见/3小时百度收录新站方法

作者&#xff1a;Mark A译者&#xff1a;前端小智来源&#xff1a;dev点赞再看&#xff0c;微信搜索 【大迁世界】 关注这个没有大厂背景&#xff0c;但有着一股向上积极心态人。本文 GitHubhttps://github.com/qq44924588... 上已经收录&#xff0c;文章的已分类&#xff0c;也…...

网站建设使用的什么软件/百度广告搜索推广

目录 Axios特征axios提供主要三种发起请求的方式方式一&#xff1a;直接axios实例直接call方式方式二&#xff1a;通过axios实例提供的不同http请求方式的方法方式三&#xff1a;其实是从第二种方式中单独提出来的响应模式给axios对象设置回调函数总结Axios github文档&#xf…...