Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revision Previous revision
Next revision
Previous revision
kvalobs:kvalobs:aggregering [2010-06-23 07:11:21]
vegardb
— (current)
Line 1: Line 1:
-====== kvAgregated ====== 
- 
- 
-==== Introduksjon ==== 
- 
-Dette programmet mottar observasjoner fra kvalobs og genererer 
-aggregerte verdier på grunnlag av disse. De aggregerte verdiene 
-sendes så tilbake til kvalobs. 
- 
-Følgende liste viser hvilke parametre fra kvalobs som generer hva: 
- 
-|Fra|Til|Når| 
-|TAN|TAN_12|06:00 og 18:00| 
-|TAX|TAX_12|06:00 og 18:00| 
-|TGN|TGN_12|06:00 og 18:00| 
-|  |  |  | 
-|RR_01|RR_1|Hver time| 
-|RR_1|RR_12|06:00 og 18:00| 
-|RA|RR_12|06:00 og 18:00| 
-|RR_12|RR_24|06:00| 
-|  |  |  | 
-|TA|TA_24|23:00| 
-|UU|UU_24|23:00| 
-|NN|NN_24|23:00| 
-|PR|PO|Hver time| 
- 
-Merk at det også genereres aggregerte verdier av de aggregerte 
-verdiene, så dersom for eksempel en stasjon kun rapporterer RR_1 vil 
-både RR_12 og RR_24 aggregeres. 
- 
-Det er også verd å merke seg at aggregeringene oppdateres etterhvert 
-som grunnlagsdata oppdateres, så dersom for eksempel en observasjon 
-av RR_1 endres av HQC, vil aggregerte verdier av RR_12 oppdateres 
-tilsvarende. 
- 
-Aggregatoren beregner både originalverdi og korrigertverdi, og legger det inn i databasen, uavhengig av om det fantes aggregerte verdier der fra før. Original og korrigert verdi beregnes hver for seg, med samme algoritme. 
- 
- 
-==== Aggregerte parametre ==== 
- 
-De aggregerte parametrene vil ha lik stasjonsid, sensor og level som de parametrene som aggregeres. typeid, derimot, vil endres til å bli lik den negative verdien av den originale typeid. Dette medfører at aggregerte verdier lett kan skilles fra ikke-aggregerte verdier i kvalobs. 
- 
-De aggregerte verdiene får kontrollflagg fylt ut med bare null-verdier, med unntak av [[kvalobs:kvalobs-flagg#vurdering_av_grunnlagsdata_ved_aggregering_aggregation|fagg]], og [[kvalobs:kvalobs-flagg#manglende_observasjon_missing|fmis]], som settes i henhold til flaggdokumentet. Som ellers i kvalobs beregnes useinfo ut ifra kontrollinfo. 
- 
- 
-==== Aggregerte parametre og kvalobs ==== 
- 
-Det er viktig å merke seg at siden de aggregerte parametrene får 
-negativ typeid, blir de av kvalobs oppfattet som forskjellige 
-stasjoner fra "grunnlagsstasjonene". Dette, sammen med at stasjoner 
-med negativ typeid ikke fins i obs_pgm, medfører at det ikke blir 
-gjort noen kvalitetskontroll av de aggregerte verdiene. 
- 
- 
-==== Oppsett før kjøring ==== 
- 
-For å kjøre kvAgregated må [[http://www.sqlite.org/|sqlite3]] være installert. 
- 
-Under installasjon kjøres skriptet kvAgregateDbInit. Dette skriptet lager en cachedatabase for aggregatoren. For at den skal kunne brukes, må aggregatoren ha skriverettigheter dit. Databasen legges i fila {localstatedir}/lib/kvagregated/database.sqlite. localstatedir er normalt området /var eller /usr/local/var på maskinen. For å gi kvalobsbrukeren skriverettigheter til denne kan man for eksempel si: 
- 
-<code bash> 
-chmod kvalobs:kvalobs /var/lib/kvagregated/database.sqlite 
-</code> 
- 
-Dette skjer automatisk dersom aggregatoren er installert via en debian-pakke (som den nå er på produksjonsmaskinene). 
- 
-==== Start av kvAgregated ==== 
- 
-Når kvAgregated startes vil den i begynne med å hente ned data fra 
-kvalobs for de siste 24 timene. Dette er resurskrevende, og programmet 
-bør ikke startes mens kvalobs har mye annet å gjøre, dvs at hver hele og 
-halve time bør unngås for oppstart. 
- 
-Etter oppstarten vil aggregerte data genereres fortløpende, etterhvert 
-som grunnlagsdata kommer inn.  
- 
-kvAgregated tar flere kommandolinjeargumenter. For å få en liste over disse, kan du kjøre følgende kommando: 
- 
-<code> 
-kvAgregated --help 
-</code> 
- 
-Opsjonene til kommandolinja lar deg styre aggregeringen på forskjellige måter. For eksempel kan du begrense hvilke stasjoner eller parametre som skal aggregeres, eller du kan få aggregatoren til å gå igjennom, og reprosessere gammel data. 
- 
- 
-==== Feilsituasjoner ==== 
- 
-Hvis kvalobs går ned kan det være en god ide å også restarte kvAgregated. 
- 
-Idet aggregatoren begynner å kjøre igjen, vil den automatisk gå igjennom data for de siste tre timene, for å se om det har kommet noe nytt å aggregere siden den gikk ned. 
- 
-Hvis aggregatorene har vært lengre nede enn tre timer, må kommandolinjeopsjoner settes for å få aggregatoren til å prosessere data lengre bak enn tre timer. Kjør %%kvAgregated --help%% for detaljer. 
- 
- 
- 
- 
-==== Spesielle regler === 
- 
- 
-=== RR_1 fra RR_01 === 
- 
-Siden det ikke kommer inn minuttverdier for nedbør når det ikke har regnet, må aggregering av minuttnedbør behandles anderledes enn andre verdier. 
- 
-Når det faktisk kommer data for minuttnedbør, beregnes RR_1 som vanlig. Men hver morgen kjøres en jobb, som legger inn null-verdier der hvor det mangler aggregert RR_1-data i databasen. 
- 
-=== RR_12 fra RA === 
- 
-Hvis en stasjon rapporterer både RA og RR_1, vil det aggregering av RR_12 fra RA prioriteres over aggregering fra RR_1. 
- 
-RR_12 vil ikke aggregeres fra RA dersom RA-verdien har minket 
-betraktelig siden sist aggregering (for eksempel dersom målebøtta har 
-blitt tømt). 
- 
-Følgende korrigeringsalgoritme er implementert: 
- 
- 
-   * Hvis RR_12(t) = RA(t)-RA(t-12) < 0       Sett RR_12(t) = 0 
- 
-   * Hvis RR_12(t) = RA(t)-RA(t-12) > 0 og RA(t-12)-RA(t-24) %%<=%% -100       sett RR_12(t) = RA(t)-RA(t-12) 
-ellers: 
- 
-   * Hvis RR_12(t) = RA(t)-RA(t-12) > 0 og RA(t)-RA(t-24) %%<=%% 0       Sett RR_12(t) = 0 
- 
-   * Hvis RR_12(t) = RA(t)-RA(t-12) > 0 og RA(t)-RA(t-24) > 0 og RA(t-12)-RA(t-24)>=0     sett RR_12(t) = RA(t)-RA(t-12) 
- 
-   * Hvis RR_12(t) = RA(t)-RA(t-12) > 0 og RA(t)-RA(t-24) >=0 og RA(t-12)-RA(t-24) < 0    sett RR_12(t) = RA(t)-RA(t-24) 
- 
- 
-=== Middelverdier === 
- 
-Noen døgnmiddelverdier (TA_24 og UU_24, men ikke NN_24) beregnes ved hjelp av Köppens formel. Konstanter for å gjøre disse beregningene hentes fra kvalobs-tabellen station_metadata, hvor metadatatypename=koppen_MÅNED, for eksempel koppen_06 for verdier som skal brukes i juni. 
- 
-=== Trykk === 
- 
-Det beregnes også PO utfra PR i aggregatoren. Stasjonsspesifikke konstanter hentes fra tabellen station_metadata i kvalobs-databasen. 
  
  • kvalobs/kvalobs/aggregering.1277277081.txt.gz
  • Last modified: 2022-05-31 09:23:18
  • (external edit)