Skip to main content

A Python package for panoramic image projection and blending using Gnomonic (and other) projections.

Project description

Panorai

Panorai is a Python package for spherical (360°) image processing, specifically focusing on sampling, projection, forward/backward transformations, and unsharp masking for panoramic or spherical data. It provides a modular pipeline to handle various steps, including:

  • Resizing input images
  • Sampling tangent points on a sphere (e.g., cube-based, Fibonacci-based)
  • Projecting spherical images into local tangential (rectilinear) planes
  • Re-projecting these rectilinear images back into the equirectangular space
  • Configuring and applying unsharp masking to sharpen the projected images
  • Logging and comparing configuration results (e.g., MSE) via an automated test suite

This README will guide you through the repository structure, installation, usage, and testing of Panorai.


Table of Contents

  1. Overview
  2. Directory Structure
  3. Installation
  4. Examples
  5. Key Modules and Classes
  6. Running Tests
  7. Extending Panorai
  8. License

Overview

Panorai is a Python library designed for advanced geometric transformations, projections, and sampling on spherical and equirectangular data. It provides a highly modular framework for implementing gnomonic projections, backward projections, and blending strategies, suitable for 360-degree image processing and panoramic data transformations.


Directory Structure

/
├── panorai/
│   ├── __pycache__/
│   ├── common/
│   │   ├── __pycache__/
│   │   ├── __init__.py
│   │   └── shared_config.py
│   ├── pipeline/
│   │   ├── __pycache__/
│   │   ├── utils/
│   │   │   ├── __pycache__/
│   │   │   ├── __init__.py
│   │   │   └── resizer.py
│   │   ├── __init__.py
│   │   ├── pipeline.py
│   │   ├── pipeline_data.py
│   │   └── pipeline_old.py
│   ├── projection/
│   │   ├── __pycache__/
│   │   ├── utils/
│   │   │   ├── __pycache__/
│   │   │   ├── __init__.py
│   │   │   ├── remapper.py
│   │   │   └── unsharp.py
│   │   ├── __init__.py
│   │   ├── projector.py
│   │   └── projector_deprecated.py
│   ├── readme/
│   │   └── gnomonic.md
│   ├── sampler/
│   │   ├── __pycache__/
│   │   ├── __init__.py
│   │   └── sampler.py
│   ├── __init__.py
├── panorai.egg-info/
│   ├── dependency_links.txt
│   ├── PKG-INFO
│   ├── SOURCES.txt
│   └── top_level.txt
├── tests/
│   ├── __pycache__/
│   └── test_config_params.py
├── .gitignore
├── best_configs_chart.png
├── requirements.txt
├── setup.py
└── test_results.db

Notable Contents

  • panorai/
    Main package directory containing submodules:

    • pipeline/: The pipeline logic for forward/backward projection and data handling, plus utility functions like resizer.
    • projection/: Projector classes (e.g., GnomonicProjector) and remapping/unsharp utility code.
    • sampler/: Sphere sampling strategies (cube, icosahedron, Fibonacci).
    • readme/: Additional notes/documentation (e.g., gnomonic.md).
  • setup.py
    A setuptools-based installation script.

  • requirements.txt
    Lists dependencies needed to run the code (e.g., NumPy, OpenCV, etc.).


Installation

  1. Clone the Repository:

    git clone https://github.com/yourusername/panorai.git
    cd panorai
    
  2. Install Dependencies:

    pip install -r requirements.txt
    
  3. Install Panorai (Editable Mode or Standard):

    pip install -e .
    # or
    python setup.py install
    

Examples

1. Data Preparation

Start by loading your input data, typically stored in an .npz file containing rgb, depth, and other channels.

import numpy as np
from panorai.pipeline.pipeline_data import PipelineData

# Load data from an NPZ file
filename = 'path/to/sample.npz'  # Replace with your file path
arr = np.load(filename)

rgb = arr['rgb']  # Shape: (H, W, 3)
depth = np.sqrt(np.sum(arr['z']**2, axis=-1))[:, :, None]  # Shape: (H, W, 1)
xyz = arr['z']  # Shape: (H, W, 3)

# Create a PipelineData instance
data = PipelineData.from_dict({
    "rgb": rgb,
    "depth": depth,
    "xyz_depth": xyz
})

2. Preprocessing Data

Adjust for shadow angle and optionally rotate the equirectangular image:

from panorai.pipeline.utils.preprocess_eq import PreprocessEquirectangularImage

# Visualize the original data
import matplotlib.pyplot as plt
plt.imshow(data.data['rgb'])
plt.show()

