Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/cenuno/pointdexter
Label longitudinal and latitudinal coordinates located inside a polygon.
https://github.com/cenuno/pointdexter
points polygon polygons r spatial-analysis spatial-statistics
Last synced: about 1 month ago
JSON representation
Label longitudinal and latitudinal coordinates located inside a polygon.
- Host: GitHub
- URL: https://github.com/cenuno/pointdexter
- Owner: cenuno
- Created: 2019-01-07T04:22:13.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2019-03-17T06:26:46.000Z (almost 6 years ago)
- Last Synced: 2024-08-06T03:04:16.126Z (5 months ago)
- Topics: points, polygon, polygons, r, spatial-analysis, spatial-statistics
- Language: R
- Homepage: https://cenuno.github.io/pointdexter/
- Size: 11.3 MB
- Stars: 4
- Watchers: 0
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.Rmd
- Code of conduct: .github/CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
---
output: github_document
---```{r setup, include = FALSE}
knitr::opts_chunk$set(collapse = TRUE
, comment = "#>"
, fig.path = "man/figures/README-"
, out.width = "100%"
, dpi = 300)
```# pointdexter
[![CRAN status](https://www.r-pkg.org/badges/version/pointdexter)](https://cran.r-project.org/package=pointdexter)
[![CRAN checks](https://cranchecks.info/badges/worst/pointdexter)](https://cran.r-project.org/web/checks/check_results_pointdexter.html)
[![CRAN Downloads](http://cranlogs.r-pkg.org/badges/pointdexter?color=brightgreen)](http://www.r-pkg.org/pkg/pointdexter)
[![Rdoc](http://www.rdocumentation.org/badges/version/pointdexter)](http://www.rdocumentation.org/packages/pointdexter)
[![Travis build status](https://travis-ci.org/cenuno/pointdexter.svg?branch=master)](https://travis-ci.org/cenuno/pointdexter)The `pointdexter` package labels longitudinal and latitudinal coordinates located inside a polygon.
## Description
For a singular polygon, the label for each coordinate pair is a logical vector of TRUE and FALSE values. For multiple polygons, the label for each coordinate pair is a character vector based on the names of each polygon.
## Spatial Packages
The package is designed to work with both [sf](https://r-spatial.github.io/sf/) and [SpatialPolygonsDataFrame](https://www.rdocumentation.org/packages/sp/versions/1.2-5/topics/SpatialPolygonsDataFrame-class) objects.
By default, `pointdexter` only installs and loads the [`sp`](https://www.rdocumentation.org/packages/sp/versions/1.3-1) and [`splancs`](https://www.rdocumentation.org/packages/splancs/versions/2.01-40) packages.
However, `pointdexter` also works with the [`sf`](https://www.rdocumentation.org/packages/sf/versions/0.7-2) package. The following is `sf` installation advice from [Matt Herman](https://nycgeo.mattherman.info/):
> Depending on your operating system and available libraries, `sf` can be tricky to install the first time. The [`sf` website](https://r-spatial.github.io/sf/index.html#installing) is a good place to start if you're having trouble. If you're using macOS, [this is a good guide](https://medium.com/@jinwujour/mapping-with-r-on-mac-installation-8c8ef997c6c2) to installing the required libraries.
## Installation
The latest stable release version can be installed from [CRAN](https://cran.r-project.org/package=pointdexter):
```R
install.packages("pointdexter")
```Development versions can be installed from GitHub:
```R
# note: by default, the development version is the master branch;
# however, that can be changed by changing the
# value in the 'ref' argument
remotes::install_github("cenuno/pointdexter")
```## Usage
### Build-in Data
`pointdexter` comes with built-in point and polygon data - entirely due to the awesome and accessible [Chicago Data Portal](https://data.cityofchicago.org/) - to help you label points in polygons:
* Chicago Public Schools (CPS) - [School Profile Information, School Year (SY) 2018-2019](https://data.cityofchicago.org/Education/Chicago-Public-Schools-School-Profile-Information-/kh4r-387c)
+ as a data frame* City of Chicago [boundary](https://data.cityofchicago.org/Facilities-Geographic-Boundaries/Boundaries-City/ewy2-6yfk)
+ as a SpatialPolygonsDataFrame; and
+ as a simple feature
* Chicago's [77 community areas](https://data.cityofchicago.org/Facilities-Geographic-Boundaries/Boundaries-Community-Areas-current-/cauq-8yn6)
+ as a SpatialPolygonsDataFrame; and
+ as a simple feature
* Chicago's [2010 census tracts](https://data.cityofchicago.org/Facilities-Geographic-Boundaries/Boundaries-Census-Tracts-2010/5jrd-6zik)
+ as a SpatialPolygonsDataFrame; and
+ as a simple feature
### ExampleUsing built-in data, down below is an example of how to use `pointdexter` to label coordinate pairs with their appropriate polygon:
```{r example}
# load necessary packages ----
library(pointdexter) # label coordinate pairs in polygons
library(sp) # classes and methods for spatial data
library(knitr) # general purpose package for dynamic report generation# load necessary data ----
data("cps_sy1819")
data("community_areas_spdf")# create list of coordinate pair matrices for each community area ----
community.area.boundaries <-
GetPolygonBoundaries(my.polygon = community_areas_spdf
, labels = community_areas_spdf$community)# identify the community that each cps school lies in ----
cps_sy1819$community <-
LabelPointsWithinPolygons(lng = cps_sy1819$school_longitude
, lat = cps_sy1819$school_latitude
, polygon.boundaries = community.area.boundaries)# store relevant columns ----
relevant.columns <-
c("school_id", "short_name"
, "school_longitude", "school_latitude", "community")# show first few records ----
kable(head(cps_sy1819[, relevant.columns], n = 10))
``````{r visualize}
# plot only CPS high schools in the the Austin, Rogers Park, and West Elsdon community areas ----# create filter condition ----
filter.condition <-
which(cps_sy1819$is_high_school &
cps_sy1819$community %in% c("AUSTIN"
, "ROGERS PARK"
, "WEST ELSDON"))# filter cps records to those that matched our condition ---
df <- cps_sy1819[filter.condition, ]# note: clear plot space
par(mar = c(0, 0, 1, 0))
plot(x = community_areas_spdf
, main = "CPS High Schools in Austin, Rogers Park, and West Elsdon communities, SY1819"
, cex.main = 0.75
, col = "gray85"
, border = "dodgerblue4")
points(x = df$school_longitude
, y = df$school_latitude
, pch = 19
, col = rgb(red = 212, green = 69, blue = 0
, alpha = 90
, maxColorValue = 255)
, cex = 1)# store relevant columns ----
relevant.columns <-
c("school_id", "short_name", "is_high_school"
, "school_longitude", "school_latitude", "community")# print table of those schools that met the condition ----
kable(df[order(df$community), relevant.columns], row.names = FALSE)```
## Resources
After you've installed the package, be sure to view the help files that introduce you to `pointdexter`'s two functions:
1. [`?pointdexter::GetPolygonBoundaries()`](https://cenuno.github.io/pointdexter/reference/GetPolygonBoundaries.html); and
2. [`?pointdexter::LabelPointsWithinPolygons()`](https://cenuno.github.io/pointdexter/reference/LabelPointsWithinPolygons.html).## Feedback
### Cite
If you use `pointdexter` for any analysis, I would love to hear about it! You can also cite the package according to `citation("pointdexter")`.
### Contribute
[Issues](https://github.com/cenuno/pointdexter/issues) and [pull requests](https://github.com/cenuno/pointdexter/pulls) are welcome anytime!
## Code of Conduct
Please note that this project is released with a [Contributor Code of Conduct](.github/CODE_OF_CONDUCT.md).
By participating in this project you agree to abide by its terms.