IGRF-13 数学细节与公式说明

本文件整理 IGRF-13 C++ 实现中的关键数学公式与算法细节,确保与官方 Fortran igrf13syn 一致。

1. 球谐展开与磁势函数

地磁标量势函数:

V ( r , θ , ϕ , t ) = a ∑ n = 1 N ∑ m = 0 n ( a r ) n + 1 [ g n m ( t ) cos ⁡ ( m ϕ ) + h n m ( t ) sin ⁡ ( m ϕ ) ] P ˉ n m ( cos ⁡ θ ) V(r,\theta,\phi,t) = a \sum_{n=1}^{N} \sum_{m=0}^{n} \left(\frac{a}{r}\right)^{n+1} \left[g_n^m(t)\cos(m\phi) + h_n^m(t)\sin(m\phi)\right] \bar{P}_n^m(\cos\theta) V(r,θ,ϕ,t)=an=1∑Nm=0∑n(ra)n+1[gnm(t)cos(mϕ)+hnm(t)sin(mϕ)]Pˉnm(cosθ)

  • a = 6371.2   k m a = 6371.2\,\mathrm{km} a=6371.2km 为 IGRF 参考半径
  • ( r , θ , ϕ ) (r,\theta,\phi) (r,θ,ϕ) 为地心球坐标( θ \theta θ 为余纬)
  • g n m , h n m g_n^m, h_n^m gnm,hnm 为高斯系数
  • P ˉ n m \bar{P}_n^m Pˉnm 为 Schmidt 半归一化勒让德函数

2. 磁场分量公式

磁场由势函数梯度给出:

B r = − ∂ V ∂ r B_r = -\frac{\partial V}{\partial r} Br=−∂r∂V

B θ = − 1 r ∂ V ∂ θ B_\theta = -\frac{1}{r}\frac{\partial V}{\partial \theta} Bθ=−r1∂θ∂V

B ϕ = − 1 r sin ⁡ θ ∂ V ∂ ϕ B_\phi = -\frac{1}{r\sin\theta}\frac{\partial V}{\partial \phi} Bϕ=−rsinθ1∂ϕ∂V

在实现中,合成结果直接在 NED(北-东-地)坐标系输出,等价于 Fortran igrf13syn 的 x , y , z x,y,z x,y,z 输出。

3. Schmidt 半归一化勒让德函数

采用 Fortran 参考递推(对应 p(k) / q(k)):

对角项( m = n m=n m=n):

P ˉ n n = sin ⁡ θ 2 n + 1 2 n    P ˉ n − 1 n − 1 \bar{P}n^n = \sin\theta \sqrt{\frac{2n+1}{2n}}\; \bar{P}{n-1}^{n-1} Pˉnn=sinθ2n2n+1 Pˉn−1n−1

一般项( m < n m<n m<n):

P ˉ n m = ( 2 n − 1 ) cos ⁡ θ    P ˉ n − 1 m − ( n − 1 ) 2 − m 2    P ˉ n − 2 m n 2 − m 2 \bar{P}n^m = \frac{(2n-1)\cos\theta\;\bar{P}{n-1}^m -\sqrt{(n-1)^2-m^2}\;\bar{P}_{n-2}^m} {\sqrt{n^2-m^2}} Pˉnm=n2−m2 (2n−1)cosθPˉn−1m−(n−1)2−m2 Pˉn−2m

Fortran 使用等效的 p ( k ) , q ( k ) p(k), q(k) p(k),q(k) 递推形式:

p ( k ) = u cos ⁡ θ   p ( i ) − t   p ( j ) p(k) = u\cos\theta\,p(i) - t\,p(j) p(k)=ucosθp(i)−tp(j)

q ( k ) = u ( cos ⁡ θ   q ( i ) − sin ⁡ θ   p ( i ) ) − t   q ( j ) q(k) = u(\cos\theta\,q(i) - \sin\theta\,p(i)) - t\,q(j) q(k)=u(cosθq(i)−sinθp(i))−tq(j)

其中 u , t u,t u,t 由 n , m n,m n,m 决定,索引 i , j i,j i,j 由三角形展开规则给出。

4. 球坐标 ↔ 笛卡尔坐标转换

球坐标到 ECEF:

x = r sin ⁡ θ cos ⁡ ϕ , y = r sin ⁡ θ sin ⁡ ϕ , z = r cos ⁡ θ x = r \sin\theta \cos\phi,\quad y = r \sin\theta \sin\phi,\quad z = r \cos\theta x=rsinθcosϕ,y=rsinθsinϕ,z=rcosθ

ECEF 到球坐标:

r = x 2 + y 2 + z 2 , θ = arctan ⁡ 2 ( x 2 + y 2 , z ) , ϕ = arctan ⁡ 2 ( y , x ) r = \sqrt{x^2+y^2+z^2},\quad \theta = \arctan2(\sqrt{x^2+y^2}, z),\quad \phi = \arctan2(y, x) r=x2+y2+z2 ,θ=arctan2(x2+y2 ,z),ϕ=arctan2(y,x)

