0

我正在使用以下 Matlab 代码来估计 Ripley 的 K 函数。

a = 0;
b = 50;
C_x = a + (b-a).*rand(100,1);
C_y = a + (b-a).*rand(100,1);

locs = zeros(length(C_x),2);
locs(:,1) = C_x;
locs(:,2) = C_y;

dist = a:1:b;
K_t = RipleysK(locs, dist, [a, b, a, b]);
plot(dist,K_t);
title('$\hat{K}$ function','Interpreter','latex','FontSize',14);
xlabel('$r$','Interpreter','latex','FontSize',14);
ylabel('$\hat{K}(r)$','Interpreter','latex','FontSize',14);
csvwrite('test.csv',locs);

“RipleysK”功能可在以下网址找到:http: //www.colorado.edu/geography/class_homepages/geog_4023_s07/labs/lab10/RipleysK.m

相比之下,我使用的是以下 R 脚本。

mydata <- read.csv("test.csv",header=F)
mydata
w <- owin(xrange = c(0,50),yrange = c(0,50))
pp <- as.ppp(mydata,w)
K <- Kest(pp,correction = "none")
plot(K)

Matlab 为指定的 r 值(即 dist)估计 K,而 R 脚本不估计(估计直到 r = 12.5)。

有人可以评论吗?哪一个是正确的?我们可以在 R 脚本中指定 r 值吗?

谢谢

4

1 回答 1

0

我没有看过matlab代码,但我很确定包Kest中的spatstat计算是正确的。从您自己的评论来看,这似乎也没有冲突——它们只是做了两件不同的事情:matlab 代码针对 r 的一个特定值评估 K 函数的估计值,而Kest对一系列 r 值进行评估(它还计算不同估计量的集合)。默认情况下,它计算 r 的 513 个值的估计值,查看它们的最简单方法是转换为 a data.frame(继续您的代码):

Kdf <- as.data.frame(K)
head(Kdf)

或者,您可以将函数值 ( fv) 对象K转换为正常的 R 函数,并在 r 的相关值处对其进行评估(这会自动在可用的估计器中选择“最佳”估计器(通常是 Ripley 的等向校正估计器)):

Kf <- as.function(K)
Kf(12.5)
于 2015-08-16T23:35:29.763 回答