Compare commits
	
		
			No commits in common. "e02b62696d2753b2b917e4e61e32d61bc27e829c" and "3da47c6f6bc47c1ccbf262d2ca65c0fe82e84989" have entirely different histories.
		
	
	
		
			e02b62696d
			...
			3da47c6f6b
		
	
		
| @ -262,10 +262,6 @@ class AutopickStation(object): | ||||
|         self.metadata = metadata | ||||
|         self.origin = origin | ||||
| 
 | ||||
|         # initialize TauPy pick estimates | ||||
|         self.estFirstP = None | ||||
|         self.estFirstS = None | ||||
| 
 | ||||
|         # initialize picking results | ||||
|         self.p_results = PickingResults() | ||||
|         self.s_results = PickingResults() | ||||
| @ -447,15 +443,15 @@ class AutopickStation(object): | ||||
|             for arr in arrivals: | ||||
|                 phases[identifyPhaseID(arr.phase.name)].append(arr) | ||||
|             # get first P and S onsets from arrivals list | ||||
|             arrival_time_p = 0 | ||||
|             arrival_time_s = 0 | ||||
|             estFirstP = 0 | ||||
|             estFirstS = 0 | ||||
|             if len(phases['P']) > 0: | ||||
|                 arrP, arrival_time_p = min([(arr, arr.time) for arr in phases['P']], key=lambda t: t[1]) | ||||
|                 arrP, estFirstP = min([(arr, arr.time) for arr in phases['P']], key=lambda t: t[1]) | ||||
|             if len(phases['S']) > 0: | ||||
|                 arrS, arrival_time_s = min([(arr, arr.time) for arr in phases['S']], key=lambda t: t[1]) | ||||
|                 arrS, estFirstS = min([(arr, arr.time) for arr in phases['S']], key=lambda t: t[1]) | ||||
|             print('autopick: estimated first arrivals for P: {} s, S:{} s after event' | ||||
|                   ' origin time using TauPy'.format(arrival_time_p, arrival_time_s)) | ||||
|             return arrival_time_p, arrival_time_s | ||||
|                   ' origin time using TauPy'.format(estFirstP, estFirstS)) | ||||
|             return estFirstP, estFirstS | ||||
| 
 | ||||
