rasterパッケージは「セル(ドット)の並びでデータを表現する」多くのコマンドが収録されています。パッケージの中から、日常用途に使いそうなコマンドをまとめました。
パッケージのバージョンは3.5-15。実行コマンドはwindows 11のR version 4.1.3で確認しています。
パッケージのインストール
下記コマンドを実行してください。
#パッケージのインストール install.packages("raster")
実行コマンド
詳細はコマンド、パッケージヘルプを確認してください。
#パッケージの読み込み library("raster") ###簡単な例##### #rasterレイヤーの作成:rasterコマンド x <- raster() ##構成の確認 #データは空です x class : RasterLayer dimensions : 180, 360, 64800 (nrow, ncol, ncell) resolution : 1, 1 (x, y) extent : -180, 180, -90, 90 (xmin, xmax, ymin, ymax) coord. ref. : +proj=longlat +datum=WGS84 +ellps=WGS84 +towgs84=0,0,0 #ピクセルサイズの変更:resコマンド #値を大きくすると画質が荒くなります #レイヤーサイズが変わります res(x) <- 30 x class : RasterLayer dimensions : 6, 12, 72 (nrow, ncol, ncell) resolution : 30, 30 (x, y) extent : -180, 180, -90, 90 (xmin, xmax, ymin, ymax) coord. ref. : +proj=longlat +datum=WGS84 +ellps=WGS84 +towgs84=0,0,0 #レイヤーにデータを代入:valuesコマンド #data source,names,values values(x) <- matrix(sample(1:300, 72, replace = TRUE), 6, 12) x class : RasterLayer dimensions : 6, 12, 72 (nrow, ncol, ncell) resolution : 30, 30 (x, y) extent : -180, 180, -90, 90 (xmin, xmax, ymin, ymax) coord. ref. : +proj=longlat +datum=WGS84 +ellps=WGS84 +towgs84=0,0,0 data source : in memory names : layer values : 5, 298 (min, max) #データの計算コマンド:calcコマンド #コマンドを実行すると新規にラスターデータが作成されます calc(x, function(x) { x * 2}) class : RasterLayer dimensions : 6, 12, 72 (nrow, ncol, ncell) resolution : 30, 30 (x, y) extent : -180, 180, -90, 90 (xmin, xmax, ymin, ymax) coord. ref. : +proj=longlat +datum=WGS84 +ellps=WGS84 +towgs84=0,0,0 data source : in memory names : layer values : 10, 596 (min, max) #データの分布を確認:densty,histコマンド density(x) hist(x) #特定セルのデータを取得する方法 #RasterLayer[i]で指定:iはセル番号 x[23] 120 #RasterLayer[rowNo, ColNo] x[2, 11] 120 #x,yのデータ範囲からセル番号を取得:cellFromXYコマンド #データをプロットすると理解しやすいです cellFromXY(x, c(120, 50)) [1] 23 #x軸のデータ範囲から列番号を取得:colFromXコマンド colFromX(x, 120) [1] 11 #y軸のデータ範囲から列番号を取得:rowFromYコマンド rowFromY(x, 50) [1] 2 #データ範囲に含まれるセルの値を取得:fourCellsFromXYコマンド fourCellsFromXY(x, cbind(c(-150, 150), c(-50, 50))) [,1] [,2] [,3] [,4] [1,] 50 62 61 49 [2,] 24 12 11 23 #行番号を指定してセルの番号を取得:cellFromRowコマンド cellFromRow(x, 2) [1] 13 14 15 16 17 18 19 20 21 22 23 24 #列番号を指定してセルの番号を取得:cellFromColコマンド cellFromCol(x, 11) [1] 11 23 35 47 59 71 #行列を指定してセルの番号を取得:cellFromRowColコマンド cellFromRowCol(x, 2, 11) [1] 23 #x, y軸の範囲を変更:extent extent(x) <- c(0, 1, 0, 1) x class : RasterLayer dimensions : 6, 12, 72 (nrow, ncol, ncell) resolution : 0.08333333, 0.1666667 (x, y) extent : 0, 1, 0, 1 (xmin, xmax, ymin, ymax) coord. ref. : +proj=longlat +datum=WGS84 +ellps=WGS84 +towgs84=0,0,0 data source : in memory names : layer values : 5, 298 (min, max) #レイヤーをプロット plot(x) #セル色の変更 SetCol = colorRampPalette(c("#00bfd4", "#6e5f72", "#e3deda")) plot(x, col = SetCol(10)) ######## ###以降、下記rasterを使用##### ##サイズを指定しレイヤーを作成 TESTRaster <- raster(nrow = 10, ncol = 10, xmn = -1000, xmx = 1000, ymn = -100, ymx = 900) values(TESTRaster) <- sample(1:10, 10 * 10, replace = TRUE) plot(TESTRaster, col = SetCol(10)) ######## #トリミング:cropコマンド #範囲の指定:extentオプション;(xmin, xmax, ymin, ymax) #トリミングデータ1 CropRas1 <- crop(TESTRaster, extent(-300, 300, 100, 300)) plot(CropRas1) #トリミングデータ2 CropRas2 <- crop(TESTRaster, extent(-1000, -500, 600, 800)) plot(CropRas2) #ラスターデータの統合:mergeコマンド CropMerge <- merge(CropRas1, CropRas2, overlap = TRUE) plot(CropMerge, col = SetCol(10)) #切り抜き:セル番号を取得するcellsFromExtentコマンドの利用 #rasterの複製 CutOutRaster <- TESTRaster #切り抜き範囲を値で指定 CellExtent <- cellsFromExtent(CutOutRaster, extent(-500, 500, 200, 600)) #範囲をNAで置き換え CutOutRaster[CellExtent] <- NA plot(CutOutRaster, col = SetCol(10)) #周囲にセルを追加:extendコマンド #追加するセル数を指定:yオプション plot(extend(CutOutRaster, y = 1), col = SetCol(10)) #データの反転:flipコマンド #基準軸を指定:directionオプション;"x" or "y" FlipCutOutRaster <- flip(CutOutRaster, direction = "y") plot(FlipCutOutRaster, col = SetCol(10)) #データの分布を確認:layerizeコマンド plot(layerize(CutOutRaster), col = SetCol(10)) #セルではなくシンボルでプロット:rasterToPointsコマンド plot(rasterToPoints(CutOutRaster), col = SetCol(10), pch = 17) #データが無い箇所を0で埋めてラスターを結合:mosaicコマンド MosaRaster <- mosaic(CropRas1, CropRas2, fun = sum) plot(MosaRaster, col = SetCol(10))
出力例
・denstyコマンド
data:image/s3,"s3://crabby-images/17a87/17a870efcf874878ebf40b9bc50ffcfc48da8800" alt="density"
・histコマンド
data:image/s3,"s3://crabby-images/0c25d/0c25ddf6eb378ddc40148b7060da63d94c54626c" alt="hist"
・ディフォルトでプロット
data:image/s3,"s3://crabby-images/0dc91/0dc9129c908efebc034a774c4c9c1c2f5c350ab0" alt="Rasterplot"
・セル色を変更してプロット
data:image/s3,"s3://crabby-images/e6855/e68553619c6d3ad0871353d585af8cbe912ddb1d" alt="RasterCellCol"
・cropコマンド
data:image/s3,"s3://crabby-images/e1d33/e1d33d0e3661f21a573a48583fbe304e08bcd0f6" alt="crop"
・mergeコマンド
data:image/s3,"s3://crabby-images/39d19/39d192e5e0b08f6e1df445edf9d37a7ac8f787a0" alt="RasterMerge"
・cellsFromExtentコマンドの利用
data:image/s3,"s3://crabby-images/222fa/222fa3f61118b7a1a5b042d8a5f92e60df6bcd0e" alt="CutOutRaster"
・extendコマンド
data:image/s3,"s3://crabby-images/aec53/aec537223db86e91fe23c7c393a458fdb94290ab" alt="ExtendRaster"
・flipコマンド
data:image/s3,"s3://crabby-images/8450c/8450ce28c10c31bf417ca213883bfb5117bd0397" alt="RasterFlip"
・layerizeコマンド
data:image/s3,"s3://crabby-images/8a6d3/8a6d3f6ea77fd8f3dec5e8a4bc5ec747bb1d27b9" alt="layerize"
・rasterToPointsコマンド
data:image/s3,"s3://crabby-images/cf840/cf84000fc44459913f4b40d6c0455e609c908dfd" alt="rasterToPoints"
・mosaicコマンド
data:image/s3,"s3://crabby-images/a5740/a5740a039f351021a1072565922d59d056945635" alt="mosaic"
少しでも、あなたの解析が楽になりますように!!