NED 坐标(北-东-地)与 ECEF 之间的变换矩阵:

B N B E B D \] = \[ − sin ⁡ φ cos ⁡ λ − sin ⁡ φ sin ⁡ λ cos ⁡ φ − sin ⁡ λ cos ⁡ λ 0 − cos ⁡ φ cos ⁡ λ − cos ⁡ φ sin ⁡ λ − sin ⁡ φ \] \[ B x B y B z \] \\begin{bmatrix}B_N\\\\B_E\\\\B_D\\end{bmatrix} = \\begin{bmatrix} -\\sin\\varphi\\cos\\lambda \& -\\sin\\varphi\\sin\\lambda \& \\cos\\varphi \\\\ -\\sin\\lambda \& \\cos\\lambda \& 0 \\\\ -\\cos\\varphi\\cos\\lambda \& -\\cos\\varphi\\sin\\lambda \& -\\sin\\varphi \\end{bmatrix} \\begin{bmatrix}B_x\\\\B_y\\\\B_z\\end{bmatrix} BNBEBD = −sinφcosλ−sinλ−cosφcosλ−sinφsinλcosλ−cosφsinλcosφ0−sinφ BxByBz 其中 φ \\varphi φ 为大地纬度, λ \\lambda λ 为经度。 ### 5. 磁场合成中 ( a / r ) n + 2 (a/r)\^{n+2} (a/r)n+2 系数 由 B r = − ∂ V / ∂ r B_r = -\\partial V/\\partial r Br=−∂V/∂r 推导得到: ( a r ) n + 2 \\left(\\frac{a}{r}\\right)\^{n+2} (ra)n+2 在实现中通过递推计算: ratio = a r , rr = ratio 2 , rr ← rr ⋅ ratio \\text{ratio} = \\frac{a}{r},\\quad \\text{rr} = \\text{ratio}\^2,\\quad \\text{rr} \\leftarrow \\text{rr} \\cdot \\text{ratio} ratio=ra,rr=ratio2,rr←rr⋅ratio 保证每阶 n n n 的幂次与 Fortran 一致。 ### 6. 大地坐标 → 地心坐标(WGS84) Fortran 参考公式: a 2 = 40680631.6 , b 2 = 40408296.0 a\^2 = 40680631.6,\\quad b\^2 = 40408296.0 a2=40680631.6,b2=40408296.0 ρ = a 2 sin ⁡ 2 θ + b 2 cos ⁡ 2 θ \\rho = \\sqrt{a\^2\\sin\^2\\theta + b\^2\\cos\^2\\theta} ρ=a2sin2θ+b2cos2θ r = h ( h + 2 ρ ) + a 2 ( a 2 sin ⁡ 2 θ ) + b 2 ( b 2 cos ⁡ 2 θ ) a 2 sin ⁡ 2 θ + b 2 cos ⁡ 2 θ r = \\sqrt{h(h + 2\\rho) + \\frac{a\^2(a\^2\\sin\^2\\theta) + b\^2(b\^2\\cos\^2\\theta)}{a\^2\\sin\^2\\theta + b\^2\\cos\^2\\theta}} r=h(h+2ρ)+a2sin2θ+b2cos2θa2(a2sin2θ)+b2(b2cos2θ) 并计算旋转参数 c d , s d cd, sd cd,sd 用于将地心结果转换为大地方向的 NED 分量。 ### 7. 公式与实现对应说明 * `computeNedFieldIgrf()`:实现 `igrf13syn` 的递推合成 * `computeEcefField()`:NED 合成后再旋转回 ECEF * `computeNedFieldGeodetic()`:直接输出 NED 所有公式均与 Fortran 版本逐项对齐,确保与官方实现一致。

相关推荐
小鸡吃米…3 小时前
机器学习 —— 数据缩放
人工智能·python·机器学习
JHC0000003 小时前
智能体造论子--简单封装大模型输出审核器
开发语言·python·机器学习
龙腾AI白云3 小时前
AI算法实战:逻辑回归在风控场景中的应用
深度学习·机器学习·知识图谱
九河云4 小时前
数字韧性时代,华为云CBR为业务连续性注入“免疫基因”
大数据·人工智能·安全·机器学习·华为云
人机与认知实验室4 小时前
人机环境系统矩阵的“秩”
线性代数·矩阵
闪电麦坤954 小时前
Leecode热题100:矩阵置零(矩阵)
线性代数·算法·矩阵
人机与认知实验室4 小时前
人机环境系统矩阵典型案例分析
线性代数·矩阵
Juicedata4 小时前
JuiceFS 企业版 5.3 特性详解:单文件系统支持超 5,000 亿文件,首次引入 RDMA
大数据·人工智能·机器学习·性能优化·开源
山楂树の4 小时前
计算机图形学 模型矩阵的逆矩阵:如何从“世界”回归“局部”?
线性代数·矩阵·回归