rgeor

covariance matrix


I was wondering if any one could explain to me how the geoR package calculates the covariance function? I mean how you would do it by hand?

library(geoR)
#suppose I have the following coordinates
X = c(60,30,20,40)
Y = c(50,20,50,50)
my_coordinates = cbind(X,Y)
print(my_coordinates)

#computing covariance
my_cov= varcov.spatial(my_coordinates,cov.model="exp", cov.pars=c(0.2,25))
print(my_cov)

And you get:

         [,1]       [,2]       [,3]       [,4]
[1,] 0.20000000 0.03664442 0.04037930 0.08986579
[2,] 0.03664442 0.20000000 0.05645288 0.05645288
[3,] 0.04037930 0.05645288 0.20000000 0.08986579
[4,] 0.08986579 0.05645288 0.08986579 0.20000000

However, one might want to do it in Matlab as well.


Solution

  • The best way to find out how a package or function does something is to look at the source code. This is one of the awesome things about open source projects, you can do this.

    try typing varcov.spatial or searching through the unpacked package tar ball for the function definition

    To calculate the covariance (which is dependant on the distance between points), you need to calculate

    The covariance functions are defined in ?cov.spatial. You can call cov.spatial to calculate these in R (exactly what geoR::varcov.spatial does)