LIGO 用 Python 分析引力波数据

美国科学家11日宣布,他们去年9月首次探测到引力波。这一发现印证了物理学大师爱因斯坦100年前的预言。宣布这一发现的,是激光干涉引力波天文台(LIGO)的负责人。

这个机构诞生于上世纪90年代,进行引力波观测已经有近30年。那么观测到的引力波数据的量应该很大,科学家如何对这些数据进行分析?有没有用到Python编程语言?

答案是肯定的。笔者在Github上发现了一个专门用于分析引力波数据的Python包:GWPY。据维护者介绍,GWPY的代码来自LIGO和另一个名叫Virgo的机构,维护者将这两个机构科学家的Python代码整理,最终的产品就是GWPY这个用户友好的Python包。

在具体介绍GWPY之前,先给和笔者一样的小白简单科普一下引力波和LIGO的相关知识。

什么是引力波?

上图是两个黑洞所产生的引力波的3-D模拟图(NASA)。

首先,什么是引力波?在物理学上,引力波是爱因斯坦广义相对论所预言的一种以光速传播的时空波动,如同石头丢进水里产生的波纹一样,引力波被视为宇宙中的“时空涟漪”。通常引力波的产生非常困难,地球围绕太阳以每秒30千米的速度前进,发出的引力波功率仅为200瓦,还不如家用电饭煲功率大。宇宙中大质量天体的加速、碰撞和合并等事件才可以形成强大的引力波,但能产生这种较强引力波的波源距离地球都十分遥远,传播到地球时变得非常微弱。

下面分享两个优秀的视频,很好地解释了引力波及背后的原理。第一个来自LIGO,第二个则是比较通俗的漫画式讲解。

LIGO科学家的解释:

漫画式通俗解释:

LIGO是什么?

激光干涉引力波观测站Laser Interferometer Gravitational-Wave ObservatoryLIGO是加州理工学院(Caltech)和麻省理工学院(MIT)的合作实验室,现在也有其他的大学参与。实验资金来源于美国国家科学基金会。LIGO是用来寻找宇宙中的引力波,从而可以验证黑洞的存在和检验广义相对论。

LIGO主要有两个观测点,位于路易斯安那Livingston Parish的LIGO Livingston观测点,和华盛顿 Hanford的LIGO Hanford观测点。除此之外,在加州Passadena 的Caltech校园中还有LIGO 40m Prototype 。

LIGO是如何探测引力波的?

GWPY:LIGO用它分析引力波数据?

接下来是本文的重头戏。我们一起来学习如何GWPY分析引力波数据。下面的介绍及示例均来自GWPY的官方文档。

安装

很简单,pip install gwpy就可以完成安装。

不过安装的过程可能会比较长,因为gwpy使用的依赖包比较多,包括numpy、 scipy、 cycler、matplotlib、astropy等。

面向对象编程

GWPY是一个面向对象编程的Python包,也就是说,数据对象是这个包的核心关注点。每一个数据对象都体现为一个类实例,包含了其属性和包含的数据。

如果想创建一个新的类实例,建议使用标准的构建器constructor。举个例子,我们可以使用一个数据数组,生成一个TimeSeries对象:

  1. >>> from gwpy.timeseries import TimeSeries
  2. >>> mydata = TimeSeries([1,2,3,4,5,6,7,8,9,10], sample_rate=1, epoch=0)

或者从在线数据服务器上下载:

  1. >>> from gwpy.timeseries import TimeSeries
  2. >>> mydata = TimeSeries.fetch('H1:LDAS-STRAIN', 964656015, 964656615)

核心数据对象

据介绍,GWPY提供了4种核心数据对象,分别代表引力波探测器所产生的四种标准数据:

  • TimeSeries(时间序列数据)
  • Spectrum(光谱数据)
  • Spectrogram(光谱图)
  • DataQualityFlag

引力波数据可视化

我们知道,将引力波探测器收集的数据可视化,对于理解引力波的特性、研究引力波信号来说非常有帮助。gwpy.plotter模块中提供了一些plot类,可以直观地展示相应的数据类型。

GWPY的核心数据对象里,大部分都内置有一个plot()方法,可以让研究人员快速对某个数据集进行可视化展示。举个例子:

  1. >>> from gwpy.timeseries import TimeSeries
  2. >>> data = TimeSeries.fetch('H1:LDAS-STRAIN', 968654552, 968654562)
  3. >>> plot = data.plot()
  4. >>> plot.show()

GWPY:利用公开的LIGO数据进行绘图

我们接下来利用LIGO公开的一些引力波时间序列数据进行绘图。我们可以直接在线加载这些数据。首先导入我们需要的模块:

  1. >>> from urllib2 import urlopen
  2. >>> from numpy import asarray
  3. >>> from gwpy.timeseries import TimeSeries

然后,下载数据,保存为文本字符串:

  1. >>> data = urlopen('http://www.ligo.org/science/GW100916/L-strain_hp30-968654552-10.txt').read()

现在,我们可以对文本进行解析,补充必要的元数据之后,就可以生成一个TimeSeries:

  1. >>> ts = TimeSeries(asarray(data.splitlines(), dtype=float),
  2. >>> epoch=968654552, sample_rate=16384, unit='strain')

