Skip to main content

No project description provided

Project description

GeoSol Research Logo

Convolve (Ellipsoid Fusion)

Ellipsoid convolution functions for combining geolocation estimates with outlier detection and multi-cluster support.

Overview

gri-convolve provides three functions of increasing sophistication for fusing collections of Ell (ellipsoid) objects into combined position estimates:

  • convolve -- combine all input ellipsoids into a single fused result with no outlier rejection
  • smart_convolve -- iteratively remove outliers by Mahalanobis distance before fusing
  • cluster_convolve -- find multiple clusters within a dataset and fuse each independently

Each function operates on Ell objects from gri-ell, which pair a 3D position with a statistical covariance (or information matrix). The output is one or more fused Ell objects representing the combined position estimate and its uncertainty.

Requires Python 3.14+.

Mathematical Background

Information matrix fusion. Given N ellipsoids, each with position x_k and information matrix I_k (the inverse of the covariance matrix, in XYZ coordinates, 1/m^2, 1-sigma), the fused position and information matrix are:

S = sum(I_k)              (combined information matrix)
x = S^{-1} sum(I_k x_k)  (fused position)

This is the maximum-likelihood estimator under Gaussian assumptions.

Inflation methods. The raw fusion above underestimates uncertainty when inputs are inconsistent. Three modes control how the output covariance is inflated:

  • "none" -- strict information matrix combination (no inflation)
  • "std" -- inflate by the sample scatter of input positions in XYZ
  • "bart" -- inflate along the semi-major axis direction in ENU (recommended default)

Outlier detection. smart_convolve computes the Mahalanobis distance from each input to the fused point:

d_M = sqrt((x - mu)^T I (x - mu))

where mu is the fused position and I is its information matrix. Distances are normalized to 95% confidence scale. Inputs exceeding max_norm are iteratively removed, worst first.

Reference: Mahalanobis, P.C. (1936). "On the generalized distance in statistics."

Installation

pip install gri-convolve

For development:

git clone https://gitlab.com/geosol-foss/python/gri-convolve.git
cd gri-convolve
. .init_venv.sh

Quick Start

from gri_convolve import convolve, smart_convolve, cluster_convolve
from gri_ell import Ell
from gri_pos import Pos
import numpy as np

# Create some ellipsoids at nearby positions
e1 = Ell.from_2d(Pos.LLA(40.0, -105.0, 1600), 100, 50, 45)
e2 = Ell.from_2d(Pos.LLA(40.001, -105.001, 1610), 120, 60, 30)
e3 = Ell.from_2d(Pos.LLA(40.0005, -104.999, 1605), 90, 45, 50)

# Simple fusion
fused = convolve([e1, e2, e3])
print(fused.lla)            # Fused position
print(fused.ellipse.sma_95) # Fused semi-major axis (95%, meters)

convolve()

Fuses all input ellipsoids into a single result. No outlier detection.

fused = convolve(ellipsoids, inflation="bart")

Parameters:

  • ellipsoids -- sequence of Ell objects
  • inflation -- "none", "std", or "bart" (default: "bart")

Returns: A single fused Ell.

smart_convolve()

Fuses with iterative outlier rejection. Computes the fused point, finds the input with the largest normalized Mahalanobis distance, and removes it if it exceeds max_norm. Repeats until all remaining inputs are within tolerance or fewer than min_pts remain.

result = smart_convolve(ellipsoids, max_norm=2.0, min_pts=3)
if result is not None:
    fused_ell, used_indices, discarded_indices = result

Parameters:

  • ellipsoids -- sequence of Ell objects
  • max_norm -- maximum allowed normalized distance (default: 2.0)
  • min_pts -- minimum inputs required for a valid result (default: 3)

Returns: (Ell, list[int], list[int]) or None if no valid cluster is found.

Pre-cluster your data before calling smart_convolve. Without pre-clustering, a large group of scattered noise points can cause valid clusters to be discarded first.

cluster_convolve()

Finds multiple clusters within a dataset by iteratively applying smart_convolve. After finding the largest valid cluster, the discarded points are passed back in to find additional clusters.

locations, used_per_location, discarded = cluster_convolve(
    ellipsoids,
    max_norm=2.0,
    min_pts=3,
    max_pts=10,
    min_sma_m=50.0,
)

for loc, indices in zip(locations, used_per_location):
    print(f"Cluster at {loc.lla} using {len(indices)} inputs")

Parameters:

  • ellipsoids -- sequence of Ell objects
  • max_norm -- maximum normalized Mahalanobis distance (default: 2.0)
  • min_pts -- minimum inputs per cluster (default: 3)
  • max_pts -- maximum inputs per cluster; splits larger groups (default: None)
  • min_sma_m -- minimum semi-major axis for output ellipsoids in meters (default: 0)
  • max_ori_spread -- sort by orientation before splitting for diversity (default: True)
  • alt_post_process -- callback for altitude correction (e.g., snap to terrain)

Returns: (list[Ell], list[list[int]], list[int])

Units and Conventions

  • Positions are in ECEF XYZ (meters) internally
  • Information matrices are in XYZ, 1/m^2, 1-sigma
  • Covariance matrices are in ENU, m^2, 1-sigma
  • Output ellipse parameters (SMA, SMI, orientation) are at 95% confidence
  • Mahalanobis distances are normalized to 95% scale for max_norm comparisons

Dependencies

  • gri-ell: Ellipsoid objects with position and covariance
  • gri-pos: Position objects (XYZ, LLA coordinates)
  • gri-utils: Coordinate conversions and constants
  • numpy: Array operations

Other Projects

Current list of other GRI FOSS Projects we are building and maintaining.

License

MIT License. See LICENSE for details.

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

gri_convolve-0.2.0.tar.gz (35.9 kB view details)

Uploaded Source

Built Distribution

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

gri_convolve-0.2.0-py3-none-any.whl (13.7 kB view details)

Uploaded Python 3

File details

Details for the file gri_convolve-0.2.0.tar.gz.

File metadata

  • Download URL: gri_convolve-0.2.0.tar.gz
  • Upload date:
  • Size: 35.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.10.4 {"installer":{"name":"uv","version":"0.10.4","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Debian GNU/Linux","version":"13","id":"trixie","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for gri_convolve-0.2.0.tar.gz
Algorithm Hash digest
SHA256 7b27fd027b5900ff34dc5645fbeff0420c58941dd6e77cf382497d17e2ef3357
MD5 2a920974dc57e37c3de80f9fde690388
BLAKE2b-256 46764bb37fb3baa1eb26245ad035975d605ccd61e341eb073a718c2228222b25

See more details on using hashes here.

File details

Details for the file gri_convolve-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: gri_convolve-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 13.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.10.4 {"installer":{"name":"uv","version":"0.10.4","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Debian GNU/Linux","version":"13","id":"trixie","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for gri_convolve-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 e16b02e6ef595bd11285eb58825838a45d7e14eafb098e75ab1fbb52b8fdcb9a
MD5 e5c27b80602c8b854753ff7e19ff08b1
BLAKE2b-256 a54a1aa84a931c7eb9b8ee7f85f3cbfd7c7bc79c7adb52bdcbd84b2f9dc58b40

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