<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
<style type="text/css" style="display:none"><!--P{margin-top:0;margin-bottom:0;} --></style>
</head>
<body dir="ltr" style="font-size:12pt;color:#000000;background-color:#FFFFFF;font-family:Calibri,Arial,Helvetica,sans-serif;">
<p>Hi Dennis,</p>
<p>I'm doing this interpolation&nbsp;because my veocity output (U and V datasets) will be&nbsp;use in another code which aspect&nbsp;both U and V on a T-Grid.</p>
<p>Interpolating U and V separatly on a T-grid I think is good.</p>
<p>I tried to do&nbsp;this with the&nbsp;following&nbsp;ncl script but I wonder if there is a way to optimized this script (is a bit time consuming)<br>
</p>
<p><br>
</p>
<p>In order to define&nbsp;the&nbsp;field&nbsp;near the coast I extrapolate the&nbsp;field using the ncl function &quot;poisson_grid_fill&quot;&nbsp;with arguments:<br>
</p>
<p>guess_type=1,nscan=2000,epsx=0.001,relc=0.6. Are these values reasonable) </p>
<p>It is possible to extrapolate with this function not in all the Land-points but just near the cost? (this can help to save time)</p>
<p><br>
</p>
<p>thanks</p>
<p>Francesco<br>
</p>
<p><br>
</p>
<p>&nbsp; &nbsp;;;;;====================================================<br>
</p>
<p>&nbsp; &nbsp;;;;;=== ZONAL VELOCITY U-GRID FILEs</p>
<p><br>
</p>
<p>&nbsp; &nbsp;out_T&nbsp;&nbsp;&nbsp; = addfile(path_exp_outdata_ocean&#43;&quot;/&quot;&#43;file_T,&quot;r&quot;)<br>
&nbsp;&nbsp; out_Mesh = addfile(path_exp_outdata_oceanMesh&#43;&quot;/&quot;&#43;file_Mesh,&quot;r&quot;)<br>
&nbsp;&nbsp;&nbsp; &nbsp;<br>
&nbsp;&nbsp; nlon&nbsp; = dimsizes(out_T-&gt;nav_lon(0,:)-1)<br>
&nbsp;&nbsp; nlat&nbsp; = dimsizes(out_T-&gt;nav_lon(:,0)-1)<br>
&nbsp;&nbsp; nlev&nbsp; = dimsizes(out_T-&gt;deptht(:)-1)<br>
&nbsp;&nbsp; ntime = dimsizes(out_T-&gt;time_counter(:)-1)<br>
<br>
&nbsp;&nbsp; lat2dt = out_T-&gt;nav_lat(:,:)<br>
&nbsp;&nbsp; lon2dt = out_T-&gt;nav_lon(:,:)<br>
&nbsp;&nbsp; deptht = out_T-&gt;deptht(:)<br>
&nbsp;&nbsp; time&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; = out_T-&gt;time_counter(0:ntime-1)<br>
&nbsp;&nbsp; time_bnds = out_T-&gt;time_counter_bnds(0:ntime-1,:)<br>
<br>
&nbsp;&nbsp; var_name = &quot;vozocrtx&quot;<br>
&nbsp;&nbsp; out_U&nbsp; = addfile(path_exp_outdata_ocean&#43;&quot;/&quot;&#43;file_U_Ugrid,&quot;r&quot;)<br>
&nbsp;&nbsp; lon1du = (/ out_U-&gt;nav_lon(0,:) /)<br>
&nbsp;&nbsp; u_T&nbsp;&nbsp;&nbsp; = new((/nlev,nlat,nlon/),typeof(out_U-&gt;$var_name$))<br>
&nbsp;&nbsp; ;Define dimensions, coord., attributes<br>
&nbsp;&nbsp; u_T!0 = &quot;deptht&quot;<br>
&nbsp;&nbsp; u_T!1 = &quot;y&quot;<br>
&nbsp;&nbsp; u_T!2 = &quot;x&quot;<br>
&nbsp;&nbsp; u_T&amp;deptht = (/deptht(0:nlev-1)/)<br>
&nbsp;&nbsp; u_T&amp;y&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; = (/lat2dt(0:nlat-1,0)/)<br>
&nbsp;&nbsp; u_T&amp;x&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; = (/lon2dt(0,0:nlon-1)/)<br>
&nbsp;&nbsp; copy_VarAtts(out_U-&gt;$var_name$,u_T)<br>
<br>
&nbsp;&nbsp; mask3dt = (/ out_Mesh-&gt;tmask(0,:,:,:) /)<br>
&nbsp;&nbsp; mask3du = (/ out_Mesh-&gt;umask(0,:,:,:) /)<br>
<br>
&nbsp;&nbsp; do itime=0,ntime-1<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; u_U = out_U-&gt;$var_name$(itime,:,:,:)<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; ;printVarSummary(u_U)<br>
<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; ;--- Assign Missing Values at Land Points (grid-U)<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; u_U(0:nlev-1,0:nlat-1,0:nlon-1) = \<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; where(mask3du(0:nlev-1,0:nlat-1,0:nlon-1).eq.0., \<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; u_U@_FillValue, \<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; u_U(0:nlev-1,0:nlat-1,0:nlon-1))<br>
<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; ;--- Interpolates linearly along the longitude dimension<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; u_T(0:nlev-1,0:nlat-1,0:nlon-1) = \<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; linint1_n(lon1du(0:nlon-1), \<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; u_U(0:nlev-1,0:nlat-1,0:nlon-1),False, \<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; lon2dt(0,0:nlon-1),0,2)<br>
<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; ;--- Assign an extrapol Value to Missing Values points<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; ;Replaces all Missing(_FillValue) values with values derived from solving Poisson's equation via relaxation.<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; poisson_grid_fill(u_T(0:nlev-1,0:nlat-1,0:nlat-1), False, 1, 2000, 0.001, 0.6, 0)<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; ;printVarSummary(u_T)<br>
<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; ;--- Assign Missing Values at Land Points (grid-T)<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; u_T(0:nlev-1,0:nlat-1,0:nlon-1) = \<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; where(mask3dt(0:nlev-1,0:nlat-1,0:nlon-1).eq.0., \<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; u_T@_FillValue, \<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; u_T(0:nlev-1,0:nlat-1,0:nlon-1))<br>
<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; write_regridVel(path_exp_outdata_ocean,file_U_Tgrid,itime,ntime,nlev,nlat,nlon, \<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; lon2dt(0:nlat-1,0:nlon-1),lat2dt(0:nlat-1,0:nlon-1),deptht(0:nlev-1), \<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; time(0:ntime-1),time_bnds(0:ntime-1,0:1), \<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; u_T(0:nlev-1,0:nlat-1,0:nlon-1),var_name)<br>
<br>
&nbsp;&nbsp; end do<br>
</p>
<p><br>
</p>
<div style="color: rgb(33, 33, 33);">
<hr tabindex="-1" style="display:inline-block; width:98%">
<div id="divRplyFwdMsg" dir="ltr"><font style="font-size:11pt" face="Calibri, sans-serif" color="#000000"><b>Da:</b> Dennis Shea &lt;shea@ucar.edu&gt;<br>
<b>Inviato:</b> venerd́ 30 giugno 2017 16:11<br>
<b>A:</b> Francesco Trotta<br>
<b>Cc:</b> ncl-talk@ucar.edu<br>
<b>Oggetto:</b> Re: [ncl-talk] from staggered grid field to interpolated unique grid field</font>
<div>&nbsp;</div>
</div>
<div>
<div dir="ltr">
<div>
<div>
<div>
<div>The Arakawa C-grid has the U, V and scalar (?T?) variables on separate grids.
<br>
<br>
</div>
To *my* knowledge, the ESMF regrid package does not interpolate vector wind components. Wind components should be interpolated together on the sphere. The wind speed is conserved but the magnitudes of the wind components will vary. For u and v on the same grid<br>
<br>
&nbsp; uNew = u*cos(rot) - v*sin(rot)&nbsp;&nbsp;&nbsp; ; rot - <span class="gmail-il">rotation</span> angle<br>
&nbsp; vNew = u*sin(rot) &#43; v*cos(rot)<br>
<br>
</div>
Actually, on the Arakawa C-grid, since u and v are on separate grids the appropriate rotation angles would be different also.<br>
<br>
---<br>
</div>
What is the objective of the interpolation? <br>
<br>
If it is 'just' graphics, then, maybe, interpolating the the V-grid and&nbsp; U-grid separately to the T-grid would be acceptable.
<br>
<br>
</div>
---<br>
<div>
<div>
<div><br>
<br>
</div>
</div>
</div>
</div>
<div class="gmail_extra"><br>
<div class="gmail_quote">On Thu, Jun 29, 2017 at 3:31 AM, Francesco Trotta <span dir="ltr">
&lt;<a href="mailto:francesco.trotta4@unibo.it" target="_blank">francesco.trotta4@unibo.it</a>&gt;</span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex; border-left:1px #ccc solid; padding-left:1ex">
<div dir="ltr" style="font-size:12pt; color:#000000; background-color:#ffffff; font-family:Calibri,Arial,Helvetica,sans-serif">
<div>Dear ncl team,</div>
<div>&nbsp; I using ncl and I&#8217;m producing 2 netcdf files of meridional e zonal velocity definite on the stagarate grid (C_arakawa U e V grids) and I need to pass this datasets to a collage on a unique T grid.</div>
<div><br>
</div>
<div>&nbsp; &nbsp;Is there in ncl some build-in-function which from 2 netcdf file with u e v defined in a staggered U e V grid produce a file with u and v field interpolate on T grid?</div>
<div><br>
</div>
<div>thanks</div>
<span class="HOEnZb"><font color="#888888">
<div>Francesco&#8203;<br>
</div>
<p><br>
</p>
</font></span></div>
<br>
______________________________<wbr>_________________<br>
ncl-talk mailing list<br>
<a href="mailto:ncl-talk@ucar.edu">ncl-talk@ucar.edu</a><br>
List instructions, subscriber options, unsubscribe:<br>
<a href="http://mailman.ucar.edu/mailman/listinfo/ncl-talk" rel="noreferrer" target="_blank">http://mailman.ucar.edu/<wbr>mailman/listinfo/ncl-talk</a><br>
<br>
</blockquote>
</div>
<br>
</div>
</div>
</div>
</body>
</html>