第一篇文章:)
我一直在将我的 R 代码从 sp() 转换为 sf()/stars(),而我仍在努力掌握的一件事是考虑我的网格中的区域。
这是一个示例代码来解释我的意思。
library(stars)
library(tidyverse)
# Reading in an example tif file, from stars() vignette
tif = system.file("tif/L7_ETMs.tif", package = "stars")
x = read_stars(tif)
x
# Get areas for each grid of the x object. Returns stars object with "area" in units of [m^2]
x_area <- st_area(x)
x_area
我尝试从这个小插图(https://github.com/r-spatial/stars/blob/master/vignettes/stars5.Rmd)松散地采用代码来将 x 中的每个值除以其网格区域,它没有按预期工作(也许是因为我的对象是星星而不是科幻?)
x$test1 = x$L7_ETMs.tif / x_area # Some computationally intensive calculation seems to happen, but doesn't produce the results I expect?
x$test1 = x$L7_ETMs.tif / x_area$area # Throws error, "non-conformable arrays"
似乎有效的方法如下。
x %>%
mutate(test1 = L7_ETMs.tif / units::set_units(as.numeric(x_area$area), m^2))
以下是我对这段代码的担忧。
我担心当我将 x_area$area(一个矩阵,纬度/经度的区域)转换为数字向量时,我可能会弄乱网格与其区域之间的纬度/经度匹配。我做了一些粗略的测试,看看这些区域是否符合我的预期,但我无法避免担心这可能会导致难以捕捉的错误。
我以正确的单位从“x_area”开始,只是在计算过程中删除然后再次设置单位,这似乎并不干净。
有人可以为我正在尝试做的事情建议一个“更清洁”的实现,即在保持整个单位的同时将网格乘以或除以其面积?或者说服我我的代码没问题?
谢谢!