satnogs-signal-classifier

ResNet-18 fine-tuned to classify SatNOGS waterfall spectrograms as signal vs no-signal (narrowband FSK/GFSK cubesat telemetry). A read-only triage aid — it suggests, it does not auto-vet.

Inputs are cropped to the spectrogram region (colorbar + axes removed), which re-centers the signal.

Held-out test metrics

Leakage-safe test set (unseen ground stations + an entirely unseen satellite), 436 observations:

Metric Model Classical baseline
ROC-AUC 0.827 0.570
PR-AUC 0.829 0.557
precision@10 1.000 0.600

Cross-satellite generalization (held-out FrontierSat, 240 obs, never trained on): ROC-AUC 0.772. By mode: GFSK 0.93, FSK 0.92, FSK AX.100 Mode 5 0.79.

Labels

0 = without-signal, 1 = with-signal; predict P(with-signal) = softmax index 1. Trained on gold human waterfall_status vettings — never the decode-based observation status.

Training data

Dataset: ryroeu/satnogs-signal-waterfalls — 4 train satellites (OTP-2, CUBEBEL-2, AEPEX, CatSat), held-out satellite FrontierSat; ~1,189 gold waterfalls, cropped to the spectrogram.

Limits & caveats

  • Sampling bias: gold labels skew toward clearer passes than the unvetted firehose; real-world performance on marginal/faint observations will be lower than these numbers.
  • Narrow family: trained on narrowband FSK/GFSK telemetry; generalization beyond it is unverified.
  • Read-only triage aid, not an auto-vetter. precision@10 = 1.0 means the top of the ranked queue is reliable.

Usage

from transformers import pipeline
clf = pipeline("image-classification", model="ryroeu/satnogs-signal-classifier")
clf("waterfall.png")
Downloads last month
31
Safetensors
Model size
11.2M params
Tensor type
F32
·
Inference Providers NEW
This model isn't deployed by any Inference Provider. 🙋 Ask for provider support

Dataset used to train ryroeu/satnogs-signal-classifier