Metadata-Version: 2.4
Name: degurba
Version: 0.2
Summary: Urban Boundary Extraction Software Based on Degree of Urbanization
Home-page: https://github.com/djw-easy/degurba
Author: djweasy
Author-email: djw@lreis.ac.cn
Classifier: Programming Language :: Python :: 3
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: OS Independent
Requires-Python: >=3.7
Description-Content-Type: text/markdown
Requires-Dist: rasterio
Requires-Dist: scipy
Dynamic: author
Dynamic: author-email
Dynamic: classifier
Dynamic: description
Dynamic: description-content-type
Dynamic: home-page
Dynamic: requires-dist
Dynamic: requires-python
Dynamic: summary

# Urban Boundary Extraction Software Based on Degree of Urbanization

[![PyPI version](https://badge.fury.io/py/degurba.svg)](https://badge.fury.io/py/degurba)

## Project Introduction

This project aims to provide a tool for urban boundary extraction based on the Degree of Urbanization (DEGURBA) algorithm. By integrating multi-source geospatial data, it offers a fast, flexible, and efficient method for extracting urban boundaries at specific times and locations, providing technical support and data for researchers.

![example](./figs/bj_result.jpg)
<center>
(a) Gridded population of Beijing in 2020.
(b) Grid cell level classification result by DEGURBA. 
(c) Local unit classification result by DEGURBA.
</center>

## Features

- **Multi-source Data Support**: Supports downloading WorldPOP and GPWV4 grid population data.
- **Grid Cell Classification**: Classifies grid cells into urban centers, urban clusters, and rural grid units based on population density, continuity, and scale.
- **Local Unit Classification**: Overlays the grid cell classification results onto local spatial units and further classifies them into urban areas, semi-dense areas, and rural areas.
- **Flexible and Efficient**: Users can generate urban boundary data with different time, location, and classification accuracy requirements.

## Installation

### Install using QGIS

#### 1. Install QGIS
- Download and install QGIS, version 3.20 or higher.

#### 2. Install rasterio
- In the QGIS QSGeo4W Shell, run `pip install rasterio`.

#### 3. Configure Plugin
- Download the plugin ZIP file (`degurba_qgis.zip`) from [GitHub Releases](https://github.com/djw-easy/degurba/releases).
- Open QGIS, go to **Plugins** -> **Manage and Install Plugins**.
- Select the **Install from ZIP** tab on the left.
- Browse and select the downloaded `degurba_qgis.zip` file, then click **Install Plugin**.
- Once installed, open the **Processing Toolbox** to find and use the DEGURBA tools.

### Install using Python

You can install the package using pip:

~~~
pip install degurba
~~~

## Usages with QGIS

1. **Download Population Data**:
   - Use the "download worldpop grid data" or "download gpwv4 grid data" tool to select the desired dataset, country, year, and clipping area (optional).

2. **Grid Cell Classification**:
   - Use the "Grid Cell Classification" tool, input the population grid data, and output raster data.

3. **Local Unit Classification**:
   - Use the "Local Units Classification" tool, input the grid cell classification result data, and output local unit data (vector data).

## Example

Using Beijing's data for the year 2020 as an example:

1. Download the WorldPOP population grid data for Beijing, setting the MASK layer to Beijing's vector boundary.

![download window](./figs/download_1.png)

![download result](./figs/download_2.png)

2. Perform grid cell classification on the downloaded population grid data.

![grid cell classification](./figs/grid_cell_classification_1.png)

![grid cell classification result](./figs/grid_cell_classification_2.png)

3. Overlay the classification results onto Beijing's local spatial units (such as districts) to complete the local unit classification.

![local unit classification](./figs/local_unit_classification_1.png)

![local unit classification result](./figs/local_unit_classification_2.png)

## Notes

- Ensure compatibility between QGIS version and the plugin.
- When downloading data, pay attention to selecting the correct dataset and parameters.
- When performing local unit classification, ensure that the input grid cell classification result data is complete and accurate.
