geosnap


Namegeosnap JSON
Version 0.15.1 PyPI version JSON
download
home_pageNone
SummaryThe Geospatial Neighborhood Analysis Package
upload_time2025-01-23 22:56:30
maintainergeosnap contributors
docs_urlNone
authorNone
requires_python>=3.8
licenseBSD 3-Clause
keywords geodemographics neighborhood dynamics urban data science spatial analysis
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            <p align="center">
<img height=200 src="https://github.com/oturns/geosnap/raw/main/docs/figs/geosnap_long.png" alt="geosnap"/>
</p>

<h2 align="center" style="margin-top:-10px">The Geospatial Neighborhood Analysis Package</h2> 

[![Continuous Integration](https://github.com/oturns/geosnap/actions/workflows/unittests.yml/badge.svg)](https://github.com/oturns/geosnap/actions/workflows/unittests.yml)
[![codecov](https://codecov.io/gh/oturns/geosnap/branch/main/graph/badge.svg)](https://codecov.io/gh/oturns/geosnap)
![PyPI - Python Version](https://img.shields.io/pypi/pyversions/geosnap)
![PyPI](https://img.shields.io/pypi/v/geosnap)
![Conda (channel only)](https://img.shields.io/conda/vn/conda-forge/geosnap)
![Conda](https://img.shields.io/conda/dn/conda-forge/geosnap)
![GitHub commits since latest release (branch)](https://img.shields.io/github/commits-since/oturns/geosnap/latest)
[![DOI](https://zenodo.org/badge/DOI/10.5281/zenodo.3526163.svg)](https://doi.org/10.5281/zenodo.3526163)

`geosnap` provides a suite of tools for exploring, modeling, and visualizing the social context and spatial extent of neighborhoods and regions over time. It brings together state-of-the-art techniques from [geodemographics](https://en.wikipedia.org/wiki/Geodemography), [regionalization](https://www.sciencedirect.com/topics/earth-and-planetary-sciences/regionalism), [spatial data science](https://geographicdata.science/book), and [segregation analysis](https://github.com/pysal/segregation) to support social science research, public policy analysis, and urban planning. It provides a simple interface tailored to formal analysis of spatiotemporal urban data.

<p align="center">
<img width='50%' src='https://github.com/oturns/geosnap/raw/main/docs/figs/Washington-Arlington-Alexandria_DC-VA-MD-WV.gif' alt='DC Transitions' style=' display: block; margin-left: auto; margin-right: auto; max-height: 540px'/>
</p>


## Main Features

* fast, efficient tooling for standardizing data from multiple time periods into a shared geographic representation appropriate for spatiotemporal analysis

* analytical methods for understanding sociospatial structure in neighborhoods, cities, and regions, using unsupervised ML from scikit-learn and spatial optimization from [PySAL](https://pysal.org)
  * classic and spatial analytic methods for diagnosing model fit, and locating (spatial) statistical outliers

* novel techniques for understanding the evolution of neighborhoods over time, including identifying hotspots of local neighborhood change, as well as modeling and simulating neighborhood conditions into the future

* quick access to [a large database](https://open.quiltdata.com/b/spatial-ucr) of commonly-used neighborhood indicators from U.S. providers including Census, EPA, LEHD, NCES, and NLCD, streamed from the cloud thanks to [quilt](https://quiltdata.com/) and the highly-performant [geoparquet](https://carto.com/blog/introducing-geoparquet-geospatial-compatibility/) file format.

## Why

Understanding neighborhood context is critical for social science research, public policy analysis, and urban planning. The social meaning, formal definition, and formal operationalization of ["neighborhood"](https://www.cnu.org/publicsquare/2019/01/29/once-and-future-neighborhood) depends on the study or application, however, so neighborhood analysis and modeling requires both flexibility and adherence to a formal pipeline. Maintaining that balance is challenging for a variety of reasons:

* many different physical and social data can characterize a neighborhood (e.g. its proximity to the urban core, its share of residents with a high school education, or the median price of its apartments) so there are countless ways to model neighborhoods by choosing different subsets of attributes to define them

* conceptually, neighborhoods evolve through both space and time, meaning their socially-construed boundaries can shift over time, as can their demographic makeup.

* geographic tabulation units change boundaries over time, meaning the raw data are aggregated to different areal units at different points in time.

* the relevant dimensions of neighborhood change are fluid, as are the thresholds that define meaningful change

To address those challenges, geosnap incorporates tools from the PySAL ecosystem and scikit-learn along with internal data-wrangling that helps keep inputs and outputs simple for users. It operates on long-form geodataframes and includes logic for common transformations, like harmonizing geographic boundaries over time, and standardizing variables within their time-period prior to conducting pooled geodemographic clustering.

This means that while geosnap has native support for commonly-used datasets like the Longitudinal Tract Database [(LTDB)](https://www.brown.edu/academics/spatial-structures-in-social-sciences/ltdb-following-neighborhoods-over-time), or the Neighborhood Change Database [(NCDB)](https://geolytics.com/products/normalized-data/neighborhood-change-database), it can also incorporate a wide variety of datasets, at _any_ spatial resolution, as long as the user understands the implications of the interpolation process.

## Research Questions

The package supports social scientists examining questions such as:

- Where are the socially-homogenous districts in the city?
  - Have the composition of these districts or their location shifted over time?
- What are the characteristics of prototypical neighborhoods in city or region X?
- Have the locations of different neighborhood prototypes changed over time? e.g:
  - do central-city neighborhoods show signs of gentrification?(and/or does poverty appear to be suburbanizing?)
  - is there equitable access to fair housing in high-opportunity neighborhoods (or a dearth of resources in highly-segregated neighborhoods)?
- Which neighborhoods have experienced dramatic change in several important variables? (and are they clustered together in space?)
- If spatial and temporal trends hold, how might we expect neighborhoods to look in the future?
  - how does the region look differently if units 1,2, and 3 are changed to a different type in the current time period?
- Has the region become more or less segregated over time?
  - at which spatial scales?
  - is the change statistically significant?


## Installation

We recommend installing `geosnap` via a package manager that supports installing conda packages from [conda-forge](https://conda-forge.org/). Installing directly from the Python Package Index (PyPI) is also supported.

### Installation via [Miniforge](https://github.com/conda-forge/miniforge)

```bash
mamba install -c conda-forge geosnap
```

### Installation via [Pixi](https://pixi.sh/latest/)

 Installation via `pixi` is supported, excluding `pixi global install`:

```bash
pixi init name_of_my_project
cd name_of_my_project
pixi add geosnap
```

### Installation via pip

```bash
pip install geosnap
```

### Installation via [uv](https://docs.astral.sh/uv/)

```bash
uv pip install geosnap
```

## User Guide

See the [User Guide](https://oturns.github.io/geosnap-guide/) for a
gentle introduction to using `geosnap` for neighborhood research

## API Documentation

See the [API docs](https://oturns.github.io/geosnap/api.html) for a thorough explanation of `geosnap`'s core functionality

## Development

geosnap development is hosted on [github](https://github.com/oturns/geosnap)

To get started with the development version,
clone this repository or download it manually then `cd` into the directory and run the
following commands:

```bash
conda env create -f environment.yml
conda activate geosnap 
pip install -e . --no-deps
```

This will download the appropriate dependencies and install geosnap in its own conda environment.

## Bug reports

To search for or report bugs, please see geosnap’s
[issues](http://github.com/oturns/geosnap/issues)

## License information

See the file “LICENSE.txt” for information on the history of this software, terms &
conditions for usage, and a DISCLAIMER OF ALL WARRANTIES.

## Citation

For a generic citation of geosnap, we recommend the following:

```latex
@misc{Knaap2019,
author = {Knaap, Elijah and Kang, Wei and Rey, Sergio and Wolf, Levi John and Cortes, Renan Xavier and Han, Su},
doi = {10.5281/ZENODO.3526163},
title = {{geosnap: The Geospatial Neighborhood Analysis Package}},
url = {https://zenodo.org/record/3526163},
year = {2019}
}
```

If you need to cite a specific release of the package, please find the appropriate version on [Zenodo](https://zenodo.org/record/3526163)

## Funding

<img src="docs/figs/nsf_logo.jpg" width=100 /> This project is supported by NSF Award #1733705,
[Neighborhoods in Space-Time Contexts](https://www.nsf.gov/awardsearch/showAward?AWD_ID=1733705\&HistoricalAwards=false)

            

Raw data

            {
    "_id": null,
    "home_page": null,
    "name": "geosnap",
    "maintainer": "geosnap contributors",
    "docs_url": null,
    "requires_python": ">=3.8",
    "maintainer_email": null,
    "keywords": "geodemographics, neighborhood dynamics, urban data science, spatial analysis",
    "author": null,
    "author_email": "Eli Knaap <ek@knaaptime.com>, Serge Rey <sjsrey@gmail.com>",
    "download_url": "https://files.pythonhosted.org/packages/1e/a0/dfc7c9092a8dc4d4f1aecb719dc2666050c9ba9b1c16d706cd8cf506b315/geosnap-0.15.1.tar.gz",
    "platform": null,
    "description": "<p align=\"center\">\n<img height=200 src=\"https://github.com/oturns/geosnap/raw/main/docs/figs/geosnap_long.png\" alt=\"geosnap\"/>\n</p>\n\n<h2 align=\"center\" style=\"margin-top:-10px\">The Geospatial Neighborhood Analysis Package</h2> \n\n[![Continuous Integration](https://github.com/oturns/geosnap/actions/workflows/unittests.yml/badge.svg)](https://github.com/oturns/geosnap/actions/workflows/unittests.yml)\n[![codecov](https://codecov.io/gh/oturns/geosnap/branch/main/graph/badge.svg)](https://codecov.io/gh/oturns/geosnap)\n![PyPI - Python Version](https://img.shields.io/pypi/pyversions/geosnap)\n![PyPI](https://img.shields.io/pypi/v/geosnap)\n![Conda (channel only)](https://img.shields.io/conda/vn/conda-forge/geosnap)\n![Conda](https://img.shields.io/conda/dn/conda-forge/geosnap)\n![GitHub commits since latest release (branch)](https://img.shields.io/github/commits-since/oturns/geosnap/latest)\n[![DOI](https://zenodo.org/badge/DOI/10.5281/zenodo.3526163.svg)](https://doi.org/10.5281/zenodo.3526163)\n\n`geosnap` provides a suite of tools for exploring, modeling, and visualizing the social context and spatial extent of neighborhoods and regions over time. It brings together state-of-the-art techniques from [geodemographics](https://en.wikipedia.org/wiki/Geodemography), [regionalization](https://www.sciencedirect.com/topics/earth-and-planetary-sciences/regionalism), [spatial data science](https://geographicdata.science/book), and [segregation analysis](https://github.com/pysal/segregation) to support social science research, public policy analysis, and urban planning. It provides a simple interface tailored to formal analysis of spatiotemporal urban data.\n\n<p align=\"center\">\n<img width='50%' src='https://github.com/oturns/geosnap/raw/main/docs/figs/Washington-Arlington-Alexandria_DC-VA-MD-WV.gif' alt='DC Transitions' style=' display: block; margin-left: auto; margin-right: auto; max-height: 540px'/>\n</p>\n\n\n## Main Features\n\n* fast, efficient tooling for standardizing data from multiple time periods into a shared geographic representation appropriate for spatiotemporal analysis\n\n* analytical methods for understanding sociospatial structure in neighborhoods, cities, and regions, using unsupervised ML from scikit-learn and spatial optimization from [PySAL](https://pysal.org)\n  * classic and spatial analytic methods for diagnosing model fit, and locating (spatial) statistical outliers\n\n* novel techniques for understanding the evolution of neighborhoods over time, including identifying hotspots of local neighborhood change, as well as modeling and simulating neighborhood conditions into the future\n\n* quick access to [a large database](https://open.quiltdata.com/b/spatial-ucr) of commonly-used neighborhood indicators from U.S. providers including Census, EPA, LEHD, NCES, and NLCD, streamed from the cloud thanks to [quilt](https://quiltdata.com/) and the highly-performant [geoparquet](https://carto.com/blog/introducing-geoparquet-geospatial-compatibility/) file format.\n\n## Why\n\nUnderstanding neighborhood context is critical for social science research, public policy analysis, and urban planning. The social meaning, formal definition, and formal operationalization of [\"neighborhood\"](https://www.cnu.org/publicsquare/2019/01/29/once-and-future-neighborhood) depends on the study or application, however, so neighborhood analysis and modeling requires both flexibility and adherence to a formal pipeline. Maintaining that balance is challenging for a variety of reasons:\n\n* many different physical and social data can characterize a neighborhood (e.g. its proximity to the urban core, its share of residents with a high school education, or the median price of its apartments) so there are countless ways to model neighborhoods by choosing different subsets of attributes to define them\n\n* conceptually, neighborhoods evolve through both space and time, meaning their socially-construed boundaries can shift over time, as can their demographic makeup.\n\n* geographic tabulation units change boundaries over time, meaning the raw data are aggregated to different areal units at different points in time.\n\n* the relevant dimensions of neighborhood change are fluid, as are the thresholds that define meaningful change\n\nTo address those challenges, geosnap incorporates tools from the PySAL ecosystem and scikit-learn along with internal data-wrangling that helps keep inputs and outputs simple for users. It operates on long-form geodataframes and includes logic for common transformations, like harmonizing geographic boundaries over time, and standardizing variables within their time-period prior to conducting pooled geodemographic clustering.\n\nThis means that while geosnap has native support for commonly-used datasets like the Longitudinal Tract Database [(LTDB)](https://www.brown.edu/academics/spatial-structures-in-social-sciences/ltdb-following-neighborhoods-over-time), or the Neighborhood Change Database [(NCDB)](https://geolytics.com/products/normalized-data/neighborhood-change-database), it can also incorporate a wide variety of datasets, at _any_ spatial resolution, as long as the user understands the implications of the interpolation process.\n\n## Research Questions\n\nThe package supports social scientists examining questions such as:\n\n- Where are the socially-homogenous districts in the city?\n  - Have the composition of these districts or their location shifted over time?\n- What are the characteristics of prototypical neighborhoods in city or region X?\n- Have the locations of different neighborhood prototypes changed over time? e.g:\n  - do central-city neighborhoods show signs of gentrification?(and/or does poverty appear to be suburbanizing?)\n  - is there equitable access to fair housing in high-opportunity neighborhoods (or a dearth of resources in highly-segregated neighborhoods)?\n- Which neighborhoods have experienced dramatic change in several important variables? (and are they clustered together in space?)\n- If spatial and temporal trends hold, how might we expect neighborhoods to look in the future?\n  - how does the region look differently if units 1,2, and 3 are changed to a different type in the current time period?\n- Has the region become more or less segregated over time?\n  - at which spatial scales?\n  - is the change statistically significant?\n\n\n## Installation\n\nWe recommend installing `geosnap` via a package manager that supports installing conda packages from [conda-forge](https://conda-forge.org/). Installing directly from the Python Package Index (PyPI) is also supported.\n\n### Installation via [Miniforge](https://github.com/conda-forge/miniforge)\n\n```bash\nmamba install -c conda-forge geosnap\n```\n\n### Installation via [Pixi](https://pixi.sh/latest/)\n\n Installation via `pixi` is supported, excluding `pixi global install`:\n\n```bash\npixi init name_of_my_project\ncd name_of_my_project\npixi add geosnap\n```\n\n### Installation via pip\n\n```bash\npip install geosnap\n```\n\n### Installation via [uv](https://docs.astral.sh/uv/)\n\n```bash\nuv pip install geosnap\n```\n\n## User Guide\n\nSee the [User Guide](https://oturns.github.io/geosnap-guide/) for a\ngentle introduction to using `geosnap` for neighborhood research\n\n## API Documentation\n\nSee the [API docs](https://oturns.github.io/geosnap/api.html) for a thorough explanation of `geosnap`'s core functionality\n\n## Development\n\ngeosnap development is hosted on [github](https://github.com/oturns/geosnap)\n\nTo get started with the development version,\nclone this repository or download it manually then `cd` into the directory and run the\nfollowing commands:\n\n```bash\nconda env create -f environment.yml\nconda activate geosnap \npip install -e . --no-deps\n```\n\nThis will download the appropriate dependencies and install geosnap in its own conda environment.\n\n## Bug reports\n\nTo search for or report bugs, please see geosnap\u2019s\n[issues](http://github.com/oturns/geosnap/issues)\n\n## License information\n\nSee the file \u201cLICENSE.txt\u201d for information on the history of this software, terms &\nconditions for usage, and a DISCLAIMER OF ALL WARRANTIES.\n\n## Citation\n\nFor a generic citation of geosnap, we recommend the following:\n\n```latex\n@misc{Knaap2019,\nauthor = {Knaap, Elijah and Kang, Wei and Rey, Sergio and Wolf, Levi John and Cortes, Renan Xavier and Han, Su},\ndoi = {10.5281/ZENODO.3526163},\ntitle = {{geosnap: The Geospatial Neighborhood Analysis Package}},\nurl = {https://zenodo.org/record/3526163},\nyear = {2019}\n}\n```\n\nIf you need to cite a specific release of the package, please find the appropriate version on [Zenodo](https://zenodo.org/record/3526163)\n\n## Funding\n\n<img src=\"docs/figs/nsf_logo.jpg\" width=100 /> This project is supported by NSF Award #1733705,\n[Neighborhoods in Space-Time Contexts](https://www.nsf.gov/awardsearch/showAward?AWD_ID=1733705\\&HistoricalAwards=false)\n",
    "bugtrack_url": null,
    "license": "BSD 3-Clause",
    "summary": "The Geospatial Neighborhood Analysis Package",
    "version": "0.15.1",
    "project_urls": {
        "Home": "https://github.com/oturns/geosnap/",
        "Repository": "https://github.com/oturns/geosnap"
    },
    "split_keywords": [
        "geodemographics",
        " neighborhood dynamics",
        " urban data science",
        " spatial analysis"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "0445af67e7af96cea5cd11d3241e1e1df928899cc931e525c2e2eb705a00490d",
                "md5": "e8a97d3e3ce2b8e556345946fbf0a881",
                "sha256": "2b931a5389e88c5b56f74f947aa519100031b68aa52b8a618b26d3a6e4e6d15b"
            },
            "downloads": -1,
            "filename": "geosnap-0.15.1-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "e8a97d3e3ce2b8e556345946fbf0a881",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.8",
            "size": 192501,
            "upload_time": "2025-01-23T22:56:26",
            "upload_time_iso_8601": "2025-01-23T22:56:26.511356Z",
            "url": "https://files.pythonhosted.org/packages/04/45/af67e7af96cea5cd11d3241e1e1df928899cc931e525c2e2eb705a00490d/geosnap-0.15.1-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "1ea0dfc7c9092a8dc4d4f1aecb719dc2666050c9ba9b1c16d706cd8cf506b315",
                "md5": "ef17af013e3e07ad6081c08e3cd25cf6",
                "sha256": "a94e13ae9b426204567a195bad4f72210bdfd10aa417033a4024e52b13bf1ac9"
            },
            "downloads": -1,
            "filename": "geosnap-0.15.1.tar.gz",
            "has_sig": false,
            "md5_digest": "ef17af013e3e07ad6081c08e3cd25cf6",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.8",
            "size": 29917014,
            "upload_time": "2025-01-23T22:56:30",
            "upload_time_iso_8601": "2025-01-23T22:56:30.511450Z",
            "url": "https://files.pythonhosted.org/packages/1e/a0/dfc7c9092a8dc4d4f1aecb719dc2666050c9ba9b1c16d706cd8cf506b315/geosnap-0.15.1.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2025-01-23 22:56:30",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "oturns",
    "github_project": "geosnap",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "lcname": "geosnap"
}
        
Elapsed time: 3.66629s