<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<style type="text/css" style="display:none;"><!-- P {margin-top:0;margin-bottom:0;} --></style>
</head>
<body dir="ltr">
<div id="divtagdefaultwrapper" style="font-size:12pt;color:#000000;font-family:Calibri,Helvetica,sans-serif;" dir="ltr">
<p>Hi Mary </p>
<p><br>
</p>
<p>Many thanks for the detailed email. I have worked with the code and produced the masked images for the variables which I need to use in my other code . </p>
<p><br>
</p>
<p>However I need to know how to use the variables in other code. </p>
<p><br>
</p>
<p>I have tried to understand the following lines but I am still struggling with it .Will it be possible for you to explain the following lines and how to output these variables to be used in another code. I would be grateful for your help </p>
<p><br>
</p>
<p></p>
<div><br>
</div>
<div>  f        = addfile("wrf_mask.nc","r")</div>
<div>  marray   = f->WRF_mask</div>
<div>  tc2_mask = mask(tc2,marray,1)</div>
<div>  lu_mask = mask(lu,marray,1)</div>
<div>  tc2f_mask = mask(tc2f,marray,1</div>
<br>
<p></p>
<p><br>
</p>
<div id="Signature">
<div id="divtagdefaultwrapper" style="font-size: 12pt; color: rgb(0, 0, 0); background-color: rgb(255, 255, 255); font-family: Calibri, Arial, Helvetica, sans-serif, EmojiFont, "Apple Color Emoji", "Segoe UI Emoji", NotoColorEmoji, "Segoe UI Symbol", "Android Emoji", EmojiSymbols;">
<div style="font-family:Tahoma; font-size:13px">
<div style="font-family:Tahoma; font-size:13px"><b><br>
</b></div>
<div style="color:rgb(33,33,33); font-family:wf_segoe-ui_normal,'Segoe UI','Segoe WP',Tahoma,Arial,sans-serif; font-size:15.4545450210571px; margin:0px; background-color:rgb(255,255,255)">
<font face="Times New Roman,serif" size="3"><span style="font-size:12pt"><font face="Arial Bold" size="2" color="#1F497D"><span style="font-size:11pt">Muhammad Omer Mughal</span></font></span></font></div>
<div style="color:rgb(33,33,33); font-family:wf_segoe-ui_normal,'Segoe UI','Segoe WP',Tahoma,Arial,sans-serif; font-size:15.4545450210571px; margin:0px; background-color:rgb(255,255,255)">
<font face="Times New Roman,serif" size="3"><span style="font-size:12pt"><font face="Arial Bold" size="2" color="#1F497D"><span style="font-size:11pt">MSc BSc Mechanical Engineering</span></font><font face="Arial,sans-serif" size="1" color="#1F497D"><span style="font-size:8pt"><br>
</span></font><font face="Arial Bold" size="2" color="#AB8303"><span style="font-size:9pt">PhD  Research Scholar</span></font></span></font></div>
<div style="color:rgb(33,33,33); font-family:wf_segoe-ui_normal,'Segoe UI','Segoe WP',Tahoma,Arial,sans-serif; font-size:15.4545450210571px; margin:0px; background-color:rgb(255,255,255)">
<font face="Times New Roman,serif" size="3"><span style="font-size:12pt"><font face="Arial Bold" size="2" color="#AB8303"><span style="font-size:9pt">Remote Sensing and Satellite Research Group</span></font></span></font></div>
<div style="color:rgb(33,33,33); font-family:wf_segoe-ui_normal,'Segoe UI','Segoe WP',Tahoma,Arial,sans-serif; font-size:15.4545450210571px; margin:0px; background-color:rgb(255,255,255)">
<font face="Times New Roman,serif" size="3"><span style="font-size:12pt"><font face="Arial Bold" size="2" color="#AB8303"><span style="font-size:9pt">Department of Imaging and Applied Physics</span></font><font face="Arial Bold" size="2" color="#AB8303"><span style="font-size:9pt"><br>
Curtin University</span></font><font face="Arial Bold" size="2" color="#AB8303"><span style="font-size:9pt"><br>
</span></font><font face="Calibri,sans-serif" size="2" color="#1F497D"><span style="font-size:11pt"><br>
</span></font><font face="Arial Bold" size="2" color="#1F497D"><span style="font-size:9pt">Curtin University</span></font><font face="Arial Bold" size="2" color="#1F497D"><span style="font-size:9pt"><br>
</span></font><font face="Arial Bold" size="2" color="#AB8303"><span style="font-size:9pt">Tel |</span></font><font face="Arial Bold" size="2" color="#1F497D"><span style="font-size:9pt"> </span></font><font face="Arial,sans-serif" size="2" color="#1F497D"><span style="font-size:9pt">+61
 8 9266 7962</span></font><font face="Calibri,sans-serif" size="2" color="#1F497D"><span style="font-size:9pt"> </span></font><font face="Calibri,sans-serif" size="1" color="#1F497D"><span style="font-size:7pt"><br>
</span></font><font face="Arial Bold" size="2" color="#AB8303"><span style="font-size:9pt">Fax |</span></font><font face="Arial Bold" size="2" color="#1F497D"><span style="font-size:9pt"> </span></font><font face="Arial,sans-serif" size="2" color="#1F497D"><span style="font-size:9pt">+61
 8 9266 2377</span></font><font face="Arial,sans-serif" size="2" color="#1F497D"><span style="font-size:9pt"><br>
</span></font><font face="Arial Bold" size="2" color="#AB8303"><span style="font-size:9pt">Mobile |</span></font><font face="Calibri,sans-serif" size="2" color="#1F497D"><span style="font-size:9pt"> </span></font><font face="Arial,sans-serif" size="2" color="#1F497D"><span style="font-size:9pt">0470 237 525</span></font><font face="Calibri,sans-serif" size="2" color="#1F497D"><span style="font-size:9pt">  </span></font><font face="Calibri,sans-serif" size="2" color="#1F497D"><span style="font-size:9pt"><br>
</span></font><font face="Calibri,sans-serif" size="2" color="#1F497D"><span style="font-size:9pt"><br>
</span></font><font face="Arial Bold" size="2" color="#AB8303"><span style="font-size:9pt">Email |</span></font><font face="Calibri,sans-serif" size="2" color="#1F497D"><span style="font-size:9pt"> </span></font><a href="mailto:m.lynch@curtin.edu.au" target="_blank" id="LPNoLP"><font face="Arial,sans-serif" size="2"><span style="font-size:9pt">m.mughal1@postgrad.curtin.edu.au</span></font></a><font face="Arial,sans-serif" size="2" color="#1F497D"><span style="font-size:9pt"> </span></font><font face="Arial,sans-serif" size="2" color="#1F497D"><span style="font-size:9pt"><br>
</span></font><font face="Arial Bold" size="2" color="#AB8303"><span style="font-size:9pt">Web |</span></font><font face="Calibri,sans-serif" size="2" color="#AB8303"><span style="font-size:9pt"> </span></font><a href="http://curtin.edu.au/" target="_blank" id="LPNoLP"><font face="Calibri,sans-serif" size="2"><span style="font-size:11pt"><font face="Arial,sans-serif" size="2"><span style="font-size:9pt">http://curtin.edu.au</span></font></span></font></a><font face="Arial,sans-serif" size="2" color="#1F497D"><span style="font-size:9pt"><br>
</span></font><font face="Calibri,sans-serif" size="1" color="#1F497D"><span style="font-size:7pt"><br>
</span></font></span></font></div>
<div style="color:rgb(33,33,33); font-family:wf_segoe-ui_normal,'Segoe UI','Segoe WP',Tahoma,Arial,sans-serif; font-size:15.4545450210571px; margin:0px; background-color:rgb(255,255,255)">
<font face="Calibri,sans-serif" size="1" color="#1F497D"><span style="font-size:6pt"></span></font><font face="Arial,sans-serif" size="1" color="#1F497D"><span style="font-size:6pt">Curtin University is a trademark of Curtin University of Technology. </span></font><br>
</div>
<div style="color:rgb(33,33,33); font-family:wf_segoe-ui_normal,'Segoe UI','Segoe WP',Tahoma,Arial,sans-serif; font-size:15.4545450210571px; margin:0px; background-color:rgb(255,255,255)">
<font face="Times New Roman,serif" size="3"><span style="font-size:12pt"><font face="Arial,sans-serif" size="1" color="#1F497D"><span style="font-size:6pt">CRICOS Provider Code 00301J (WA), 02637B (NSW)</span></font></span></font></div>
<div style="color:rgb(33,33,33); font-family:wf_segoe-ui_normal,'Segoe UI','Segoe WP',Tahoma,Arial,sans-serif; font-size:15.4545450210571px; margin:0px; background-color:rgb(255,255,255)">
<font face="Times New Roman,serif" size="3"><span style="font-size:12pt"><font face="Arial,sans-serif" size="1" color="#1F497D"><span style="font-size:6pt"><br>
</span></font></span></font></div>
<div style="color:rgb(33,33,33); font-family:wf_segoe-ui_normal,'Segoe UI','Segoe WP',Tahoma,Arial,sans-serif; font-size:15.4545450210571px; margin:0px; background-color:rgb(255,255,255)">
<font face="Times New Roman,serif" size="3"><span style="font-size:12pt"><font face="Arial,sans-serif" size="1" color="#1F497D"><span style="font-size:6pt"><br>
</span></font></span></font></div>
</div>
</div>
</div>
</div>
<hr style="display:inline-block;width:98%" tabindex="-1">
<div id="divRplyFwdMsg" dir="ltr"><font face="Calibri, sans-serif" style="font-size:11pt" color="#000000"><b>From:</b> Mary Haley <haley@ucar.edu><br>
<b>Sent:</b> Friday, 10 November 2017 4:28:25 AM<br>
<b>To:</b> Muhammad Omer Mughal<br>
<b>Cc:</b> ncl-talk@ucar.edu<br>
<b>Subject:</b> Re: [ncl-talk] Masking</font>
<div> </div>
</div>
<div>
<div dir="ltr">
<div class="x_gmail_default" style="font-size:small">Muhammad,</div>
<div class="x_gmail_default" style="font-size:small"><br>
</div>
<div class="x_gmail_default" style="font-size:small">A long email follows. Please read carefully, visit the links I've provided, and look at the two scripts I've provided.</div>
<div class="x_gmail_default" style="font-size:small"><br>
</div>
<div class="x_gmail_default" style="font-size:small">As I said in a previous email, you have curvilinear data, which means your data is represented by two-dimensional latitude / longitude arrays. You cannot use coordinate arrays with curvilinear data, as you
 are trying to do with this code:</div>
<div class="x_gmail_default">
<div class="x_gmail_default"><br>
</div>
<div class="x_gmail_default"><font face="monospace, monospace">  lat1d       = fspan(minlat,maxlat,nlat)</font></div>
<div class="x_gmail_default"><font face="monospace, monospace">  lon1d       = fspan(minlon,maxlon,nlon)</font></div>
<div class="x_gmail_default"><font face="monospace, monospace">  lat1d@units = "degrees_north"</font></div>
<div class="x_gmail_default"><font face="monospace, monospace">  lon1d@units = "degrees_east"</font></div>
<div class="x_gmail_default"><font face="monospace, monospace">  tc2a = wrf_user_getvar(a, "T2",0)</font></div>
<div class="x_gmail_default"><font face="monospace, monospace">  tc2a@_FillValue = -9999</font></div>
<div class="x_gmail_default"><font face="monospace, monospace"><br>
</font></div>
<div class="x_gmail_default"><font face="monospace, monospace">  tc2a!0      = "lat"</font></div>
<div class="x_gmail_default"><font face="monospace, monospace">  tc2a!1      = "lon"</font></div>
<div class="x_gmail_default"><font face="monospace, monospace">  tc2a&lat    = lat1d</font></div>
<div class="x_gmail_default"><font face="monospace, monospace">  tc2a&lon    = lon1d</font></div>
<div class="x_gmail_default"><br>
</div>
<div class="x_gmail_default">When you use coordinate arrays via "&", this tells NCL that you have rectilinear data. This will NOT work for your data. To help understand the difference between curvilinear and rectilinear data, please see our "Plotting data on
 a map" examples page:</div>
<div class="x_gmail_default"><br>
</div>
<div class="x_gmail_default"><a href="http://www.ncl.ucar.edu/Applications/plot_data_on_map.shtml" target="_blank">http://www.ncl.ucar.edu/Applic<wbr>ations/plot_data_on_map.shtml</a><br>
</div>
<div class="x_gmail_default"><br>
</div>
<div class="x_gmail_default">In particular, look at these two images, where the actual lat/lon grid is drawn with lines:</div>
<div class="x_gmail_default"><br>
</div>
<div class="x_gmail_default"><a href="http://www.ncl.ucar.edu/Applications/Images/dataonmap_grid_1_lg.png" target="_blank">http://www.ncl.ucar.edu/Applic<wbr>ations/Images/dataonmap_grid_<wbr>1_lg.png</a><br>
</div>
<div class="x_gmail_default"><a href="http://www.ncl.ucar.edu/Applications/Images/dataonmap_grid_3_lg.png" target="_blank">http://www.ncl.ucar.edu/Applic<wbr>ations/Images/dataonmap_grid_<wbr>3_lg.png</a><br>
</div>
<div class="x_gmail_default"><br>
</div>
<div class="x_gmail_default">The dataonmap_grid1.ncl script shows how to plot rectilinear data, and the dataonma_grid_3.ncl is plotting curvilinear data.</div>
<div class="x_gmail_default"><br>
</div>
<div class="x_gmail_default">You said that the code I sent you a couple of days ago was working, so I'm not sure why you went back to trying to use coordinate arrays.</div>
<div class="x_gmail_default"><br>
</div>
<div class="x_gmail_default">Here's the correct way, which is just copied-and-pasted from the email I sent you before.</div>
<div class="x_gmail_default"><br>
</div>
<div class="x_gmail_default"><span style="font-family:monospace,monospace; font-size:12.8px"> nt = 0</span><span class="x_gmail-m_-5317956723310135004m_8949088970929600368gmail-m_1005084403795383051gmail-im" style="font-family:monospace,monospace; font-size:12.8px"><br>
 tc2a 
<div class="x_gmail_default" style="font-size:small; display:inline">​      ​</div>
= wrf_user_getvar(a, "T2", 
<div class="x_gmail_default" style="font-size:small; display:inline">​ ​</div>
</span><span style="font-family:monospace,monospace; font-size:12.8px">nt)</span><br style="font-family:monospace,monospace; font-size:12.8px">
<span style="font-family:monospace,monospace; font-size:12.8px"> </span><span style="font-family:monospace,monospace; font-size:12.8px">tc2a</span><span style="font-family:monospace,monospace; font-size:12.8px">@lat2d = wrf_user_getvar(a, "lat", nt)   ; This
 is necessary for shapefile masking, but do not</span><br style="font-family:monospace,monospace; font-size:12.8px">
<span style="font-family:monospace,monospace; font-size:12.8px"> </span><span style="font-family:monospace,monospace; font-size:12.8px">tc2a</span><span style="font-family:monospace,monospace; font-size:12.8px">@lon2d = wrf_user_getvar(a,</span>
<div class="x_gmail_default" style="font-family:monospace,monospace; display:inline">
​ ​</div>
<span style="font-family:monospace,monospace; font-size:12.8px">"lon",</span>
<div class="x_gmail_default" style="font-family:monospace,monospace; display:inline">
​ ​</div>
<span style="font-family:monospace,monospace; font-size:12.8px">nt)   ; write these two attributes to a new NetCDF file!</span><br style="font-family:monospace,monospace; font-size:12.8px">
<span style="font-family:monospace,monospace; font-size:12.8px"> </span><span style="font-family:monospace,monospace; font-size:12.8px">tc2a</span><span style="font-family:monospace,monospace; font-size:12.8px">@_FillValue = -9999</span><br style="font-family:monospace,monospace; font-size:12.8px">
<br style="font-family:monospace,monospace; font-size:12.8px">
<span style="font-family:monospace,monospace; font-size:12.8px"> opt       = True</span><br style="font-family:monospace,monospace; font-size:12.8px">
<span style="font-family:monospace,monospace; font-size:12.8px"> opt@debug = True</span><br style="font-family:monospace,monospace; font-size:12.8px">
<span style="font-family:monospace,monospace; font-size:12.8px"> </span><span style="font-family:monospace,monospace; font-size:12.8px">tc2a</span><span style="font-family:monospace,monospace; font-size:12.8px">_mask = shapefile_mask_data(</span><span style="font-family:monospace,monospace; font-size:12.8px">tc2a</span><span style="font-family:monospace,monospace; font-size:12.8px">,"</span><span style="font-family:monospace,monospace; font-size:12.8px">Shap<wbr>efile/malay.shp",opt)</span></div>
<div class="x_gmail_default"><br>
</div>
<div class="x_gmail_default"><br>
</div>
<div class="x_gmail_default"><font face="arial, helvetica, sans-serif">If you are wanting to apply the same mask to all other variables on the file, then what you can do is have shapefile_mask_data return a mask array, which is an array with 0s and 1s, where
 1s represent data that falls inside the area, and 0s represent data that falls outside the area. You can then use this mask array to mask all other variables that are defined on the same lat/lon grid. </font></div>
<div class="x_gmail_default"><font face="arial, helvetica, sans-serif"><br>
</font></div>
<div class="x_gmail_default"><span style="font-size:12.8px"><font face="arial, helvetica, sans-serif">Please see the attached wrf_gsn_5.ncl script, which I adapted from the one on the web. It takes a shapefile that has the Mississippi River Basin outline, and
 uses this to mask WRF data that covers the east part of the United States.  The WRF data doesn't cover the full area of the Mississippi River Basin, but I wanted to use this example because I can provide you with the data files so you can try it yourself.
  </font></span></div>
<div class="x_gmail_default"><span style="font-size:12.8px"><font face="arial, helvetica, sans-serif"><br>
</font></span></div>
<div class="x_gmail_default"><span style="font-size:12.8px"><font face="arial, helvetica, sans-serif">The wrf_gsn_5.ncl script writes the mask array to a NetCDF file, and then the wrf_mask.ncl script shows how you can read this mask array back in and apply
 it to other variables on the WRF file.  This is MUCH faster than calling shapefile_mask_data every single time. In this case, shapefile_mask_data takes over a minute to create the mask array. Once you have this array, masking data takes a fraction of a second.</font></span></div>
<div class="x_gmail_default"><span style="font-size:12.8px"><font face="arial, helvetica, sans-serif"><br>
</font></span></div>
<div class="x_gmail_default"><span style="font-size:12.8px"><font face="arial, helvetica, sans-serif">Try running wrf_gsn_5.ncl first, which will create several plots (to an X11 window). It will also write the mask array to "<a href="http://wrf_mask.nc">wrf_mask.nc</a>".
 This script will take over a minute to run.</font></span></div>
<div class="x_gmail_default"><span style="font-size:12.8px"><font face="arial, helvetica, sans-serif"><br>
</font></span></div>
<div class="x_gmail_default"><span style="font-size:12.8px"><font face="arial, helvetica, sans-serif">Then, run wrf_mask.ncl, which masks the same variables, but this time it uses the mask array read off
<a href="http://wrf_mask.nc">wrf_mask.nc</a> to mask the data. This script takes a few seconds to run. It will produce a single PNG image, which I've attached.</font></span></div>
<div class="x_gmail_default"><span style="font-size:12.8px"><font face="arial, helvetica, sans-serif"><br>
</font></span></div>
<div class="x_gmail_default"><span style="font-size:12.8px"><font face="arial, helvetica, sans-serif">I've attached the four mrb.xxx files which are the files that represent the shapefile.</font></span></div>
<br>
To get the WRF output fie, which is larger:<br>
<br>
<font face="monospace, monospace">wget <a href="ftp://ftp.cgd.ucar.edu//incoming/wrfout_d01_2005-12-14_13:00:00">
ftp://ftp.cgd.ucar.edu//incoming/wrfout_d01_2005-12-14_13:00:00</a><br>
</font><br>
or:<br>
<br>
<font face="monospace, monospace">ftp <a href="http://ftp.cgd.ucar.edu">ftp.cgd.ucar.edu</a><br>
[login as anonymous]<br>
cd incoming<br>
get  wrfout_d01_2005-12-14_13:00:00<br>
quit</font>
<div class="x_gmail_default"><span style="font-size:12.8px"><font face="arial, helvetica, sans-serif"><br>
</font></span></div>
<div class="x_gmail_default"><span style="font-size:12.8px"><font face="arial, helvetica, sans-serif">--Mary</font></span></div>
<div class="x_gmail_default"><span style="font-size:12.8px"><font face="arial, helvetica, sans-serif"><br>
</font></span></div>
<div class="x_gmail_default"><br>
</div>
</div>
</div>
<div class="x_gmail_extra"><br>
<div class="x_gmail_quote">On Thu, Nov 9, 2017 at 6:39 AM, Muhammad Omer Mughal <span dir="ltr">
<<a href="mailto:m.mughal1@postgrad.curtin.edu.au" target="_blank">m.mughal1@postgrad.curtin.edu.au</a>></span> wrote:<br>
<blockquote class="x_gmail_quote" style="margin:0 0 0 .8ex; border-left:1px #ccc solid; padding-left:1ex">
Hi Marry<br>
<br>
Thank you again for the reply. I found the problem after I used  CDO the time dimension stripped out from the data. In order to correct this problem I use the following<br>
<span class="">lat=a->XLAT<br>
 lon=a->XLONG<br>
  minlat=min(lat)<br>
  maxlat=max(lat)<br>
  minlon=min(lon)<br>
  maxlon=max(lon)<br>
<br>
 nlat=129<br>
 nlon=210<br>
<br>
  lat1d       = fspan(minlat,maxlat,nlat)<br>
  lon1d       = fspan(minlon,maxlon,nlon)<br>
</span><span class="">  lat1d@units = "degrees_north"<br>
  lon1d@units = "degrees_east"<br>
</span>  tc2a = wrf_user_getvar(a, "T2",0)<br>
  tc2a@_FillValue = -9999<br>
<br>
  tc2a!0      = "lat"<br>
  tc2a!1      = "lon"<br>
  tc2a&lat    = lat1d<br>
  tc2a&lon    = lon1d<br>
  tc2a_mask = shapefile_mask_data(tc2a,"/<wbr>data/muhdomer/NSCC/scratch/<wbr>Shapefiles/SGP_adm0.shp",opt)<br>
<br>
Is there a way to get all variables masked using a shapefile_mask_data command ?<br>
<span class=""><br>
<br>
<br>
<br>
Muhammad Omer Mughal<br>
MSc BSc Mechanical Engineering<br>
PhD  Research Scholar<br>
Remote Sensing and Satellite Research Group<br>
Department of Imaging and Applied Physics<br>
Curtin University<br>
<br>
Curtin University<br>
Tel | <a href="tel:%2B61%208%209266%207962" value="+61892667962">+61 8 9266 7962</a><br>
Fax | <a href="tel:%2B61%208%209266%202377" value="+61892662377">+61 8 9266 2377</a><br>
Mobile | 0470 237 525<br>
<br>
</span>Email | <a href="mailto:m.mughal1@postgrad.curtin.edu.au">m.mughal1@postgrad.curtin.edu.<wbr>au</a><mailto:<a href="mailto:m.lynch@curtin.edu.au">m.lynch@curtin.edu.<wbr>au</a>><br>
Web | <a href="http://curtin.edu.au" rel="noreferrer" target="_blank">http://curtin.edu.au</a><<a href="http://curtin.edu.au/" rel="noreferrer" target="_blank">http://<wbr>curtin.edu.au/</a>><br>
<span class=""><br>
Curtin University is a trademark of Curtin University of Technology.<br>
CRICOS Provider Code 00301J (WA), 02637B (NSW)<br>
<br>
<br>
______________________________<wbr>__<br>
From: Mary Haley <<a href="mailto:haley@ucar.edu">haley@ucar.edu</a>><br>
</span>Sent: Thursday, 9 November 2017 12:30:26 AM<br>
<span class="">To: Muhammad Omer Mughal<br>
Cc: <a href="mailto:ncl-talk@ucar.edu">ncl-talk@ucar.edu</a><br>
Subject: Re: [ncl-talk] Masking<br>
<br>
Muhammad,<br>
<br>
</span>
<div>
<div class="x_h5">Something is not right with data2.<br>
<br>
In order to correctly mask curvilinear data, your lat/lon arrays must be the same size as your data. If you look at the output from data2:<br>
<br>
Variable: data2<br>
Type: float<br>
Total Size: 108360 bytes<br>
27090 values<br>
Number of Dimensions: 2<br>
Dimensions and sizes: [y | 129] x [x | 210]<br>
Coordinates:<br>
Number Of Attributes: 9<br>
lon2d : <ARRAY of 210 elements><br>
lat2d : <ARRAY of 210 elements><br>
stagger :<br>
description : TEMP at 2 M<br>
<br>
The data2 variable is 129 x 210, but the lat2d and lon2d are each 1D arrays of length 210. lat2d and lon2d should be 2D arrays that are the same size as data2.<br>
<br>
However, and this is important, attaching lat2d and lon2d attributes to the data variable is an NCL specific thing for plotting, regridding, and masking, and should NOT be used when writing new data to a file. This is needlessly expensive, because you likely
 already have the lat, lon arrays written as separate variables on the file.<br>
<br>
You can look at your original WRF output file to see how curvilinear data is generally represented on a NetCDF file. Here's an example:<br>
<br>
      float T2 ( Time, south_north, west_east )<br>
         FieldType :    104<br>
         MemoryOrder :  XY<br>
         description :  TEMP at 2 M<br>
         units :        K<br>
         stagger :<br>
         coordinates :  XLONG XLAT XTIME<br>
<br>
Note the "coordinates" attribute attached T2. This is what tells you that the lat/lon arrays associated with T2 are called "XLONG" and "XLAT" on the file, which is what I used earlier to get the lat/lon for masking.<br>
<br>
The data2 variable longer has this coordinates attribute, so either NCO didn't do something correctly, or this variable was modified in some way.<br>
<br>
Please double-check that you are using NCO correctly, and don't write those lat2d / lon2d attributes.  Also make sure that the coordinates attribute is included, and that you have the correct XLAT and XLONG variables written to the file.  Once you do this,
 you can then mask your new data in the exact same way that you did for the original T2 variable.<br>
<br>
--Mary<br>
<br>
<br>
<br>
<br>
<br>
</div>
</div>
<div>
<div class="x_h5">On Wed, Nov 8, 2017 at 12:35 AM, Muhammad Omer Mughal <<a href="mailto:m.mughal1@postgrad.curtin.edu.au">m.mughal1@postgrad.curtin.<wbr>edu.au</a><mailto:<a href="mailto:m.mughal1@postgrad.curtin.edu.au">m.mughal1@<wbr>postgrad.curtin.edu.au</a>>>
 wrote:<br>
Hi Mary<br>
<br>
Thank you for the reply. The adjustment works perfectly to mask the data. I have another question related to this. When I use the wrfoutput file and use the commands lat2d I get this output<br>
<br>
Variable: data3<br>
Type: float<br>
Total Size: 108360 bytes<br>
27090 values<br>
Number of Dimensions: 2<br>
Dimensions and sizes: [south_north | 129] x [west_east | 210]<br>
Coordinates:<br>
Number Of Attributes: 8<br>
lon2d : <ARRAY of 27090 elements><br>
lat2d : <ARRAY of 27090 elements><br>
coordinates : XLONG XLAT XTIME<br>
stagger :<br>
units : K<br>
description : TEMP at 2 M<br>
MemoryOrder : XY<br>
FieldType : 104<br>
<br>
<br>
When I use this to a sliced file from nco which has changed the attributes of the file I get the following output.<br>
<br>
Variable: data2<br>
Type: float<br>
Total Size: 108360 bytes<br>
27090 values<br>
Number of Dimensions: 2<br>
Dimensions and sizes: [y | 129] x [x | 210]<br>
Coordinates:<br>
Number Of Attributes: 9<br>
lon2d : <ARRAY of 210 elements><br>
lat2d : <ARRAY of 210 elements><br>
stagger :<br>
description : TEMP at 2 M<br>
MemoryOrder : XY<br>
FieldType : 104<br>
coordinates : XLONG XLAT<br>
units : K<br>
time : 40320<br>
<br>
Also when I use the sliced  file to mask the data I get the error<br>
(0) shapefile_mask_data:Error: not a valid rectilinear,curvilinear, or unstructured grid.<br>
<br>
I will appreciate your help<br>
Muhammad Omer Mughal<br>
MSc BSc Mechanical Engineering<br>
PhD  Research Scholar<br>
Remote Sensing and Satellite Research Group<br>
Department of Imaging and Applied Physics<br>
Curtin University<br>
<br>
Curtin University<br>
Tel | +61 8 9266 7962<br>
Fax | +61 8 9266 2377<br>
Mobile | 0470 237 525<br>
<br>
</div>
</div>
Email | <a href="mailto:m.mughal1@postgrad.curtin.edu.au">m.mughal1@postgrad.curtin.edu.<wbr>au</a><mailto:<a href="mailto:m.lynch@curtin.edu.au">m.lynch@curtin.edu.<wbr>au</a>><br>
Web | <a href="http://curtin.edu.au" rel="noreferrer" target="_blank">http://curtin.edu.au</a><<a href="http://curtin.edu.au/" rel="noreferrer" target="_blank">http://<wbr>curtin.edu.au/</a>><br>
<span class=""><br>
Curtin University is a trademark of Curtin University of Technology.<br>
CRICOS Provider Code 00301J (WA), 02637B (NSW)<br>
<br>
<br>
______________________________<wbr>__<br>
</span>From: Mary Haley <<a href="mailto:haley@ucar.edu">haley@ucar.edu</a><mailto:<a href="mailto:haley@ucar.edu">haley@<wbr>ucar.edu</a>>><br>
<span class="">Sent: Wednesday, 8 November 2017 12:42:12 AM<br>
To: Muhammad Omer Mughal<br>
</span>Cc: <a href="mailto:ncl-talk@ucar.edu">ncl-talk@ucar.edu</a><mailto:<a href="mailto:ncl-talk@ucar.edu">ncl-<wbr>talk@ucar.edu</a>><br>
<span class="">Subject: Re: [ncl-talk] Masking<br>
<br>
Muhammad,<br>
<br>
It looks like you are trying to use a rectilinear lat/lon grid for masking rather than the original lat/lon data associated with your "T2" variable.<br>
<br>
If your file is indeed a WRF output file, then you should use the XLAT/XLONG variables on the file, rather than trying to create your own lat/lon arrays.<br>
<br>
Your code would look something like this:<br>
<br>
 nt = 0<br>
 data<br>
​      ​<br>
= wrf_user_getvar(a, "T2",<br>
​ ​<br>
nt)<br>
 data@lat2d = wrf_user_getvar(a, "lat", nt)<br>
 data@lon2d = wrf_user_getvar(a,<br>
​ ​<br>
"lon",<br>
​ ​<br>
nt)<br>
 data@_FillValue = -9999<br>
<br>
 opt       = True<br>
 opt@debug = True<br>
 data_mask = shapefile_mask_data(data,"<wbr>Shapefile/malay.shp",opt)<br>
<br>
<br>
For an example that masks a WRF output file, see example shapefile_14_mask.ncl<br>
​ ​<br>
at:<br>
<br>
<a href="http://www.ncl.ucar.edu/Applications/shapefiles.shtml#ex14" rel="noreferrer" target="_blank">http://www.ncl.ucar.edu/<wbr>Applications/shapefiles.shtml#<wbr>ex14</a><br>
<br>
Note that this example is specifying "Ohio" as the specific area in the shapefile to mask against, but if you simply want to use the whole shapefile, then you do not need to set "shape_var" or "shape_names" as this script is doing.<br>
<br>
--Mary<br>
<br>
</span>
<div>
<div class="x_h5">On Tue, Nov 7, 2017 at 6:48 AM, Muhammad Omer Mughal <<a href="mailto:m.mughal1@postgrad.curtin.edu.au">m.mughal1@postgrad.curtin.<wbr>edu.au</a><mailto:<a href="mailto:m.mughal1@postgrad.curtin.edu.au">m.mughal1@<wbr>postgrad.curtin.edu.au</a>>>
 wrote:<br>
Hi<br>
I am using a WRF output file and I did the following changes "ONLY" to the code[ <a href="https://www.ncl.ucar.edu/Applications/Scripts/mask_9.ncl" rel="noreferrer" target="_blank">
https://www.ncl.ucar.edu/<wbr>Applications/Scripts/mask_9.<wbr>ncl</a>] . I want to  mask the temperature in Malaysia using the shape file malay.shp. Can you kindly tell me what else do  I need to change as currently I am not able to see the data masked within
 Malaysia. I will be grateful for your help<br>
<br>
load "$NCARG_ROOT/lib/ncarg/<wbr>nclscripts/wrf/WRFUserARW.ncl"<br>
<br>
begin<br>
  MASK_INSIDE = True<br>
<br>
  a = addfile("./UTC_0.nc","r")<br>
   lat=a->XLAT<br>
   lon=a->XLONG<br>
<br>
  minlat=min(lat)<br>
  maxlat=max(lat)<br>
  minlon=min(lon)<br>
  maxlon=max(lon)<br>
<br>
 nlat=129<br>
 nlon=210<br>
<br>
  lat1d       = fspan(minlat,maxlat,nlat)<br>
  lon1d       = fspan(minlon,maxlon,nlon)<br>
<br>
 data = wrf_user_getvar(a, "T2", 0)<br>
 data@_FillValue = -9999<br>
<br>
<br>
<br>
  lat1d       = fspan(minlat,maxlat,nlat)<br>
  lon1d       = fspan(minlon,maxlon,nlon)<br>
  lat1d@units = "degrees_north"<br>
  lon1d@units = "degrees_east"<br>
<br>
;---Attach lat/lon coordinate array information.<br>
  data!0      = "lat"<br>
  data!1      = "lon"<br>
  data&lat    = lat1d<br>
  data&lon    = lon1d<br>
<br>
<br>
<br>
  f       = addfile("Shapefile/malay.shp", "r")<br>
  mrb_lon = f->x<br>
  mrb_lat = f->y<br>
  nmrb    = dimsizes(mrb_lon)<br>
<br>
  min_mrb_lat = min(mrb_lat)<br>
  max_mrb_lat = max(mrb_lat)<br>
  min_mrb_lon = min(mrb_lon)<br>
  max_mrb_lon = max(mrb_lon)<br>
<br>
<br>
</div>
</div>
<a href="http://www.ncl.ucar.edu" rel="noreferrer" target="_blank">www.ncl.ucar.edu</a><<a href="https://www.ncl.ucar.edu/Applications/Scripts/mask_9.ncl" rel="noreferrer" target="_blank">https://www.<wbr>ncl.ucar.edu/Applications/<wbr>Scripts/mask_9.ncl</a>><br>
<a href="http://www.ncl.ucar.edu" rel="noreferrer" target="_blank">www.ncl.ucar.edu</a><<a href="http://www.ncl.ucar.edu" rel="noreferrer" target="_blank">http://www.<wbr>ncl.ucar.edu</a>><br>
<span class="">;***** ; mask_9.ncl ; ; Concepts illustrated: ; - Drawing the Mississippi River Basin using data from a shapefile ; - Masking a data array based on a geographical ...<br>
<br>
<br>
<br>
</span><a href="http://www.ncl.ucar.edu" rel="noreferrer" target="_blank">www.ncl.ucar.edu</a><<a href="https://www.ncl.ucar.edu/Applications/Scripts/mask_9.ncl" rel="noreferrer" target="_blank">https://www.<wbr>ncl.ucar.edu/Applications/<wbr>Scripts/mask_9.ncl</a>><br>
<a href="http://www.ncl.ucar.edu" rel="noreferrer" target="_blank">www.ncl.ucar.edu</a><<a href="http://www.ncl.ucar.edu" rel="noreferrer" target="_blank">http://www.<wbr>ncl.ucar.edu</a>><br>
<span class="">;***** ; mask_9.ncl ; ; Concepts illustrated: ; - Drawing the Mississippi River Basin using data from a shapefile ; - Masking a data array based on a geographical ...<br>
<br>
<br>
<br>
<br>
Muhammad Omer Mughal<br>
MSc BSc Mechanical Engineering<br>
PhD  Research Scholar<br>
Remote Sensing and Satellite Research Group<br>
Department of Imaging and Applied Physics<br>
Curtin University<br>
<br>
Curtin University<br>
Tel | <a href="tel:%2B61%208%209266%207962" value="+61892667962">+61 8 9266 7962</a><br>
Fax | <a href="tel:%2B61%208%209266%202377" value="+61892662377">+61 8 9266 2377</a><br>
Mobile | 0470 237 525<br>
<br>
</span>Email | <a href="mailto:m.mughal1@postgrad.curtin.edu.au">m.mughal1@postgrad.curtin.edu.<wbr>au</a><mailto:<a href="mailto:m.lynch@curtin.edu.au">m.lynch@curtin.edu.<wbr>au</a>><br>
Web | <a href="http://curtin.edu.au" rel="noreferrer" target="_blank">http://curtin.edu.au</a><<a href="http://curtin.edu.au/" rel="noreferrer" target="_blank">http://<wbr>curtin.edu.au/</a>><br>
<span class=""><br>
Curtin University is a trademark of Curtin University of Technology.<br>
CRICOS Provider Code 00301J (WA), 02637B (NSW)<br>
<br>
<br>
<br>
______________________________<wbr>_________________<br>
ncl-talk mailing list<br>
</span><a href="mailto:ncl-talk@ucar.edu">ncl-talk@ucar.edu</a><mailto:<a href="mailto:ncl-talk@ucar.edu">ncl-<wbr>talk@ucar.edu</a>><br>
<div class="x_HOEnZb">
<div class="x_h5">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>
<br>
<br>
</div>
</div>
</blockquote>
</div>
<br>
</div>
</div>
</body>
</html>