1

我一直在尝试计算满足 R 特定条件的三个光栅文件的像素数(在 Windows 10 和 R 版本 3.6.3 中)。这个想法是使用这三个图像(它们是预处理的)并计算满足if以下代码语句中的条件的像素数量。

library(rgdal)
library(raster)  

mydir<- file.path("D:/files")
    setwd(mydir)

    listado1 <- list.files(pattern="crNDVI*")
    listado2 <- list.files(pattern="crNBR*")
    listado3 <- list.files(pattern="dNBR*")

    df <- data.frame(NULL)


    for (i in 1:length(listado1)) {
      r1 <- raster(listado1[i])
      v1 <- values(r1)

      for (j in 1:length(listado2)) {
        r2 <- raster(listado2[j])
        v2 <- values(r2)

        for (k in 1:length(listado3)) {
          r3 <- raster(listado3[k])
          v3 <- values(r3)

          if ((i==j) & (j==k)){

            df2 <- data.frame(NULL)
            df2 <- data.frame(v1, v2, v3)
            burn <- subset(df2, df2$v1 >= 0.3 & df2$v1 <= 1.0 & df2$v2 >= 0.2 & df2$v2 <= 1.3 & df2$v3 > 0.1 & df2$v3 <= 1.3)
            burned_area <- nrow(burn)*(xres(r1)*yres(r1))*10^(-4) # Hectares

            name <- paste(substr(listado1[i], 8, 15), sep="")
            df <- rbind(df, data.frame(name,burned_area))
            print(paste("iteracion:",i,j,k," ok",sep = " "))

          }
          else {
            print(paste("iteracion:",i,j,k," passed",sep = " "))
            invisible()}

        }
      }
    }

    write.csv(df,file = "burned_area.csv")

可以观察到,我有三种类型的预处理光栅 ( ) 文件,它们以和*.tif开头crNDVI,所有这些文件都列在每个“ ”变量中。这个想法是迭代每种类型的文件并每天获取每个光栅文件的值。代码做了它应该做的(我得到了带有烧毁区域的文件(满足条件的像素),但是,它需要永远计算,因为每个光栅文件对应于特定的一天,因此结果是每天的值。因此,发生这种情况的唯一可能性是 when ,但应用后一个代码,迭代会遍历循环中的每个可能性。代码从 i=1 开始,然后 j=1,然后 k=1,2,3.. . 直到最后一个文件crNBRdNBRlistado.csvburned_areai=j=kforlistado3[k],并且当长度listado3[k]结束时,它传递到以下j+1索引并再次循环k到每个(不必要的)迭代中。

谁能帮助我以更有效的方式做同样的事情?是否有可能对i=j=k整个嵌套for循环强制“仅”?非常感谢您的任何建议。提前感谢,豪尔赫。

注意:所有栅格文件的范围相同nrowncolncell

4

2 回答 2

1

嵌套循环需要什么?如果您使用一个循环,那么 i=j=k 将始终为真。

于 2020-03-31T20:09:39.313 回答
0

这是一个最小的独立示例。

library(raster)
set.seed(0)
r1 <- raster(nrow=10, ncol=10, vals=1:100) / 100
r2 <- raster(nrow=10, ncol=10, vals=c(1:50, 50:1)) / 100
r3 <- raster(nrow=10, ncol=10, vals=c(rep(1, 10), 11:100)) / 100

x <- ((r1==r2) & (r2==r3))
s <- stack(r1, r2, r3)
s <- mask(s, x, maskvalue=1)
于 2020-03-31T23:36:22.407 回答