R语言 在横断面上创建等距点的问题

5vf7fwbs  于 2023-10-13  发布在  其他
关注(0)|答案(1)|浏览(136)

我尝试使用CurveTransect在横断面上创建等距点。https://github.com/esbach/CurveTransect
但是,我总是遇到一个错误。

transectXY = data.frame(matrix(nrow=11, ncol=2))
colnames(transectXY) = c("x", "y")
transectXY$x = c(1096002, 1096052, 1096002, 1095952, 1096002, 1096052, 1096002, 1095952, 1096002, 1096052, 1096002)
transectXY$y = c(-39178.7, -39078.7, -38978.7, -38878.7, -38778.7, -38678.7, -38578.7, -38478.7, -38378.7, -38278.7, -38178.7)
transectXY = data.matrix(transectXY)
library(Orcs) #coords2Line
transect = coords2Lines(transectXY, ID="A") # transectXY into line
library(smoothr) #curve smoothing
transect = smooth(transect, method="chaikin") # smooth line
projected = CRS("+proj=utm +zone=17 +ellps=intl +units=m +datum=WGS84 +no_defs") # add a crs
proj4string(transect) = projected

plot(transect)
print(plot)

library(rgeos) # gLength
length = round(gLength(transect))

transectXY = data.matrix(transect@lines[[1]]@Lines[[1]]@coords)
**transectXY = observerXY(transect=transectXY, spacing=1)**   in this step!!

is.data.frame(frame)中的错误:试图从一个没有槽的基本类(“matrix”)的对象中获取槽“行”
我解决不了这个问题。有人能帮帮我吗?谢谢你,谢谢
此错误消息表示该函数试图从类“matrix”的对象访问名为“lines”的插槽,该对象没有任何插槽。
在将矩阵传递给observerXY()函数之前,我尝试使用as.data.frame()函数将其转换为 Dataframe 。
然而,它不能工作。

bhmjp9jg

bhmjp9jg1#

看起来这个例子与正确版本的函数“XnverXY”不匹配。该函数接受一个SpatialLinesDataFrame,并自动执行您发布的倒数第二行(即,您不需要transectXY = data.matrix(transect@lines[[1]]@Lines[[1]]@coords)
length = round(gLength(transect))之后,您可以使用以下命令:

transectXY = observerXY(transect=transect, spacing=1)

这是一个完全可重复的结果:

library(Orcs)
library(smoothr)
library(sp)
library(CurveTransect)

transectXY = data.frame(matrix(nrow=11, ncol=2))
colnames(transectXY) = c("x", "y")
transectXY$x = c(1096002, 1096052, 1096002, 1095952, 1096002, 1096052, 1096002, 1095952, 1096002, 1096052, 1096002)
transectXY$y = c(-39178.7, -39078.7, -38978.7, -38878.7, -38778.7, -38678.7, -38578.7, -38478.7, -38378.7, -38278.7, -38178.7)
transectXY = data.matrix(transectXY)
transect = coords2Lines(transectXY, ID="A") # transectXY into line
transect = smooth(transect, method="chaikin") # smooth line
projected = CRS("+proj=utm +zone=17 +ellps=intl +units=m +datum=WGS84 +no_defs") # add a crs
proj4string(transect) = projected

transectXY = observerXY(transect=transect, spacing=100)

coordinates(transectXY) = ~x.obs + y.obs

plot(transect)
points(transectXY, col="red", pch=20)

相关问题