twindow
Syntax
twindow(func, funcArgs, T, range, [prevailing=false],
[excludedPeriod])
Arguments
func is an aggregate function.
funcArgs is the argument(s) of func. If func has multiple parameters, funcArgs is a tuple.
T is a non-strictly increasing vector of integers or temporal type.
range is a data pair of INT or DURATION type (both boundaries are inclusive).
prevailing can be 0/false (default), 1/true, or 2, indicating how duplicate values at window boundaries are handled. The specific windowing rules for each value are introduced in Details.
excludedPeriod is a pair of time values (of TIME, NANOTIME, MINUTE, and SECOND type) representing the start and end time of the period which is excluded from the calculation. When the excludedPeriod is set, the input T cannot contain the time range specified by excludedPeriod and must be of TIMESTAMP, NANOTIMESTAMP, TIME, and NANOTIME types. Note that excludedPeriod must be within a calendar day and cannot be longer than the value of (24 - range).
Details
Apply func over a sliding window of funcArgs. Each element in funcArgs corresponds to a window that is determined by T and range. The result has the same dimension as that of funcArgs (If funcArgs is a tuple, the result has the same dimension as that of each element in the tuple).
Suppose range is set to d1:d2, the windows are determined based on the following rules:
- When range is an integral pair:
- T is a vector of integral type: For element Ti in T, the window range is [Ti+d1, Ti+d2].
- T is a vector of temporal type: range has the precision of T by default. For element Ti in T, the window range is [temporalAdd(Ti, d1, unit), temporalAdd(Ti, d2, unit)], where "unit" indicates the precision of T.
- When range is a duration pair, T can only be a vector of temporal type. For element Ti in T, the window range is [temporalAdd(Ti, d1), temporalAdd(Ti, d2)].
When the window boundary matches multiple duplicates, the prevailing parameter determines whether those duplicates are included in the window.
- If prevailing = 0/false, the window includes all duplicates.
- If prevailing = 1/true, the calculation window includes the last record of duplicates at the left boundary and all duplicates at the right boundary.
- If prevailing = 2,
- When d1 is 0, the window starts at the current record, excluding prior duplicates while including all duplicates at the right boundary.
- When d2 is 0, the window ends at the current record, excluding following duplicates while including duplicates at the left boundary.
- Note that prevailing and excludedPeriod cannot be set simultaneously.
Compared with the tmoving
function, twindow
has
more flexible windows. Thetmoving
function can be considered
roughly as a special case of twindow
, where the right boundary of
the range parameter is 0 and prevailing is set to 0. However, when the
window is measured by time, the range of the window is (Ti - window,
Ti] or (temporalAdd(Ti, -window), Ti], where
the left boundary is exclusive. The current record is included as the last element
in the corresponding window, regardless of whether the following records have
identical values.
Examples
The following examples show different windowing rules when the window boundary matches multiple duplicates.
- When prevailing = 0, the calculation window includes all
duplicates.
t1 = table(`A`A`B`B`C`C as sym, 09:56:03 09:56:07 09:56:02 09:56:05 09:56:04 09:56:06 as time, 10.6 10.7 20.6 11.6 11.7 19.6 as price) select *, twindow(func=avg, funcArgs=t1.price, T=t1.time, range=2s:4s) from t1 context by sym
sym time price twindow_avg A 09:56:03 10.6 10.7 A 09:56:07 10.7 B 09:56:02 20.6 11.6 B 09:56:05 11.6 C 09:56:04 11.7 19.6 C 09:56:06 19.6 t = 2021.01.02 2021.01.02 2021.01.06 2021.03.09 2021.03.10 2021.03.12 2021.03.12 x = -5 5 NULL -1 2 4 -8 twindow(func=min,funcArgs=x,T=t,range=0:2) // output: [-5, -5, , -1, -8, -8, -8]
- When prevailing = 1, the calculation window only includes the last record
with the identical
value.
twindow(func=min,funcArgs=x,T=t,range=0:2,prevailing=1) // output: [5, 5, , -1, -8, -8, -8]
- When prevailing = 2 and the range's left/right boundary is 0, the
calculation window starts at the current record, excluding prior/following
duplicates.
twindow(func=min,funcArgs=x,T=t,range=0:2,prevailing=2) // output: [-5, 5, , -1, -8, -8, -8] twindow(func=min,funcArgs=x,T=t,range=-2:0,prevailing=2) // output: [-5, -5, , -1, -1, 2, -8]
The following example specifies the excludedPeriod parameter. The closing hours from 11:30 to 13:00 will be excluded from the calculation.
excludedPeriod=(11:30:00:13:00:00)
ts=timestamp(2023.11.01T11:21:00+1..500) join timestamp(2023.11.01T13:00:00+1..500)
t=table(ts, rand(10.0,size(ts)) as price)
// with excludedPeriod specified
res1=select ts, twindow(func=avg, T=ts, funcArgs=price, range=-1m:0m, excludedPeriod=excludedPeriod) from t
select * from res1 where ts between timestamp(2023.11.01T13:00:00) and timestamp(2023.11.01T13:01:00)
// without excludedPeriod specified
res2=select ts, twindow(func=avg, T=ts, funcArgs=price, range=-1m:0m) from t
select * from res2 where ts between timestamp(2023.11.01T13:00:00) and timestamp(2023.11.01T13:01:00)