Випадкова вибірка растру з використанням 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 пакета , розділ 5.2. Ось один із способів:

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) НЕ ПРАВДА?
csheth

2

Ви можете використовувати sampleRandomфункцію:

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

x <- sampleRandom(r, ncell(r)*.3, asRaster=TRUE)
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.