|         def exit_taupy(): | ||||
|             """If taupy failed to calculate theoretical starttimes, picking continues. | ||||
| @ -481,13 +477,10 @@ class AutopickStation(object): | ||||
|             raise AttributeError('No source origins given!') | ||||
| 
 | ||||
|         arrivals = create_arrivals(self.metadata, self.origin, self.pickparams["taup_model"]) | ||||
|         arrival_P, arrival_S = first_PS_onsets(arrivals) | ||||
| 
 | ||||
|         self.estFirstP = (self.origin[0].time + arrival_P) - self.ztrace.stats.starttime | ||||
| 
 | ||||
|         estFirstP, estFirstS = first_PS_onsets(arrivals) | ||||
|         # modifiy pstart and pstop relative to estimated first P arrival (relative to station time axis) | ||||
|         self.pickparams["pstart"] += self.estFirstP | ||||
|         self.pickparams["pstop"] += self.estFirstP | ||||
|         self.pickparams["pstart"] += (self.origin[0].time + estFirstP) - self.ztrace.stats.starttime | ||||
|         self.pickparams["pstop"] += (self.origin[0].time + estFirstP) - self.ztrace.stats.starttime | ||||
|         print('autopick: CF calculation times respectively:' | ||||
|               ' pstart: {} s, pstop: {} s'.format(self.pickparams["pstart"], self.pickparams["pstop"])) | ||||
|         # make sure pstart and pstop are inside the starttime/endtime of vertical trace | ||||
| @ -498,10 +491,9 @@ class AutopickStation(object): | ||||
|             # for the two horizontal components take earliest and latest time to make sure that the s onset is not clipped | ||||
|             # if start and endtime of horizontal traces differ, the s windowsize will automatically increase | ||||
|             trace_s_start = min([self.etrace.stats.starttime, self.ntrace.stats.starttime]) | ||||
|             self.estFirstS = (self.origin[0].time + arrival_S) - trace_s_start | ||||
|             # modifiy sstart and sstop relative to estimated first S arrival (relative to station time axis) | ||||
|             self.pickparams["sstart"] += self.estFirstS | ||||
|             self.pickparams["sstop"] += self.estFirstS | ||||
|             self.pickparams["sstart"] += (self.origin[0].time + estFirstS) - trace_s_start | ||||
|             self.pickparams["sstop"] += (self.origin[0].time + estFirstS) - trace_s_start | ||||
|             print('autopick: CF calculation times respectively:' | ||||
|                   ' sstart: {} s, sstop: {} s'.format(self.pickparams["sstart"], self.pickparams["sstop"])) | ||||
|             # make sure pstart and pstop are inside the starttime/endtime of horizontal traces | ||||
| @ -617,12 +609,6 @@ class AutopickStation(object): | ||||
|             # plot tapered trace filtered with bpz2 filter settings | ||||
|             ax1.plot(tdata, self.tr_filt_z_bpz2.data / max(self.tr_filt_z_bpz2.data), color=linecolor, linewidth=0.7, | ||||
|                      label='Data') | ||||
|             # plot pickwindows for P | ||||
|             pstart, pstop = self.pickparams['pstart'], self.pickparams['pstop'] | ||||
|             if pstart is not None and pstop is not None: | ||||
|                 ax1.axvspan(pstart, pstop, color='r', alpha=0.1, zorder=0, label='P window') | ||||
|             if self.estFirstP is not None: | ||||
|                 ax1.axvline(self.estFirstP, ls='dashed', color='r', alpha=0.4, label='TauPy estimate') | ||||
|             if self.p_results.weight < 4: | ||||
|                 # plot CF of initial onset (HOScf or ARZcf) | ||||
|                 ax1.plot(self.cf1.getTimeArray(), self.cf1.getCF() / max(self.cf1.getCF()), 'b', label='CF1') | ||||
| @ -727,15 +713,6 @@ class AutopickStation(object): | ||||
|                         ax3.plot([refSpick.getpick() - 0.5, refSpick.getpick() + 0.5], [-1.3, -1.3], 'g', linewidth=2) | ||||
|                         ax3.plot([self.s_results.lpp, self.s_results.lpp], [-1.1, 1.1], 'g--', label='lpp') | ||||
|                         ax3.plot([self.s_results.epp, self.s_results.epp], [-1.1, 1.1], 'g--', label='epp') | ||||
| 
 | ||||
|                 # plot pickwindows for S | ||||
|                 sstart, sstop = self.pickparams['sstart'], self.pickparams['sstop'] | ||||
|                 if sstart is not None and sstop is not None: | ||||
|                     for axis in [ax2, ax3]: | ||||
|                         axis.axvspan(sstart, sstop, color='b', alpha=0.1, zorder=0, label='S window') | ||||
|                         if self.estFirstS is not None: | ||||
|                             axis.axvline(self.estFirstS, ls='dashed', color='b', alpha=0.4, label='TauPy estimate') | ||||
| 
 | ||||
|                 ax3.legend(loc=1) | ||||
|                 ax3.set_yticks([]) | ||||
|                 ax3.set_ylim([-1.5, 1.5]) | ||||
| @ -858,21 +835,14 @@ class AutopickStation(object): | ||||
|             self.cf1 = None | ||||
|         assert isinstance(self.cf1, CharacteristicFunction), 'cf1 is not set correctly: maybe the algorithm name ({})' \ | ||||
|                                                              ' is corrupted'.format(self.pickparams["algoP"]) | ||||
|         # get the original waveform stream from first CF class cut to identical length as CF for plotting | ||||
|         cut_ogstream = self.cf1.getDataArray(self.cf1.getCut()) | ||||
| 
 | ||||
|         # MP: Rename to cf_stream for further use of z_copy and to prevent chaos when z_copy suddenly becomes a cf | ||||
|         # stream and later again a waveform stream | ||||
|         cf_stream = z_copy.copy() | ||||
|         cf_stream[0].data = self.cf1.getCF() | ||||
| 
 | ||||
|         # calculate AIC cf from first cf (either HOS or ARZ) | ||||
|         aiccf = AICcf(cf_stream, cuttimes) | ||||
|         z_copy[0].data = self.cf1.getCF() | ||||
|         aiccf = AICcf(z_copy, cuttimes) | ||||
|         # get preliminary onset time from AIC-CF | ||||
|         self.set_current_figure('aicFig') | ||||
|         aicpick = AICPicker(aiccf, self.pickparams["tsnrz"], self.pickparams["pickwinP"], self.iplot, | ||||
|                             Tsmooth=self.pickparams["aictsmooth"], fig=self.current_figure, | ||||
|                             linecolor=self.current_linecolor, ogstream=cut_ogstream) | ||||
|                             linecolor=self.current_linecolor) | ||||
|         # save aicpick for plotting later | ||||
|         self.p_data.aicpick = aicpick | ||||
|         # add pstart and pstop to aic plot | ||||
| @ -885,7 +855,7 @@ class AutopickStation(object): | ||||
|                           label='P stop') | ||||
|                 ax.legend(loc=1) | ||||
| 
 | ||||
|         Pflag = self._pick_p_quality_control(aicpick, cf_stream, tr_filt) | ||||
|         Pflag = self._pick_p_quality_control(aicpick, z_copy, tr_filt) | ||||
|         # go on with processing if AIC onset passes quality control | ||||
|         slope = aicpick.getSlope() | ||||
|         if not slope: slope = 0 | ||||
| @ -924,7 +894,7 @@ class AutopickStation(object): | ||||
|         refPpick = PragPicker(self.cf2, self.pickparams["tsnrz"], self.pickparams["pickwinP"], self.iplot, | ||||
|                               self.pickparams["ausP"], | ||||
|                               self.pickparams["tsmoothP"], aicpick.getpick(), self.current_figure, | ||||
|                               self.current_linecolor, ogstream=cut_ogstream) | ||||
|                               self.current_linecolor) | ||||
|         # save PragPicker result for plotting | ||||
|         self.p_data.refPpick = refPpick | ||||
|         self.p_results.mpp = refPpick.getpick() | ||||
| @ -1176,14 +1146,11 @@ class AutopickStation(object): | ||||
|         # calculate AIC cf | ||||
|         haiccf = self._calculate_aic_cf_s_pick(cuttimesh) | ||||
| 
 | ||||
|         # get the original waveform stream cut to identical length as CF for plotting | ||||
|         ogstream = haiccf.getDataArray(haiccf.getCut()) | ||||
| 
 | ||||
|         # get preliminary onset time from AIC cf | ||||
|         self.set_current_figure('aicARHfig') | ||||
|         aicarhpick = AICPicker(haiccf, self.pickparams["tsnrh"], self.pickparams["pickwinS"], self.iplot, | ||||
|                                Tsmooth=self.pickparams["aictsmoothS"], fig=self.current_figure, | ||||
|                                linecolor=self.current_linecolor, ogstream=ogstream) | ||||
|                                linecolor=self.current_linecolor) | ||||
|         # save pick for later plotting | ||||
|         self.aicarhpick = aicarhpick | ||||
| 
 | ||||
|  | ||||
| @ -37,8 +37,7 @@ class AutoPicker(object): | ||||
| 
 | ||||
|     warnings.simplefilter('ignore') | ||||
| 
 | ||||
|     def __init__(self, cf, TSNR, PickWindow, iplot=0, aus=None, Tsmooth=None, Pick1=None, | ||||
|                  fig=None, linecolor='k', ogstream=None): | ||||
|     def __init__(self, cf, TSNR, PickWindow, iplot=0, aus=None, Tsmooth=None, Pick1=None, fig=None, linecolor='k'): | ||||
|         """ | ||||
|         Create AutoPicker object | ||||
|         :param cf: characteristic function, on which the picking algorithm is applied | ||||
| @ -60,15 +59,12 @@ class AutoPicker(object): | ||||
|         :type fig: `~matplotlib.figure.Figure` | ||||
|         :param linecolor: matplotlib line color string | ||||
|         :type linecolor: str | ||||
|         :param ogstream: original stream (waveform), e.g. for plotting purposes | ||||
|         :type ogstream: `~obspy.core.stream.Stream` | ||||
|         """ | ||||
| 
 | ||||
|         assert isinstance(cf, CharacteristicFunction), "%s is not a CharacteristicFunction object" % str(cf) | ||||
|         self._linecolor = linecolor | ||||
|         self._pickcolor_p = 'b' | ||||
|         self.cf = cf.getCF() | ||||
|         self.ogstream = ogstream | ||||
|         self.Tcf = cf.getTimeArray() | ||||
|         self.Data = cf.getXCF() | ||||
|         self.dt = cf.getIncrement() | ||||
| @ -351,12 +347,6 @@ class AICPicker(AutoPicker): | ||||
|                 self.Tcf = self.Tcf[0:len(self.Tcf) - 1] | ||||
|             ax1.plot(self.Tcf, cf / max(cf), color=self._linecolor, linewidth=0.7, label='(HOS-/AR-) Data') | ||||
|             ax1.plot(self.Tcf, aicsmooth / max(aicsmooth), 'r', label='Smoothed AIC-CF') | ||||
|             # plot the original waveform also for evaluation of the CF and pick | ||||
|             if self.ogstream: | ||||
|                 data = self.ogstream[0].data | ||||
|                 if len(data) == len(self.Tcf): | ||||
|                     ax1.plot(self.Tcf, 0.5 * data / max(data), 'k', label='Seismogram', alpha=0.3, zorder=0, | ||||
|                              lw=0.5) | ||||
|             if self.Pick is not None: | ||||
|                 ax1.plot([self.Pick, self.Pick], [-0.1, 0.5], 'b', linewidth=2, label='AIC-Pick') | ||||
|             ax1.set_xlabel('Time [s] since %s' % self.Data[0].stats.starttime) | ||||
|  | ||||
| @ -15,7 +15,7 @@ import numpy as np | ||||
| from obspy.core import Stream, UTCDateTime | ||||
| from scipy.signal import argrelmax | ||||
| 
 | ||||
| from pylot.core.util.utils import get_bool, get_none, SetChannelComponents, common_range | ||||
| from pylot.core.util.utils import get_bool, get_none, SetChannelComponents | ||||
| 
 | ||||
| 
 | ||||
| def earllatepicker(X, nfac, TSNR, Pick1, iplot=0, verbosity=1, fig=None, linecolor='k'): | ||||
| @ -828,22 +828,14 @@ def checksignallength(X, pick, minsiglength, pickparams, iplot=0, fig=None, line | ||||
|     if len(X) > 1: | ||||
|         # all three components available | ||||
|         # make sure, all components have equal lengths | ||||
|         earliest_starttime = min(tr.stats.starttime for tr in X) | ||||
|         cuttimes = common_range(X) | ||||
|         X = X.slice(cuttimes[0], cuttimes[1]) | ||||
|         x1, x2, x3 = X[:3] | ||||
| 
 | ||||
|         if not (len(x1) == len(x2) == len(x3)): | ||||
|             raise PickingFailedException('checksignallength: unequal lengths of components!') | ||||
| 
 | ||||
|         ilen = min([len(X[0].data), len(X[1].data), len(X[2].data)]) | ||||
|         x1 = X[0][0:ilen] | ||||
|         x2 = X[1][0:ilen] | ||||
|         x3 = X[2][0:ilen] | ||||
|         # get RMS trace | ||||
|         rms = np.sqrt((np.power(x1, 2) + np.power(x2, 2) + np.power(x3, 2)) / 3) | ||||
|         ilen = len(rms) | ||||
|         dt = earliest_starttime - X[0].stats.starttime | ||||
|         pick -= dt | ||||
|     else: | ||||
|         x1 = X[0].data | ||||
|         x2 = x3 = None | ||||
|         ilen = len(x1) | ||||
|         rms = abs(x1) | ||||
| 
 | ||||
| @ -882,10 +874,6 @@ def checksignallength(X, pick, minsiglength, pickparams, iplot=0, fig=None, line | ||||
|         fig._tight = True | ||||
|         ax = fig.add_subplot(111) | ||||
|         ax.plot(t, rms, color=linecolor, linewidth=0.7, label='RMS Data') | ||||
|         ax.plot(t, x1, 'k', alpha=0.3, lw=0.3, zorder=0) | ||||
|         if x2 is not None and x3 is not None: | ||||
|             ax.plot(t, x2, 'r', alpha=0.3, lw=0.3, zorder=0) | ||||
|             ax.plot(t, x3, 'g', alpha=0.3, lw=0.3, zorder=0) | ||||
|         ax.axvspan(t[inoise[0]], t[inoise[-1]], color='y', alpha=0.2, lw=0, label='Noise Window') | ||||
|         ax.axvspan(t[isignal[0]], t[isignal[-1]], color='b', alpha=0.2, lw=0, label='Signal Window') | ||||
|         ax.plot([t[isignal[0]], t[isignal[len(isignal) - 1]]], | ||||
| @ -895,7 +883,6 @@ def checksignallength(X, pick, minsiglength, pickparams, iplot=0, fig=None, line | ||||
|         ax.set_xlabel('Time [s] since %s' % X[0].stats.starttime) | ||||
|         ax.set_ylabel('Counts') | ||||
|         ax.set_title('Check for Signal Length, Station %s' % X[0].stats.station) | ||||
|         ax.set_xlim(pickparams["pstart"], pickparams["pstop"]) | ||||
|         ax.set_yticks([]) | ||||
|         if plt_flag == 1: | ||||
|             fig.show() | ||||
|  | ||||
| @ -1076,7 +1076,7 @@ def check4rotated(data, metadata=None, verbosity=1): | ||||
|             return wfs_in | ||||
| 
 | ||||
|         # check metadata quality | ||||
|         t_start = full_range(wfs_in)[0] | ||||
|         t_start = full_range(wfs_in) | ||||
|         try: | ||||
|             azimuths = [] | ||||
|             dips = [] | ||||
|  | ||||
| @ -121,8 +121,8 @@ class TestAutopickStation(unittest.TestCase): | ||||
|         with HidePrints(): | ||||
|             result, station = autopickstation(wfstream=self.gra1, pickparam=self.pickparam_taupy_disabled, | ||||
|                                               metadata=(None, None)) | ||||
|         compare_dicts(expected=expected['P'], result=result['P'], hint='P-') | ||||
|         compare_dicts(expected=expected['S'], result=result['S'], hint='S-') | ||||
|         compare_dicts(expected=expected['P'], result=result['P']) | ||||
|         compare_dicts(expected=expected['S'], result=result['S']) | ||||
|         self.assertEqual('GRA1', station) | ||||
| 
 | ||||
|     def test_autopickstation_taupy_enabled_gra1(self): | ||||
| @ -140,8 +140,8 @@ class TestAutopickStation(unittest.TestCase): | ||||
|         with HidePrints(): | ||||
|             result, station = autopickstation(wfstream=self.gra1, pickparam=self.pickparam_taupy_enabled, | ||||
|                                               metadata=self.metadata, origin=self.origin) | ||||
|         compare_dicts(expected=expected['P'], result=result['P'], hint='P-') | ||||
|         compare_dicts(expected=expected['S'], result=result['S'], hint='S-') | ||||
|         compare_dicts(expected=expected['P'], result=result['P']) | ||||
|         compare_dicts(expected=expected['S'], result=result['S']) | ||||
|         self.assertEqual('GRA1', station) | ||||
| 
 | ||||
|     def test_autopickstation_taupy_disabled_gra2(self): | ||||
| @ -157,8 +157,8 @@ class TestAutopickStation(unittest.TestCase): | ||||
|         with HidePrints(): | ||||
|             result, station = autopickstation(wfstream=self.gra2, pickparam=self.pickparam_taupy_disabled, | ||||
|                                               metadata=(None, None)) | ||||
|         compare_dicts(expected=expected['P'], result=result['P'], hint='P-') | ||||
|         compare_dicts(expected=expected['S'], result=result['S'], hint='S-') | ||||
|         compare_dicts(expected=expected['P'], result=result['P']) | ||||
|         compare_dicts(expected=expected['S'], result=result['S']) | ||||
|         self.assertEqual('GRA2', station) | ||||
| 
 | ||||
|     def test_autopickstation_taupy_enabled_gra2(self): | ||||
| @ -175,8 +175,8 @@ class TestAutopickStation(unittest.TestCase): | ||||
|         with HidePrints(): | ||||
|             result, station = autopickstation(wfstream=self.gra2, pickparam=self.pickparam_taupy_enabled, | ||||
|                                               metadata=self.metadata, origin=self.origin) | ||||
|         compare_dicts(expected=expected['P'], result=result['P'], hint='P-') | ||||
|         compare_dicts(expected=expected['S'], result=result['S'], hint='S-') | ||||
|         compare_dicts(expected=expected['P'], result=result['P']) | ||||
|         compare_dicts(expected=expected['S'], result=result['S']) | ||||
|         self.assertEqual('GRA2', station) | ||||
| 
 | ||||
|     def test_autopickstation_taupy_disabled_ech(self): | ||||
| @ -190,8 +190,8 @@ class TestAutopickStation(unittest.TestCase): | ||||
|                           'fm': None, 'spe': None, 'channel': u'LHE'}} | ||||
|         with HidePrints(): | ||||
|             result, station = autopickstation(wfstream=self.ech, pickparam=self.pickparam_taupy_disabled) | ||||
|         compare_dicts(expected=expected['P'], result=result['P'], hint='P-') | ||||
|         compare_dicts(expected=expected['S'], result=result['S'], hint='S-') | ||||
|         compare_dicts(expected=expected['P'], result=result['P']) | ||||
|         compare_dicts(expected=expected['S'], result=result['S']) | ||||
|         self.assertEqual('ECH', station) | ||||
| 
 | ||||
|     def test_autopickstation_taupy_enabled_ech(self): | ||||
| @ -208,8 +208,8 @@ class TestAutopickStation(unittest.TestCase): | ||||
|         with HidePrints(): | ||||
|             result, station = autopickstation(wfstream=self.ech, pickparam=self.pickparam_taupy_enabled, | ||||
|                                               metadata=self.metadata, origin=self.origin) | ||||
|         compare_dicts(expected=expected['P'], result=result['P'], hint='P-') | ||||
|         compare_dicts(expected=expected['S'], result=result['S'], hint='S-') | ||||
|         compare_dicts(expected=expected['P'], result=result['P']) | ||||
|         compare_dicts(expected=expected['S'], result=result['S']) | ||||
|         self.assertEqual('ECH', station) | ||||
| 
 | ||||
|     def test_autopickstation_taupy_disabled_fiesa(self): | ||||
| @ -224,8 +224,8 @@ class TestAutopickStation(unittest.TestCase): | ||||
|                           'fm': None, 'spe': None, 'channel': u'LHE'}} | ||||
|         with HidePrints(): | ||||
|             result, station = autopickstation(wfstream=self.fiesa, pickparam=self.pickparam_taupy_disabled) | ||||
|         compare_dicts(expected=expected['P'], result=result['P'], hint='P-') | ||||
|         compare_dicts(expected=expected['S'], result=result['S'], hint='S-') | ||||
|         compare_dicts(expected=expected['P'], result=result['P']) | ||||
|         compare_dicts(expected=expected['S'], result=result['S']) | ||||
|         self.assertEqual('FIESA', station) | ||||
| 
 | ||||
|     def test_autopickstation_taupy_enabled_fiesa(self): | ||||
| @ -242,8 +242,8 @@ class TestAutopickStation(unittest.TestCase): | ||||
|         with HidePrints(): | ||||
|             result, station = autopickstation(wfstream=self.fiesa, pickparam=self.pickparam_taupy_enabled, | ||||
|                                               metadata=self.metadata, origin=self.origin) | ||||
|         compare_dicts(expected=expected['P'], result=result['P'], hint='P-') | ||||
|         compare_dicts(expected=expected['S'], result=result['S'], hint='S-') | ||||
|         compare_dicts(expected=expected['P'], result=result['P']) | ||||
|         compare_dicts(expected=expected['S'], result=result['S']) | ||||
|         self.assertEqual('FIESA', station) | ||||
| 
 | ||||
|     def test_autopickstation_gra1_z_comp_missing(self): | ||||
| @ -272,8 +272,8 @@ class TestAutopickStation(unittest.TestCase): | ||||
|         with HidePrints(): | ||||
|             result, station = autopickstation(wfstream=wfstream, pickparam=self.pickparam_taupy_disabled, | ||||
|                                               metadata=(None, None)) | ||||
|         compare_dicts(expected=expected['P'], result=result['P'], hint='P-') | ||||
|         compare_dicts(expected=expected['S'], result=result['S'], hint='S-') | ||||
|         compare_dicts(result=result['P'], expected=expected['P']) | ||||
|         compare_dicts(result=result['S'], expected=expected['S']) | ||||
|         self.assertEqual('GRA1', station) | ||||
| 
 | ||||
|     def test_autopickstation_a106_taupy_enabled(self): | ||||
| @ -291,8 +291,8 @@ class TestAutopickStation(unittest.TestCase): | ||||
|         with HidePrints(): | ||||
|             result, station = autopickstation(wfstream=self.a106, pickparam=self.pickparam_taupy_enabled, | ||||
|                                               metadata=self.metadata, origin=self.origin) | ||||
|         compare_dicts(expected=expected['P'], result=result['P'], hint='P-') | ||||
|         compare_dicts(expected=expected['S'], result=result['S'], hint='S-') | ||||
|         compare_dicts(result=result['P'], expected=expected['P']) | ||||
|         compare_dicts(result=result['S'], expected=expected['S']) | ||||
| 
 | ||||
| 
 | ||||
|     def test_autopickstation_station_missing_in_metadata(self): | ||||
| @ -314,8 +314,8 @@ class TestAutopickStation(unittest.TestCase): | ||||
|         with HidePrints(): | ||||
|             result, station = autopickstation(wfstream=self.a005a, pickparam=self.pickparam_taupy_enabled, | ||||
|                                               metadata=self.metadata, origin=self.origin) | ||||
|         compare_dicts(expected=expected['P'], result=result['P'], hint='P-') | ||||
|         compare_dicts(expected=expected['S'], result=result['S'], hint='S-') | ||||
|         compare_dicts(result=result['P'], expected=expected['P']) | ||||
|         compare_dicts(result=result['S'], expected=expected['S']) | ||||
| 
 | ||||
| 
 | ||||
| def run_dict_comparison(result, expected): | ||||
| @ -330,11 +330,11 @@ def run_dict_comparison(result, expected): | ||||
|             assert expected_value == pytest.approx(res), f'{key}: {expected_value} != {res}' | ||||
| 
 | ||||
| 
 | ||||
| def compare_dicts(result, expected, hint=''): | ||||
| def compare_dicts(result, expected): | ||||
|     try: | ||||
|         run_dict_comparison(result, expected) | ||||
|     except AssertionError: | ||||
|         raise AssertionError(f'{hint}Dictionaries not equal.' | ||||
|         raise AssertionError(f'Dictionaries not equal.' | ||||
|                              f'\n\n<<Expected>>\n{pretty_print_dict(expected)}' | ||||
|                              f'\n\n<<Result>>\n{pretty_print_dict(result)}') | ||||
| 
 | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user