# This function extrapolates horizontally a (x,y) field using the
# nearest neighbour method.
#
# Usage : python extrap2d.py
# <2d longitude name in grid file>
# <2d latitude name in grid file>
#
#
# History : Virginie Guemas - Initial version - 2012
# Virginie Guemas - Masking the outputs - March 2014
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
import cdms2 as cdms
import sys,string
from cdms2 import MV
import numpy as N
from numpy import ma
#
# 1. Input arguments
# ===================
#
# Input file and var names :
# ---------------------------
fileIN=sys.argv[1]
varIN=sys.argv[2]
#
# Meshmask file :
# ----------------
fileM=sys.argv[3]
varlon=sys.argv[4]
varlat=sys.argv[5]
#
# Location of points to fill :
# ----------------------------
fileF=sys.argv[6]
varF=sys.argv[7]
#
# Output file name :
# -------------------
fileOUT=sys.argv[8]
#
# 2. Get the input files
# =======================
#
f=cdms.open(fileIN)
var0_a=f(varIN,squeeze=1)
f.close()
(ly0,lx0)=var0_a.shape
mask3d=var0_a.mask
if mask3d.size==1 :
if var0_a.id in ('gsu','gru','gtu','ssu_m'):
varmask='umask'
elif var0_a.id in ('gsv','grv','gtv','ssv_m'):
varmask='vmask'
else:
varmask='tmask'
if (ly0,lx0) == (1021,1442) :
f=cdms.open('/home/vguemas/SCRIP/interpvert/mesh_mask_glorys2v1_lev0.nc')
mask3d=1-f(varmask,squeeze=1)
f.close()
#
f=cdms.open(fileM)
lon=f(varlon,squeeze=1)
lat=f(varlat,squeeze=1)
f.close()
#
f=cdms.open(fileF)
Pfill=f(varF,squeeze=1)
f.close()
#
var4=N.zeros((ly0,lx0))
var4=var4.astype('d')
var4=N.where(mask3d==False,var0_a,var4)
pi=N.pi
coslat=N.cos(lat*pi/180)
coslon=N.cos(lon*pi/180)
sinlat=N.sin(lat*pi/180)
sinlon=N.sin(lon*pi/180)
indexes1=N.where(Pfill[:,:]>=1)
for ind in N.arange(indexes1[0].shape[0]) :
jy=indexes1[0][ind]
jx=indexes1[1][ind]
distance=MV.arccos(coslat[jy,jx]*coslat*(coslon[jy,jx]*coslon+sinlon[jy,jx]*sinlon)+sinlat[jy,jx]*sinlat)
distance=N.where(mask3d[:,:]==False,distance,1e20)
dismin=distance.min()
test=cdms.createVariable(var0_a[:,:],mask=MV.where(distance==dismin,False,True))
var4[jy,jx]=test.mean()
maskout=MV.where(Pfill>0.5,False,mask3d)
var4=cdms.createVariable(var4,id=var0_a.id)
var4=MV.where(maskout<0.5,var4,1e20)
var4.getAxis(0).id='y'
var4.getAxis(1).id='x'
var4.id=var0_a.id
h=cdms.open(fileOUT,'w')
h.write(var4)
h.close()