S1005403_RisCC/doc/manual/08_riferimenti_tecnici.md
2025-11-11 10:19:51 +01:00

116 lines
5.4 KiB
Markdown

### File: `08_riferimenti_tecnici.md`
# Capitolo 8: Riferimenti Tecnici
Questo capitolo finale fornisce dettagli tecnici sui formati dei file utilizzati dall'applicazione e un glossario dei termini chiave.
## 8.1. Formato dei File di Dati
L'applicazione utilizza il formato JSON (JavaScript Object Notation) per la persistenza di tutte le sue configurazioni e dati. Questo formato è stato scelto per la sua leggibilità umana e per la facilità di parsing in Python.
### 8.1.1. File di Impostazioni (`settings.json`)
Questo file contiene tutte le impostazioni globali dell'applicazione, esclusi gli scenari. È suddiviso in sezioni:
* **`general`**: Contiene le impostazioni generali della GUI (es. geometria della finestra) e la configurazione della connessione.
* **`connection`**: Un oggetto che contiene le sotto-sezioni `target` e `lru`, ciascuna delle quali definisce il tipo di protocollo (`sfp`, `tftp`, `serial`) e i relativi parametri.
* **`debug`**: Contiene flag e impostazioni per le funzionalità di debug (es. `save_tftp_scripts`).
*Esempio di Struttura:*
```json
{
"general": {
"scan_limit": 60,
"max_range": 100,
"geometry": "1200x900+100+100",
"last_selected_scenario": "Scen_Esempio",
"connection": {
"target": {
"type": "sfp",
"sfp": {
"ip": "127.0.0.1",
"port": 60003,
"local_port": 60002,
"use_json_protocol": true,
"prediction_offset_ms": 20.0
},
"tftp": { ... },
"serial": { ... }
},
"lru": { ... }
}
},
"debug": {
"enable_io_trace": false
}
}
```
### 8.1.2. File degli Scenari (`scenarios.json`)
Questo file contiene le definizioni di tutti gli scenari creati dall'utente. È un dizionario JSON in cui ogni chiave è il nome di uno scenario.
* **Ogni scenario** contiene a sua volta una lista di `targets`.
* **Ogni target** contiene il suo `target_id` e una lista di `trajectory` (i waypoint).
* **Ogni waypoint** è un oggetto che descrive una manovra con i suoi parametri specifici.
*Esempio di Struttura:*```json
{
"Scen_Virata_Semplice": {
"name": "Scen_Virata_Semplice",
"targets": [
{
"target_id": 0,
"active": true,
"traceable": true,
"use_spline": false,
"trajectory": [
{
"maneuver_type": "Fly to Point",
"target_range_nm": 50.0,
"target_azimuth_deg": 45.0,
"target_altitude_ft": 20000.0,
"target_velocity_fps": 843.9,
"target_heading_deg": 270.0
},
{
"maneuver_type": "Dynamic Maneuver",
"duration_s": 20.0,
"lateral_acceleration_g": 2.0,
"turn_direction": "Right"
}
]
}
]
}
}
```
### 8.1.3. File di Archivio Simulazione (`YYYYMMDD_HHMMSS_NomeScenario.json`)
Questi file, salvati nella cartella `archive_simulations/`, contengono un resoconto completo di una singola sessione di simulazione.
* **`metadata`**: Informazioni sulla sessione (timestamp, durata, latenza stimata, etc.).
* **`scenario_definition`**: Una copia dello scenario così com'era al momento dell'avvio.
* **`ownship_trajectory`**: Una serie di snapshot dello stato dell'ownship durante la simulazione.
* **`simulation_results`**: Il cuore dei dati. Un dizionario per `target_id` che contiene due liste:
* **`simulated`**: La "ground truth" di tutti gli stati `(timestamp, x, y, z)` generati dal `SimulationEngine`.
* **`real`**: Tutti gli stati `(timestamp, x, y, z)` ricevuti dal sistema radar per quel target.
## 8.2. Glossario
* **Azimuth:** L'angolo orizzontale di un target rispetto al Nord. Nell'applicazione, la convenzione è: 0° = Nord, angoli positivi in senso antiorario (CCW, verso Sinistra/Ovest), angoli negativi in senso orario (CW, verso Destra/Est).
* **Heading (Prua):** La direzione orizzontale in cui l'aereo (ownship o target) sta volando. Segue la stessa convenzione dell'azimuth.
* **North-Up:** Modalità di visualizzazione PPI in cui la griglia è fissa con il Nord (0°) in alto.
* **Heading-Up:** Modalità di visualizzazione PPI in cui la prua dell'ownship è sempre fissa verso l'alto e la griglia del mondo ruota.
* **Ownship:** La propria piattaforma (il nostro aereo) su cui il radar è installato.
* **PPI (Plan Position Indicator):** La classica visualizzazione radar circolare che mostra range e azimut dei target.
* **Simulation Frame:** Il sistema di coordinate cartesiane fisso, definito dallo stato dell'ownship a T=0, all'interno del quale si evolvono i target simulati.
* **SFP (Simple Fragmentation Protocol):** Protocollo di comunicazione su UDP usato per lo scambio di dati con il sistema radar.
* **Target:** Un oggetto (simulato o reale) tracciato dal sistema.
* **Trajectory:** La sequenza di manovre (waypoint) che definisce il percorso di un target simulato.
* **Waypoint:** Un singolo segmento di una traiettoria che definisce una manovra specifica (es. volo rettilineo, virata a 'g' costante).
```