Python - 如何使用obspy模块将计数转换为m / s

时间:2013-04-17 22:52:14

标签: python

我有一个带有单通道跟踪的miniseed文件,我假设数据在计数中(我如何检查跟踪的单位?)。我需要将其转换为m / s。 我已经检查了obspy教程,我的主要问题是我不知道如何从迷你文件中访问极点和零点以及放大因子。 另外,我需要校准文件吗?

这是我的代码:

from obspy.core import *
st=read('/Users/guilhermew/Documents/Projecto/Dados sismicos 1 dia/2012_130_DOC01.mseed')
st.plot()

提前致谢, Guilherme的

编辑: 我终于明白了如何转换数据。 Obspy有不同的方法来实现这一目标,但这一切都归结为从波形数据中删除仪器响应。 就像@Robert Barsch说的那样,我需要另一个文件来获取仪器响应元数据。 所以我想出了以下代码:

parser=Parser("dir/parser/file")
for tr in stream_aux:
    stream_id=tr.stats.network+'.'+tr.stats.station+ '..' + tr.stats.channel
    paz=parser.getPAZ(stream_id, tr.stats.starttime)
    df = tr.stats.sampling_rate
    tr.data = seisSim(tr.data, df, paz_remove=paz)

我使用seisSim函数转换数据。 我现在的问题是输出看起来不正确(但我似乎无法发布图像)

2 个答案:

答案 0 :(得分:1)

这显然是一个应该向地震学界提出的问题,而不是StackOverflow!你怎么写ObsPy user mailinglist

更新:我仍然觉得答案是他/她应该直接在ObsPy邮件列表上询问。但是,为了给出实际问题的正确答案:MiniSEED是一种仅数据格式,不包含任何元信息,如极点和零点或使用的单位。所以是的,你需要另一个文件,如RESP,SAC PAZ,无数据SEED,全SEED等,以获得电台特定的元数据。要应用地震计校正,请阅读http://docs.obspy.org/tutorial/code_snippets/seismometer_correction_simulation.html

答案 1 :(得分:0)

要获得真实单位而非计数,您需要删除仪器响应。我使用以下代码删除了仪器响应:

# Define math defaults
from __future__ import division #allows real devision without rounding

# Retrieve modules needed
from obspy.core import read
import numpy as np
import matplotlib.pyplot as plt

#%% Choose and import data
str1 = read(fileloc)
print(str1) #show imported data
print(str1[0].stats) #show stats for trace

#%% Remove instrument response

# create dictionary of poles and zeros
TrillC = {'gain': 800.0,
        'poles': [complex(-3.691000e-02,3.712000e-02),
                  complex(-3.691000e-02,-3.712000e-02),
                  complex(-3.739000e+02,4.755000e+02),
                  complex(-3.739000e+02,-4.755000e+02),
                  complex(-5.884000e+02,1.508000e+03),
                  complex(-5.884000e+02,-1.508000e+03)],
        'sensitivity': 8.184000E+11,
        'zeros': [0 -4.341E+02]}
str1_remres = str1.copy() #make a copy of data, so original isn't changed
str1_remres.simulate(paz_remove=TrillC, paz_simulate=None, water_level=60.0)
print("Instrument Response Removed")

plt.figure()
str1_remres_m = str1_remres.merge()
plt.plot(str1_remres_m[0].data) #only will plot first trace of the stream

正如你所看到的,我已经手动定义了极点和零点。可能有一种方法可以自动输入它,但这是我发现有效的方式。

请记住每种乐器都有不同的极点和零点。

您使用的零数取决于您希望输出的内容。地震计通常是速度(2个零)

  • 3 zeros = displacement
  • 2 zeros = velocity
  • 1 zero = acceleration