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.0b0.tar.gz (40.5 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.0b0-py3-none-any.whl (52.4 kB view details)

Uploaded Python 3

File details

Details for the file panorai-1.0b0.tar.gz.

File metadata

  • Download URL: panorai-1.0b0.tar.gz
  • Upload date:
  • Size: 40.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.12.4

File hashes

Hashes for panorai-1.0b0.tar.gz
Algorithm Hash digest
SHA256 ee644054877e1794f2b77eca6641d079e9147f751fed76cc168a0405eef006e4
MD5 14c1984ded6a17c53f6fb4a4210f0d53
BLAKE2b-256 1b6b6780d941df98d971beead5c9834fee9d3f398f8d89324f2f1d30d81b7f19

See more details on using hashes here.

File details

Details for the file panorai-1.0b0-py3-none-any.whl.

File metadata

  • Download URL: panorai-1.0b0-py3-none-any.whl
  • Upload date:
  • Size: 52.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.12.4

File hashes

Hashes for panorai-1.0b0-py3-none-any.whl
Algorithm Hash digest
SHA256 e8fa5ffaed9d09bcdd4580f0ed641483d14e53231871e42015cbf0f5ff04bd73
MD5 87ba8a40611133269d18f942f56955d5
BLAKE2b-256 1aecbdc8618b1be03a6e05385a80eed7a1f2ec59f5ca7334c23dc8cdd517416a

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