Skip to main content

Official Python SDK for MAPIR Chloros image processing

Project description

Chloros Python SDK

Official Python SDK for MAPIR Chloros image processing software. Provides programmatic access to the Chloros API for automation, integration, and custom workflows.

🚀 Quick Start

from chloros_sdk import ChlorosLocal

# Initialize SDK (auto-starts backend)
chloros = ChlorosLocal()

# Create project and import images
chloros.create_project("MyProject", camera="Survey3N_RGN")
chloros.import_images("C:/DroneImages/Flight001")

# Configure settings
chloros.configure(
    vignette_correction=True,
    reflectance_calibration=True,
    indices=["NDVI", "NDRE", "GNDVI"]
)

# Process images
chloros.process(mode="parallel", wait=True)

One-Line Processing

from chloros_sdk import process_folder

results = process_folder("C:/DroneImages/Flight001", indices=["NDVI", "NDRE"])

📋 Requirements

Requirement Details
Chloros Desktop Must be installed locally
License Chloros+ required (paid plan)
Operating System Windows 10/11 (64-bit)
Python Python 3.7 or higher
Memory 8GB RAM minimum (16GB recommended)

⚠️ License Requirement: The Chloros SDK requires an active Chloros+ subscription. Standard (free) plans do not have API access. Upgrade at https://cloud.mapir.camera/pricing

📥 Installation

From PyPI (Recommended)

pip install chloros-sdk

From Source

git clone https://github.com/mapircamera/chloros-sdk.git
cd chloros-sdk
pip install -e .

With Progress Monitoring

pip install chloros-sdk[progress]

📖 Documentation

Complete documentation available at: https://docs.chloros.com/api-python-sdk

🎯 Use Cases

Research & Academia

# Integrate Chloros into analysis pipelines
import chloros_sdk
import pandas as pd

chloros = chloros_sdk.ChlorosLocal()

results = []
for survey in field_surveys:
    chloros.process(survey.images)
    ndvi_data = chloros.get_index_values("NDVI")
    results.append({'chloros_ndvi': ndvi_data, 'biomass': survey.biomass})

df = pd.DataFrame(results)
correlation = df.corr()

Batch Processing

# Process multiple flights automatically
from chloros_sdk import ChlorosLocal

chloros = ChlorosLocal()

for flight in flight_database:
    chloros.create_project(flight.name)
    chloros.import_images(flight.folder)
    chloros.configure(indices=flight.requested_indices)
    chloros.process()

Custom Workflows

# Advanced progress monitoring
def progress_callback(progress, message):
    print(f"[{progress}%] {message}")

chloros = ChlorosLocal()
chloros.create_project("CustomWorkflow")
chloros.import_images("C:/Data")
chloros.configure(indices=["NDVI", "NDRE"])
chloros.process(progress_callback=progress_callback)

🔑 License Activation

The SDK uses the same license as Chloros Desktop:

  1. Open Chloros Desktop GUI
  2. Login with your Chloros+ credentials (one-time)
  3. SDK automatically uses cached license
  4. License persists across reboots (30-day offline support)

🛠️ API Reference

ChlorosLocal Class

Main SDK class for local Chloros processing.

chloros = ChlorosLocal(
    api_url="http://localhost:5000",     # Backend URL
    auto_start_backend=True,             # Auto-start if not running
    backend_exe=None,                    # Auto-detect backend path
    timeout=30                           # Request timeout (seconds)
)

Methods

create_project(project_name, camera=None)

Create a new Chloros project.

import_images(folder_path, recursive=False)

Import images from a folder.

configure(**settings)

Configure processing settings.

process(mode="parallel", wait=True, progress_callback=None)

Start processing images.

get_config()

Get current project configuration.

get_status()

Get backend status.

🔐 Security

  • Proprietary Software: Licensed under MAPIR proprietary license
  • Local Processing: All processing happens locally (localhost API)
  • License Enforcement: Requires active Chloros+ subscription
  • No Data Transmission: Images never leave your computer

💡 Examples

See complete examples in the documentation.

🐛 Support

📄 License

Copyright (c) 2025 MAPIR Inc. All rights reserved.

This is proprietary software requiring an active Chloros+ subscription. Unauthorized use, distribution, or modification is prohibited.

🔄 Version History

v1.0.0 (2025)

  • Initial release
  • Full API coverage for local processing
  • Auto-backend startup
  • Progress monitoring support
  • Context manager support

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

chloros_sdk-1.0.3.tar.gz (531.1 kB view details)

Uploaded Source

Built Distribution

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

chloros_sdk-1.0.3-py3-none-any.whl (19.7 kB view details)

Uploaded Python 3

File details

Details for the file chloros_sdk-1.0.3.tar.gz.

File metadata

  • Download URL: chloros_sdk-1.0.3.tar.gz
  • Upload date:
  • Size: 531.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.11

File hashes

Hashes for chloros_sdk-1.0.3.tar.gz
Algorithm Hash digest
SHA256 324aef3e3ba69b525eaebfd0c707464a8f66ac313f8dd2f749e54c33b0fe0948
MD5 3b7988686a457c915868f7f3ad67c488
BLAKE2b-256 2e167ba14876d4ea39064c6a3a53cc674cf021b5cd0a46813da68e09be0dd035

See more details on using hashes here.

File details

Details for the file chloros_sdk-1.0.3-py3-none-any.whl.

File metadata

  • Download URL: chloros_sdk-1.0.3-py3-none-any.whl
  • Upload date:
  • Size: 19.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.11

File hashes

Hashes for chloros_sdk-1.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 636ba44c49f97caf7077088b54c02bbf802de7765974ebcd400ac1ead4901865
MD5 39518581db42e158cd107c2c63c550c5
BLAKE2b-256 b3f27b366fda64ab6faf6769ca95a703a9be99f8789b04a9c878bca87f91ca07

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