Rを使用したラスターのランダムサンプリング?


13

プロセスの出力がラスタになるように、ラスタをランダムにサンプリングする簡単な方法はありますか?

r-sig-geo リストにある例を使用していsampleRandomますが、rasterパッケージ内の関数も試しました。これらのアプローチはどちらも出力を生成しますが、ラスターに変換する方法がわかりません。「SpatialPointsDataFrameラスター」のいくつかの組み合わせを検索した後、アプローチを見つけることができませんでした。

library(raster)

# read in raster
rasterSource <- 'landsat.TIF'
r <- raster(rasterSource)

# convert to spatial points data frame
r.spgrd<-as(r,"SpatialPointsDataFrame") 

# elminate NA values
r.spgrd = r.spgrd[!is.na(r.spgrd[[1]]),] 

# sample points
selectedPoints = sample(1:length(r.spgrd[[1]]), 1000)
r.sampled = r.spgrd[selectedPoints,]

# try to make spgrd into a raster
r.test <- raster(r.sampled)

実行するr.testと出力が得られます:

class       : RasterLayer 
dimensions  : 10, 10, 100  (nrow, ncol, ncell)
resolution  : 28617, 14766  (x, y)
extent      : 1838505, 2124675, 2328685, 2476345  (xmin, xmax, ymin, ymax)
coord. ref. : +proj=aea +lat_1=29.5 +lat_2=45.5 +lat_0=23 +lon_0=-96 +x_0=0 +y_0=0 +datum=WGS84 +units=m +no_defs +ellps=WGS84 +towgs84=0,0,0 
values      : none

したがって、ラスターを書き込もうとする次の行はメッセージを生成します。

# write out as ascii file
writeRaster(r.test, filename="test1.ASC", datatype="ascii", overwrite=TRUE)

Error: hasValues(x) is not TRUE

私の主な目的は、サンプリングプロセス後に何らかのタイプのラスターを作成することです。また、ラスター内の値を変更するだけでも問題ありません(その方法がわからないだけです)。

回答:


21

Rasterパッケージvignetteのセクション5.2の例を適用できます。1つの方法を次に示します。

r <- raster(ncol=30,nrow=20)
r[] <- 1:(30*20)              # Raster for testing
#plot(r)                      # (If you want to see it)
r[runif(30*20) >= 0.30] <- NA # Randomly *unselect* 70% of the data
plot(r)

ラスター選択


10
この答えは...私はRを学びたくなる
SaultDon

2
これは非常に明白かもしれませんが、任意のセルの値がで参照できることを理解するのに時間がかかりましたr[r "condition"]。あなたは、ラスタのすべての値を設定したいのであれば100あることを1あなたが書くことができますがr[r == 100] <- 1。ありがとう@whuber-非常に便利な例!
djq

@whuberエラー:hasValues(x)がTRUEにならない理由は何ですか?
csheth

2

次のsampleRandom機能を使用できます。

library(raster)
r <- raster(ncol=30,nrow=20)
r[] <- 1:ncell(r)

x <- sampleRandom(r, ncell(r)*.3, asRaster=TRUE)
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.