Re: interpolate pixel level data into regular grid

From: Luo, Chao <chao.luo_at_nyahnyahspammersnyahnyah>
Date: Tue Oct 30 2012 - 14:06:50 MDT

I have tried this and still there is error. The message is:
write_grid_description: can't determine what type of source grid you have.
I think this is related to lat/lon of var I want to interpolate. Following is the script I have tried. Please guide me what's wrong of my script. Thanks!

CL

---------------------------
begin

;---Interpolation methods to use
    methods = (/"bilinear","patch","conserve"/)
    nmethods = dimsizes(methods)

;---Read variable to regrid

    srcFileName = "../dat/biomass_burning_20120313_18_23.nc"
    sfile = addfile(srcFileName,"r") ; source grid

    x = sfile->CO_emission ; 6 x 1129
    var = x(:,0) ; first time
    latin = sfile->Latitude
    latin@units = "degrees_north"
    lonin = sfile->Longitude
    lonin@units = "degrees_east"

    dimx = dimsizes( var )
    nlat = dimx(0)
    mlon = dimx(0)

    print(nlat)
    print(mlon)

;---Create destination lat/lon arrays
    NLAT36 = 112
    MLON36 = 148

; lat36 = new (/NLAT36,MLON36/)
; lon36 = new (/NLAT36,MLON36/)

    lat36 = asciiread("/data11/cluo/cmaq4.6/data/post/obs/grids_148x112/crogrids_lat_148x112.dat" \
                       , (/NLAT36,MLON36/),"float")
    lon36 = asciiread("/data11/cluo/cmaq4.6/data/post/obs/grids_148x112/crogrids_lon_148x112.dat" \
                       , (/NLAT36,MLON36/),"float")

    Opt = True ; Regridding options
    Opt@ForceOverwrite = True
    Opt@DstGridLat = lat36
    Opt@DstGridLon = lon36

    var_regrid = ESMF_regrid(var,Opt)

-----------------------

----- Original Message -----
From: "Mary Haley" <haley@ucar.edu>
To: "Chao Luo" <chao.luo@eas.gatech.edu>
Cc: "ncl-talk Talk" <ncl-talk@ucar.edu>
Sent: Tuesday, October 30, 2012 10:50:05 AM
Subject: Re: interpolate pixel level data into regular grid

Chao,

Dennis suggested the ESMF regridding routines.

You might want to look at ESMF_regrid specifically.

Since you have 1D coordinate arrays for the source grid, and want a 12 km x 12 km destination grid, I suggest looking at example ESMF_regrid_2.ncl:

http://www.ncl.ucar.edu/Applications/ESMF.shtml

This shows how to regrid from a rectilinear grid (which it looks like you have), to a lat/lon grid that you define, which I assume you have.

This example uses all three methods of interpolation (bilinear, patch, conserve) and regrids to two different grids.

I think you just need to set:

---Common resources
    Opt = True

    Opt@ForceOverwrite = True

    Opt@DstGridLat = lat12
    Opt@DstGridLon = lon12

where lat12 and lon12 contain arrays that represent the 12 km grid.

Then, call ESMF_regrid:

  var_regrid = ESMF_regrid(var,Opt)

Where "var" is the variable you want to regrid that contains the 1D coordinate arrays.

--Mary

On Oct 30, 2012, at 11:09 AM, Luo, Chao wrote:

> x refer to time. This is hourly biomass emission data from 18:00-23:00 on 3/17/2012. What I want to do is to interpolate this pixel level data to regular grid (12km x 12km), but don't know which function can be used. Any suggestions are very appreciated!
>
> ----- Original Message -----
> From: "Dennis Shea" <shea@ucar.edu>
> To: "Chao Luo" <chao.luo@eas.gatech.edu>
> Cc: "ncl-talk" <ncl-talk@ucar.edu>
> Sent: Monday, October 29, 2012 5:00:34 PM
> Subject: Re: interpolate pixel level data into regular grid
>
> The issue is "What does the named dimension 'x' refer to?"
> There is nothing on the file to indicate its purpose.
> You must find out before proceding.
>
> Attached is a simple NCL script that plots the data.
>
> netcdf biomass_burning_20120317_18_23 {
> dimensions:
> x = 6 ;
> y = 371 ;
> variables:
> float Latitude(y) ;
> Latitude:long_name = "Latitude" ;
> Latitude:units = "degree" ;
> Latitude:valid_range = -90.f, 90.f ;
> Latitude:scale_factor = 1.f ;
> Latitude:add_offset = 0.f ;
> Latitude:_FillValue = -9.f ;
> float Longitude(y) ;
> Longitude:long_name = "Longitude" ;
> Longitude:units = "degree" ;
> Longitude:valid_range = -180.f, 180.f ;
> Longitude:scale_factor = 1.f ;
> Longitude:add_offset = 0.f ;
> Longitude:_FillValue = -9.f ;
> float Burned_area(y, x) ;
> [snip]
>
> On 10/29/12 5:15 PM, Luo, Chao wrote:
>> Hi Dennis,
>>
>> I have checked example 8 and 15. They both require two dimensional lat/lon. The lat/lon of files I have are 1 dimension, but data array is 2D (I am not familiar with these format data). Do I need convert lat/lon from 1D to 2D, and then do interpolation in this case? I am attaching the file. Any suggestions and help are very appreciated!
>>
>> CL
>>
>> ----- Original Message -----
>> From: "Dennis Shea" <shea@ucar.edu>
>> To: "Chao Luo" <chao.luo@eas.gatech.edu>
>> Cc: "ncl-talk" <ncl-talk@ucar.edu>
>> Sent: Monday, October 29, 2012 3:35:54 PM
>> Subject: Re: interpolate pixel level data into regular grid
>>
>> http://www.ncl.ucar.edu/Applications/ESMF.shtml
>>
>> Examples 8 and 15 may be of use.
>>
>> On 10/29/12 3:59 PM, Luo, Chao wrote:
>>> Hi,
>>>
>>> I was wondering if NCL has some functions, which can be used to
>>> interpolate satellite pixel level data into regular data. Any helps are
>>> very appreciated.
>>>
>>> CL
>>>
>>>
>>> _______________________________________________
>>> ncl-talk mailing list
>>> List instructions, subscriber options, unsubscribe:
>>> http://mailman.ucar.edu/mailman/listinfo/ncl-talk
>>>
> _______________________________________________
> ncl-talk mailing list
> List instructions, subscriber options, unsubscribe:
> http://mailman.ucar.edu/mailman/listinfo/ncl-talk
_______________________________________________
ncl-talk mailing list
List instructions, subscriber options, unsubscribe:
http://mailman.ucar.edu/mailman/listinfo/ncl-talk
Received on Tue Oct 30 14:07:05 2012

This archive was generated by hypermail 2.1.8 : Wed Oct 31 2012 - 09:14:12 MDT