Akcia CALCSTATFUNCARR


Funkcia
Výpočet archívnej štatistickej funkcie pre všetky dané časové intervaly.
Deklarácia
CALCSTATFUNCARR archIdent, bt_TmA, et_TmA, step, deepTime, statFuncIdent_Int, validPercIdent_Int, paramIdent, locVarColValueIdent_Rec, statusIdent_Int [,archivInstance_Int]

Parametre
archIdent in Odkaz na jednu archívnu hodnotu alebo odkaz na ľubovoľný objekt, ktorého hodnoty sa archivujú.

Upozornenie: Ak sa parameter odkazuje na objekt, ktorý je viacnásobne archivovaný, nie je určené, hodnoty ktorého archívneho objektu sa použijú pre akciu.
bt_TmA in Identifikátor typu AbsTime - začiatok intervalu.
et_TmA in Identifikátor typu AbsTime - koniec intervalu.
step in Identifikátor typu Int - časový krok [s].

Poznámka: hodnota parametra musí byť kladné číslo.
deepTime in Identifikátor typu Int - časová hĺbka [s] pre výpočet štatistiky.

Poznámka: hodnota parametra musí byť kladné číslo.
statFunctIdent_Int in Identifikátor typu Int - typ štatistickej funkcie.
validPercIdent_Int in Identifikátor typu Int - validačné kritérium.
paramIdent in Identifikátor typu Int alebo Real - parameter pre niektoré typy funkcií.
locVarColValueIdent_Rec out Odkaz na stĺpec lokálnej premennej typu RECORD - výsledné hodnoty.
statusIdent_Int out Úspešnosť výpočtu.
archivInstance_Int in Nepovinný identifikátor typu Int - identifikácia inštancie archívu. Ak nie je uvedený, nahradí sa hodnotou 0.

Popis
Akcia vykoná výpočet štatistickej funkcie danej parametrom statFuncIdent_Int na archívnych dátach reprezentovaných archívnym objektom archIdent pre nasledujúce časové intervaly dané parametrami bt_TmA, et_TmA, step a deepTime:
  • prvý časový interval - <bt_TmA - deepTime; bt_TmA>
  • druhý časový interval - <bt_TmA + step - deepTime; bt_TmA + step>
  • .....
  • n-tý časový interval - <bt + (N-1)*step - deepTime; bt + (N-1)*_step>

Časová značka výsledku za určitý časový interval je zhodná s koncovým časom príslušného časového intervalu. Po úspešnom vykonaní akcie sú výsledky výpočtu dosadené do stĺpca lokálnej štruktúrovanej premennej danej parametrom locVarColValueIdent_Rec.

Návratový kód statusIdent_Int môže nadobúdať jednu z nasledujúcich hodnôt:
  • _ERR_TRANS_ABORT
  • _ERR_TRANS_ERROR
  • _ERR_TRANS_IGNORED
  • _ERR_NO_ERROR

Množina implementovaných funkcií je zhodná z funkciami, ktoré je možné konfigurovať pre štatistický archív (okrem funkcií FILTER a ECOAVG). Pre jednotlivé funkcie sú v ESL preddefinované lokálne konštanty.

Parameter validPerctIdent_Int predstavuje validačné kritérium použité pri vyhodnocovaní štatistickej funkcie. Môže nadobúdať hodnoty 0 .. 100 (chyba pri nedodržaní podmienky ERR_RANGE_ERROR).

Pre niektoré štatistické funkcie je potrebné zadať parameter paramIdent podľa nasledujúcej tabuľky:

Štatistická funkcia Popis parametra
_STAT_F_INTEGRAL Časový rozmer vstupu. Pre jednotlivé typy sú taktiež zavedené preddefinované lokálne konštanty podľa tabuľky:

Konštanta Popis
_INTEGRAL_HOURUNIT Hodinový integrál
_INTEGRAL_MINUNIT Minútový integrál
_INTEGRAL_SECUNIT Sekundový integrál
_STAT_F_GE_TIME
_STAT_F_GT_TIME
_STAT_F_LE_TIME
_STAT_F_LT_TIME
_STAT_F_ADDITION_PARAM
_STAT_F_INCREMENT_PARAM
_STAT_F_DELTA_PARAM
Referenčná hodnota

Pre ostatné štatistické funkcie sa parameter paramIdent nevyhodnocuje.

Hodnota parametra archivInstance_Int udáva inštanciu archívu, ktorá realizuje požiadavku. Ak nie je uvedený (alebo má hodnotu 0) požiadavku realizuje aktívna inštancia archívu.


Príklad
Výpočet váženého plávajúceho priemeru z hodnôt v rozsahu 2 hodín.
 
 TIME _bt
 TIME _et
 INT _step
 INT _deepTime
 REAL _retCode
 INT  _idx
 RECORD NOALIAS (SD.Data) _statData
 
 _bt := %StrToTime("0:00:00 16-11-2006")
 _et := %StrToTime("0:00:00 17-11-2006")
 _step := 3600         ; hodnota pre každú hodinu
 _deepTime := 2*_step  ; plávajúci priemer, hĺbka 2 hodiny
 
 CALCSTATFUNCARR H.Col[1], _bt, _et, _step, _deepTime, _STAT_F_WGAVG, 100, 0, _statData^Value, _retCode
 IF _retCode = _ERR_NO_ERROR THEN
   ; výpočet prebehol, prezeranie hodnôt
      FOR _idx=1 TO _statData\DIM DO_LOOP
     ; _statData[_idx]^Value - hodnota
 ELSE
   ; nastala nejaká chyba
 ENDIF 

Poznámka
Použitie akcie CALCSTATFUNARR neumožňuje počítať štatistické funkcie FILTER a EACOAVG.

Súvisiace stránky:

0 komentárov

Nie ste prihlásený. Akékoľvek zmeny, ktoré vykonáte, sa označia ako anonymné. Ak už máte svoj účet, pravdepodobne sa budete chcieť prihlásiť .