mirror of
https://github.com/azaion/gps-denied-onboard.git
synced 2026-04-23 01:46:38 +00:00
094895b21b
Phase 2 — Visual Odometry: - ORBVisualOdometry (dev/CI), CuVSLAMVisualOdometry (Jetson) - TRTInferenceEngine (TensorRT FP16, conditional import) - create_vo_backend() factory Phase 3 — Satellite Matching + GPR: - SatelliteDataManager: local z/x/y tiles, ESKF ±3σ tile selection - GSD normalization (SAT-03), RANSAC inlier-ratio confidence (SAT-04) - GlobalPlaceRecognition: Faiss index + numpy fallback Phase 4 — MAVLink I/O: - MAVLinkBridge: GPS_INPUT 15+ fields, IMU callback, 1Hz telemetry - 3-consecutive-failure reloc request - MockMAVConnection for CI Phase 5 — Pipeline Wiring: - ESKF wired into process_frame: VO update → satellite update - CoordinateTransformer + SatelliteDataManager via DI - MAVLink state push per frame (PIPE-07) - Real pixel_to_gps via ray-ground projection (PIPE-06) - GTSAM ISAM2 update when available (PIPE-03) Phase 6 — Docker + CI: - Multi-stage Dockerfile (python:3.11-slim) - docker-compose.yml (dev), docker-compose.sitl.yml (ArduPilot SITL) - GitHub Actions: ci.yml (lint+pytest+docker smoke), sitl.yml (nightly) - tests/test_sitl_integration.py (8 tests, skip without SITL) Phase 7 — Accuracy Validation: - AccuracyBenchmark + SyntheticTrajectory - AC-PERF-1: 80% within 50m ✅ - AC-PERF-2: 60% within 20m ✅ - AC-PERF-3: p95 latency < 400ms ✅ - AC-PERF-4: VO drift 1km < 100m ✅ (actual ~11m) - scripts/benchmark_accuracy.py CLI Tests: 195 passed / 8 skipped Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
55 lines
1.4 KiB
Python
55 lines
1.4 KiB
Python
"""Metric Refinement schemas (Component F09)."""
|
|
|
|
from typing import Optional
|
|
|
|
import numpy as np
|
|
from pydantic import BaseModel
|
|
|
|
from gps_denied.schemas import GPSPoint
|
|
|
|
|
|
class AlignmentResult(BaseModel):
|
|
"""Result of aligning a UAV image to a single satellite tile."""
|
|
model_config = {"arbitrary_types_allowed": True}
|
|
|
|
matched: bool
|
|
homography: np.ndarray # (3, 3)
|
|
gps_center: GPSPoint
|
|
confidence: float
|
|
inlier_count: int
|
|
total_correspondences: int
|
|
reprojection_error: float # Mean error in pixels
|
|
|
|
|
|
class Sim3Transform(BaseModel):
|
|
"""Sim(3) transformation: scale, rotation, translation."""
|
|
model_config = {"arbitrary_types_allowed": True}
|
|
|
|
translation: np.ndarray # (3,)
|
|
rotation: np.ndarray # (3, 3) rotation matrix
|
|
scale: float
|
|
|
|
|
|
class ChunkAlignmentResult(BaseModel):
|
|
"""Result of aligning a chunk array of UAV images to a satellite tile."""
|
|
model_config = {"arbitrary_types_allowed": True}
|
|
|
|
matched: bool
|
|
chunk_id: str
|
|
chunk_center_gps: GPSPoint
|
|
rotation_angle: float
|
|
confidence: float
|
|
inlier_count: int
|
|
transform: Sim3Transform
|
|
reprojection_error: float
|
|
|
|
|
|
class LiteSAMConfig(BaseModel):
|
|
"""Configuration for LiteSAM alignment."""
|
|
model_path: str = "mock_path"
|
|
confidence_threshold: float = 0.7
|
|
min_inliers: int = 15
|
|
max_reprojection_error: float = 2.0 # pixels
|
|
multi_scale_levels: int = 3
|
|
chunk_min_inliers: int = 30
|