最后,我们就可以绘图了:

  1. >>> plot = ts.plot()
  2. >>> plot.set_title('LIGO Livingston Observatory data for GW100916')
  3. >>> plot.set_ylabel('Gravitational-wave strain amplitude')
  4. >>> plot.show()

本文来自云栖社区合作伙伴“Linux中国”

原文发布时间为:2013-04-02.

LIGO 用 Python 分析引力波数据相关推荐

  1. python大数据分析实例-如何用Python分析大数据(以Twitter数据挖掘为例)

    原标题:如何用Python分析大数据(以Twitter数据挖掘为例) 来源:艾翻译(http://www.itran.cc/) 原文标题:Twitter Data Mining: A Guide to ...

  2. 如何去使用Python分析股票数据?学到就是赚到

    对于炒股的同学来说,必须会看懂数据才能避免入坑.今天小千就来教大家如何去使用Python分析股票数据,学到就是赚到.(小千提醒,股市有风险,请谨慎投资) 这次的美股例子就选择了美国显卡制造商英伟达,其 ...

  3. python sci数据_scanpy学习笔记:用Python分析单细胞数据

    Scanpy 是一个基于 Python 分析单细胞数据的软件包,内容包括预处理,可视化,聚类,拟时序分析和差异表达分析等.本文翻译自 scanpy 的官方教程 Preprocessing and cl ...

  4. 大数据如何使用Python分析微信数据

    截至2020年第二季度,微信拥有超过27亿活跃用户.这意味着,如果你正在阅读大数据如何使用Python分析微信数据,那么你很可能是微信用户.但是,你到底有多少微信用户?你实际发布了多少?我们可以使用P ...

  5. 零基础小白如何使用Python分析调查数据

    进行调查和民意调查是收集数据和深入了解诸如客户为何离开我们网站等问题的最佳方法之一.还是为什么选民会吸引这位候选人?但是分析调查数据可能是一个真正的挑战! 在本教程中,我们将逐步介绍如何使用Pytho ...

  6. python分析股票数据 彤_Python数据分析:股票数据

    最近股市比较火,我7月初上车了,现在已经下了.中间虽然吃了点肉,但下车的时候都亏进去了,最后连点汤都没喝着. 这篇文章我们就用它python 对股票数据做个简单的分析.数据集是从1999年到2016年 ...

  7. python 分析大数据

    Python是一种高级编程语言,可用于分析大数据.常用的 Python 库如 Pandas 和 NumPy 可用于数据清洗.数据分析和数据可视化.此外,还有许多其他库,如 Scikit-learn.T ...

  8. python分析鸢尾花数据_python数据挖掘学习笔记】十六.逻辑回归LogisticRegression分析鸢尾花数据...

    但是很多时候数据是非线性的,所以这篇文章主要讲述逻辑回归及Sklearn机器学习包中的LogisticRegression算法 #2018-03-28 16:57:56 March Wednesday ...

  9. python 分析外汇数据_Python爬取中国银行外汇牌价(statsmodels预测分析)--(二)

    Author: sunhailin-Leo E-mail:379978424@qq.com 简介 如果数据还没获取到的话请移步看第一篇文章(本篇文章默认数据已存储在 数据库 中) 步入正题 上一篇文章 ...

最新文章

  1. 手机主宰了你的生活,这不是乔布斯想看到的
  2. scala中Stream理解
  3. oracle函数胡书写,Oracle中序列表sequence的使用.docx
  4. 在流程梳理的过程中,OA工作组应采用国际先进方法
  5. ThinkPHP框架开发的应用的标准执行流程
  6. python文件操作小总结
  7. JavaScript之面向对象与原型笔记整理--------创建对象之原型(2)
  8. 算法 Tricks(六)— if 条件分支的简化
  9. 使用 matlab 数字图像处理(十)—— 维纳滤波复原
  10. centos安装后连不上网
  11. html怎么插入jq背景,HTML 全屏背景的方法
  12. 基于node.js和Vue的音乐管理系统 /音乐网站的设计与实现
  13. VASSISTX在vs里面应用的快捷键
  14. 2021应届生DJI校招在线测评几点说明
  15. 管理_立项任务书怎么写——毛宇菲
  16. dll文件保存到服务器,dll是什么文件?dll文件怎么打开?
  17. 2007word文档删除尾注线
  18. linux 切换 amd 显卡,ubuntu 14.10 (64位)下载amd显卡,实现双显卡切换
  19. LDN的蓝牙双模键盘帮助文档
  20. 初识SRC漏洞平台提交漏洞

热门文章

  1. 【前端之旅】HTML大总结
  2. HTB Optimum[Hack The Box HTB靶场]writeup系列6
  3. 遇到的那些奇奇怪怪的文件格式(持续更新。。。)
  4. vue-devtools工具的安装和使用
  5. 俄罗斯“扎克伯格”:创建区块链版“微信” 27岁身价已达2.5亿美元
  6. python中的ideavim有什么作用_【进击的Vimmer】为什么选择vim
  7. jQuery效果-隐藏和显示
  8. 全世界的程序员,我只服女程序员
  9. 信息安全系列(3)--从王宝*离婚案论个人信息安全
  10. 有用的文章集锦(干货和有效知识)