Location via proxy:   [ UP ]  
[Report a bug]   [Manage cookies]                
Skip to content

JintaoLee-Roger/IGRF

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

26 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

IGRF

计算地球非偶极子场

若无法查看公式,请安装 MathJax Plugin for Github 插件 或者 TeX All the Things 插件

CONTENTS

环境

env

数据

数据来自 International Geomagnetic Reference Field

txt格式数据文件下载

excel格式数据文件下载

将txt文件的前四行删掉

公式

公式如下: $$ 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] P_{n}^{m}(\cos \theta) $$

我们只计算它的$z$分量,公式如下: $$ V(r, \theta, \phi, t)=-(n+1) \sum_{n=1}^{N} \sum_{m=0}^{n}\left(\frac{a}{r}\right)^{n+2}\left[g_{n}^{m}(t) \cos (m \phi)+h_{n}^{m}(t) \sin (m \phi)\right] P_{n}^{m}(\cos \theta) $$

其中 $a$ 为地球半径,我们只计算地表的,即 $r = a$.

$P_{n}^{m}(\cos \theta)$ 是半归一化的连带勒让德函数,而python中的scipy.special.lpmv()函数是完全没有归一化的,我们需要将其归一化,可用以下公式: $$ P_{n}(x) \qquad \text { for } m=0 $$ $$ s_{n}^{m}(x)=(-1)^{m} \sqrt{\frac{2(n-m) !}{(n+m) !}} P_{n}^{m}(x) \qquad \text { for } m>0 $$

结果

将所得结果放置在pngfile目录下,共25张,还有一张gif动图(IGRF.gif)在主目录下.

动图如下

gif

代码

igrfcode.py

constant.py

About

计算地球非偶极子场

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages