indexOf | R Documentation |
Find the index in the time series for each timestamp given in argument x
.
Values of x
that are before the earliest value or after the latest value in
y
will be returned as NA
. Alternatively, when x
is a numeric vector of
index values, return the valid indices of the same vector, with the side
effect being the attribute "CFTime" associated with the result.
indexOf(x, y, method = "constant", rightmost.closed = FALSE)
x |
Vector of |
y |
A CFTime instance. |
method |
Single value of "constant" or "linear". If |
rightmost.closed |
Whether or not to include the upper limit of
argument |
Timestamps can be provided as vectors of character strings, POSIXct
or
Date.
Matching also returns index values for timestamps that fall between two
elements of the time series - this can lead to surprising results when time
series elements are positioned in the middle of an interval (as the CF
Metadata Conventions instruct us to "reasonably assume"): a time series of
days in January would be encoded in a netCDF file as
c("2024-01-01 12:00:00", "2024-01-02 12:00:00", "2024-01-03 12:00:00", ...)
so x <- c("2024-01-01", "2024-01-02", "2024-01-03")
would result in
(NA, 1, 2)
(or (NA, 1.5, 2.5)
with method = "linear"
) because the date
values in x
are at midnight. This situation is easily avoided by ensuring
that y
has bounds set (use bounds(y) <- TRUE
as a proximate solution if
bounds are not stored in the netCDF file). See the Examples.
If bounds are set, the indices are informed by those bounds. If the
bounds are not contiguous, returned values may be NA
even if the
value of x
falls between two valid timestamps.
Values of x
that are not valid timestamps according to the calendar of y
will be returned as NA
.
x
can also be a numeric vector of index values, in which case the valid
values in x
are returned. If negative values are passed, the positive
counterparts will be excluded and then the remainder returned. Positive and
negative values may not be mixed. Using a numeric vector has the side effect
that the result has the attribute "CFTime" describing the temporal dimension
of the slice. If index values outside of the range of y
(1:length(y)
) are
provided, an error will be thrown.
A numeric vector giving indices into y
for the values of
x
. If there is at least 1 valid index, then attribute "CFTime"
contains an instance of CFTime
that describes the dimension of
filtering the dataset associated with y
with the result of this
method, excluding any NA
values.
cf <- CFtime("days since 2020-01-01", "360_day", 1440:1799 + 0.5)
as_timestamp(cf)[1:3]
x <- c("2024-01-01", "2024-01-02", "2024-01-03")
indexOf(x, cf)
indexOf(x, cf, method = "linear")
bounds(cf) <- TRUE
indexOf(x, cf)
# Non-existent calendar day in a `360_day` calendar
x <- c("2024-03-30", "2024-03-31", "2024-04-01")
indexOf(x, cf)
# Numeric x
indexOf(c(29, 30, 31), cf)
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.