[add] docstrings for event.py
This commit is contained in:
parent
983e4c25a3
commit
b6fddaf208
@ -15,6 +15,11 @@ class Event(ObsPyEvent):
|
|||||||
'''
|
'''
|
||||||
|
|
||||||
def __init__(self, path):
|
def __init__(self, path):
|
||||||
|
"""
|
||||||
|
Initialize event by event directory
|
||||||
|
:param path: path to event directory
|
||||||
|
:type path: str
|
||||||
|
"""
|
||||||
self.pylot_id = path.split('/')[-1]
|
self.pylot_id = path.split('/')[-1]
|
||||||
# initialize super class
|
# initialize super class
|
||||||
super(Event, self).__init__(resource_id=ResourceIdentifier('smi:local/' + self.pylot_id))
|
super(Event, self).__init__(resource_id=ResourceIdentifier('smi:local/' + self.pylot_id))
|
||||||
@ -30,10 +35,20 @@ class Event(ObsPyEvent):
|
|||||||
self.get_notes()
|
self.get_notes()
|
||||||
|
|
||||||
def get_notes_path(self):
|
def get_notes_path(self):
|
||||||
|
"""
|
||||||
|
Notes files is freely editable by the user and can contain notes regarding the event
|
||||||
|
:return: path to notes file
|
||||||
|
:rtype: str
|
||||||
|
"""
|
||||||
notesfile = os.path.join(self.path, 'notes.txt')
|
notesfile = os.path.join(self.path, 'notes.txt')
|
||||||
return notesfile
|
return notesfile
|
||||||
|
|
||||||
def get_notes(self):
|
def get_notes(self):
|
||||||
|
"""
|
||||||
|
set self.note attribute to content of notes file
|
||||||
|
:return:
|
||||||
|
:rtype: None
|
||||||
|
"""
|
||||||
notesfile = self.get_notes_path()
|
notesfile = self.get_notes_path()
|
||||||
if os.path.isfile(notesfile):
|
if os.path.isfile(notesfile):
|
||||||
with open(notesfile) as infile:
|
with open(notesfile) as infile:
|
||||||
@ -48,34 +63,81 @@ class Event(ObsPyEvent):
|
|||||||
pass
|
pass
|
||||||
|
|
||||||
def addNotes(self, notes):
|
def addNotes(self, notes):
|
||||||
|
"""
|
||||||
|
Set new notes string
|
||||||
|
:param notes: notes to save in Event object
|
||||||
|
:type notes: str
|
||||||
|
:return:
|
||||||
|
:rtype: None
|
||||||
|
"""
|
||||||
self.notes = str(notes)
|
self.notes = str(notes)
|
||||||
|
|
||||||
def clearNotes(self):
|
def clearNotes(self):
|
||||||
|
"""
|
||||||
|
Clear event notes
|
||||||
|
:return:
|
||||||
|
:rtype: None
|
||||||
|
"""
|
||||||
self.notes = None
|
self.notes = None
|
||||||
|
|
||||||
def isRefEvent(self):
|
def isRefEvent(self):
|
||||||
|
"""
|
||||||
|
Return reference event flag
|
||||||
|
:return: True if event is refence event
|
||||||
|
:rtype: bool
|
||||||
|
"""
|
||||||
return self._refEvent
|
return self._refEvent
|
||||||
|
|
||||||
def isTestEvent(self):
|
def isTestEvent(self):
|
||||||
|
"""
|
||||||
|
Return test event flag
|
||||||
|
:return: True if event is test event
|
||||||
|
:rtype: bool
|
||||||
|
"""
|
||||||
return self._testEvent
|
return self._testEvent
|
||||||
|
|
||||||
def setRefEvent(self, bool):
|
def setRefEvent(self, bool):
|
||||||
|
"""
|
||||||
|
Set reference event flag
|
||||||
|
:param bool: new reference event flag
|
||||||
|
:type bool: bool
|
||||||
|
:return:
|
||||||
|
:rtype: None
|
||||||
|
"""
|
||||||
self._refEvent = bool
|
self._refEvent = bool
|
||||||
if bool: self._testEvent = False
|
if bool: self._testEvent = False
|
||||||
|
|
||||||
def setTestEvent(self, bool):
|
def setTestEvent(self, bool):
|
||||||
|
"""
|
||||||
|
Set test event flag
|
||||||
|
:param bool: new test event flag
|
||||||
|
:type bool: bool
|
||||||
|
:return:
|
||||||
|
:rtype: None
|
||||||
|
"""
|
||||||
self._testEvent = bool
|
self._testEvent = bool
|
||||||
if bool: self._refEvent = False
|
if bool: self._refEvent = False
|
||||||
|
|
||||||
def clearObsPyPicks(self, picktype):
|
def clearObsPyPicks(self, picktype):
|
||||||
|
"""
|
||||||
|
Remove picks of a certain type from event
|
||||||
|
:param picktype: type of picks to remove, 'auto' or 'manual'
|
||||||
|
:type picktype: str
|
||||||
|
:return:
|
||||||
|
:rtype: None
|
||||||
|
"""
|
||||||
for index, pick in reversed(list(enumerate(self.picks))):
|
for index, pick in reversed(list(enumerate(self.picks))):
|
||||||
if picktype in str(pick.method_id):
|
if picktype in str(pick.method_id):
|
||||||
self.picks.pop(index)
|
self.picks.pop(index)
|
||||||
|
|
||||||
def addPicks(self, picks):
|
def addPicks(self, picks):
|
||||||
'''
|
"""
|
||||||
add pylot picks and overwrite existing ones
|
add pylot picks and overwrite existing ones
|
||||||
'''
|
:param picks: picks to add to event in pick dictionary
|
||||||
|
:type picks: dict
|
||||||
|
:return:
|
||||||
|
:rtype: None
|
||||||
|
"""
|
||||||
for station in picks:
|
for station in picks:
|
||||||
self.pylot_picks[station] = picks[station]
|
self.pylot_picks[station] = picks[station]
|
||||||
# add ObsPy picks (clear old manual and copy all new manual from pylot)
|
# add ObsPy picks (clear old manual and copy all new manual from pylot)
|
||||||
@ -83,6 +145,13 @@ class Event(ObsPyEvent):
|
|||||||
self.picks += picks_from_picksdict(self.pylot_picks)
|
self.picks += picks_from_picksdict(self.pylot_picks)
|
||||||
|
|
||||||
def addAutopicks(self, autopicks):
|
def addAutopicks(self, autopicks):
|
||||||
|
"""
|
||||||
|
Add automatic picks to event
|
||||||
|
:param autopicks: automatic picks to add to event
|
||||||
|
:type autopicks dict:
|
||||||
|
:return:
|
||||||
|
:rtype: None
|
||||||
|
"""
|
||||||
for station in autopicks:
|
for station in autopicks:
|
||||||
self.pylot_autopicks[station] = autopicks[station]
|
self.pylot_autopicks[station] = autopicks[station]
|
||||||
# add ObsPy picks (clear old auto and copy all new auto from pylot)
|
# add ObsPy picks (clear old auto and copy all new auto from pylot)
|
||||||
@ -90,6 +159,15 @@ class Event(ObsPyEvent):
|
|||||||
self.picks += picks_from_picksdict(self.pylot_autopicks)
|
self.picks += picks_from_picksdict(self.pylot_autopicks)
|
||||||
|
|
||||||
def setPick(self, station, pick):
|
def setPick(self, station, pick):
|
||||||
|
"""
|
||||||
|
Set pick for a station
|
||||||
|
:param station: station name
|
||||||
|
:type station: str
|
||||||
|
:param pick:
|
||||||
|
:type pick: dict
|
||||||
|
:return:
|
||||||
|
:rtype:
|
||||||
|
"""
|
||||||
if pick:
|
if pick:
|
||||||
self.pylot_picks[station] = pick
|
self.pylot_picks[station] = pick
|
||||||
else:
|
else:
|
||||||
@ -101,21 +179,46 @@ class Event(ObsPyEvent):
|
|||||||
self.picks += picks_from_picksdict(self.pylot_picks)
|
self.picks += picks_from_picksdict(self.pylot_picks)
|
||||||
|
|
||||||
def setPicks(self, picks):
|
def setPicks(self, picks):
|
||||||
'''
|
"""
|
||||||
set pylot picks and delete and overwrite all existing
|
Set pylot picks and delete and overwrite all existing
|
||||||
'''
|
:param picks: new picks
|
||||||
|
:type picks: dict
|
||||||
|
:return:
|
||||||
|
:rtype: None
|
||||||
|
"""
|
||||||
self.pylot_picks = picks
|
self.pylot_picks = picks
|
||||||
self.clearObsPyPicks('manual')
|
self.clearObsPyPicks('manual')
|
||||||
self.picks += picks_from_picksdict(self.pylot_picks)
|
self.picks += picks_from_picksdict(self.pylot_picks)
|
||||||
|
|
||||||
def getPick(self, station):
|
def getPick(self, station):
|
||||||
|
"""
|
||||||
|
Get pick at station
|
||||||
|
:param station: station name
|
||||||
|
:type station: str
|
||||||
|
:return: pick dictionary of station
|
||||||
|
:rtype: dict
|
||||||
|
"""
|
||||||
if station in self.pylot_picks.keys():
|
if station in self.pylot_picks.keys():
|
||||||
return self.pylot_picks[station]
|
return self.pylot_picks[station]
|
||||||
|
|
||||||
def getPicks(self):
|
def getPicks(self):
|
||||||
|
"""
|
||||||
|
Return pylot picks
|
||||||
|
:return:
|
||||||
|
:rtype: dict
|
||||||
|
"""
|
||||||
return self.pylot_picks
|
return self.pylot_picks
|
||||||
|
|
||||||
def setAutopick(self, station, pick):
|
def setAutopick(self, station, pick):
|
||||||
|
"""
|
||||||
|
Set pick at station
|
||||||
|
:param station: station name
|
||||||
|
:type station: str
|
||||||
|
:param pick:
|
||||||
|
:type pick: dict
|
||||||
|
:return:
|
||||||
|
:rtype: None
|
||||||
|
"""
|
||||||
if pick:
|
if pick:
|
||||||
self.pylot_autopicks[station] = pick
|
self.pylot_autopicks[station] = pick
|
||||||
else:
|
else:
|
||||||
@ -127,25 +230,46 @@ class Event(ObsPyEvent):
|
|||||||
self.picks += picks_from_picksdict(self.pylot_autopicks)
|
self.picks += picks_from_picksdict(self.pylot_autopicks)
|
||||||
|
|
||||||
def setAutopicks(self, picks):
|
def setAutopicks(self, picks):
|
||||||
'''
|
"""
|
||||||
set pylot picks and delete and overwrite all existing
|
Set pylot picks and delete and overwrite all existing
|
||||||
'''
|
:param picks: new picks
|
||||||
|
:type picks: dict
|
||||||
|
:return:
|
||||||
|
:rtype: None
|
||||||
|
"""
|
||||||
self.pylot_autopicks = picks
|
self.pylot_autopicks = picks
|
||||||
self.clearObsPyPicks('auto')
|
self.clearObsPyPicks('auto')
|
||||||
self.picks += picks_from_picksdict(self.pylot_autopicks)
|
self.picks += picks_from_picksdict(self.pylot_autopicks)
|
||||||
|
|
||||||
def getAutopick(self, station):
|
def getAutopick(self, station):
|
||||||
|
"""
|
||||||
|
Return autopick at station
|
||||||
|
:param station: station name
|
||||||
|
:type station: str
|
||||||
|
:return: pick dictionary
|
||||||
|
:rtype: dict
|
||||||
|
"""
|
||||||
if station in self.pylot_autopicks.keys():
|
if station in self.pylot_autopicks.keys():
|
||||||
return self.pylot_autopicks[station]
|
return self.pylot_autopicks[station]
|
||||||
|
|
||||||
def getAutopicks(self):
|
def getAutopicks(self):
|
||||||
|
"""
|
||||||
|
Get autopicks of event
|
||||||
|
:return: dict containing automatic picks
|
||||||
|
:rtype: dict
|
||||||
|
"""
|
||||||
return self.pylot_autopicks
|
return self.pylot_autopicks
|
||||||
|
|
||||||
def save(self, filename):
|
def save(self, filename):
|
||||||
'''
|
"""
|
||||||
Save PyLoT Event to a file.
|
Save PyLoT Event to a file.
|
||||||
Can be loaded by using event.load(filename).
|
Can be loaded by using event.load(filename).
|
||||||
'''
|
Uses pickling to save event object to file
|
||||||
|
:param filename: filename to save project under
|
||||||
|
:type filename: str
|
||||||
|
:return:
|
||||||
|
:rtype: None
|
||||||
|
"""
|
||||||
try:
|
try:
|
||||||
import cPickle
|
import cPickle
|
||||||
except ImportError:
|
except ImportError:
|
||||||
@ -159,9 +283,13 @@ class Event(ObsPyEvent):
|
|||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def load(filename):
|
def load(filename):
|
||||||
'''
|
"""
|
||||||
Load project from filename.
|
Load project from filename
|
||||||
'''
|
:param filename: to load event file
|
||||||
|
:type filename: str
|
||||||
|
:return: event loaded from file
|
||||||
|
:rtype: Event
|
||||||
|
"""
|
||||||
try:
|
try:
|
||||||
import cPickle
|
import cPickle
|
||||||
except ImportError:
|
except ImportError:
|
||||||
|
Loading…
Reference in New Issue
Block a user