From 640794d46eea063b95bba98d78271f90cd2e8220 Mon Sep 17 00:00:00 2001 From: Darren Boss Date: Fri, 26 Jan 2024 09:15:18 -0800 Subject: [PATCH 1/2] Process one station --- api/app/jobs/common_model_fetchers.py | 3 ++- api/app/weather_models/process_grib.py | 3 ++- 2 files changed, 4 insertions(+), 2 deletions(-) diff --git a/api/app/jobs/common_model_fetchers.py b/api/app/jobs/common_model_fetchers.py index c7bbdddb3..133840a6a 100644 --- a/api/app/jobs/common_model_fetchers.py +++ b/api/app/jobs/common_model_fetchers.py @@ -187,7 +187,8 @@ class ModelValueProcessor: def __init__(self, session, station_source: StationSourceEnum = StationSourceEnum.UNSPECIFIED): """ Prepare variables we're going to use throughout """ self.session = session - self.stations = get_stations_synchronously(station_source) + all_stations = get_stations_synchronously(station_source) + self.stations = list(station for station in all_stations if station.code == 208) self.station_count = len(self.stations) def _process_model_run(self, model_run: PredictionModelRunTimestamp, model_type: ModelEnum): diff --git a/api/app/weather_models/process_grib.py b/api/app/weather_models/process_grib.py index a6ed3a343..8ad0e5a78 100644 --- a/api/app/weather_models/process_grib.py +++ b/api/app/weather_models/process_grib.py @@ -149,7 +149,8 @@ def __init__(self, raster_to_geo_transformer=None, geo_to_raster_transformer=None): # Get list of stations we're interested in, and store it so that we only call it once. - self.stations = get_stations_synchronously(station_source) + all_stations = get_stations_synchronously(station_source) + self.stations = list(station for station in all_stations if station.code == 208) self.padf_transform = padf_transform self.raster_to_geo_transformer = raster_to_geo_transformer self.geo_to_raster_transformer = geo_to_raster_transformer From 81b34f911a395b3877c0f17c307b23abbaec1870 Mon Sep 17 00:00:00 2001 From: Darren Boss Date: Fri, 26 Jan 2024 09:39:13 -0800 Subject: [PATCH 2/2] Limit model processing --- api/app/jobs/env_canada.py | 19 ++++++++++--------- 1 file changed, 10 insertions(+), 9 deletions(-) diff --git a/api/app/jobs/env_canada.py b/api/app/jobs/env_canada.py index 954bdacb4..1500c2fe3 100644 --- a/api/app/jobs/env_canada.py +++ b/api/app/jobs/env_canada.py @@ -143,12 +143,13 @@ def get_file_date_part(now, model_run_hour, is_hrdps: bool = False) -> str: def get_model_run_hours(model_type: ModelEnum): """ Yield model run hours for GDPS (00h00 and 12h00) """ - if model_type == ModelEnum.GDPS: - for hour in [0, 12]: - yield hour - elif model_type in (ModelEnum.HRDPS, ModelEnum.RDPS): - for hour in [0, 6, 12, 18]: - yield hour + yield 0 + # if model_type == ModelEnum.GDPS: + # for hour in [0]: + # yield hour + # elif model_type in (ModelEnum.HRDPS, ModelEnum.RDPS): + # for hour in [0]: + # yield hour def get_model_run_urls(now: datetime.datetime, model_type: ModelEnum, model_run_hour: int): @@ -170,7 +171,7 @@ def get_global_model_run_download_urls(now: datetime.datetime, # hhh: prediction hour [000, 003, 006, ..., 240] hh = f"{model_run_hour:02d}" # For the global model, we have prediction at 3 hour intervals up to 240 hours. - for h in range(0, 241, 3): + for h in range(0, 13, 3): hhh = format(h, '03d') for level in GRIB_LAYERS: # Accumulated precipitation does not exist for 000 hour, so the url for this doesn't exist @@ -187,7 +188,7 @@ def get_high_res_model_run_download_urls(now: datetime.datetime, hour: int) -> G """ Yield urls to download HRDPS (high-res) model runs """ hh = f"{hour:02d}" # For the high-res model, predictions are at 1 hour intervals up to 48 hours. - for h in range(0, 49): + for h in range(0, 3): hhh = format(h, '03d') for level in HRDPS_GRIB_LAYERS: # Accumulated precipitation does not exist for 000 hour, so the url for this doesn't exist @@ -204,7 +205,7 @@ def get_regional_model_run_download_urls(now: datetime.datetime, hour: int) -> G """ Yield urls to download RDPS model runs """ hh = f"{hour:02d}" # For the RDPS model, predictions are at 1 hour intervals up to 84 hours. - for h in range(0, 85): + for h in range(0, 3): hhh = format(h, '03d') for level in GRIB_LAYERS: # Accumulated precipitation does not exist for 000 hour, so the url for this doesn't exist