首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >geosphere::areaPolygon根据折点的排序返回不同的结果

geosphere::areaPolygon根据折点的排序返回不同的结果
EN

Stack Overflow用户
提问于 2019-11-10 20:24:00
回答 1查看 56关注 0票数 0

我正在尝试计算用纬度和经度定义的多边形的面积:

代码语言:javascript
复制
example_polygon <- data.frame(
  lat = c(42.7093213,42.7079761,42.7093941,42.7080938,42.7093213), 
  lon = c(23.3194939,23.3194379,23.3194379,23.3182881,23.3194939)
) # last point equals first point

使用geosphere包中的函数areaPolygon

代码语言:javascript
复制
geosphere::areaPolygon(cbind(example_polygon$lon, example_polygon$lat))
[1] 350.9063

但是,我注意到,如果对多边形中的点进行重新排序,则会得到不同的结果:

代码语言:javascript
复制
example_scrambled <- example_polygon[c(2,1,3,4,2),]
geosphere::areaPolygon(cbind(example_scrambled$lon, example_scrambled$lat))
[1] 7780.469

我的问题是,结果中出现这种差异的原因是什么(函数文档没有提到排序问题)?有没有一种正确的方法来排序多边形中的点,它是什么?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-11-10 21:45:45

把它们都画出来,你就能明白原因了:

代码语言:javascript
复制
par(mfrow=c(1,2))
plot(example_polygon, type = "l")
plot(example_scrambled, type = "l")

它们是完全不同的多边形。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/58788614

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档