Накладання просторового багатокутника з сіткою та перевірка того, у яких конкретних координатах елемента сітки розташовані за допомогою R [закрито]


32

Як можна використовувати R для

  1. розділіть форму форми на 200 / квадратні підполігони,
  2. побудуйте цю сітку (включаючи ідентифікаційні номери для кожного квадрата) над початковою картою нижче та
  3. оцінити, в якому квадраті розташовані конкретні географічні координати .

Я початківець в ГІС, і це, мабуть, основне питання, але я не знайшов підручника, як це зробити в Р.

Що я вже робив, це завантажувати файл форми 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-метод для отримання ідентифікаторів комірок:

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

Щоб побудувати графік форми та сітку з ідентифікаторами комірок:

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 stackoverflow.com/search?q=R+tag
Бред Nesom

@rcs цей код схожий на те, що я намагаюся зробити, але мій файл форми є в іншій проекції: proj4string (DK_reg1) [1] "+proj=longlat +datum=WGS84 +no_defs +ellps=WGS84 +towgs84=0,0,0" чи є хтось із пропозицій про те, як розбити ці файли форм цієї проекції на 1000 осередків сітки однакового розміру? а потім випадковим чином вибрати 100 з них і виділити їх?
I Del Toro

9

Нью-Йоркський набір даних, наданий у запитанні, більше не доступний для завантаження. Я використовую набір даних nc з пакету sf, щоб продемонструвати рішення за допомогою пакету 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)

введіть тут опис зображення


Спасибі. Я оновив посилання у своєму питанні, щоб повторно змінити зміни на їх веб-сторінці. Тепер він повинен працювати знову.
18:18

Мені справді потрібно почати користуватися sfпакетом. Це круто!
philiporlando

Чи є простий спосіб побудувати лише клітинки сітки, які перетинаються з полігоном стану?
philiporlando

st_intersection (grid_50, nc) повинен це зробити
sebdalgarno

Чи є спосіб повторити те саме, але точки в центрі кожної сітки, тож сітка малюється з lat / long як центр сітки @sebdalgarno
Vijay Ramesh

2

Якщо ви ще не переглянули растровий пакет R, у нього є інструменти для перетворення в / з векторних GIS-об'єктів, тому ви повинні мати можливість: a) створити растр (сітку) з клітинками 200x200m і b) перетворити його на набір полігонів за допомогою якийсь логічний ідентифікатор. Звідти я поглянув на пакет sp, щоб допомогти в перетині точок та сітці багатокутника. Ця http://cran.r-project.org/web/packages/sp/vignettes/over.pdf сторінка може стати хорошим початком. Подорожуючи документами пакету sp, ви можете почати з класу SpatialGrid і повністю пропустити растрову частину.


-1

"Всесвіт ГІС" є складним і має багато стандартів, згідно з якими ваші дані повинні відповідати. Усі "інструменти ГІС" взаємодіють за GIS-стандартами . Усі "серйозні дані ГІС" сьогодні (2014 р.) Зберігаються в базі даних .

Найкращий спосіб "використовувати R" в контексті ГІС з іншими інструментами FOSS - вбудований у SQL. Найкращими інструментами є PostgreSQL 9.X (див. PL / R ) та PostGIS .


Ви відповідаєте:

  • Для імпорту / експорту файлів форм: використовуйте shp2pgsqlтаpgsql2shp .
  • Для того, щоб «розбити файл форми в 200 метрових квадратах / суб-багатокутники»: см ST_SnapToGrid(), ST_AsRaster()і т.д. Нам потрібно краще зрозуміти , ваші потреби , щоб висловити в «рецепт».
  • ви говорите, що потрібні "географічні координати розташовані" .. можливо, ST_Centroid()квадратів (?) ... Ви можете висловити "більш математично", щоб я зрозумів.

... Можливо, вам не потрібна будь-яка растрова конверсія, лише матриця точок, відібраних у регюляр.


Примітивний спосіб - це використання R без PL / R у звичайному зовнішньому компіляторі: конвертуйте лише свої багатокутники та експортуйте у формі або як WKT (див. ST_AsText), А потім конвертуйте дані за допомогою awk або іншого фільтра у формат R.


1
Спасибі за вашу допомогу. Однак я б наголосив на рішенні, яке повністю покладається на R та існуючі пакети. Коли я в змозі розділити файл фігури на підполігони 200м * 200м, я можу перевірити, з point.in.polygonякими координатами входять багатокутники. Моя проблема полягає в тому, щоб розділити оригінальний файл форми на ці підполігони.
majom
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.