From 3795a9bbd24313c7ec502ce1fb9c01a2e407e700 Mon Sep 17 00:00:00 2001 From: spencer <swilbur@usgs.gov> Date: Mon, 3 Mar 2025 15:35:03 -0700 Subject: [PATCH] Addressed Josh's Comments --- geomagio/edge/FDSNFactory.py | 44 ++++++++++-------------------------- 1 file changed, 12 insertions(+), 32 deletions(-) diff --git a/geomagio/edge/FDSNFactory.py b/geomagio/edge/FDSNFactory.py index a15f25af..4445d98c 100644 --- a/geomagio/edge/FDSNFactory.py +++ b/geomagio/edge/FDSNFactory.py @@ -69,15 +69,14 @@ class FDSNFactory(TimeseriesFactory): Notes ----- - This is designed to read from the FDSN Client and EDGE if data is less than 1 day old, but it - currently only writes to an edge. + This is designed to read from the FDSN Client and EDGE if data is less than 1 day old """ def __init__( self, - base_url: str = "http://service.iris.edu", - host: Optional[str] = None, - port: Optional[int] = None, + fdsn_url: str = "http://service.iris.edu", + host: Optional[str] = "edgecwb.usgs.gov", + port: Optional[int] = 2061, tag: str = "GeomagAlg", observatory: Optional[str] = None, network: str = "NT", @@ -92,7 +91,7 @@ class FDSNFactory(TimeseriesFactory): ] = None, # Accepts "remove_sensitivity" or "remove_response" ): TimeseriesFactory.__init__(self, observatory, channels, type, interval) - self.Client = FDSNClient(base_url) + self.Client = FDSNClient(fdsn_url) self.port = port # Need to add this paramter for later logic self.host = host self.remove_sensitivity = remove_sensitivity @@ -254,11 +253,11 @@ class FDSNFactory(TimeseriesFactory): ) # Determine whether to use FDSN Client or request data from EDGE - if endtime >= (UTCDateTime.now() - 86400): - print("The endtime is less than a day later!", endtime) + oldest_neic_utc = UTCDateTime.now() - ( + 86_400 * 60 + ) # `date` ensures a midnight boundary + if starttime >= oldest_neic_utc: - self.host = "137.227.252.145" - self.port = 2061 # use NEIC Client instead neic_client = neic.Client(self.host, self.port) @@ -275,8 +274,6 @@ class FDSNFactory(TimeseriesFactory): endtime=endtime + half_delta, ) - data.attach_response(inv) - else: data = self.Client.get_waveforms( @@ -286,9 +283,11 @@ class FDSNFactory(TimeseriesFactory): channel=sncl.channel, starttime=starttime, endtime=endtime + half_delta, - attach_response=True, ) + # Attach the channel response. This must be done before the _calibarate_sensitivity_and_response function is called + data.attach_response(inv) + # Perfrom calibrations to properly remove response/sensitivity data = self._calibrate_sensitivty_and_response(data) @@ -415,23 +414,6 @@ class FDSNFactory(TimeseriesFactory): Channels are mapped as follows: 'X' -> '*F2', 'Y' -> '*F1', 'Z' -> '*FZ'. """ - # Initialize FDSN client and get the necessary data - # FDSN = self.Client - # Determine if the requested channel is X, Y, or - - # inv = FDSN.get_stations( - # network=sncl.network, - # station=sncl.station, - # location=sncl.location, # Use location if necessary - # channel=sncl.channel, # Request *F1, *F2, and *FZ - # starttime=starttime, - # endtime=endtime, - # level="response", - # ) - print( - "The SNCL Channel being requested for teh inventory object in rotations: ", - sncl.channel, - ) # Rotate the stream to ZNE data.rotate(method="->ZNE", inventory=inv) @@ -486,6 +468,4 @@ class FDSNFactory(TimeseriesFactory): # Geomag Program observatories use 2nd order instrument_polynomial # to capture both offset and scale, but no frequency response data.remove_response() - else: - print("NO RESPONSE ATTIBUTE WAS DEALT WITH") return data -- GitLab