Hazard Winds#

from datetime import datetime

print("execution start: {0}".format(datetime.today().strftime('%Y-%m-%d %H:%M:%S')))
execution start: 2022-09-13 07:40:03
import os
import os.path as op
import sys
import glob

import pandas as pd
import numpy as np
import xarray as xr

# raster tools
from rasterio.crs import CRS
import json
import rioxarray

# kepler 
from keplergl import KeplerGl

# bluemath 
sys.path.insert(0, op.join(op.abspath(''), '..', '..'))
sys.path.insert(0, op.join(op.abspath(''), '..'))

# operational utils
from operational.util import read_config_args
Warning: ecCodes 2.21.0 or higher is recommended. You are running version 2.16.0

Forecast Parameters#

# project database
p_data = r'/media/administrador/HD2/SamoaTonga/data'
p_db = r'/media/administrador/HD1/DATABASES'

#site = 'Savaii'  # Savaii / Upolu / Tongatapu

# (optional) get site from config file
nb_args = read_config_args(op.abspath(''), '09b_hazard')
site = nb_args['site']

print('Study site: {0}'.format(site))
Study site: Upolu
# Hazard winds
process_raster = False
# site related parameteres
if site == 'Savaii':

    # site
    site_ = site.lower()
    nm = 'sp'
    
    # riskscape
    site_main = 'Samoa'
    code_utm = 32702
    
elif site == 'Upolu':

    # site
    site_ = site.lower()
    nm = 'up'
    
    # riskscape  
    site_main = 'Samoa'
    code_utm = 32702

elif site == 'Tongatapu':

    # site
    site_ = site
    nm = 'tp'
        
    # riskscape
    site_main = 'Tongatapu'
    code_utm = 32701

Database#

p_site = op.join(p_data, site)

# riskscape folder
p_riskscape = op.join(p_data, 'riskscape_projects')
p_riskscape_site = op.join(p_riskscape, site)
p_riskscape_data = op.join(p_riskscape, site, 'data')
p_riskscape_data_rain = op.join(p_riskscape_data, 'rain')

# kepler config files
p_kepler_config = op.join(p_riskscape_site, 'config_files', 'config_hazard_rain_{0}.json'.format(site.lower()))

Forecast Output Folder#

p_forecast = op.join(p_site, 'forecast', '09_rainfall_tc_inundation')

# last valid execution of 10a
dates_exec = sorted([x for x in os.listdir(p_forecast) if len(glob.glob(op.join(p_forecast, x, 'Forecast_*.nc'))) > 0])
dates_exec = [x for x in dates_exec if 'reforecast' not in x]

if len(dates_exec) == 0:
    raise ValueError('No solved TCs available from 09a')

# choose last date
date = dates_exec[-1]

print('last available date: {0}'.format(date))
last available date: 202209010245
# available TC names
fs = glob.glob(op.join(p_forecast, date, 'Forecast_*.nc'))
names = list(set([op.basename(x).split('_')[1] for x in fs]))

print('available TCs: {0}'.format(names))
available TCs: ['amos']
# select tc name
tc_name = names[0]

# forecast folder
p_fore_date = op.join(p_forecast, date)
print('forecast date code: {0}'.format(date))

p_fore_tc = op.join(p_fore_date, tc_name + '_forecast')
p_out_tracks = op.join(p_fore_tc, 'OUT_TRACKS')
forecast date code: 202209010245
tk = 'max' #Track number or max

if tk == 'max':
    file_name = op.join(p_out_tracks, 'Flooding_Metamodel_Analogues_envelope.nc')
    ds_rain = xr.open_dataset(file_name).to_dataframe().set_index(['x','y']).to_xarray()
else:
    file_name = op.join(p_out_tracks, 'Flooding_Metamodel_Analogues_{0}_{1}_raster.nc'.format(tc_name, tk))
    ds_rain = xr.open_dataset(file_name)

tif_riskscape = op.join(p_riskscape, site, 'data', 'rainfall', 'Flooding_Metamodel_' + tc_name + '_tk_' + tk + '_' + date + '_.tif') #Always save in the same folder
print('Saving tif at: ' + tif_riskscape)
---------------------------------------------------------------------------
KeyError                                  Traceback (most recent call last)
/media/administrador/HD2/git_nico/SamoaTonga/venv/lib/python3.7/site-packages/xarray/backends/file_manager.py in _acquire_with_cache_info(self, needs_lock)
    198             try:
--> 199                 file = self._cache[self._key]
    200             except KeyError:

/media/administrador/HD2/git_nico/SamoaTonga/venv/lib/python3.7/site-packages/xarray/backends/lru_cache.py in __getitem__(self, key)
     52         with self._lock:
---> 53             value = self._cache[key]
     54             self._cache.move_to_end(key)

KeyError: [<class 'netCDF4._netCDF4.Dataset'>, ('/media/administrador/HD2/SamoaTonga/data/Upolu/forecast/09_rainfall_tc_inundation/202209010245/amos_forecast/OUT_TRACKS/Flooding_Metamodel_Analogues_envelope.nc',), 'r', (('clobber', True), ('diskless', False), ('format', 'NETCDF4'), ('persist', False))]

During handling of the above exception, another exception occurred:

