6

我在“足迹”形状高度不规则的区域中有一系列点:

LE82

我想确定足迹顶点内的所有坐标。最终目标是确定哪些数据点位于此足迹之外。

有没有人有一种有效的方法来做到这一点?


我最好的解决方法是根据绿色区域的顶点绘制一个多边形,然后使用所述多边形的坐标来确定“离群点”(不过,我还不确定如何做到这一点——一次一步!)。

然而,当我尝试创建一个凸包时,由于我的绿色空间的不规则形状,它显然会产生问题。[有人知道创建凹形船体的方法吗?]

或者,有没有办法使用“单击图形”类型的方法手动绘制多边形?


...再次,如果您对我的问题有比使用多边形更好的解决方案,请务必提出该解决方案!

4

1 回答 1

4

或者,有没有办法使用“单击图形”类型的方法手动绘制多边形?

这是一个想法。首先,一些随机点:

library(manipulate)
library(sp)
set.seed(1)
par(pch = 19, cex=.5)
x <- runif(1000)
y <- runif(1000)

现在,绘制并捕获多边形:

coords <- data.frame()
manipulate({
  plot(y~x)
  res <- manipulatorMouseClick()
  coords <<- rbind(coords, data.frame(x=res$userX, y=res$userY))
  if (length(coords)) lines(coords)
})

在此处输入图像描述

并确定哪些点在其内部/外部(请参阅?point.in.polygon):

res <- point.in.polygon(x, y, coords$x, coords$y)!=0 

plot(y~x, col = res + 1L)
lines(coords)

在此处输入图像描述

于 2016-09-19T20:55:39.190 回答