salinity_ferry_track
Module¶Render figure objects produced by the nowcast.figures.comparison.salinity_ferry_track
module.
Provides data for visual testing to confirm that refactoring has not adversely changed figure for web page.
Set-up and function call replicates as nearly as possible what is done in the nowcast.workers.make_plots
worker.
Notebooks like this should be developed in a
Nowcast Figures Development Environment
so that all of the necessary dependency packages are installed.
The development has to be done on a workstation that has the Salish Sea Nowcast system /results/
parition mounted.
import io
from pathlib import Path
import arrow
import yaml
from salishsea_tools import nc_tools
from nowcast.figures.comparison import salinity_ferry_track
%matplotlib inline
This figure module needs to access the ONC web services API.
Doing so requires a user token which you can generate on the Web Services API tab of your
ONC account profile page.
The _prep_plot_data()
function assumes that the token will be stored in an environment variable
named ONC_USER_TOKEN
.
You can do that using a cell like the following,
but be careful not to commit the notebook with your token in the cell
or you will publish it to the world in this notebook.
import os
os.environ['ONC_USER_TOKEN'] = 'my-token'
# Relevant part of config from nowcast.yaml file
config = '''
bathymetry: /results/nowcast-sys/NEMO-forcing/grid/bathy_meter_SalishSea2.nc
coastline: /ocean/rich/more/mmapbase/bcgeo/PNW.mat
observations:
ferry data': /ocean/jieliu/research/meopar/ONC_ferries/
run:
results_archive:
nowcast: /results/SalishSea/nowcast/
'''
config = yaml.load(io.StringIO(config))
run_date = arrow.get('2016-03-23')
run_type = 'nowcast'
dmy = run_date.format('DDMMMYY').lower()
results_home = Path(config['run']['results_archive'][run_type])
results_dir = results_home/dmy
grid_T_hr = nc_tools.dataset_from_path(
results_dir/'SalishSea_1h_{0}_{0}_grid_T.nc'.format(run_date.format('YYYYMMDD')))
%%timeit -n1 -r1
# Reference rendering of figure
fig = salinity_ferry_track.salinity_ferry_track(grid_T_hr)
1 loop, best of 1: 207 ms per loop
%%timeit -n1 -r1
# Refactored rendering of figure
from importlib import reload
from nowcast.figures import website_theme
reload(salinity_ferry_track)
reload(website_theme)
fig = salinity_ferry_track.make_figure(
grid_T_hr,
theme=website_theme)
733 ms ± 0 ns per loop (mean ± std. dev. of 1 run, 1 loop each)