improvements, refreshFigure() now possible and done automatically after deleting of picks

This commit is contained in:
Marcel Paffrath 2015-10-12 14:40:29 +02:00
parent 34abad46e2
commit cdd33d7e2f

View File

@ -2,47 +2,98 @@ import matplotlib.pyplot as plt
plt.interactive(True) plt.interactive(True)
class regions(object): class regions(object):
def __init__(self, ax, shot_dict): '''
A class used for manual inspection and processing of all picks for the user.
Examples:
region.chooseRectangles():
- lets the user choose several rectangular regions in the plot
region.plotTracesInRegions():
- creates plots (shot.plot_traces) for all traces in the active regions (i.e. chosen by e.g. chooseRectangles)
region.setActiveRegionsForDeletion():
- highlights all shots in a the active regions for deletion
region.deleteMarkedPicks():
- deletes the picks (pick flag set to 0) for all shots set for deletion
region.deselectSelection(number):
- deselects the region of number = number
'''
def __init__(self, ax, survey):
self.ax = ax self.ax = ax
self.shot_dict = shot_dict self.survey = survey
self.shot_dict = self.survey.getShotDict()
self._x0 = [] self._x0 = []
self._y0 = [] self._y0 = []
self._x1 = [] self._x1 = []
self._y1 = [] self._y1 = []
self._allpicks = None
self.shots_found = {} self.shots_found = {}
self.shots_for_deletion = {} self.shots_for_deletion = {}
self._generateList()
def _onselect(self, eclick, erelease): def _onselect(self, eclick, erelease):
'eclick and erelease are matplotlib events at press and release' #print ' startposition : (%f, %f)' % (eclick.xdata, eclick.ydata) 'eclick and erelease are matplotlib events at press and release'
#print ' startposition : (%f, %f)' % (eclick.xdata, eclick.ydata)
#print ' endposition : (%f, %f)' % (erelease.xdata, erelease.ydata) #print ' endposition : (%f, %f)' % (erelease.xdata, erelease.ydata)
print 'region selected x0, y0 = (%3s, %3s), x1, y1 = (%3s, %3s)'%(eclick.xdata, eclick.ydata, erelease.xdata, erelease.ydata) print 'region selected x0, y0 = (%3s, %3s), x1, y1 = (%3s, %3s)'%(eclick.xdata, eclick.ydata, erelease.xdata, erelease.ydata)
x0 = min(eclick.xdata, erelease.xdata) x0 = min(eclick.xdata, erelease.xdata)
x1 = max(eclick.xdata, erelease.xdata) x1 = max(eclick.xdata, erelease.xdata)
y0 = min(eclick.ydata, erelease.ydata) y0 = min(eclick.ydata, erelease.ydata)
y1 = max(eclick.ydata, erelease.ydata) y1 = max(eclick.ydata, erelease.ydata)
self._x0.append(x0)
self._x1.append(x1) shots = self.findTracesInShotDict((x0, x1), (y0, y1))
self._y0.append(y0) if self.shots_found.keys() == []:
self._y1.append(y1) key = 1
self.markCurrentRegion(x0, x1, y0, y1) else:
key = max(self.shots_found.keys()) + 1
self.shots_found[key] = {'shots': shots,
'distbin': (x0, x1),
'pickbin': (y0, y1)}
self.markRegion((x0, x1), (y0, y1), key)
def chooseRectangles(self): def chooseRectangles(self):
'''
Activates matplotlib widget RectangleSelector.
'''
from matplotlib.widgets import RectangleSelector from matplotlib.widgets import RectangleSelector
print 'Select rectangle is active' print 'Select rectangle is active'
return RectangleSelector(self.ax, self._onselect) return RectangleSelector(self.ax, self._onselect)
def _getx0(self): def deselectLastSelection(self):
return self._x0 if self.shots_found.keys() == []:
print('No selection found.')
return
key = max(self.shots_found.keys())
self.deselectSelection(key)
def _getx1(self): def deselectSelection(self, key, color = 'green', alpha = 0.1):
return self._x1 try:
if color is not None:
self.markRegion(self.shots_found[key]['distbin'],
self.shots_found[key]['pickbin'],
key = key, color = color, alpha = alpha, linewidth = 0)
value = self.shots_found.pop(key)
print('Deselected selection number %d'% key)
return
except:
print('No selection found.')
return
def _gety0(self): def _generateList(self):
return self._y0 allpicks = []
for shot in self.shot_dict.values():
def _gety1(self): for traceID in shot.getTraceIDlist():
return self._y1 allpicks.append((shot.getDistance(traceID), shot.getPickIncludeRemoved(traceID),
shot.getShotnumber(), traceID, shot.getFlag(traceID)))
allpicks.sort()
self._allpicks = allpicks
def getShotDict(self): def getShotDict(self):
return self.shot_dict return self.shot_dict
@ -50,119 +101,164 @@ class regions(object):
def getShotsForDeletion(self): def getShotsForDeletion(self):
return self.shots_for_deletion return self.shots_for_deletion
def findTracesInShotDict(self, picks = 'normal'): def findTracesInShotDict(self, (x0, x1), (y0, y1), picks = 'normal'):
''' '''
Returns traces corresponding to a certain area in a plot with all picks over the distances. Returns traces corresponding to a certain area in the plot with all picks over the distances.
''' '''
print "findTracesInShotDict: Searching for marked traces in the shot dictionary... " shots_found = {}; numtraces = 0
if picks == 'normal': pickflag = 0
elif picks == 'includeCutOut': pickflag = None
for shot in self.shot_dict.values(): for line in self._allpicks:
whichpicks = {'normal': shot.getPick, dist, pick, shotnumber, traceID, flag = line
'includeCutOut': shot.getPick_backup} if flag == pickflag: continue ### IMPROVE THAT
for index in range(len(self._getx1())): if (x0 <= dist <= x1 and y0 <= pick <= y1):
distancebin = (self._getx0()[index], self._getx1()[index]) if not shotnumber in shots_found.keys():
pickbin = (self._gety0()[index], self._gety1()[index]) shots_found[shotnumber] = []
if shot.getTraceIDs4Dist(distancebin = distancebin) is not None: shots_found[shotnumber].append(traceID)
for traceID in shot.getTraceIDs4Dist(distancebin = distancebin): numtraces += 1
if pickbin[0] < whichpicks[picks](traceID) < pickbin[1]:
self.highlightPick(shot, traceID) print('Found %d traces: %s' %(numtraces, shots_found))
if shot.getShotnumber() not in self.shots_found.keys(): return shots_found
self.shots_found[shot.getShotnumber()] = []
if traceID not in self.shots_found[shot.getShotnumber()]:
self.shots_found[shot.getShotnumber()].append(traceID)
self.refreshFigure()
print self.shots_found
def highlightPick(self, shot, traceID, annotations = True): def highlightPick(self, shot, traceID, annotations = True):
'''
Highlights a single pick for a shot(object)/shotnumber and traceID.
If annotations == True: Displays shotnumber and traceID in the plot.
'''
if type(shot) == int:
shot = self.survey.getShotDict()[shot]
self.ax.scatter(shot.getDistance(traceID), shot.getPick(traceID), s = 50, marker = 'o', facecolors = 'none', edgecolors = 'm', alpha = 1) self.ax.scatter(shot.getDistance(traceID), shot.getPick(traceID), s = 50, marker = 'o', facecolors = 'none', edgecolors = 'm', alpha = 1)
if annotations == True: if annotations == True:
self.ax.annotate(s = 's%s|t%s'%(shot.getShotnumber(), traceID), xy = (shot.getDistance(traceID), shot.getPick(traceID)), fontsize = 'xx-small') self.ax.annotate(s = 's%s|t%s'%(shot.getShotnumber(), traceID), xy = (shot.getDistance(traceID), shot.getPick(traceID)), fontsize = 'xx-small')
self.ax.set_ylim(shot.getCut()) self.ax.set_ylim(shot.getCut())
def plotTracesInRegion(self): def highlightAllRegions(self):
'''
Highlights all picks in all active regions.
'''
for key in self.shots_found.keys():
for shotnumber in self.shots_found[key]['shots'].keys():
for traceID in self.shots_found[key]['shots'][shotnumber]:
self.highlightPick(self.shot_dict[shotnumber], traceID)
self.drawFigure()
def plotTracesInRegions(self, keys = 'all', maxfigures = 20):
'''
Plots all traces in the active region or for all specified keys.
:param: keys
:type: int or list
:param: maxfigures, maximum value of figures opened
:type: int
'''
count = 0 count = 0
maxfigures = 20 if keys == 'all':
# if len(self.shots_found) == 0: keys = self.shots_found.keys()
self.findTracesInShotDict() elif type(keys) == int:
keys = [keys]
if len(self.shots_found) > 0: if len(self.shots_found) > 0:
for shot in self.shot_dict.values(): for shot in self.shot_dict.values():
for shotnumber in self.shots_found: for key in keys:
if shot.getShotnumber() == shotnumber: for shotnumber in self.shots_found[key]['shots']:
for traceID in self.shots_found[shotnumber]: if shot.getShotnumber() == shotnumber:
count += 1 for traceID in self.shots_found[key]['shots'][shotnumber]:
if count > maxfigures: count += 1
print 'Maximum number of figures (%s) reached. %sth figure was not opened.' %(maxfigures, count) if count > maxfigures:
break print 'Maximum number of figures (%s) reached. %sth figure was not opened.' %(maxfigures, count)
shot.plot_traces(traceID) break
shot.plot_traces(traceID)
else: else:
print 'No picks yet defined in the regions x = (%s, %s), y = (%s, %s)' %(self._x0, self._x1, self._y0, self._y1) print('No picks defined in that region(s)')
def plotTracesInRegion_withCutOutTraces(self): def setActiveRegionsForDeletion(self):
count = 0 keys = []
maxfigures = 20 for key in self.shots_found.keys():
# if len(self.shots_found) == 0: keys.append(key)
self.findTracesInShotDict(picks = 'includeCutOut') self.setRegionForDeletion(keys)
if len(self.shots_found) > 0: def setRegionForDeletion(self, keys):
for shot in self.shot_dict.values(): if type(keys) == int:
for shotnumber in self.shots_found: keys = [keys]
if shot.getShotnumber() == shotnumber:
for traceID in self.shots_found[shotnumber]: for key in keys:
count += 1 for shotnumber in self.shots_found[key]['shots'].keys():
if count > maxfigures: if not shotnumber in self.shots_for_deletion:
print 'Maximum number of figures (%s) reached. %sth figure was not opened.' %(maxfigures, count) self.shots_for_deletion[shotnumber] = []
break for traceID in self.shots_found[key]['shots'][shotnumber]:
shot.plot_traces(traceID) if not traceID in self.shots_for_deletion[shotnumber]:
else: self.shots_for_deletion[shotnumber].append(traceID)
print 'No picks yet defined in the regions x = (%s, %s), y = (%s, %s)' %(self._x0, self._x1, self._y0, self._y1) self.deselectSelection(key, color = 'red', alpha = 0.2)
print 'Set region(s) %s for deletion'%keys
def markAllActiveRegions(self):
for key in self.shots_found.keys():
self.markRegion(self.shots_found[key]['distbin'],
self.shots_found[key]['pickbin'], key = key)
def setCurrentRegionsForDeletion(self): def markRegion(self, (x0, x1), (y0, y1), key = None, color = 'grey', alpha = 0.1, linewidth = 0.1):
# if len(self.shots_found) == 0: '''
self.findTracesInShotDict() Mark a rectangular region on the axes.
'''
for shotnumber in self.shots_found:
if not shotnumber in self.shots_for_deletion:
self.shots_for_deletion[shotnumber] = []
for traceID in self.shots_found[shotnumber]:
if not traceID in self.shots_for_deletion[shotnumber]:
self.shots_for_deletion[shotnumber].append(traceID)
self.markAllRegions(color = 'red')
print 'Marked regions for deletion'
def markAllRegions(self, color = 'grey'):
from matplotlib.patches import Rectangle from matplotlib.patches import Rectangle
for index in range(len(self._getx0())): self.ax.add_patch(Rectangle((x0, y0), (x1 - x0), (y1 - y0),
x0 = self._getx0()[index] alpha = alpha, facecolor = color, linewidth = linewidth))
y0 = self._gety0()[index] if key is not None:
x1 = self._getx1()[index] self.ax.text((x0 + (x1 - x0) / 2), (y0 + (y1 - y0) / 2), str(key))
y1 = self._gety1()[index] self.drawFigure()
self.ax.add_patch(Rectangle((x0, y0), (x1 - x0), (y1 - y0), alpha=0.5, facecolor = color)) def refreshFigure(self):
self.refreshFigure() print('Refreshing figure...')
self.ax.clear()
self.ax = self.survey.plotAllPicks(ax = self.ax)
self.markAllActiveRegions()
self.drawFigure()
print('Done!')
def markCurrentRegion(self, x0, x1, y0, y1, color = 'grey'): def clearShotsForDeletion(self):
from matplotlib.patches import Rectangle '''
Clears the list of shots marked for deletion.
'''
self.shots_for_deletion = {}
print('Cleared all shots that were set for deletion.')
self.ax.add_patch(Rectangle((x0, y0), (x1 - x0), (y1 - y0), alpha=0.1, facecolor = color)) def getShotsForDeletion(self):
self.refreshFigure() return self.shots_for_deletion
def deleteMarkedPicks(self): def deleteMarkedPicks(self):
'''
Deletes all shots set for deletion.
'''
if len(self.getShotsForDeletion()) is 0:
print('No shots set for deletion.')
return
for shot in self.getShotDict().values(): for shot in self.getShotDict().values():
for shotnumber in self.getShotsForDeletion(): for shotnumber in self.getShotsForDeletion():
if shot.getShotnumber() == shotnumber: if shot.getShotnumber() == shotnumber:
for traceID in self.getShotsForDeletion()[shotnumber]: for traceID in self.getShotsForDeletion()[shotnumber]:
shot.removePick(traceID) shot.removePick(traceID)
print "Deleted the pick for traceID %s on shot number %s" %(traceID, shotnumber) print "Deleted the pick for traceID %s on shot number %s" %(traceID, shotnumber)
self.shots_for_deletion = {} # clear dictionary self.clearShotsForDeletion()
self.refreshFigure()
def highlightPicksForShot(self, shot, annotations = False): def highlightPicksForShot(self, shot, annotations = False):
'''
Highlight all picks for a given shot.
'''
if type(shot) is int:
shot = self.survey.getShotDict()[shotnumber]
for traceID in shot.getTraceIDlist(): for traceID in shot.getTraceIDlist():
if shot.getFlag(traceID) is not 0: if shot.getFlag(traceID) is not 0:
self.highlightPick(shot, traceID, annotations) self.highlightPick(shot, traceID, annotations)
self.refreshFigure() self.drawFigure()
def refreshFigure(self): def drawFigure(self):
plt.draw() plt.draw()