Title: | R Package for the Quantification of Technical Resilience |
---|---|
Description: | kwb.resilience allows quantification of a number of resilience indicators. Calculation requires a time series of performance values of a technical system, as well as values for acceptable and worst case performance. |
Authors: | Andreas Matzinger [aut, cre] , Kompetenzzentrum Wasser Berlin gGmbH (KWB) [cph], Hauke Sonnenberg [ctb] , Michael Rustler [ctb] |
Maintainer: | Andreas Matzinger <[email protected]> |
License: | MIT + file LICENSE |
Version: | 0.1.0 |
Built: | 2025-01-08 04:58:40 UTC |
Source: | https://github.com/KWB-R/kwb.resilience |
Data series "oxygen" are included in kwb.resilience as test data
for the use of the package. The included data is referred to in
the supplied package tutorial (see vignettes), as well as in the supporting
research paper
The data are simulated concentrations of dissolved oxygen (DO) in mg/l for different
management scenarios. Simulations and assumptions are described in detail in Riechel et al. 2016.
data(oxygen)
data(oxygen)
A data frame with 23425 rows and 5 variables
Columns in data.frame:
timestamp (POSIXct).
S2_storage_2020 (numeric).
S3_storage_increase (numeric).
S4_red_Imp_Surface (numeric).
S5_increase_in_DO (numeric).
Calculates resilience indices (see Matzinger et al. 2018) for each failure event in time series of performance P(t). Failure is defined by acceptable performance Pa and maximal failure Pmax.
resilience.events(time_stamp, Pt, Pa, Pmax, evtSepTime, signalWidth)
resilience.events(time_stamp, Pt, Pa, Pmax, evtSepTime, signalWidth)
time_stamp |
vector containing timestamp (sorted in ascending order) |
Pt |
vector with performance P(t) (same length as timestamp) |
Pa |
accpetable performance |
Pmax |
maximal failure |
evtSepTime |
"event separation time" in seconds. Maximal allowed time difference between two consecutive timestamps within the same event. |
signalWidth |
"signal width" in seconds. Length of time interval that one timestamp is representing, e.g. 5*60 = 300 if each timestamp respresents a time interval of five minutes (as e.g. a time series is recorded on a five minute time scale). This parameter is needed to calculate event durations. |
Returns data.frame containing one row by failure event. First columns are identical to kwb.event::hsEvents. Following columns are additional resilience indices:
Sev: severity by event
Res0: resilience index by event
trec: recovery time in seconds
trec_percent: trec relative to event duration in per cent
worst_P: P(t) closest to Pmax within event
script is stopped if no failure event with message "Pa never exceeded"
calculates severity Sev (see Matzinger et al. 2018) of failures for time series of performance P(t). Entire time period is used, failure is defined by acceptable performance Pa and maximal failure Pmax.
resilience.severity(time_stamp, Pt, Pa, Pmax, integral_method = 2)
resilience.severity(time_stamp, Pt, Pa, Pmax, integral_method = 2)
time_stamp |
vector containing timestamp (sorted in ascending order) |
Pt |
vector with performance P(t) (same length as timestamp) |
Pa |
accpetable performance |
Pmax |
maximal failure (worst case) |
integral_method |
either 1 or 2. Switches between two different versions of integral calculation. Both methods should return the same but method 2 should be much faster when applied to long vectors. Default is method 2. |
Returns severity integrated over entire time series (one number)
Calculates resilience indices (see Matzinger et al. 2018) for entire time series of performance P(t). Failure is defined by acceptable performance Pa and maximal failure Pmax. Entire time series is considered
resilience.summary(time_stamp, Pt, Pa, Pmax, evtSepTime, signalWidth)
resilience.summary(time_stamp, Pt, Pa, Pmax, evtSepTime, signalWidth)
time_stamp |
vector containing timestamp (sorted in ascending order) |
Pt |
vector or data.frame (if several colums) with performance P(t) (same length as timestamp) |
Pa |
accpetable performance |
Pmax |
maximal failure |
evtSepTime |
"event separation time" in seconds. Maximal allowed time difference between two consecutive timestamps within the same event. |
signalWidth |
"signal width" in seconds. Length of time interval that one timestamp is representing, e.g. 5*60 = 300 if each timestamp respresents a time interval of five minutes (as e.g. a time series is recorded on a five minute time scale). This parameter is needed to calculate event durations. |
Returns data.frame containing one row by time series. Columns are:
num_events: number of failure events in time series
worst_P: P(t) closest to Pmax within time series
total_dur: total duration of failure events in seconds
total_trec: total recovery time of failure events in seconds
mean_trec_percent: trec relative to event duration in per cent, averaged over all failure events in time series
Sev: severity over entire time series (=0 if no exceedance of Pa)
Res0: resilience index over entire time series (=1 if no exceedance of Pa)