Skip to main content

A Python library for regularizing building footprints in geospatial data. This library helps clean up and standardize building polygon geometries by aligning edges to principal directions.

Project description

Building Regulariser

A Python library for regularizing building footprints in geospatial data. This library helps clean up and standardize building polygon geometries by aligning edges to principal directions. Built as an open source alternative to the ArcGIS Regularize Building Footprint (3D Analyst) tool.

PyPI conda-forge Downloads Python CI License

Example Results

Before and after regularization:

Example 1: Before and After Regularization Example 2: Before and After Regularization

Try in Colab

Colab_Button

Overview

Building footprints extracted from remote sensing imagery often contain noise, irregular edges, and geometric inconsistencies. This library provides tools to regularize these footprints by:

  • Aligning edges to principal directions (orthogonal and optional 45-degree angles)
  • Converting near-rectangular buildings to perfect rectangles
  • Converting near-circular buildings to perfect circles
  • Simplifying complex polygons while maintaining their essential shape
  • Supporting parallel processing for efficient computation with large datasets
  • Fine-tune building alignment with neighboring buildings

Inspired by RS-building-regularization, this library takes a geometric approach to building regularization with improvements for usability and integration with the GeoPandas ecosystem.

Installation

pip install buildingregulariser

or

conda install conda-forge::buildingregulariser

or

uv add buildingregulariser

Quick Start

import geopandas as gpd
from buildingregulariser import regularize_geodataframe

# Load your building footprints
buildings = gpd.read_file("buildings.gpkg")

# Regularize the building footprints
regularized_buildings = regularize_geodataframe(
    buildings, 
)

# Save the results
regularized_buildings.to_file("regularized_buildings.gpkg")

Features

  • GeoDataFrame Integration: Works seamlessly with GeoPandas GeoDataFrames
  • Polygon Regularization: Aligns edges to principal directions
  • 45-Degree Support: Optional alignment to 45-degree angles
  • Align with neighboring buildings: Align each building with neighboring buildings
  • Circle Detection: Identifies and converts near-circular shapes to perfect circles
  • Edge Simplification: Reduces the number of vertices while preserving shape
  • Parallel Processing: Utilizes multiple CPU cores for faster processing of large datasets

Usage Examples

Basic Regularization

from buildingregulariser import regularize_geodataframe
import geopandas as gpd

buildings = gpd.read_file("buildings.gpkg")
regularized = regularize_geodataframe(buildings)

Fine-tuning Regularization Parameters

regularized = regularize_geodataframe(
    buildings,
    parallel_threshold=2.0,        # Higher values allow less edge alignment
    simplify_tolerance=0.5,        # Controls simplification level, should be 2-3 x the raster pixel size
    allow_45_degree=True,          # Enable 45-degree angles
    allow_circles=True,            # Enable circle detection
    circle_threshold=0.9,          # IOU threshold for circle detection
    neighbor_alignment=True,       # After regularization try to align each building with neighboring buildings
    neighbor_search_distance=100,  # Search distance around each building when looking for neighbors
    neighbor_max_rotation=10,      # Maximum rotation allowed to align with neighbors
)

Parameters

  • geodataframe: Input GeoDataFrame with polygon geometries
  • parallel_threshold: Distance threshold for handling parallel lines (default: 1.0)
  • target_crs: Optional CRS (string or pyproj.CRS) to reproject the input to before regularization (default: None)
  • simplify: If True, applies simplification to the geometry (default: True)
  • simplify_tolerance: Tolerance for simplification (default: 0.5)
  • allow_45_degree: If True, allows edges to be oriented at 45-degree angles (default: True)
  • diagonal_threshold_reduction: Used to reduce the chance of diagonal edges being generated, can be from 0 to 22.5 (default: 15.0)
  • allow_circles: If True, detects and converts near-circular shapes to perfect circles (default: True)
  • circle_threshold: Intersection over Union (IoU) threshold for circle detection (default: 0.9)
  • num_cores: Number of CPU cores to use for parallel processing; 0 uses all available cores (default: 0)
  • include_metadata: Include the main direction, IOU, perimeter and aligned_direction (if used) in output gdf (default: False)
  • neighbor_alignment: If True, try to align each building with neighboring buildings (default: False)
  • neighbor_search_distance: The distance to find neighboring buildings (default: 100.0)
  • neighbor_max_rotation: The maximum allowable rotation to align with neighbors (default: 10)

Returns

  • A new GeoDataFrame with regularized polygon geometries

How It Works

  1. Edge Analysis: Analyzes each polygon to identify principal directions
  2. Edge Orientation: Aligns edges to be parallel, perpendicular, or at 45 degrees to the main direction
  3. Circle Detection: Optionally identifies shapes that are nearly circular and converts them to perfect circles
  4. Edge Connection: Ensures proper connectivity between oriented edges
  5. Angle Enforcement: Post-processing to ensure target angles are precisely maintained
  6. Neighbor Alignment: Optionally align each building with neighboring buildings, via rotation around centroid.

License

This project is licensed under the MIT License

Acknowledgments

This library was inspired by the RS-building-regularization project, with improvements for integration with the GeoPandas ecosystem and enhanced regularization algorithms.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

buildingregulariser-0.2.5.tar.gz (2.3 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

buildingregulariser-0.2.5-py3-none-any.whl (20.8 kB view details)

Uploaded Python 3

File details

Details for the file buildingregulariser-0.2.5.tar.gz.

File metadata

  • Download URL: buildingregulariser-0.2.5.tar.gz
  • Upload date:
  • Size: 2.3 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for buildingregulariser-0.2.5.tar.gz
Algorithm Hash digest
SHA256 1fca90766dac1cdf202aca9de91846528a72b6ad4bd2d6b98bc69413324f7094
MD5 259f8973a59e5b952479f14f1991616a
BLAKE2b-256 914d9170a1f12b5e0de28b3666c12cc05763cdffd36689d912317bc00310975c

See more details on using hashes here.

Provenance

The following attestation bundles were made for buildingregulariser-0.2.5.tar.gz:

Publisher: publish.yml on DPIRD-DMA/Building-Regulariser

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file buildingregulariser-0.2.5-py3-none-any.whl.

File metadata

File hashes

Hashes for buildingregulariser-0.2.5-py3-none-any.whl
Algorithm Hash digest
SHA256 a47aba9431309318c6a7dead0ba0e32098b78ad968ff99d9e293a17a6b69c443
MD5 06b63b5fd0d11ccf969f1bf74068c870
BLAKE2b-256 45fd052ff368651408a0ec07307fbbaf4b6be943e99637f187d54717d796aac9

See more details on using hashes here.

Provenance

The following attestation bundles were made for buildingregulariser-0.2.5-py3-none-any.whl:

Publisher: publish.yml on DPIRD-DMA/Building-Regulariser

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page