r - 从 R 导出克里格值
问题描述
有没有人对如何从 R 中的克里格数据导出值有任何建议。我将它们导出为栅格,但我需要实际的单元格值。我正在使用的数据是鱼的密度。我正在对数据进行克里格法,然后将密度转换为丰度。但是为了转换为丰度,我需要 .csv 格式的克里格值。
下面是我正在使用的代码:
library(sp)
library(gstat)
library(raster)
library(automap)
library(ggplot2)
library(rgdal)
library(maptools)
fsite.fit=fit.variogram(fsite.vario, vgm(model="Sph",psill=fmy.psill,range=fmy.range,nugget=fmy.nugget),
fit.method=1)
fXloc = data.frame(Data.krig)$fXloc
fYloc = data.frame(Data.krig)$fYloc
fsite.chull = chull(fXloc,fYloc)
plot(fXloc,fYloc)
lines(fXloc[fsite.chull],fYloc[fsite.chull])
fsite.grid = polygrid(
xgrid=seq(min(fXloc),max(fXloc),length=100),
ygrid=seq(min(fYloc),max(fYloc),length=100),
cbind(
fXloc[fsite.chull],
fYloc[fsite.chull]))
names(fsite.grid)=c("fXloc","fYloc")
coordinates(fsite.grid)=c("fXloc","fYloc")
fsite.grid = as(fsite.grid, "SpatialPixels")
plot(fYloc~fXloc,cex=1.2,pch=20,col=2)
points(data.frame(fsite.grid)$fXloc,data.frame(fsite.grid)$fYloc,pch="+")
fsite.ok = krige(fADens~1, Data.krig, fsite.grid, fsite.fit)
现在我想要的是在 fsite.grid 中导出 fsite.ok 但我无法将它们加入同一个数据框中。我不知道从这里去哪里。请让我知道您是否希望我添加任何其他内容。目前,我不允许分享我的数据。
解决方案
这是一个最小的、可重现的示例gstat
。看起来您对 object 感兴趣fsite.ok
。大概是一个Spatial*DataFrame
。
示例代码
library(gstat)
library(sp)
data(meuse)
coordinates(meuse) = ~x+y
data(meuse.grid)
gridded(meuse.grid) = ~x+y
meuse.gstat <- gstat(id = "zinc", formula = zinc ~ 1, data = meuse,
nmax = 7, set = list(idp = .5))
meuse.gstat
z <- predict(meuse.gstat, meuse.grid)
现在你可以做
d <- data.frame(z)
write.csv(d, "values.csv", row.names=FALSE)
所以在你的例子中
write.csv(data.frame(fsite.ok), "values.csv", row.names=FALSE)
推荐阅读
- sql - 当行为空时,翻转上一行的值
- java - Java:从字符串数组中挑选出随机短语
- c# - 修复元素不可交互的硒 C#
- html - 在按钮或按钮本身中设置文本样式,使其不占用额外的垂直空间
- vba - 关闭子表单,删除主表单过滤器并返回原始记录
- java - Java 数组值被覆盖
- java - 尝试访问从资产复制的数据库时出错 - AndroidStudio
- vue.js - Vuejs输入表单意外的令牌
- amazon-web-services - 自动检测 Ansible 的 EC2 实例 ssh/sudo 用户
- python-3.x - 无法从 GtkDialog 中 GtkListBox 上的单击事件中更新 GtkIconView