R의 모자이크 래스터?


10

에 게시 것을 나는 스크립트를 사용하여 R.에서 하나의 큰 래스터에 모자이크 여러 래스터에 노력하고 /programming/15287807/how-can-i-create-raster-mosaic-using-list-of-rasters 그러나 경고 메시지와 오류 메시지가 나타납니다.

rasters1 <- list.files("F:\\MOD15A2_LAI_1km\\MOD15A2_LAI_2009", 
                      pattern = "mod15a2.a2009001.*.005.*.img$", 
                      full.names = TRUE, recursive = TRUE)

mos1 <-mosaic(rasters1, fun=mean)

아래와 같이 오류를보고했습니다

Error in (function (classes, fdef, mtable)  : 
  unable to find an inherited method for function ‘extent’ for signature ‘"character"

그런 다음 다른 버전을 시도했습니다.

rasters1.mosaicargs <- rasters1
rasters1.mosaicargs$fun <- mean

그러나 여기에 아래와 같은 경고 메시지가 있습니다.

Warning message:
In rasters1.mosaicargs$fun <- mean : Coercing LHS to a list

나는 그 메시지를 무시하고 계속했다

mos2 <- do.call(mosaic, rasters1.mosaicargs)

그러나 위에서 언급 한 것과 동일한 오류

Error in (function (classes, fdef, mtable)  : 
  unable to find an inherited method for function ‘mosaic’ for signature ‘"character", "character"

답변:


17

여기서의 문제는 mosaic 및 do.call이 "rasters1"벡터에 포함 된 래스터의 문자 이름뿐만 아니라 목록에 래스터 객체를 예상한다는 것입니다. 실제로 래스터 객체가 아닌 벡터에 이름을 모자이크로 표시하려고합니다.

# Create some example data
require(raster)
    r <- raster(ncol=100, nrow=100)
      r1 <- crop(r, extent(-10, 11, -10, 11))
        r1[] <- 1:ncell(r1)
          r2 <- crop(r, extent(0, 20, 0, 20))
          r2[] <- 1:ncell(r2)
      r3 <- crop(r, extent(9, 30, 9, 30))
    r3[] <- 1:ncell(r3)

# If I create a list object of the raster names, as your are doing with list.files, 
#    do.call will fail with a character signature error 
rast.list <- list("r1","r2","r3")   
  rast.list$fun <- mean     
    rast.mosaic <- do.call(mosaic,rast.list)

# However, if I create a list contaning raster objects, the do.call function 
#   will work when mosaic is passed to it.      
rast.list <- list(r1, r2, r3)     
  rast.list$fun <- mean
    rast.mosaic <- do.call(mosaic,rast.list)
      plot(rast.mosaic)

# You could specify a for loop to create a list object, 
#   contaning raster objects
rasters1 <- list.files("F:/MOD15A2_LAI_1km/MOD15A2_LAI_2009", 
                       pattern="mod15a2.a2009001.*.005.*.img$", 
                       full.names=TRUE, recursive=TRUE)
rast.list <- list()
  for(i in 1:length(rasters1)) { rast.list[i] <- raster(rasters1[i]) }

# And then use do.call on the list of raster objects
rast.list$fun <- mean
  rast.mosaic <- do.call(mosaic,rast.list)
    plot(rast.mosaic)

1

테마에 약간의 변형이 있습니다. 빈 목록for 루프 생성을 피할 수 있습니다 ...

    rast.list <- list()

    for(i in 1:length(rasters1)) { 
rast.list[i] <- raster(rasters1[i])
}

... 웃음 명령으로.

    rast.list <- lapply(1:length(rasters1),
 function(x) {
raster(rasters1[x])
})
당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.