空間ポリゴンにグリッドをオーバーレイし、Rを使用してグリッド要素固有の座標がどこにあるかを確認


32

どのようにR使用して

  1. シェープファイルを200メートルの正方形/サブポリゴンに分割し
  2. 以下の元のマップ上にこのグリッド(各正方形のID番号を含む)をプロットし
  3. 特定の地理座標がどの正方形にあるかを評価します

私はGISの初心者であり、これはおそらく基本的な質問ですが、Rでこれを行う方法に関するチュートリアルは見つかりませんでした。

これまでに行ったことは、NYCのシェープファイルを読み込んで、いくつかの典型的な地理座標をプロットすることです。

以下のデータを使用してこれを行う例(Rコード)を探しています。

# Load packages 
library(maptools)

# Download shapefile for NYC
# OLD URL (no longer working)
# shpurl <- "http://www.nyc.gov/html/dcp/download/bytes/nybb_13a.zip"
shpurl <- "https://www1.nyc.gov/assets/planning/download/zip/data-maps/open-data/nybb_13a.zip"

tmp    <- tempfile(fileext=".zip")
download.file(shpurl, destfile=tmp)
files <- unzip(tmp, exdir=getwd())

# Load & plot shapefile
shp <- readShapePoly(files[grep(".shp$", files)])
plot(shp)

# Define coordinates 
points_of_interest <- data.frame(y=c(919500, 959500, 1019500, 1049500, 1029500, 989500), 
                 x =c(130600, 150600, 180600, 198000, 248000, 218000),
                 id  =c("A"), stringsAsFactors=F)

# Plot coordinates
points(points_of_interest$y, points_of_interest$x, pch=19, col="red")

ここに画像の説明を入力してください


回答:


36

SpatialGridオブジェクトを使用した例を次に示します。

### read shapefile
library("rgdal")
shp <- readOGR("nybb_13a", "nybb")

proj4string(shp)  # units us-ft
# [1] "+proj=lcc +lat_1=40.66666666666666 +lat_2=41.03333333333333 
# +lat_0=40.16666666666666 +lon_0=-74 +x_0=300000 +y_0=0 +datum=NAD83
# +units=us-ft +no_defs +ellps=GRS80 +towgs84=0,0,0"

### define coordinates and convert to SpatialPointsDataFrame
poi <- data.frame(x=c(919500, 959500, 1019500, 1049500, 1029500, 989500),
                  y=c(130600, 150600, 180600, 198000, 248000, 218000),
                  id="A", stringsAsFactors=F)
coordinates(poi) <- ~ x + y
proj4string(poi) <- proj4string(shp)

### define SpatialGrid object
bb <- bbox(shp)
cs <- c(3.28084, 3.28084)*6000  # cell size 6km x 6km (for illustration)
                                # 1 ft = 3.28084 m
cc <- bb[, 1] + (cs/2)  # cell offset
cd <- ceiling(diff(t(bb))/cs)  # number of cells per direction
grd <- GridTopology(cellcentre.offset=cc, cellsize=cs, cells.dim=cd)
grd
# cellcentre.offset 923018 129964
# cellsize           19685  19685
# cells.dim              8      8

sp_grd <- SpatialGridDataFrame(grd,
                               data=data.frame(id=1:prod(cd)),
                               proj4string=CRS(proj4string(shp)))
summary(sp_grd)
# Object of class SpatialGridDataFrame
# Coordinates:
#      min     max
# x 913175 1070655
# y 120122  277602
# Is projected: TRUE
# ...

これで、実装された over -methodを使用してセルIDを取得。

over(poi, sp_grd)
#   id
# 1 57
# 2 51
# 3 38
# 4 39
# 5 14
# 6 28

セルIDでシェープファイルとグリッドをプロットするには:

library("lattice")
spplot(sp_grd, "id",
       panel = function(...) {
         panel.gridplot(..., border="black")
         sp.polygons(shp)
         sp.points(poi, cex=1.5)
         panel.text(...)
       })

spplot1

カラー/カラーキーなし:

library("lattice")
spplot(sp_grd, "id", colorkey=FALSE,
       panel = function(...) {
         panel.gridplot(..., border="black", col.regions="white")
         sp.polygons(shp)
         sp.points(poi, cex=1.5)
         panel.text(..., col="red")
       })

spplot2


これは私の答えのように見えますが、何か違うものを探している場合に備えて。stackoverflowでrタグを試してくださいstackoverflow.com/search?q=R+tag
Brad Nesom

@rcsこのコードは私がやろうとしているもののように見えますが、私のシェープファイルは別のプロジェクションにあります: proj4string (DK_reg1) [1] "+proj=longlat +datum=WGS84 +no_defs +ellps=WGS84 +towgs84=0,0,0" このプロジェクションのこのシェープファイルを1000個の等しいサイズのグリッドセルに分割する方法についての提案はありますか?ランダムに100個を選択して強調表示しますか?
I・デル・トロ

