A UAV Remote ID Spoofing Defense System
Project description
Argus
A UAV Remote ID Spoofing Defense System.
#UAV Swarm Security #Remote ID Spoofing #Graph-Theoretic Modeling #Cryptographic Defenses
Overview
Argus is a research framework for investigating UAV swarm vulnerabilities to Remote ID spoofing attacks. It combines graph-theoretic analysis with cryptographic defenses to detect and prevent:
- 🎭 Phantom UAV Injection: Non-existent UAVs broadcasting fake Remote ID messages
- 📍 Position Falsification: Legitimate UAVs reporting spoofed GPS coordinates
- 🔀 Coordinated Attacks: Multiple synchronized spoofers disrupting swarm consensus
Key Features
- Swarm Simulation: Dynamic graph-based UAV network modeling with configurable parameters
- Attack Injection: Multiple spoofing scenarios with ground truth tracking
- Detection Methods:
- Spectral analysis via Laplacian eigenvalues
- Centrality-based anomaly detection
- Machine learning with Node2Vec embeddings + isolation forests
- Cryptographic verification with Ed25519 signatures (100% TPR, 0% FPR!)
- Consensus Analysis: Quantify attack impact on swarm coordination
- Visualization:
- Publication-quality plots (ROC curves, heatmaps, comparisons) - 300 DPI PDF+PNG
- Live real-time animation with PyQt5 - Watch UAVs move and attacks unfold!
- Enhanced interactive visualization with detection overlay
Installation
Prerequisites
- Python 3.10 or higher
- pip or uv package manager
From PyPI (Recommended)
# Install from PyPI
pip install argus_uav
# Verify installation
argus --help
From Source (For Development)
# Clone the repository
git clone https://github.com/Sang-Buster/Argus.git
cd Argus
# Create virtual environment
uv v -p 3.10
source venv/bin/activate # On Windows: venv\Scripts\activate
# Install in development mode
pip install -e .
# Verify installation
argus --help
pytest tests/ -v
Quick Start
Interactive CLI (Recommended)
The easiest way to get started is with the interactive CLI:
# After installation, use the 'argus' command
argus
# Quick command-line usage
argus --attack phantom --detectors all --mode comparison
# See all options
argus --help
See CLI User Guide for complete documentation.
The CLI provides:
- ✨ Interactive mode - guided experience for beginners
- 🎬 Live visualization - watch attacks and detection in real-time
- 📊 Performance comparison - automated benchmarking and plots
- 🎯 All attacks & detectors - test any combination of 3 attacks × 4 detection methods
1. Simulate a Clean UAV Swarm
from argus_uav.core.swarm import Swarm
import numpy as np
# Create reproducible simulation
rng = np.random.default_rng(seed=42)
swarm = Swarm(
num_uavs=20,
comm_range=100.0,
bounds=(1000, 1000, 200),
rng=rng
)
# Run for 10 seconds
for t in range(10):
swarm.step(dt=1.0)
print(f"Time {t}s: {swarm.get_graph().number_of_edges()} links")
2. Inject and Detect Phantom UAVs
from argus_uav.attacks.phantom_uav import PhantomInjector
from argus_uav.attacks import AttackScenario, AttackType
from argus_uav.detection.spectral import SpectralDetector
# Configure phantom attack
attack = AttackScenario(
attack_type=AttackType.PHANTOM,
start_time=5.0,
duration=10.0,
phantom_count=3
)
# Setup detection
detector = SpectralDetector()
detector.train([swarm.get_graph().copy() for _ in range(20)])
# Run with attack
injector = PhantomInjector()
for t in range(20):
if attack.is_active(float(t)):
injector.inject(swarm, attack, float(t))
swarm.step(dt=1.0)
result = detector.detect(swarm.get_graph())
metrics = result.compute_metrics()
print(f"TPR: {metrics['tpr']:.2%}, FPR: {metrics['fpr']:.2%}")
3. Compare All Detection Methods
# Run performance comparison with all detectors
argus --attack phantom --detectors all --mode comparison
# Live visualization with specific detectors
argus --attack coordinated --detectors spectral crypto --mode live
# Both live and comparison modes
argus --attack position --detectors centrality --mode both
Project Structure
src/argus_uav/
├── core/ # Simulation engine (UAV, swarm, Remote ID)
├── attacks/ # Attack injection (phantom, position spoof, coordinated)
├── detection/ # Detection algorithms (spectral, centrality, ML)
├── crypto/ # Ed25519 signing and verification
├── consensus/ # Swarm consensus algorithms
├── evaluation/ # Metrics, visualizations, ROC curves
├── experiments/ # Experiment runner and configuration
└── utils/ # Random seeds, logging
tests/
├── unit/ # Unit tests for individual components
├── integration/ # End-to-end scenario tests
├── contract/ # Interface compliance tests
└── performance/ # Benchmark and profiling tests
examples/ # Example demonstrations and scripts
docs/ # Documentation and examples
results/ # Experiment outputs (gitignored)
Usage Examples
Command-Line Options
# Interactive mode (recommended for beginners)
argus
# Quick demos
argus --attack phantom --detectors spectral --mode live
argus --attack position --detectors all --mode comparison
argus --attack coordinated --detectors crypto --mode both
# Custom swarm configuration
argus --attack phantom --detectors all --mode comparison \
--num-uavs 50 --comm-range 150
# See all available options
argus --help
Programmatic Usage
For advanced experiments with custom configurations, you can use the Python API directly. See the examples/ directory for comprehensive demonstrations.
Documentation
📚 Complete Documentation Index
Quick Links:
- Quickstart Guide - Get started in 10 minutes
- Project Status - Complete status & features
- Algorithm Details - Theory and implementation
- Data Formats - Specifications and schemas
- References - 19 research paper citations
Design Artifacts (Spec Kit):
- Specification - Requirements and user stories
- Implementation Plan - Architecture decisions
- Data Model - Entity relationships
Research Background
This project investigates defenses against Remote ID spoofing, a critical security challenge for UAV swarms. Remote ID is mandated by aviation authorities (FAA 14 CFR Part 89) but lacks authentication, making it vulnerable to falsified messages.
Key Research Questions
- Can graph-theoretic metrics detect topological anomalies from phantom UAVs?
- How effective is machine learning (Node2Vec + isolation forests) vs pure graph analysis?
- What is the performance overhead of Ed25519 cryptographic signing for real-time swarms?
- How do spoofing attacks impact swarm consensus algorithms?
Methodology
- Simulation: Software-only UAV swarm modeling (no hardware required)
- Attack Scenarios: Phantom injection, position falsification, coordinated spoofers
- Detection: Spectral analysis, centrality metrics, ML embeddings
- Defense: Ed25519 digital signatures for message authentication
- Evaluation: TPR, FPR, detection latency, consensus error
Performance Benchmarks
Expected performance on modern laptop (8 cores, 16GB RAM):
| Operation | Time |
|---|---|
| Simulate 50 UAVs for 100 steps | ~5 seconds |
| Spectral detection (100 nodes) | ~40ms |
| Node2Vec detection (100 nodes) | ~80ms |
| Ed25519 signing | ~0.05ms |
| Ed25519 verification | ~0.1ms |
Testing
# Run all tests
pytest tests/
# Run with coverage
pytest tests/ --cov=argus --cov-report=html
# Run specific test suites
pytest tests/unit/ # Unit tests only
pytest tests/integration/ # Integration tests only
pytest tests/performance/ # Performance benchmarks
Contributing
This is a research project. Contributions are welcome! Areas of interest:
- Additional detection algorithms (GNNs, threshold signatures)
- Real-world Remote ID traffic datasets
- Hardware integration (RTL-SDR, physical UAVs)
- Scalability optimizations for larger swarms
References
- Peel, L., et al. (2015). "Detecting Change Points in Evolving Networks"
- Olfati-Saber, R., & Murray, R. M. (2004). "Consensus Problems in Networks"
- Grover, A., & Leskovec, J. (2016). "node2vec: Scalable Feature Learning"
- Liu, F. T., et al. (2008). "Isolation Forest"
- Bernstein, D. J., et al. (2012). "High-speed high-security signatures" (Ed25519)
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file argus_uav-0.1.0.tar.gz.
File metadata
- Download URL: argus_uav-0.1.0.tar.gz
- Upload date:
- Size: 185.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.8.15
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0d45269a3318b314b96a2a236714d74ab91341e4446cc4b22e0f2770ece42dbf
|
|
| MD5 |
663d71c9838017edf015abf74626b432
|
|
| BLAKE2b-256 |
1daf620b948b029dd7f103f58506308b1e786dd0a325370daa96d74bfeef1436
|
File details
Details for the file argus_uav-0.1.0-py3-none-any.whl.
File metadata
- Download URL: argus_uav-0.1.0-py3-none-any.whl
- Upload date:
- Size: 57.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.8.15
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
7aba42afd3b079c8b97bfe8ac06472f51b2735182008a8614496d9bf173a90c9
|
|
| MD5 |
c910f533c16ff280126afe32987e67ea
|
|
| BLAKE2b-256 |
7def11fa4d9d1bef46b4f47adac34b746ccf5f019ac581ef466a8f6b69fdfdec
|