1 #ifndef ARCHIVIATORE_CUM_BAC_CLASS_H
2 #define ARCHIVIATORE_CUM_BAC_CLASS_H
17 #include <radarelab/algo/vpr.h>
27 #define NUM_AZ_X_PPI 400
31 #define RES_VERT_CIL 0.25
32 #define RES_HOR_CIL 0.25
40 struct CalcoloSteiner;
49 namespace elaboradar {
205 void generate_maps(CartProducts& products);
225 log4c_category_t* logging_category;
228 radarelab::algo::InstantaneousVPR inst_vpr;
265 int analyse_VPR(
float *vpr_liq,
int *snow,
float *hliq);
292 int combina_profili(
const radarelab::algo::InstantaneousVPR& inst_vpr);
317 void merge_metodi(
const radarelab::algo::CalcoloSteiner& steiner,
const radarelab::algo::CalcoloVIZ& viz);
337 radarelab::Image<unsigned char>
cart;
361 void write_out(
Assets& assets,
const std::string tagname,
const std::string format=
"PNG");
378 float comp_levels(
float v0,
float v1,
float nodata,
float peso);
radarelab::PolarScan< unsigned char > corr_polar
correzione vpr in byte 0-128 negativa 128-256 positiva, in coord az-ra
radarelab::algo::DBZ dbz
????
bool do_quality
Feature set required for this run.
float comp_levels(float v0, float v1, float nodata, float peso)
combina livelli
bool do_readStaticMap
Read Static clutter map.
double htbb
altezza top brightband
radarelab::PolarScan< unsigned char > bb_first_level
mappa di elevazioni da beam blocking (input)
Class to manage reflectivity functions (simply attenuation correction, conversion between Z...
CUM_BAC & cum_bac
oggeto CUM_BAC di riferimento
radarelab::PolarScan< unsigned char > neve
matrice az-range che memorizza punti di neve
unsigned MyMAX_BIN
LUNGHEZZA MASSIMA.
int ier_stampa_vpr
flag d'errore su stampa profilo
Definisce le principali strutture che contengono i dati.
bool do_medium
medium processing flag
bool do_beamblocking
beamblocking corretion
int corr_vpr()
correzione vpr
CUM_BAC(radarelab::Volume< double > &volume, const Config &cfg, const Site &site, bool medium=false, unsigned max_bin=512)
Constructor.
bool do_anaprop
anaprop correction
radarelab::PolarScan< unsigned char > first_level_static
mappa statica
int profile_heating(bool has_inst_vpr)
calcola riscaldamento in quarti d'ora
int combina_profili(const radarelab::algo::InstantaneousVPR &inst_vpr)
funzione che combina il profilo verticale corrente con quello precedente tramite il metodo di Germann...
Struttara per il calcolo del VPR.
CalcoloVPR * calcolo_vpr
Oggetto per calcolare e correggere con VPR.
void leggo_first_level()
funzione che legge la mappa statica e la mappa di elevazioni da beam blocking e le condensa in un uni...
long int gap
distanza temporale dall'ultimo file vpr [numero acquisizioni intercorse dall'ultimo vpr ...
void classifica_rain()
funzione che classifica la precipitazione se stratiforme o convettiva
radarelab::PolarScan< unsigned char > first_level
mappa dinamica complessiva
bool do_zlr_media
Compute ZLR map using averaging.
unsigned MyMAX_BIN
maximum number of beam size
void ScrivoStatistica(const radarelab::algo::anaprop::GridStats &)
funzione scrittura matrici statistica
Struttura per gestire output cartesiano di un singolo campo.
int trovo_hvprmax(int *hmax)
trova il massimo del profilo
const Config & cfg
Configuration object.
static void read_sp20_volume(radarelab::Volume< double > &volume, const Site &site, const char *nome_file, bool do_clean=false, bool do_medium=false)
Read from SP20 data file.
SingleCart(unsigned max_bin)
Constructor.
CalcoloVPR(CUM_BAC &cum_bac)
Constructor.
float t_ground
2m temperature
void esegui_tutto()
Metodo che lancia tutte le operazioni per il calcolo e la correzione del vpr.
char date[20]
Acquisition date.
log4c_category_t * logging_category
logging category
double hbbb
altezza bottom brightband
radarelab::Volume< double > & volume
Polar volume of Reflectivity.
int hvprmax
quota picco vpr
radarelab::PolarScan< float > dem
dem in coordinate azimut range
radarelab::algo::VPR vpr
Informa se il pixel è convettivo.
int stampa_vpr()
stampa profilo combinato
radarelab::CylindricalVolume cil
Volume resampled as a cylindrical volume.
Classe principale del programma.
bool do_class
Convective-stratiform classification.
bool do_bloccorr
bloccorrection
float resol[2]
array di parametri, fisso , RES_HOR_CIL E RES_VERT_CIL
static void read_odim_volume(radarelab::Volume< double > &volume, const Site &site, const char *nome_file, bool do_clean=false, bool do_medium=false)
Read from ODIM data file.
bool do_devel
Produce additional output.
void vpr_class()
Esegue tutta la catena vpr (e classificazione) se richiesta.
int ier_max
flag d'errore su calcolo quota max
radarelab::PolarScan< unsigned char > beam_blocking
mappa di beam blocking (input)
radarelab::Volume< unsigned char > qual
qualita volume polare
radarelab::Image< unsigned char > cart
vol_pol interpolated in a cartesian map
Finds resources, like data files, used by the program.
void creo_cart(const radarelab::Volume< double > &volume, unsigned int el_index)
conversione da polare a cartesiano alta risoluzione
int livmin
quota livello minimo calcolato
void caratterizzo_volume()
funzione che caratterizza i volumi polari tramite la qualita'
const unsigned max_bin
dimensione matrice
time_t NormalizzoData(time_t time)
funzione che a partire dal tempo in secondi arrotonda al NMIN-esimo minuto precedente o successivo ...
int analyse_VPR(float *vpr_liq, int *snow, float *hliq)
funzione che analizza il profilo
int heating
variabile di riscaldamento
radarelab::PolarScan< unsigned char > top
Echo top a ???? dBZ [hm].
radarelab::Volume< double > SD_Z6
Polar volume of standard deviation of reflectivity over 6 km length.
Radar volume mapped to cylindrical coordinates.
Gestisce risorse usate dal programma.
void merge_metodi(const radarelab::algo::CalcoloSteiner &steiner, const radarelab::algo::CalcoloVIZ &viz)
fa il merge dei metodi
void creo_matrice_conv()
funzioni di conversione cartesiana:associa a pixel matrice alta ris azimut e range, crea alta risoluzione e crea bassa risoluzione
void want_vpr()
Call this just after creating the CUM_BAC object, to signal that VPR should also be computed...
radarelab::algo::Anaprop< double > anaprop
Oggetto per correzione ANAPRO.
const Site & site
site information object
void declutter_anaprop()
funzione che elabora il dato radar rimuovendo anaprop e beam blocking
void write_out(Assets &assets, const std::string tagname, const std::string format="PNG")
Produce in output le immagini PNG dei campi in $DIR_DEBUG.
bool do_declutter
use only static declutter map
void conversione_convettiva()
Nei punti convettivi ricalcola la Z come MP classica, partendo dalla stima di R (convettiva) ...