[R-sig-Geo] how to go from SpatialGrid to SpatialGridDataFrame ?

Edzer J. Pebesma e.pebesma at geog.uu.nl
Wed Feb 1 13:41:40 CET 2006


Horacio Samaniego wrote:

> Edzer,
>
> the class is:
>
> > class(data.new_alb[gd.glm,])
> [1] "SpatialPointsDataFrame"
> attr(,"package")
> [1] "sp"
> > class(data.grd)
> [1] "SpatialGrid"
> attr(,"package")
> [1] "sp"
>
> I use the [gd.glm,] to avoid the NA in the datasets for that  
> variable. However, I get the same results when omitted
> >

> Error in krige(glmpred ~ 1, data = data.new_alb, newd = data.grd) :
>     no direct or inherited method for function 'krige' for this call
>
> this indicates that the problem is elsewhere.

Yes; sorry it took me a while to recognize.
You should omit the "data =" in the call, i.e.
krige(glmpred~1,data.new_alb[gd.glm,],newd=data.grd)
will work. This is a change in interface, which I recently
posted to R-pkgs:
https://stat.ethz.ch/pipermail/r-packages/2006/000154.html

>
>
> If newdata accepts SpatialGrids will it output a SpatialGridDataFrame  
> with the prediction as a dataframe of that?

Yes.

>
>
> Regarding the example, I am not quite sure that I understand how to  
> adapt the example to my data. I have a generated a grid based on my  
> grass extend, and I need the predictions from my model (idw in this  
> 'toy' example) to go in that grid. In the meuse.grid example, you  
> have a regular grid of samples and make a grid based on that, I have  
> irregular samples and need to create a continuous surface of those  
> values. So, I chose to build the GridTopology from my grass location.

Should work.
--
Edzer

>
> thanks
>
> Horacio
>
>
>
> On Feb 1, 2006, at 12:54 PM, Edzer J. Pebesma wrote:
>
> A Horacio Samaniego wrote:
>
>> I wonder how I should go from a SpatialGrid to a SpatialGridDataFrame.
>>
>>
> Using for example the function SpatialGridDataFrame()
>
>> I have defined a grid using the functions from the sp, gstat and  
>> spgrass6 packages:
>>
>> G<-gmeta6()
>> kk<-SpatialGrid(GridTopology(c(G$south,G$west),c(G$nsres,G$ewres),c 
>> (G$rows,G$cols)),alb.proj)
>>
>>> str(kk)
>>>
>> Formal class 'SpatialGrid' [package "sp"] with 5 slots
>>   ..@ grid       :Formal class 'GridTopology' [package "sp"] with 3  
>> slots
>>   .. .. ..@ cellcentre.offset: num [1:2] -1333373 -2356259
>>   .. .. ..@ cellsize         : num [1:2] 1000 1000
>>   .. .. ..@ cells.dim        : int [1:2] 2899 4615
>>   ..@ grid.index : int(0)
>>   ..@ coords     : num [1:2, 1:2] -1333373  1564162 -2356259  2257928
>>   .. ..- attr(*, "dimnames")=List of 2
>>   .. .. ..$ : NULL
>>   .. .. ..$ : chr [1:2] "coords.x1" "coords.x2"
>>   ..@ bbox       : num [1:2, 1:2] -1333872 -2356759  1564662  2258428
>>   .. ..- attr(*, "dimnames")=List of 2
>>   .. .. ..$ : chr [1:2] "coords.x1" "coords.x2"
>>   .. .. ..$ : chr [1:2] "min" "max"
>>   ..@ proj4string:Formal class 'CRS' [package "sp"] with 1 slots
>>   .. .. ..@ projargs: chr "+proj=aea +lat_1=29.75 +lat_2=45.25  
>> +lat_0=37.5 +lon_0=-96 +x_0=0 +y_0=0 +no_defs +a=6378137  
>> +rf=298.257222101 +towgs84=0.000,0"| __truncated__
>>
>> Now I try to interpolate on that grid, with no success:
>> interp.vals<-idw(var1~1,data,newdata=kk)
>> Error in idw(corrext ~ 1, data = data.new_alb[gd.glm, ], newdata =  
>> data.grd) :
>>     no direct or inherited method for function 'idw' for this call
>>
>> So, I guess that I need to have a 'SpatialGridDataFrame' instead of  
>> just 'SpatialGrid' as the interpolation needs to be assigned to a  
>> spatial location
>>
> newdata can be of class SpatialGrid; probably idw fails because
> of the data argument. What is the class of data.new_alb[gd.glm,] ?
>
>> kk2<-as(kk,'SpatialGridDataFrame');
>> Formal class 'SpatialGridDataFrame' [package "sp"] with 6 slots
>>   ..@ data       :Formal class 'AttributeList' [package "sp"] with  1 
>> slots
>>   .. .. ..@ att: list()
>>   ..@ grid       :Formal class 'GridTopology' [package "sp"] with 3  
>> slots
>>   .. .. ..@ cellcentre.offset: num [1:2] -1333373 -2356259
>>   .. .. ..@ cellsize         : num [1:2] 1000 1000
>>   .. .. ..@ cells.dim        : int [1:2] 2899 4615
>>   ..@ grid.index : int(0)
>>   ..@ coords     : num [1:2, 1:2] -1333373  1564162 -2356259  2257928
>>   .. ..- attr(*, "dimnames")=List of 2
>>   .. .. ..$ : NULL
>>   .. .. ..$ : chr [1:2] "coords.x1" "coords.x2"
>>   ..@ bbox       : num [1:2, 1:2] -1333872 -2356759  1564662  2258428
>>   .. ..- attr(*, "dimnames")=List of 2
>>   .. .. ..$ : chr [1:2] "coords.x1" "coords.x2"
>>   .. .. ..$ : chr [1:2] "min" "max"
>>   ..@ proj4string:Formal class 'CRS' [package "sp"] with 1 slots
>>   .. .. ..@ projargs: chr "+proj=aea +lat_1=29.75 +lat_2=45.25  
>> +lat_0=37.5 +lon_0=-96 +x_0=0 +y_0=0 +no_defs +a=6378137  
>> +rf=298.257222101 +towgs84=0.000,0"| __truncated__
>>
>> promotes the grid to the correct class SpatialGridDataFrame but do  
>> not assign to space for the variable. Is there any way to assign an  
>> empty "slot" just as we would do for a data.frame?
>>
>> To sum.  I cant seem to be able to create a "slot" (or z dimension)  
>> to hold the output of my interpolation. Is there any trick out  there 
>> that I am missing? Any help will be appreciated.
>>
>> thanks,
>>
>> H
>>
>> _______________________________________________
>> R-sig-Geo mailing list
>> R-sig-Geo at stat.math.ethz.ch
>> https://stat.ethz.ch/mailman/listinfo/r-sig-geo
>>
>
>




More information about the R-sig-Geo mailing list