本文主要是介绍解决obspy.plot(type=‘section‘)绘制按震中距度数排列报错,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
1. 利用python的obspy库绘制按震中距排列的波形对比图时如果使用震中距为°排列(即设置dist_degree=True),设置了ev_coord也会报错,报错信息如下:
存在问题:trace.stats中并没有coordinates这个属性(似乎可以自己定义,尚不清楚)。
ValueError: Define latitude/longitude in trace.stats.coordinates
2. 解决方法(这或许是一个折中的方法):
如果SAC数据头段中定义了震中距gcarc的值或dist值,可以赋值给trace.stats.distance,这样在dist_degree=False的情况下也可以画出按震中距排列的波形对比图(单位为°)。如果只给出dist值,可以手动转换成°,乘以1000是因为obspy.plot(type='section')下震中距默认单位为km。
for tr in st:tr.stats.distance = tr.stats.sac['gcarc'] * 1000
3.完整代码:
import os
import glob
import obspy
import matplotlib.pyplot as plt
from obspy import Streamsacfile = sorted(glob.glob('*/*sac'))# Original mean stacked waveforms
st = Stream()
for data in sacfile:st += obspy.read(data)for tr in st:tr.stats.distance = tr.stats.sac['gcarc'] * 1000fig = plt.figure(figsize=(10,6))
st.plot(type='section',orientation='horizontal',recordlength=1200,linewidth=1.0, show=False, fig=fig)
plt.xlabel('Time/(s)')
plt.ylabel('Distance/(°)')
plt.savefig('Wave_gcarc.png',dpi=300)
# plt.show()
参考问题描述:[obspy-users] plotting record sections: type oftrace.stats.coordinates
这篇关于解决obspy.plot(type=‘section‘)绘制按震中距度数排列报错的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!