Skip to main content

Python library for computing Harmonic Beltrami Signature(HBS)

Project description

HBS - Harmonic Beltrami Signature

This is a Python library for computing Harmonic Beltrami Signature(HBS). It provides a set of tools for boundary conditions, mesh generation, conformal welding and other mathematical problems, particularly suited for numerical computations in complex analysis.

Reference

This implementation is based on the paper:

Harmonic Beltrami Signature: A Novel 2D Shape Representation for Object Classification
Chenran Lin, Lok Ming Lui DOI: 10.1137/22M1470852

Installation

Install directly from PyPI:

pip install hbs

Or install from source:

  1. Clone this repository:
    git clone https://github.com/ChanceAroundYou/hbs_python.git
    
  2. Install dependencies:
    pip install -r requirements.txt
    

Main Modules

  • hbs.py: HBS algorithm for computing HBS and recontructing shape from HBS
  • boundary.py: Boundary processing tools
  • conformal_welding.py: Conformal welding algorithm implementation
  • mesh.py: Mesh generation and processing
  • utils/:
    • geodesic_welding.py: Geodesic welding
    • mobius.py: Möbius transformations
    • poisson.py: Poisson integral implementation
    • tool_functions.py: Utility functions
    • zipper.py: Zipper algorithm implementation
  • qc/: Quasiconformal mapping algorithms
    • bc.py: Beltrami coefficient computation
    • lsqc.py: Least squares quasiconformal mapping algorithm

Usage Example

Compute HBS from image

from hbs.boundary import get_boundary
from hbs import get_hbs

img_path = 'img/example.jpg'
bound = get_boundary(img_path, bound_point_num)
hbs, he, cw, disk = get_hbs(bound, circle_point_num, density)

Reconstruct shape from HBS

from hbs import reconstruct_from_hbs

## `disk` must be a DiskMesh corresponding to give `hbs`
bound, _, _, _ = reconstruct_from_hbs(hbs, disk)

Please also refer to example.ipynb

Dependencies

  • NumPy
  • SciPy
  • Matplotlib
  • Opencv

Contributing

Contributions are welcome via pull requests.

Code Author

  • Chenran Lin

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

hbs-0.3.0.tar.gz (14.5 kB view details)

Uploaded Source

Built Distribution

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

hbs-0.3.0-py3-none-any.whl (16.8 kB view details)

Uploaded Python 3

File details

Details for the file hbs-0.3.0.tar.gz.

File metadata

  • Download URL: hbs-0.3.0.tar.gz
  • Upload date:
  • Size: 14.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.10.10

File hashes

Hashes for hbs-0.3.0.tar.gz
Algorithm Hash digest
SHA256 9723d6eec2f83277c259a7c98a957408b3fd62c0c44f7220bc05cf937fa74977
MD5 64aa5b1c11380a45e93665f037e530dd
BLAKE2b-256 f739c68ff6fbfcb58ca34b4017da1fed64dd9c4ef018989ef20078a036fcb42c

See more details on using hashes here.

File details

Details for the file hbs-0.3.0-py3-none-any.whl.

File metadata

  • Download URL: hbs-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 16.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.10.10

File hashes

Hashes for hbs-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 b15282e375e220bdc85350a1450e4d3f8115344ca0463209dc03593dac92d889
MD5 e26116ee19ac93b1047cbe398e25269c
BLAKE2b-256 7a8bdd33c59afc451fd8169684961421a9b628c927ed5002fe9910892c16be56

See more details on using hashes here.

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