9

質問で提供されたニューヨークのデータセットはダウンロードできなくなりました。sfパッケージのncデータセットを使用して、sfパッケージを使用したソリューションを示します。

library(sf)
library(ggplot2)

# read nc polygon data and transform to UTM 
nc <- st_read(system.file('shape/nc.shp', package = 'sf')) %>%
  st_transform(32617)

# random sample of 5 points
pts <- st_sample(nc, size = 5) %>% st_sf

# create 50km grid - here you can substitute 200 for 50000
grid_50 <- st_make_grid(nc, cellsize = c(50000, 50000)) %>% 
  st_sf(grid_id = 1:length(.))

# create labels for each grid_id
grid_lab <- st_centroid(grid_50) %>% cbind(st_coordinates(.))

# view the sampled points, polygons and grid
ggplot() +
  geom_sf(data = nc, fill = 'white', lwd = 0.05) +
  geom_sf(data = pts, color = 'red', size = 1.7) + 
  geom_sf(data = grid_50, fill = 'transparent', lwd = 0.3) +
  geom_text(data = grid_lab, aes(x = X, y = Y, label = grid_id), size = 2) +
  coord_sf(datum = NA)  +
  labs(x = "") +
  labs(y = "")

# which grid square is each point in?
pts %>% st_join(grid_50, join = st_intersects) %>% as.data.frame

#>   grid_id                 geometry
#> 1      55 POINT (359040.7 3925435)
#> 2      96   POINT (717024 4007464)
#> 3      91 POINT (478906.6 4037308)
#> 4      40 POINT (449671.6 3901418)
#> 5      30 POINT (808971.4 3830231)

ここに画像の説明を入力してください


ありがとう。質問のリンクを更新して、彼らのWebページの変更を反映させました。これで再び動作するはずです。
マジョム

私は本当にsfパッケージの使用を開始する必要があります。これはすごい!
philiporlando

状態ポリゴンと交差するグリッドセルのみをプロットする簡単な方法はありますか?
philiporlando

st_intersection(grid_50、nc)はそれを行う必要があります
sebdalgarno

同じことを複製する方法はありますが、各グリッドの中心にある点なので、グリッドはグリッドの中心として緯度/経度で描画されています@sebdalgarno
Vijay Ramesh

2

Rラスターパッケージをまだ見ていない場合は、ベクターGISオブジェクトとの間で変換するツールがあるため、a)200x200mのセルでラスター(グリッド)を作成し、b)でポリゴンセットに変換することができます。ある種の論理ID。そこから、spパッケージを見て、ポイントとポリゴングリッドの交差を支援します。このhttp://cran.r-project.org/web/packages/sp/vignettes/over.pdfページは良い出発点です。spパッケージドキュメントをさまようと、SpatialGridクラスから始めて、ラスター部分を完全にスキップできるかもしれません。


-1

「GISユニバース」は複雑であり、データが準拠する必要がある多くの標準があります。すべての「GISツール」は、GIS標準に従って相互運用します。今日(2014年)のすべての「深刻なGISデータ」 はデータベースに保存されます

他のFOSSツールを使用して、GISコンテキストで「Rを使用する」最良の方法は、SQLに組み込まれています。最適なツールは、PostgreSQL 9.XPL / Rを参照)およびPostGISです。


あなたは答えます:

  • 形状ファイルをインポート/エクスポートするには:とを使用shp2pgsqlしますpgsql2shpます。
  • 「形状ファイルを200メートルの正方形/サブポリゴンに分割するには」を参照してくださいST_SnapToGrid()ST_AsRaster()などを我々は「レシピ」に表現するために、より良いあなたのニーズを理解する必要が。
  • 「地理座標が配置されている」必要があると言います。..おそらくST_Centroid()正方形(?)...

...おそらく、ラスター変換は不要で、通常のサンプリングポイントのマトリックスのみが必要です。


基本的な方法は、通常の外部コンパイラでPL / Rを使用せずにRを使用することです:ポリゴンを変換し、シェイプまたはWKT(を参照ST_AsText)としてエクスポートしてから、awkまたは別のフィルターでデータをR形式に変換します。


1
ご協力いただきありがとうございます。ただし、Rと既存のパッケージに完全に依存するソリューションを強くお勧めします。シェープファイルを200m * 200mのサブpoint.in.polygonポリゴンに分割できる場合、どの座標がどのポリゴンにあるかを確認できます。私の問題は、元のシェープファイルをこれらのサブポリゴンに分割することです。
マジョム14年
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.