# Preprocess the data (e.g., handle shadow angle)
data.preprocess(shadow_angle=30)
plt.imshow(data.data['rgb'])
plt.show()

3. Using Projections

3.1. Forward Projection

Project equirectangular data into a gnomonic projection.

from panorai.submodules.projections import ProjectionRegistry

# Access the gnomonic projection
proj = ProjectionRegistry.get_projection('gnomonic', return_processor=True)

# Perform forward projection
face = proj.forward(data.data['rgb'])
plt.imshow(face)
plt.show()

3.2. Backward Projection

Reconstruct the equirectangular image from a projection:

# Perform backward projection
eq_img = proj.backward(face)
plt.imshow(eq_img)
plt.show()

4. Using the ProjectionPipeline

The ProjectionPipeline provides a high-level API for projections.

from panorai.pipeline.pipeline import ProjectionPipeline

# Initialize the pipeline
pipe = ProjectionPipeline(projection_name='gnomonic')

# Forward projection
face = pipe.project(data)
plt.imshow(face['rgb'].astype(np.uint8))
plt.show()

4.1. Using Samplers

Use samplers to generate multiple projections (e.g., cube or icosahedron samplers):

pipe = ProjectionPipeline(projection_name='gnomonic', sampler_name='CubeSampler')
faces = pipe.project(data)

# Visualize a specific face
plt.imshow(faces['point_1']['rgb'].astype(np.uint8))
plt.show()

4.2. Blending Projections

Blend multiple projections into a seamless equirectangular image:

# Reconstruct equirectangular image
reconstructed = pipe.backward(faces)
plt.imshow(reconstructed['stacked'])
plt.show()

4.3. Custom Configurations

Modify the pipeline configuration to customize the behavior:

pipe = ProjectionPipeline(projection_name='gnomonic', sampler_name='IcosahedronSampler')
faces = pipe.project(data, subdivisions=2, fov_deg=40)
reconstructed = pipe.backward(faces)
plt.imshow(reconstructed['stacked'])
plt.show()

Key Modules and Classes

  1. PipelineData
    A container for storing and stacking multiple image channels (e.g., rgb, depth).

  2. ProjectionPipeline
    Manages the forward/backward transformations using a chosen sampler and projector.

  3. Samplers

    • CubeSampler: Tangent points for cube-based projections.
    • IcosahedronSampler: Icosahedron-based tangent points.
    • FibonacciSampler: Fibonacci sphere sampling for uniform distribution.
  4. ProjectionRegistry


Extending Panorai

  • Add new samplers: Implement a new class inheriting from Sampler and register it in SAMPLER_CLASSES.
  • Add new projectors: Implement a new class inheriting from ProjectionStrategy and add it to PROJECTOR_CLASSES.
  • HF integration to handle depth estimation: Implement seamless integration with HF to load and run DA inference

License

This project is licensed under the MIT License. See the LICENSE file for details.


Contact

For questions or feedback, contact the maintainers:


Enjoy using Panorai for your panoramic image processing!

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

panorai-1.2.tar.gz (29.1 kB view details)

Uploaded Source

Built Distribution

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

panorai-1.2-py3-none-any.whl (31.7 kB view details)

Uploaded Python 3

File details

Details for the file panorai-1.2.tar.gz.

File metadata

  • Download URL: panorai-1.2.tar.gz
  • Upload date:
  • Size: 29.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.8

File hashes

Hashes for panorai-1.2.tar.gz
Algorithm Hash digest
SHA256 3ff439df4a88cd94e3ed7f4c392dfbd55b661771206486fdee2cb1b892fcffc1
MD5 2d4e19f024291d7d45ba6dc4700ae42b
BLAKE2b-256 9171685b3a86341551d2579952c344f84e42bcdf5aa90774650615d0066e4458

See more details on using hashes here.

Provenance

The following attestation bundles were made for panorai-1.2.tar.gz:

Publisher: python-publish.yml on RobinsonGarcia/PanorAi

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

File details

Details for the file panorai-1.2-py3-none-any.whl.

File metadata

  • Download URL: panorai-1.2-py3-none-any.whl
  • Upload date:
  • Size: 31.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.8

File hashes

Hashes for panorai-1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 47315949ab6ca3b1d7e0863189e4192013224b27c692b33c3e204004772af17a
MD5 3173c28053c6c1cb0f225e509fac767f
BLAKE2b-256 88f5bf4d664f65b6eb66b511e0243c8be5b62c68d94ee1adb0be05736609f3f3

See more details on using hashes here.

Provenance

The following attestation bundles were made for panorai-1.2-py3-none-any.whl:

Publisher: python-publish.yml on RobinsonGarcia/PanorAi

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