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

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

答案是肯定的。笔者在Github上发现了一个专门用于分析引力波数据的Python包:GWPY[1]。据维护者介绍,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的官方文档[2]。

安装

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

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

面向对象编程

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

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

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

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

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

核心数据对象

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

TimeSeries(时间序列数据)

Spectrum(光谱数据)

Spectrogram(光谱图)

DataQualityFlag

引力波数据可视化

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

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

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

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

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

>>> from urllib2 import urlopen>>> from numpy import asarray>>> from gwpy.timeseries import TimeSeries

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

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

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

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

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

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

====================================分割线================================
文章转载自 开源中国社区[http://www.oschina.net]

引力波数据居然是用 Python 分析的相关推荐

  1. python录入数据至ppt_利用python分析weibo数据做成图表放入PPT中

    起因 很久以前,就有个想法,就是自动分析微博的数据,但是之前一直想的是网页版展示,flask想学了好久都没学,偶然的一次看到了一篇关于python处理pptx的文章,再加上同窗三年的室友在毕业后竟然主 ...

  2. 大数据随记 —— 利用Python分析快手APP全国大学生用户数据(2022 年初赛第四题 )

    大数据系列文章:

  3. Python怎么用大数据分析_用Python制作大数据教程/如何使用Python分析大数据

    ✅作者简介:华为云开发者联盟优质内容创作者.CSDN内容合伙人.GitHub专业技术人员

  4. 一键备份微博并导出生成PDF,顺便用Python分析微博账号数据!

    这里再分享下如何快速导出你的所有微博数据,然后用Python分析某个微博账号的数据,比如高赞,转发,评论微博,微博词云,微博发布时间轴,以及使用的手机. 稳部落 这是一个专业备份导出微博记录工具 ht ...

  5. 一键备份微博并导出生成PDF,顺便用Python分析微博账号数据

    苏生不惑第139 篇原创文章,将本公众号设为星标,第一时间看最新文章. 关于微博之前写过以下文章: 那些你可能不知道的微博奇技淫巧 想方便快捷的分享/收藏图片?试试免费好用的微博/b站图床 如何轻松下 ...

  6. LIGO 用 Python 分析引力波数据

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

  7. 最近‘张同学’在DY实在是太火了,忍不住用Python分析了一下他的dy评论数据,相信有朝一日我也能够爆火起来

    最近抖音张同学突然火了,两个月涨粉一千多万. 今天这篇文章,我抓取了张同学的视频的评论数据,想从文本分析的角度,挖掘一下大家对张同学感兴趣的点. 张同学 10.4号开始发视频,视频的点赞量一直很高,1 ...

  8. 为什么抖音张同学这么火爆?用 Python 分析 1w+条评论数据,我发现了其中的秘密

    大家好,最近抖音张同学突然火了,两个月涨粉一千多万.今天这篇文章,我抓取了张同学的视频的评论数据,想从文本分析的角度,挖掘一下大家对张同学感兴趣的点. 张同学 10.4号开始发视频,视频的点赞量一直很 ...

  9. 用Python分析张同学dy评论数据

    首先 相信有很多小伙伴都喜欢玩抖音吧,最近抖音张同学突然火了,两个月涨粉一千多万.看了他的视频,满满的生活气息,让人有一种家的感觉.这就让我很感兴趣了,必须得用Python对他分析一下. 今天这篇文章 ...

最新文章

  1. java 读取excel_Java12POI操作Excel
  2. R语言ggplot2可视化:ggplot2中使用element_text函数设置轴标签文本粗体字体(bold text,只设置x轴的标签文本使用粗体字体)
  3. 蓝桥杯: 基础练习 数列排序
  4. pyQt4 for mac OS 10.8
  5. Linux怎么更新镜像,利用 Zsync 更新已有的 Ubuntu ISO 镜像
  6. 中消协:视频平台不应向VIP老会员收取超前点播费
  7. 真实到可怕!英伟达MIT造出马良的神笔
  8. 10截图时屏幕变大_刚刚才知道!华为手机还有7种截图方式,其中1种居然能隔空截图...
  9. 在eclipse下使用java调用weka
  10. C# Winform关于控件TabControl闪烁的问题
  11. jQuery 中文文档
  12. 联想G460驱动问题
  13. SwitchHosts For Mac快速切换修改hosts文件工具
  14. 谷歌翻译 翻译文档爬虫
  15. mysqldump 使用 --set-gtid-purged
  16. 使用EasyPoi导出word并转换为pdf
  17. 数据透视表mysql_MySQL查询和数据透视表
  18. glassfish linux,使用glassfish在linux上的部署网站
  19. Flink 多流转换
  20. ZXing.Net条形码二维码标签编辑打印软件

热门文章

  1. 张鑫溢:9.28黄金原油走势分析及操作建议指导.
  2. 宝宝为什么不吃奶粉,奶爸必读文章
  3. 习题5-7 使用函数求余弦函数的近似值(15 分)
  4. css实现图片毛玻璃效果
  5. Python函数式编程(fn)
  6. 手机edge浏览器无法打开三方应用
  7. Git常用命令、及常见报错处理:You have not concluded your merge (MERGE_HEAD exists)
  8. cacheable 表达式,多个方法参数的@Cacheable键
  9. 你今天Git了吗?上传资源上Github最新教程!
  10. 通过ffmpeg把图片转换成视频