Complete signal processing pipeline from complex baseband to decoded PCM telemetry, verified against the 1965 NAA Study Guide (A-624): Core demod (Phase 1): - PM demodulator with carrier PLL recovery - 1.024 MHz subcarrier extractor (bandpass + downconvert) - BPSK demodulator with Costas loop + symbol sync - Convenience hier_block2 combining subcarrier + BPSK PCM frame processing (Phase 2): - 32-bit frame sync with Hamming distance correlator - SEARCH/VERIFY/LOCKED state machine, complement-on-odd handling - Frame demultiplexer (128-word, A/D voltage scaling) - AGC downlink decoder (15-bit word reassembly from DNTM1/DNTM2) Voice and analog (Phase 3): - 1.25 MHz FM voice subcarrier demod to 8 kHz audio - SCO demodulator for 9 analog sensor channels (14.5-165 kHz) Virtual AGC integration (Phase 4): - TCP bridge client with auto-reconnect and channel filtering - DSKY uplink encoder (VERB/NOUN/DATA command sequences) Top-level receiver (Phase 5): - usb_downlink_receiver hier_block2: one block, complex in, PDUs out - 14 GRC block YAML definitions for GNU Radio Companion - Example scripts for signal analysis and full-chain demo Infrastructure: - constants.py with all timing/frequency/frame parameters - protocol.py for sync word + AGC packet encode/decode - Synthetic USB signal generator for testing - 222 tests passing, ruff lint clean
45 lines
1.0 KiB
YAML
45 lines
1.0 KiB
YAML
id: apollo_uplink_encoder
|
|
label: Apollo Uplink Encoder
|
|
category: '[Apollo USB]'
|
|
flags: [python]
|
|
|
|
parameters:
|
|
- id: channel
|
|
label: INLINK Channel
|
|
dtype: int
|
|
default: '37'
|
|
|
|
inputs:
|
|
- label: command
|
|
domain: message
|
|
|
|
outputs:
|
|
- label: uplink_words
|
|
domain: message
|
|
|
|
templates:
|
|
imports: from apollo import uplink_encoder
|
|
make: >-
|
|
apollo.uplink_encoder.uplink_encoder(
|
|
channel=${channel})
|
|
|
|
documentation: |-
|
|
Apollo Uplink Command Encoder
|
|
|
|
Converts high-level DSKY commands into AGC INLINK word sequences
|
|
suitable for delivery via the AGC Bridge block.
|
|
|
|
Accepts command PDUs with metadata containing:
|
|
"type": "VERB", "NOUN", "DATA", or "PROCEED"
|
|
"data": integer value (verb/noun number or data word)
|
|
|
|
Emits one PDU per keystroke in the encoded sequence.
|
|
For example, V37 emits 3 PDUs: VERB key, digit 3, digit 7.
|
|
|
|
Connect the uplink_words output to the AGC Bridge uplink_data input.
|
|
|
|
Parameters:
|
|
channel: AGC I/O channel for uplink (default 37 = octal 045 INLINK)
|
|
|
|
file_format: 1
|