-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathgetpsd.py
executable file
·104 lines (92 loc) · 3.94 KB
/
getpsd.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
#!/usr/bin/env python
import glob
from obspy.core import read, Stream
from matplotlib.mlab import csd
from obspy.signal.invsim import evalresp
import numpy as np
import matplotlib.pyplot as plt
from obspy.signal.spectral_estimation import get_NLNM
from multiprocessing import Pool
import os
import sys
def getspectra(string):
try:
#if True:
debug = True
lenfft = 20000
resppath = '/APPS/metadata/RESPS/'
stringTEMP = string.split('_')
net = stringTEMP[0]
sta = stringTEMP[1]
loc = stringTEMP[2]
chan = stringTEMP[3]
year = stringTEMP[4]
jday = stringTEMP[5]
if debug:
print 'Working on: ' + net + ' ' + sta + ' ' + loc + ' ' + chan
path = '/xs0/seed/' + net + '_' + sta + '/' + year + '/' + \
year + '_' + jday + '*/' + loc + '*' + chan + '*.seed'
files = glob.glob(path)
st = Stream()
for curfile in files:
st += read(curfile)
if len(st) == 1:
power,freq = csd(st[0].data,st[0].data, NFFT = lenfft,
noverlap = int(lenfft*.5), Fs = 1/st[0].stats.delta,
scale_by_freq = True)
power = power[1:].real
freq = freq[1:]
resp = evalresp(t_samp = st[0].stats.delta, nfft = lenfft, filename= resppath + 'RESP.' + net + '.' + \
sta + '.' + loc + '.' + chan, date = st[0].stats.starttime, station = sta,
channel = chan, network = net, locid = loc, units = 'ACC')
resp = resp[1:]
power = 10.*np.log10(power/np.absolute(resp*np.conjugate(resp)))
else:
power =[]
freq=[]
if len(power) > 1:
if debug:
print 'Writing data for: ' + string
if not os.path.exists('/TEST_ARCHIVE/PSDS/' + sta):
os.makedirs('/TEST_ARCHIVE/PSDS/' + sta)
if not os.path.exists('/TEST_ARCHIVE/PSDS/' + sta + '/' + year):
os.makedirs('/TEST_ARCHIVE/PSDS/' + sta + '/' + year)
fpsd = open('/TEST_ARCHIVE/PSDS/' + sta + '/' + year + '/PSD_' + string,'w')
for p,f in zip(power,freq):
fpsd.write(str(p) + ', ' + str(f) + '\n')
fpsd.close()
except:
print 'Unable to process: ' + string
return
if __name__ == "__main__":
debug = True
network = 'IC'
for year in range(2009,1988,-1):
year = str(year)
for jday in range(001,367):
strings = []
jday = str(jday).zfill(3)
mdgetOUTPUT = os.popen('mdget -b ' + year + ',' + jday + '-00:00:00 -s \'' + network + '.....[BL]H...\'')
for line in mdgetOUTPUT:
if '* NETWORK' in line:
net = (line.replace('* NETWORK','')).strip()
tempString = net + '_'
if '* STATION' in line:
sta = (line.replace('* STATION','')).strip()
tempString += sta + '_'
if '* COMPONENT' in line:
comp = (line.replace('* COMPONENT','')).strip()
if '* LOCATION' in line:
loc = (line.replace('* LOCATION','')).strip()
tempString += loc + '_' + comp + '_' + year + '_' + jday
if not os.path.isfile('/TEST_ARCHIVE/PSDS/' + sta + '/' + year + '/PSD_' + net + \
'_' + sta + '_' + loc + '_' + comp + '_' + year + '_' + jday):
print 'Adding: ' + tempString
strings.append(tempString)
if debug:
print 'Here are the number of strings: ' + str(len(strings))
print 'Here is the day: ' + str(jday) + ' ' + str(year)
#for string in strings:
pool = Pool(14)
pool.map(getspectra,strings)
#getspectra(strings[1])