Skip to content
Snippets Groups Projects
Commit d71784ee authored by Hal Simpson's avatar Hal Simpson
Browse files

cleaned up some code, added obsd as an input, added check_stream to make...

cleaned up some code, added obsd as an input,  added check_stream to make certain the expected channels are coming in.
parent 24c043e8
No related branches found
No related tags found
No related merge requests found
...@@ -24,10 +24,10 @@ ...@@ -24,10 +24,10 @@
""" """
import argparse import argparse
from os import path import sys
# ensure geomag is on the path before importing # ensure geomag is on the path before importing
if __file__ != 'main.py': if __file__ != 'xyz.py':
import sys from os import path
script_dir = path.dirname(path.abspath(__file__)) script_dir = path.dirname(path.abspath(__file__))
sys.path.append(path.normpath(path.join(script_dir, '..'))) sys.path.append(path.normpath(path.join(script_dir, '..')))
...@@ -83,10 +83,10 @@ def convert_stream(timeseries, informat, outformat): ...@@ -83,10 +83,10 @@ def convert_stream(timeseries, informat, outformat):
if outformat == 'geo' and informat == 'mag': if outformat == 'geo' and informat == 'mag':
out_stream = StreamConverter.get_geo_from_mag(timeseries) out_stream = StreamConverter.get_geo_from_mag(timeseries)
elif outformat == 'geo' and informat == 'obs': elif outformat == 'geo' and informat == 'obs' or informat == 'obsd':
out_stream = StreamConverter.get_geo_from_obs(timeseries) out_stream = StreamConverter.get_geo_from_obs(timeseries)
elif outformat == 'mag' and informat == 'obs': elif outformat == 'mag' and informat == 'obs' or informat == 'obsd':
out_stream = StreamConverter.get_mag_from_obs(timeseries) out_stream = StreamConverter.get_mag_from_obs(timeseries)
elif outformat == 'mag' and informat == 'geo': elif outformat == 'mag' and informat == 'geo':
...@@ -99,18 +99,40 @@ def convert_stream(timeseries, informat, outformat): ...@@ -99,18 +99,40 @@ def convert_stream(timeseries, informat, outformat):
out_stream = StreamConverter.get_obs_from_geo(timeseries) out_stream = StreamConverter.get_obs_from_geo(timeseries)
elif outformat == 'obsd' and informat == 'geo': elif outformat == 'obsd' and informat == 'geo':
out_stream = StreamConverter.get_obs_from_geo(timeseries, True) out_stream = StreamConverter.get_obs_from_geo(timeseries,
include_d=True)
elif outformat == 'obs' and informat == 'obs': elif outformat == 'obs' and informat == 'obs' or informat == 'obsd':
out_stream = StreamConverter.get_obs_from_obs(timeseries, out_stream = StreamConverter.get_obs_from_obs(timeseries,
True, False) include_d=True)
elif outformat == 'obsd' and informat =='obs': elif outformat == 'obsd' and informat =='obs':
out_stream = StreamConverter.get_obs_from_obs(timeseries, out_stream = StreamConverter.get_obs_from_obs(timeseries,
False, True) include_d=True)
return out_stream return out_stream
def check_stream(timeseries, channels):
"""checks an input stream to make certain all the required channels
exist.
Parameters
----------
timeseries: obspy.core.Stream
stream that was read in.
channels: array
channels that are expected in stream.
"""
channels_in = []
for series in timeseries:
channels_in += series.stats.channel
for channel in channels:
try:
channels_in.index(channel)
except ValueError:
print 'Channel %s not found in input' % channel
return False
return True
def main(): def main():
...@@ -118,7 +140,7 @@ def main(): ...@@ -118,7 +140,7 @@ def main():
description='Use @ to read commands from a file.', description='Use @ to read commands from a file.',
fromfile_prefix_chars='@') fromfile_prefix_chars='@')
parser.add_argument('--informat', choices=['geo', 'mag', 'obs']) parser.add_argument('--informat', choices=['geo', 'mag', 'obs', 'obsd'])
parser.add_argument('--outformat', choices=['geo', 'mag', 'obs', 'obsd']) parser.add_argument('--outformat', choices=['geo', 'mag', 'obs', 'obsd'])
parser.add_argument('--infile', help='iaga2002 input file') parser.add_argument('--infile', help='iaga2002 input file')
parser.add_argument('--outfile', help='iaga2002 out file') parser.add_argument('--outfile', help='iaga2002 out file')
...@@ -134,13 +156,16 @@ def main(): ...@@ -134,13 +156,16 @@ def main():
factory = iaga2002.IAGA2002Factory(None) factory = iaga2002.IAGA2002Factory(None)
timeseries = factory.parse_string(iagaFile) timeseries = factory.parse_string(iagaFile)
if check_stream(timeseries, CHANNELS[args.informat]) == False:
sys.exit()
out_stream = convert_stream(timeseries, args.informat, args.outformat) out_stream = convert_stream(timeseries, args.informat, args.outformat)
channels = CHANNELS[args.outformat] channels = CHANNELS[args.outformat]
if args.outfile != None: if args.outfile != None:
fh = open(args.outfile, 'w') fh = open(args.outfile, 'w')
else: else:
fh = sys.stdout fh = sys.stdout
factory.write_string(fh, out_stream, channels) factory.write_file(fh, out_stream, channels)
fh.close()
if __name__ == '__main__': if __name__ == '__main__':
......
...@@ -339,7 +339,7 @@ class IAGA2002Factory(TimeseriesFactory): ...@@ -339,7 +339,7 @@ class IAGA2002Factory(TimeseriesFactory):
day = obspy.core.UTCDateTime(day.timestamp + 86400) day = obspy.core.UTCDateTime(day.timestamp + 86400)
return days return days
def write_string(self, fh, timeseries, channels): def write_file(self, fh, timeseries, channels):
"""writes timeseries data to the given file object. """writes timeseries data to the given file object.
Parameters Parameters
...@@ -391,7 +391,7 @@ class IAGA2002Factory(TimeseriesFactory): ...@@ -391,7 +391,7 @@ class IAGA2002Factory(TimeseriesFactory):
self._get_url(observatory, day, type, interval)) self._get_url(observatory, day, type, interval))
day_timeseries = self._get_slice(timeseries, day) day_timeseries = self._get_slice(timeseries, day)
with open(day_filename, 'w') as fh: with open(day_filename, 'w') as fh:
self.write_string(fh, day_timeseries, channels) self.write_file(fh, day_timeseries, channels)
def _get_file_from_url(self, url): def _get_file_from_url(self, url):
"""Get a file for writing. """Get a file for writing.
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment