import netCDF4 as nc
import numpy as np
from matplotlib import pyplot as plt
import cmocean as cm
import datetime as dt
import glob
from salishsea_tools import viz_tools, visualisations
%matplotlib inline
Look at the difference in biological fields between Feb 6 2015 and the same date in other years to try to get an idea of why resetting to 2015 biological fields on that date in 2017 worked so well.
f2015=nc.Dataset('/results2/SalishSea/hindcast/06feb15/SalishSea_1h_20150206_20150206_ptrc_T.nc')
f2016=nc.Dataset('/results2/SalishSea/hindcast/06feb16/SalishSea_1h_20160206_20160206_ptrc_T.nc')
f2017=nc.Dataset('/results2/SalishSea/hindcast/06feb17/SalishSea_1h_20170206_20170206_ptrc_T.nc')
f2015.variables.keys()
odict_keys(['nav_lat', 'nav_lon', 'bounds_lon', 'bounds_lat', 'area', 'deptht', 'deptht_bounds', 'nitrate', 'time_centered', 'time_centered_bounds', 'time_counter', 'time_counter_bounds', 'ammonium', 'silicon', 'diatoms', 'flagellates', 'ciliates', 'microzooplankton', 'dissolved_organic_nitrogen', 'particulate_organic_nitrogen', 'biogenic_silicon', 'Fraser_tracer', 'mesozooplankton'])
cmap = plt.get_cmap(cm.cm.balance) #('nipy_spectral')
cmap.set_bad('burlywood')
with nc.Dataset('/ocean/eolson/MEOPAR/NEMO-forcing/grid/mesh_mask201702_noLPE.nc') as fm:
tmask=np.copy(fm.variables['tmask'])
for var in ('nitrate', 'ammonium', 'silicon', 'diatoms', 'flagellates', 'ciliates', 'microzooplankton', 'dissolved_organic_nitrogen', 'particulate_organic_nitrogen', 'biogenic_silicon', 'mesozooplankton'):
fig,ax = plt.subplots(1,5,figsize=(24,8))
for ii in range(0,5):
viz_tools.set_aspect(ax[ii])
lev=0
iax=ax[0]
diff=f2017.variables[var][0,lev,200:800,50:]-f2015.variables[var][0,lev,200:800,50:]
cl=np.mean(f2017.variables[var][0,lev,200:800,50:])+np.std(f2017.variables[var][0,lev,200:800,50:])
mesh=iax.pcolormesh(np.ma.masked_where(tmask[0,lev,200:800,50:]==0,diff),vmin=-cl,vmax=cl,cmap=cmap)
iax.set_title(var+' 2017-2015 \nz='+str(f2015.variables['deptht'][lev])+' m', fontsize=14)
cbar = fig.colorbar(mesh,ax=iax)
cbar.ax.tick_params(labelsize=14)
iax.get_xaxis().set_visible(False)
iax.get_yaxis().set_visible(False)
iax.get_yaxis().set_visible(False)
iax.set_xlim((50,348))
lev=9
iax=ax[1]
diff=f2017.variables[var][0,lev,200:800,50:]-f2015.variables[var][0,lev,200:800,50:]
cl=np.mean(f2017.variables[var][0,lev,200:800,50:])+np.std(f2017.variables[var][0,lev,200:800,50:])
mesh=iax.pcolormesh(np.ma.masked_where(tmask[0,lev,200:800,50:]==0,diff),vmin=-cl,vmax=cl,cmap=cmap)
iax.set_title(var+' 2017-2015 \nz='+str(f2015.variables['deptht'][lev])+' m', fontsize=14)
cbar = fig.colorbar(mesh,ax=iax)
cbar.ax.tick_params(labelsize=14)
iax.get_xaxis().set_visible(False)
iax.get_yaxis().set_visible(False)
iax.get_yaxis().set_visible(False)
iax.set_xlim((50,348))
lev=20
iax=ax[2]
diff=f2017.variables[var][0,lev,200:800,50:]-f2015.variables[var][0,lev,200:800,50:]
cl=np.mean(f2017.variables[var][0,lev,200:800,50:])+np.std(f2017.variables[var][0,lev,200:800,50:])
mesh=iax.pcolormesh(np.ma.masked_where(tmask[0,lev,200:800,50:]==0,diff),vmin=-cl,vmax=cl,cmap=cmap)
iax.set_title(var+' 2017-2015 \nz='+str(f2015.variables['deptht'][lev])+' m', fontsize=14)
cbar = fig.colorbar(mesh,ax=iax)
cbar.ax.tick_params(labelsize=14)
iax.get_xaxis().set_visible(False)
iax.get_yaxis().set_visible(False)
iax.get_yaxis().set_visible(False)
iax.set_xlim((50,348))
lev=25
iax=ax[3]
diff=f2017.variables[var][0,lev,200:800,50:]-f2015.variables[var][0,lev,200:800,50:]
cl=np.mean(f2017.variables[var][0,lev,200:800,50:])+np.std(f2017.variables[var][0,lev,200:800,50:])
mesh=iax.pcolormesh(np.ma.masked_where(tmask[0,lev,200:800,50:]==0,diff),vmin=-cl,vmax=cl,cmap=cmap)
iax.set_title(var+' 2017-2015 \nz='+str(f2015.variables['deptht'][lev])+' m', fontsize=14)
cbar = fig.colorbar(mesh,ax=iax)
cbar.ax.tick_params(labelsize=14)
iax.get_xaxis().set_visible(False)
iax.get_yaxis().set_visible(False)
iax.get_yaxis().set_visible(False)
iax.set_xlim((50,348))
lev=30
iax=ax[4]
diff=f2017.variables[var][0,lev,200:800,50:]-f2015.variables[var][0,lev,200:800,50:]
cl=np.mean(f2017.variables[var][0,lev,200:800,50:])+np.std(f2017.variables[var][0,lev,200:800,50:])
#cl=np.max(np.abs(diff))
mesh=iax.pcolormesh(np.ma.masked_where(tmask[0,lev,200:800,50:]==0,diff),vmin=-cl,vmax=cl,cmap=cmap)
iax.set_title(var+' 2017-2015 \nz='+str(f2015.variables['deptht'][lev])+' m', fontsize=14)
cbar = fig.colorbar(mesh,ax=iax)
cbar.ax.tick_params(labelsize=14)
iax.get_xaxis().set_visible(False)
iax.get_yaxis().set_visible(False)
iax.get_yaxis().set_visible(False)
iax.set_xlim((50,348))
for var in ('nitrate', 'ammonium', 'silicon', 'diatoms', 'flagellates', 'ciliates', 'microzooplankton', 'dissolved_organic_nitrogen', 'particulate_organic_nitrogen', 'biogenic_silicon', 'mesozooplankton'):
fig,ax = plt.subplots(1,5,figsize=(24,8))
for ii in range(0,5):
viz_tools.set_aspect(ax[ii])
lev=0
iax=ax[0]
diff=f2016.variables[var][0,lev,200:800,50:]-f2015.variables[var][0,lev,200:800,50:]
cl=np.mean(f2016.variables[var][0,lev,200:800,50:])+np.std(f2016.variables[var][0,lev,200:800,50:])
mesh=iax.pcolormesh(np.ma.masked_where(tmask[0,lev,200:800,50:]==0,diff),vmin=-cl,vmax=cl,cmap=cmap)
iax.set_title(var+' 2016-2015 \nz='+str(f2015.variables['deptht'][lev])+' m', fontsize=14)
cbar = fig.colorbar(mesh,ax=iax)
cbar.ax.tick_params(labelsize=14)
iax.get_xaxis().set_visible(False)
iax.get_yaxis().set_visible(False)
iax.get_yaxis().set_visible(False)
iax.set_xlim((50,348))
lev=9
iax=ax[1]
diff=f2016.variables[var][0,lev,200:800,50:]-f2016.variables[var][0,lev,200:800,50:]
cl=np.mean(f2016.variables[var][0,lev,200:800,50:])+np.std(f2016.variables[var][0,lev,200:800,50:])
mesh=iax.pcolormesh(np.ma.masked_where(tmask[0,lev,200:800,50:]==0,diff),vmin=-cl,vmax=cl,cmap=cmap)
iax.set_title(var+' 2016-2015 \nz='+str(f2015.variables['deptht'][lev])+' m', fontsize=14)
cbar = fig.colorbar(mesh,ax=iax)
cbar.ax.tick_params(labelsize=14)
iax.get_xaxis().set_visible(False)
iax.get_yaxis().set_visible(False)
iax.get_yaxis().set_visible(False)
iax.set_xlim((50,348))
lev=20
iax=ax[2]
diff=f2016.variables[var][0,lev,200:800,50:]-f2015.variables[var][0,lev,200:800,50:]
cl=np.mean(f2016.variables[var][0,lev,200:800,50:])+np.std(f2016.variables[var][0,lev,200:800,50:])
mesh=iax.pcolormesh(np.ma.masked_where(tmask[0,lev,200:800,50:]==0,diff),vmin=-cl,vmax=cl,cmap=cmap)
iax.set_title(var+' 2016-2015 \nz='+str(f2015.variables['deptht'][lev])+' m', fontsize=14)
cbar = fig.colorbar(mesh,ax=iax)
cbar.ax.tick_params(labelsize=14)
iax.get_xaxis().set_visible(False)
iax.get_yaxis().set_visible(False)
iax.get_yaxis().set_visible(False)
iax.set_xlim((50,348))
lev=25
iax=ax[3]
diff=f2016.variables[var][0,lev,200:800,50:]-f2015.variables[var][0,lev,200:800,50:]
cl=np.mean(f2016.variables[var][0,lev,200:800,50:])+np.std(f2016.variables[var][0,lev,200:800,50:])
mesh=iax.pcolormesh(np.ma.masked_where(tmask[0,lev,200:800,50:]==0,diff),vmin=-cl,vmax=cl,cmap=cmap)
iax.set_title(var+' 2016-2015 \nz='+str(f2015.variables['deptht'][lev])+' m', fontsize=14)
cbar = fig.colorbar(mesh,ax=iax)
cbar.ax.tick_params(labelsize=14)
iax.get_xaxis().set_visible(False)
iax.get_yaxis().set_visible(False)
iax.get_yaxis().set_visible(False)
iax.set_xlim((50,348))
lev=30
iax=ax[4]
diff=f2016.variables[var][0,lev,200:800,50:]-f2015.variables[var][0,lev,200:800,50:]
cl=np.mean(f2016.variables[var][0,lev,200:800,50:])+np.std(f2016.variables[var][0,lev,200:800,50:])
#cl=np.max(np.abs(diff))
mesh=iax.pcolormesh(np.ma.masked_where(tmask[0,lev,200:800,50:]==0,diff),vmin=-cl,vmax=cl,cmap=cmap)
iax.set_title(var+' 2016-2015 \nz='+str(f2015.variables['deptht'][lev])+' m', fontsize=14)
cbar = fig.colorbar(mesh,ax=iax)
cbar.ax.tick_params(labelsize=14)
iax.get_xaxis().set_visible(False)
iax.get_yaxis().set_visible(False)
iax.get_yaxis().set_visible(False)
iax.set_xlim((50,348))
for var in ('nitrate', 'ammonium', 'silicon', 'diatoms', 'flagellates', 'ciliates', 'microzooplankton', 'dissolved_organic_nitrogen', 'particulate_organic_nitrogen', 'biogenic_silicon', 'mesozooplankton'):
fig,ax = plt.subplots(1,5,figsize=(24,8))
for ii in range(0,5):
viz_tools.set_aspect(ax[ii])
lev=0
iax=ax[0]
diff=f2017.variables[var][0,lev,200:800,50:]-f2016.variables[var][0,lev,200:800,50:]
cl=np.mean(f2017.variables[var][0,lev,200:800,50:])+np.std(f2017.variables[var][0,lev,200:800,50:])
mesh=iax.pcolormesh(np.ma.masked_where(tmask[0,lev,200:800,50:]==0,diff),vmin=-cl,vmax=cl,cmap=cmap)
iax.set_title(var+' 2017-2016 \nz='+str(f2016.variables['deptht'][lev])+' m', fontsize=14)
cbar = fig.colorbar(mesh,ax=iax)
cbar.ax.tick_params(labelsize=14)
iax.get_xaxis().set_visible(False)
iax.get_yaxis().set_visible(False)
iax.get_yaxis().set_visible(False)
iax.set_xlim((50,348))
lev=9
iax=ax[1]
diff=f2017.variables[var][0,lev,200:800,50:]-f2016.variables[var][0,lev,200:800,50:]
cl=np.mean(f2017.variables[var][0,lev,200:800,50:])+np.std(f2017.variables[var][0,lev,200:800,50:])
mesh=iax.pcolormesh(np.ma.masked_where(tmask[0,lev,200:800,50:]==0,diff),vmin=-cl,vmax=cl,cmap=cmap)
iax.set_title(var+' 2017-2016 \nz='+str(f2016.variables['deptht'][lev])+' m', fontsize=14)
cbar = fig.colorbar(mesh,ax=iax)
cbar.ax.tick_params(labelsize=14)
iax.get_xaxis().set_visible(False)
iax.get_yaxis().set_visible(False)
iax.get_yaxis().set_visible(False)
iax.set_xlim((50,348))
lev=20
iax=ax[2]
diff=f2017.variables[var][0,lev,200:800,50:]-f2016.variables[var][0,lev,200:800,50:]
cl=np.mean(f2017.variables[var][0,lev,200:800,50:])+np.std(f2017.variables[var][0,lev,200:800,50:])
mesh=iax.pcolormesh(np.ma.masked_where(tmask[0,lev,200:800,50:]==0,diff),vmin=-cl,vmax=cl,cmap=cmap)
iax.set_title(var+' 2017-2016 \nz='+str(f2016.variables['deptht'][lev])+' m', fontsize=14)
cbar = fig.colorbar(mesh,ax=iax)
cbar.ax.tick_params(labelsize=14)
iax.get_xaxis().set_visible(False)
iax.get_yaxis().set_visible(False)
iax.get_yaxis().set_visible(False)
iax.set_xlim((50,348))
lev=25
iax=ax[3]
diff=f2017.variables[var][0,lev,200:800,50:]-f2016.variables[var][0,lev,200:800,50:]
cl=np.mean(f2017.variables[var][0,lev,200:800,50:])+np.std(f2017.variables[var][0,lev,200:800,50:])
mesh=iax.pcolormesh(np.ma.masked_where(tmask[0,lev,200:800,50:]==0,diff),vmin=-cl,vmax=cl,cmap=cmap)
iax.set_title(var+' 2017-2016 \nz='+str(f2016.variables['deptht'][lev])+' m', fontsize=14)
cbar = fig.colorbar(mesh,ax=iax)
cbar.ax.tick_params(labelsize=14)
iax.get_xaxis().set_visible(False)
iax.get_yaxis().set_visible(False)
iax.get_yaxis().set_visible(False)
iax.set_xlim((50,348))
lev=30
iax=ax[4]
diff=f2017.variables[var][0,lev,200:800,50:]-f2016.variables[var][0,lev,200:800,50:]
cl=np.mean(f2017.variables[var][0,lev,200:800,50:])+np.std(f2017.variables[var][0,lev,200:800,50:])
#cl=np.max(np.abs(diff))
mesh=iax.pcolormesh(np.ma.masked_where(tmask[0,lev,200:800,50:]==0,diff),vmin=-cl,vmax=cl,cmap=cmap)
iax.set_title(var+' 2017-2016 \nz='+str(f2016.variables['deptht'][lev])+' m', fontsize=14)
cbar = fig.colorbar(mesh,ax=iax)
cbar.ax.tick_params(labelsize=14)
iax.get_xaxis().set_visible(False)
iax.get_yaxis().set_visible(False)
iax.get_yaxis().set_visible(False)
iax.set_xlim((50,348))
for var in ('diatoms', 'flagellates', 'ciliates'):
fig,ax=plt.subplots(1,3,figsize=(10,5))
lev=0
iax=ax[0]
mesh=iax.pcolormesh(np.ma.masked_where(tmask[0,lev,200:800,50:]==0,f2015.variables[var][0,lev,200:800,50:]),vmin=0,vmax=.1,cmap=cm.cm.thermal)
iax.set_title(var+' 2015 \nz='+str(f2015.variables['deptht'][lev])+' m', fontsize=14)
cbar = fig.colorbar(mesh,ax=iax)
cbar.ax.tick_params(labelsize=14)
iax.get_xaxis().set_visible(False)
iax.get_yaxis().set_visible(False)
iax.get_yaxis().set_visible(False)
iax.set_xlim((50,348))
iax=ax[1]
mesh=iax.pcolormesh(np.ma.masked_where(tmask[0,lev,200:800,50:]==0,f2016.variables[var][0,lev,200:800,50:]),vmin=0,vmax=.1,cmap=cm.cm.thermal)
iax.set_title(var+' 2016 \nz='+str(f2016.variables['deptht'][lev])+' m', fontsize=14)
cbar = fig.colorbar(mesh,ax=iax)
cbar.ax.tick_params(labelsize=14)
iax.get_xaxis().set_visible(False)
iax.get_yaxis().set_visible(False)
iax.get_yaxis().set_visible(False)
iax.set_xlim((50,348))
iax=ax[2]
mesh=iax.pcolormesh(np.ma.masked_where(tmask[0,lev,200:800,50:]==0,f2017.variables[var][0,lev,200:800,50:]),vmin=0,vmax=.1,cmap=cm.cm.thermal)
iax.set_title(var+' 2017 \nz='+str(f2017.variables['deptht'][lev])+' m', fontsize=14)
cbar = fig.colorbar(mesh,ax=iax)
cbar.ax.tick_params(labelsize=14)
iax.get_xaxis().set_visible(False)
iax.get_yaxis().set_visible(False)
iax.get_yaxis().set_visible(False)
iax.set_xlim((50,348))
print('2015 mean '+var+':',np.mean(np.ma.masked_where(tmask[0,lev,200:800,50:]==0,f2015.variables[var][0,lev,200:800,50:])))
print('2016 mean '+var+':',np.mean(np.ma.masked_where(tmask[0,lev,200:800,50:]==0,f2016.variables[var][0,lev,200:800,50:])))
print('2017 mean '+var+':',np.mean(np.ma.masked_where(tmask[0,lev,200:800,50:]==0,f2017.variables[var][0,lev,200:800,50:])))
2015 mean diatoms: 0.2994138538389916 2016 mean diatoms: 0.0052069774292256635 2017 mean diatoms: 0.0042569331713563615 2015 mean flagellates: 0.5958488399375316 2016 mean flagellates: 0.5322612523926462 2017 mean flagellates: 0.5961680333189898 2015 mean ciliates: 0.14880374354078257 2016 mean ciliates: 0.17392012421821676 2017 mean ciliates: 0.21673917443503873
fb=nc.Dataset('/data/eolson/MEOPAR/NEMO-forcing-new/grid/bathymetry_201702.nc')
fm=nc.Dataset('/ocean/eolson/MEOPAR/NEMO-forcing/grid/mesh_mask201702_noLPE.nc')
for var in ('nitrate', 'ammonium', 'silicon', 'diatoms', 'flagellates', 'ciliates', 'microzooplankton', 'dissolved_organic_nitrogen', 'particulate_organic_nitrogen', 'biogenic_silicon', 'mesozooplankton'):
fig,ax = plt.subplots(1,1,figsize=(18,6))
diff=f2017.variables[var][0,:,:,:]-f2015.variables[var][0,:,:,:]
cl=np.mean(np.abs(diff))+np.std(np.abs(diff))
m=visualisations.contour_thalweg(ax,diff,fb,fm,method='pcolormesh',cmap=cm.cm.balance,mesh_args={'vmin':-cl,'vmax':cl})
ax.set_title(var+ '2017-2015')