FileNotFoundError                         Traceback (most recent call last)
/tmp/ipykernel_30387/3794932057.py in <module>
      3 if tk == 'max':
      4     file_name = op.join(p_out_tracks, 'Flooding_Metamodel_Analogues_envelope.nc')
----> 5     ds_rain = xr.open_dataset(file_name).to_dataframe().set_index(['x','y']).to_xarray()
      6 else:
      7     file_name = op.join(p_out_tracks, 'Flooding_Metamodel_Analogues_{0}_{1}_raster.nc'.format(tc_name, tk))

/media/administrador/HD2/git_nico/SamoaTonga/venv/lib/python3.7/site-packages/xarray/backends/api.py in open_dataset(filename_or_obj, group, decode_cf, mask_and_scale, decode_times, concat_characters, decode_coords, engine, chunks, lock, cache, drop_variables, backend_kwargs, use_cftime, decode_timedelta)
    552 
    553         opener = _get_backend_cls(engine)
--> 554         store = opener(filename_or_obj, **extra_kwargs, **backend_kwargs)
    555 
    556     with close_on_error(store):

/media/administrador/HD2/git_nico/SamoaTonga/venv/lib/python3.7/site-packages/xarray/backends/netCDF4_.py in open(cls, filename, mode, format, group, clobber, diskless, persist, lock, lock_maker, autoclose)
    376             netCDF4.Dataset, filename, mode=mode, kwargs=kwargs
    377         )
--> 378         return cls(manager, group=group, mode=mode, lock=lock, autoclose=autoclose)
    379 
    380     def _acquire(self, needs_lock=True):

/media/administrador/HD2/git_nico/SamoaTonga/venv/lib/python3.7/site-packages/xarray/backends/netCDF4_.py in __init__(self, manager, group, mode, lock, autoclose)
    324         self._group = group
    325         self._mode = mode
--> 326         self.format = self.ds.data_model
    327         self._filename = self.ds.filepath()
    328         self.is_remote = is_remote_uri(self._filename)

/media/administrador/HD2/git_nico/SamoaTonga/venv/lib/python3.7/site-packages/xarray/backends/netCDF4_.py in ds(self)
    385     @property
    386     def ds(self):
--> 387         return self._acquire()
    388 
    389     def open_store_variable(self, name, var):

/media/administrador/HD2/git_nico/SamoaTonga/venv/lib/python3.7/site-packages/xarray/backends/netCDF4_.py in _acquire(self, needs_lock)
    379 
    380     def _acquire(self, needs_lock=True):
--> 381         with self._manager.acquire_context(needs_lock) as root:
    382             ds = _nc4_require_group(root, self._group, self._mode)
    383         return ds

/usr/lib/python3.7/contextlib.py in __enter__(self)
    110         del self.args, self.kwds, self.func
    111         try:
--> 112             return next(self.gen)
    113         except StopIteration:
    114             raise RuntimeError("generator didn't yield") from None

/media/administrador/HD2/git_nico/SamoaTonga/venv/lib/python3.7/site-packages/xarray/backends/file_manager.py in acquire_context(self, needs_lock)
    185     def acquire_context(self, needs_lock=True):
    186         """Context manager for acquiring a file."""
--> 187         file, cached = self._acquire_with_cache_info(needs_lock)
    188         try:
    189             yield file

/media/administrador/HD2/git_nico/SamoaTonga/venv/lib/python3.7/site-packages/xarray/backends/file_manager.py in _acquire_with_cache_info(self, needs_lock)
    203                     kwargs = kwargs.copy()
    204                     kwargs["mode"] = self._mode
--> 205                 file = self._opener(*self._args, **kwargs)
    206                 if self._mode == "w":
    207                     # ensure file doesn't get overriden when opened again

src/netCDF4/_netCDF4.pyx in netCDF4._netCDF4.Dataset.__init__()

src/netCDF4/_netCDF4.pyx in netCDF4._netCDF4._ensure_nc_success()

FileNotFoundError: [Errno 2] No such file or directory: b'/media/administrador/HD2/SamoaTonga/data/Upolu/forecast/09_rainfall_tc_inundation/202209010245/amos_forecast/OUT_TRACKS/Flooding_Metamodel_Analogues_envelope.nc'
raster = ds_rain.rio.write_crs('EPSG:{0}'.format(code_utm)).transpose('y', 'x')
raster = raster.where(raster < 5)
raster.rio.to_raster(tif_riskscape)

Hazard Winds#

# project to lon, lat (WGS84) to plot in Kepler
data_sim_84 = raster.rio.reproject(CRS.from_epsg(4326)).copy()
data_sim_84 = data_sim_84.where((data_sim_84>=0.2) & (data_sim_84<=100))

df_sim_84 = data_sim_84.to_dataframe().reset_index().dropna()\
    .rename(columns={'x':'Lon', 'y':'Lat'})
df_sim_84

Plot Hazard - SWATH winds#

a_file = open(p_kepler_config, "rb")
config_rain = json.load(a_file)

# Hazard - flooding depth
map_1 = KeplerGl(height=700, data={"Depth Metamodel": df_sim_84}, config=config_rain, show_docs=False)
map_1

with open(p_kepler_config, “w”) as outfile: json.dump(map_1.config, outfile)

print("execution end: {0}".format(datetime.today().strftime('%Y-%m-%d %H:%M:%S')))