aggregate.DTSg | R Documentation |
Applies a temporal aggregation level function to the .dateTime column of a
DTSg
object and aggregates its values column-wise to the function's
temporal aggregation level utilising one or more provided summary functions.
Additionally, it sets the object's aggregated
field to TRUE
.
## S3 method for class 'DTSg'
aggregate(
x,
funby,
fun,
...,
cols = self$cols(class = "numeric"),
n = FALSE,
ignoreDST = FALSE,
multiplier = 1L,
funbyHelpers = NULL,
funbyApproach = self$funbyApproach,
clone = getOption("DTSgClone")
)
x |
A |
funby |
One of the temporal aggregation level functions described in
|
fun |
A summary function, (named) |
... |
Further arguments passed on to |
cols |
A character vector specifying the columns to aggregate. Another
possibility is a character string containing either comma separated column
names, for example, |
n |
A logical specifying if a column named |
ignoreDST |
A logical specifying if day saving time shall be ignored
by |
multiplier |
A positive integerish value “multiplying” the
temporal aggregation level of certain |
funbyHelpers |
An optional |
funbyApproach |
A character string specifying the flavour of the applied
temporal aggregation level function. Either |
clone |
A logical specifying if the object shall be modified in place or if a deep clone (copy) shall be made beforehand. |
Returns an aggregated DTSg
object.
User defined temporal aggregation level functions have to return a
POSIXct
vector of the same length as the time series and accept two
arguments: a POSIXct
vector as its first and a list
with helper data
as its second. The default elements of this list
are as follows:
timezone: Same as the timezone
field.
ignoreDST: Same as the ignoreDST
argument.
periodicity: Same as the periodicity
field.
na.status: Same as the na.status
field.
multiplier: Same as the multiplier
argument.
funbyApproach: Same as the funbyApproach
argument.
Any additional element specified in the funbyHelpers
argument is appended
to the end of the default list
. In case funbyHelpers
contains an
ignoreDST, multiplier or funbyApproach element, it takes precedence over
the respective method argument. timezone, periodicity and na.status
elements are rejected, as they are always taken directly from the object.
The temporal aggregation level of certain TALFs
can be adjusted with the
help of the multiplier
argument. A multiplier
of 10
, for example, makes
byY_____
aggregate to decades instead of years. Another example
is a multiplier
of 6
provided to by_m____
. The function
then aggregates all months of all first and all months of all second half
years instead of all months of all years separately. This feature is
supported by the following TALFs
of the package:
byY_____
byYm____
byYmdH__
(UTC and equivalent as well as all Etc/GMT time zones only)
byYmdHM_
byYmdHMS
by_m____
by___H__
(UTC and equivalent as well as all Etc/GMT time zones only)
by____M_
by_____S
Some examples for fun
are as follows:
mean
list(min = min, max = max)
c(sd = "sd", var = "var")
A list
or character vector must have names in case more than one summary
function is provided. The method can benefit from data.table's
GForce optimisation in case a character
vector specifying summary functions is provided.
Depending on the number of columns to aggregate, the .n
column contains
different counts:
One column: The counts are calculated from the columns' values disregarding
any missing values. This means that missing values are always stripped
regardless of the value of a possible na.rm
argument.
More than one column: The counts are calculated from the .dateTime column including all missing values.
ignoreDST
tells a temporal aggregation level function if it is supposed to
ignore day saving time while transforming the timestamps. This can be a
desired feature for time series strictly following the position of the sun
such as hydrological time series. Doing so ensures that diurnal variations
are preserved by all means and all intervals are of the “correct”
length, however, a possible limitation might be that the day saving time
shift is invariably assumed to be one hour long. This feature requires that
the periodicity of the time series has been recognised and is supported by
the following TALFs
of the package:
byY_____
byYQ____
byYm____
byYmd___
by_Q____
by_m____
by___H__
cols
, getOption
# new DTSg object
x <- DTSg$new(values = flow)
# mean yearly river flows
## R6 method
x$aggregate(
funby = byY_____,
fun = "mean",
na.rm = TRUE
)$print()
## S3 method
print(aggregate(
x = x,
funby = byY_____,
fun = "mean",
na.rm = TRUE
))
# variance and standard deviation of river flows per quarter
## R6 method
x$aggregate(
funby = byYQ____,
fun = c(var = "var", sd = "sd"),
na.rm = TRUE
)$print()
## S3 method
print(aggregate(
x = x,
funby = byYQ____,
fun = c(var = "var", sd = "sd"),
na.rm = TRUE
))
# mean of river flows of all first and all second half years
## R6 method
x$aggregate(
funby = by_m____,
fun = "mean",
na.rm = TRUE,
multiplier = 6
)$print()
## S3 method
print(aggregate(
x = x,
funby = by_m____,
fun = "mean",
na.rm = TRUE,
multiplier = 6
))
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.