-- A --
as_epiweek()
as_epiweek.default()
as_epiweek.Date()
as_epiweek.POSIXt()
as_epiweek.character()
as_epiweek.factor()
as_int_period()
as_int_period.default()
as_int_period.integer()
as_int_period.double()
as_isoweek()
as_isoweek.default()
as_isoweek.Date()
as_isoweek.POSIXt()
as_isoweek.character()
as_isoweek.factor()
as_month()
as_month.default()
as_month.Date()
as_month.POSIXt()
as_month.character()
as_month.factor()
as_period()
as_period.default()
as_period.Date()
as_period.POSIXt()
as_period.character()
as_period.factor()
as_year()
as_year.default()
as_year.Date()
as_year.POSIXt()
as_year.character()
as_year.factor()
as_yearmonth()
as_yearmonth.default()
as_yearmonth.Date()
as_yearmonth.POSIXt()
as_yearmonth.character()
as_yearmonth.factor()
as_yearquarter()
as_yearquarter.default()
as_yearquarter.Date()
as_yearquarter.POSIXt()
as_yearquarter.character()
as_yearquarter.factor()
as_yearweek()
as_yearweek.default()
as_yearweek.Date()
as_yearweek.POSIXt()
as_yearweek.character()
as_yearweek.factor()
-- B --
boundaries
-- D --
date_start()
date_end()
-- E --
epiweek()
-- F --
format.grates_int_period()
format.grates_month()
format.grates_period()
format.grates_year()
format.grates_yearmonth()
format.grates_yearquarter()
-- G --
grouped_date_accessors
get_firstday()
get_firstday.default()
get_firstday.grates_yearweek_monday()
get_firstday.grates_yearweek_tuesday()
get_firstday.grates_yearweek_wednesday()
get_firstday.grates_yearweek_thursday()
get_firstday.grates_yearweek_friday()
get_firstday.grates_yearweek_saturday()
get_firstday.grates_yearweek_sunday()
get_week()
get_week.default()
get_week.grates_yearweek()
get_week.grates_epiweek()
get_week.grates_isoweek()
get_year()
get_year.default()
get_year.grates_yearweek()
get_year.grates_epiweek()
get_year.grates_isoweek()
get_year.grates_yearmonth()
get_year.grates_yearquarter()
get_year.grates_year()
get_n()
get_n.default()
get_n.grates_month()
get_n.grates_period()
get_n.grates_int_period()
get_offset()
get_offset.default()
get_offset.grates_period()
-- I --
isoweek()
is_epiweek()
is_int_period()
is_isoweek()
is_month()
is_period()
is_yearmonth()
is_yearquarter()
is_yearweek()
is_year()
-- N --
new_epiweek()
new_int_period()
new_isoweek()
new_month()
new_period()
new_yearmonth()
new_yearquarter()
new_yearweek()
-- P --
print.grates_int_period()
print.grates_month()
print.grates_period()
print.grates_year()
print.grates_yearmonth()
print.grates_yearquarter()
-- S --
scale_x_grates_epiweek()
scale_x_grates_int_period()
scale_x_grates_isoweek()
scale_x_grates_month()
scale_x_grates_period()
scale_x_grates_year()
scale_x_grates_yearmonth()
scale_x_grates_yearquarter()
scale_x_grates_yearweek()
scale_x_grates_yearweek_monday()
scale_x_grates_yearweek_isoweek()
scale_x_grates_yearweek_tuesday()
scale_x_grates_yearweek_wednesday()
scale_x_grates_yearweek_thursday()
scale_x_grates_yearweek_friday()
scale_x_grates_yearweek_saturday()
scale_x_grates_yearweek_sunday()
scale_x_grates_yearweek_epiweek()
-- Y --
year()
yearmonth()
yearquarter()
yearweek()
-- misc --
%during%()
Generic for conversion to <grates_epiweek>
as_epiweek(x, ...)
## Default S3 method:
as_epiweek(x, ...)
## S3 method for class 'Date'
as_epiweek(x, ...)
## S3 method for class 'POSIXt'
as_epiweek(x, ...)
## S3 method for class 'character'
as_epiweek(x, format, tryFormats = c("%Y-%m-%d", "%Y/%m/%d"), ...)
## S3 method for class 'factor'
as_epiweek(x, format, tryFormats = c("%Y-%m-%d", "%Y/%m/%d"), ...)
x |
R object. |
... |
Other values passed to as.Date(). |
format |
Passed to as.Date() unless If not specified, it will try tryFormats one by one on the first non-NA
element, and give an error if none works. Otherwise, the processing is via
|
tryFormats |
Format strings to try if format is not specified. |
Date, POSIXct, and POSIXlt are converted with the timezone respected.
Character objects are first coerced to date via as.Date()
unless
format = "yearweek"
in which case input is assumed to be in the form
"YYYY-Wxx" and parsed accordingly.
A <grates_epiweek>
object.
new_epiweek()
and as.Date()
.
as_epiweek(Sys.Date())
#> <grates_epiweek[1]>
#> [1] "2025-W03"
as_epiweek(as.POSIXct("2019-03-04 01:01:01", tz = "America/New_York"))
#> <grates_epiweek[1]>
#> [1] "2019-W10"
as_epiweek("2019-05-03")
#> <grates_epiweek[1]>
#> [1] "2019-W18"
as_epiweek("2019-W12", format = "yearweek")
#> <grates_epiweek[1]>
#> [1] "2019-W12"
as_int_period()
is a generic for coercing input in to <grates_int_period>
.
as_int_period(x, n, ...)
## Default S3 method:
as_int_period(x, n = 1L, ...)
## S3 method for class 'integer'
as_int_period(x, n = 1L, ...)
## S3 method for class 'double'
as_int_period(x, n = 1L, ...)
x |
An R object.
|
n |
Number of consecutive integers that are being grouped. Must be greater than 0. |
... |
Further arguments passed to or from other methods. |
A <grates_int_period>
object.
Internally grates_int_period
objects are stored as the position, starting
at 0, of n-integer groups from 0. Here n-months is taken to mean a 'grouping
of n consecutive integers'.
as_int_period(1:10, n = 4L)
#> <grates_int_period[10]>
#> [1] [0, 3] [0, 3] [0, 3] [4, 7] [4, 7] [4, 7] [4, 7] [8, 11] [8, 11]
#> [10] [8, 11]
Generic for conversion to <grates_isoweek>
as_isoweek(x, ...)
## Default S3 method:
as_isoweek(x, ...)
## S3 method for class 'Date'
as_isoweek(x, ...)
## S3 method for class 'POSIXt'
as_isoweek(x, ...)
## S3 method for class 'character'
as_isoweek(x, format, tryFormats = c("%Y-%m-%d", "%Y/%m/%d"), ...)
## S3 method for class 'factor'
as_isoweek(x, format, tryFormats = c("%Y-%m-%d", "%Y/%m/%d"), ...)
x |
R object. |
... |
Other values passed to as.Date(). |
format |
Passed to as.Date() unless If not specified, it will try tryFormats one by one on the first non-NA
element, and give an error if none works. Otherwise, the processing is via
|
tryFormats |
Format strings to try if format is not specified. |
Date, POSIXct, and POSIXlt are converted with the timezone respected.
Character objects are first coerced to date via as.Date()
unless
format = "yearweek"
in which case input is assumed to be in the form
"YYYY-Wxx" and parsed accordingly.
A <grates_isoweek>
object.
new_isoweek()
and as.Date()
.
as_isoweek(Sys.Date())
#> <grates_isoweek[1]>
#> [1] "2025-W03"
as_isoweek(as.POSIXct("2019-03-04 01:01:01", tz = "America/New_York"))
#> <grates_isoweek[1]>
#> [1] "2019-W10"
as_isoweek("2019-05-03")
#> <grates_isoweek[1]>
#> [1] "2019-W18"
as_isoweek("2019-W12", format = "yearweek")
#> <grates_isoweek[1]>
#> [1] "2019-W12"
as_month()
is a generic for coercing input in to <grates_month>
.
as_month(x, n, ...)
## Default S3 method:
as_month(x, n, ...)
## S3 method for class 'Date'
as_month(x, n, ...)
## S3 method for class 'POSIXt'
as_month(x, n, ...)
## S3 method for class 'character'
as_month(x, n, ...)
## S3 method for class 'factor'
as_month(x, n, ...)
x |
An R object. Character input is first parsed using POSIXt inputs are converted with the timezone respected. |
n |
Number of months that are being grouped. Must be greater than 1 (use
|
... |
Only used For character input where additional arguments are passed through
to |
A <grates_month>
object.
Internally grates_month
objects are stored as the position, starting at 0,
of n-month groups since the Unix Epoch (1970-01-01). Here n-months is taken
to mean a 'grouping of n consecutive months'. Precision is only to the month
level (i.e. the day of the month is always dropped).
The algorithm to convert between dates and months relative to the UNIX Epoch comes from the work of Davis Vaughan in the unreleased datea package.
as.Date()
as_month("2019-05-03", n = 4L)
#> <grates_month[1]>
#> [1] "2019-May to 2019-Aug"
as_month(as.POSIXct("2019-03-04 01:01:01", tz = "America/New_York"), n = 2)
#> <grates_month[1]>
#> [1] "2019-Mar to 2019-Apr"
as_period()
is a generic for coercing input in to <grates_period>
.
as_period(x, n, ...)
## Default S3 method:
as_period(x, n = 1L, offset = 0L, ...)
## S3 method for class 'Date'
as_period(x, n = 1L, offset = 0L, ...)
## S3 method for class 'POSIXt'
as_period(x, n = 1L, offset = 0L, ...)
## S3 method for class 'character'
as_period(x, n = 1L, offset = 0L, ...)
## S3 method for class 'factor'
as_period(x, n = 1L, offset = 0L, ...)
x |
An R object:
|
n |
Number of days that are being grouped. |
... |
Only used For character input where additional arguments are passed through
to |
offset |
Value you wish to start counting periods from relative to the Unix Epoch:
|
A <grates_period>
object.
Internally grates_period
objects are stored as the integer number, starting
at 0L, of periods since the Unix Epoch (1970-01-01) and a specified offset.
Here periods are taken to mean groupings of n
consecutive days.
as.Date()
as_period("2019-05-03")
#> <grates_period[1]>
#> [1] "2019-05-03"
as_period("2019-05-03", n = 2, offset = 1)
#> <grates_period[1]>
#> [1] "2019-05-03 to 2019-05-04"
as_period(as.POSIXct("2019-03-04 01:01:01", tz = "America/New_York"), n = 10)
#> <grates_period[1]>
#> [1] "2019-02-23 to 2019-03-04"
as_period(as.Date("2020-03-02"), n = 2L, offset = as.Date("2020-03-01"))
#> <grates_period[1]>
#> [1] "2020-03-01 to 2020-03-02"
as_year()
is a generic for coercing input in to <grates_year>
.
as_year(x, ...)
## Default S3 method:
as_year(x, ...)
## S3 method for class 'Date'
as_year(x, ...)
## S3 method for class 'POSIXt'
as_year(x, ...)
## S3 method for class 'character'
as_year(x, ...)
## S3 method for class 'factor'
as_year(x, ...)
x |
R object. Character input is first parsed using POSIXct and POSIXlt are converted with the timezone respected. |
... |
Only used For character input where additional arguments are passed through
to |
A <grates_year>
object.
as.Date()
as_year(Sys.Date())
#> <grates_year[1]>
#> [1] 2025
as_year(as.POSIXct("2019-03-04 01:01:01", tz = "America/New_York"), interval = 2)
#> <grates_year[1]>
#> [1] 2019
as_year("2019-05-03")
#> <grates_year[1]>
#> [1] 2019
as_yearmonth()
is a generic for coercing input in to <grates_yearmonth>
.
Character input is first parsed using as.Date()
. POSIXct and POSIXlt are
all converted, with the timezone respected.
as_yearmonth(x, ...)
## Default S3 method:
as_yearmonth(x, ...)
## S3 method for class 'Date'
as_yearmonth(x, ...)
## S3 method for class 'POSIXt'
as_yearmonth(x, ...)
## S3 method for class 'character'
as_yearmonth(x, ...)
## S3 method for class 'factor'
as_yearmonth(x, ...)
x |
R object. |
... |
Only used For character input where additional arguments are passed through
to |
A <grates_yearmonth>
object.
Internally <grates_yearmonth>
objects are stored as the number of
months (starting at 0) since the Unix Epoch (1970-01-01). Precision is only
to the month level (i.e. the day of the month is always dropped).
The algorithm to convert between dates and months relative to the UNIX Epoch comes from the work of Davis Vaughan in the unreleased datea package.
as.Date()
as_yearmonth(Sys.Date())
#> <grates_yearmonth[1]>
#> [1] "2025-Jan"
as_yearmonth(as.POSIXct("2019-03-04 01:01:01", tz = "America/New_York"), interval = 2)
#> <grates_yearmonth[1]>
#> [1] "2019-Mar"
as_yearmonth("2019-05-03")
#> <grates_yearmonth[1]>
#> [1] "2019-May"
as_yearquarter()
is a generic for coercing input in to <grates_yearquarter>
.
Character input is first parsed using as.Date()
. POSIXct and POSIXlt are
all converted, with the timezone respected.
as_yearquarter(x, ...)
## Default S3 method:
as_yearquarter(x, ...)
## S3 method for class 'Date'
as_yearquarter(x, ...)
## S3 method for class 'POSIXt'
as_yearquarter(x, ...)
## S3 method for class 'character'
as_yearquarter(x, ...)
## S3 method for class 'factor'
as_yearquarter(x, ...)
x |
R object |
... |
Only used For character input where additional arguments are passed through
to |
A <grates_yearquarter>
object.
Internally <grates_yearquarter>
objects are stored as the number of
quarters (starting at 0) since the Unix Epoch (1970-01-01).
as.Date()
as_yearquarter(Sys.Date())
#> <grates_yearquarter[1]>
#> [1] "2025-Q1"
as_yearquarter(as.POSIXct("2019-03-04 01:01:01", tz = "America/New_York"), interval = 2)
#> <grates_yearquarter[1]>
#> [1] "2019-Q1"
as_yearquarter("2019-05-03")
#> <grates_yearquarter[1]>
#> [1] "2019-Q2"
Generic for conversion to <grates_yearweek>.
as_yearweek(x, ...)
## Default S3 method:
as_yearweek(x, ...)
## S3 method for class 'Date'
as_yearweek(x, firstday = 1L, ...)
## S3 method for class 'POSIXt'
as_yearweek(x, firstday = 1L, ...)
## S3 method for class 'character'
as_yearweek(
x,
firstday = 1L,
format,
tryFormats = c("%Y-%m-%d", "%Y/%m/%d"),
...
)
## S3 method for class 'factor'
as_yearweek(
x,
firstday = 1L,
format,
tryFormats = c("%Y-%m-%d", "%Y/%m/%d"),
...
)
x |
R object. |
... |
Other values passed to as.Date(). |
firstday |
The day the week starts on from 1 (Monday) to 7 (Sunday). |
format |
Passed to as.Date() unless If not specified, it will try tryFormats one by one on the first non-NA
element, and give an error if none works. Otherwise, the processing is via
|
tryFormats |
Format strings to try if format is not specified. |
Date, POSIXct, and POSIXlt are converted with the timezone respected.
Character objects are first coerced to date via as.Date()
unless
format = "yearweek"
in which case input is assumed to be in the form
"YYYY-Wxx" and parsed accordingly.
A <grates_yearweek>
object.
as.Date()
and new_yearweek()
.
as_yearweek(Sys.Date())
#> <grates_yearweek_monday[1]>
#> [1] "2025-W03"
as_yearweek(as.POSIXct("2019-03-04 01:01:01", tz = "America/New_York"))
#> <grates_yearweek_monday[1]>
#> [1] "2019-W10"
as_yearweek("2019-05-03", firstday = 5L)
#> <grates_yearweek_friday[1]>
#> [1] "2019-W18"
as_yearweek("2019-W12", format = "yearweek")
#> <grates_yearweek_monday[1]>
#> [1] "2019-W12"
Utility functions for accessing the start (end) dates for each element of a grates object and also checking whether a date is contained within that range
date_start(x)
date_end(x)
date %during% x
x |
grouped date vector. |
date |
A scalar |
For date_start
and date_end
The requested start (end) dates for each
element in the input. For %during%
a logical vector indicating whether the
date was present within the range of the tested object.
dates <- as.Date("2020-01-01") + 1:14
week <- as_isoweek(dates)
date_start(week)
#> [1] "2019-12-30" "2019-12-30" "2019-12-30" "2019-12-30" "2020-01-06"
#> [6] "2020-01-06" "2020-01-06" "2020-01-06" "2020-01-06" "2020-01-06"
#> [11] "2020-01-06" "2020-01-13" "2020-01-13" "2020-01-13"
date_end(week)
#> [1] "2020-01-05" "2020-01-05" "2020-01-05" "2020-01-05" "2020-01-12"
#> [6] "2020-01-12" "2020-01-12" "2020-01-12" "2020-01-12" "2020-01-12"
#> [11] "2020-01-12" "2020-01-19" "2020-01-19" "2020-01-19"
dates[1L] %during% week
#> [1] TRUE TRUE TRUE TRUE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE
#> [13] FALSE FALSE
period <- as_period(dates, n = 3)
date_start(period)
#> [1] "2019-12-31" "2020-01-03" "2020-01-03" "2020-01-03" "2020-01-06"
#> [6] "2020-01-06" "2020-01-06" "2020-01-09" "2020-01-09" "2020-01-09"
#> [11] "2020-01-12" "2020-01-12" "2020-01-12" "2020-01-15"
date_end(period)
#> [1] "2020-01-02" "2020-01-05" "2020-01-05" "2020-01-05" "2020-01-08"
#> [6] "2020-01-08" "2020-01-08" "2020-01-11" "2020-01-11" "2020-01-11"
#> [11] "2020-01-14" "2020-01-14" "2020-01-14" "2020-01-17"
dates[14L] %during% period
#> [1] FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE
#> [13] FALSE TRUE
epiweek()
is a constructor for <grates_epiweek>
objects.
epiweek(year = integer(), week = integer())
year |
Vector representing the year associated with
|
week |
Vector representing the week associated with 'year.
|
Epiweeks are defined to start on a Sunday and <grates_epiweek>
objects are
stored as the number of weeks (starting at 0) from the first Sunday after the
Unix Epoch (1970-01-01). That is, the number of seven day periods from
1970-01-04.
Internally they have the same representation as a <grates_yearweek_sunday>
object so are akin to an alias but with a marginally more efficient
implementation.
A <grates_epiweek>
object.
as_epiweek()
and new_epiweek()
.
epiweek(year = 2000L, week = 3L)
#> <grates_epiweek[1]>
#> [1] "2000-W03"
Generics and methods for accessing information about grouped date objects.
get_firstday(x, ...)
## Default S3 method:
get_firstday(x, ...)
## S3 method for class 'grates_yearweek_monday'
get_firstday(x, ...)
## S3 method for class 'grates_yearweek_tuesday'
get_firstday(x, ...)
## S3 method for class 'grates_yearweek_wednesday'
get_firstday(x, ...)
## S3 method for class 'grates_yearweek_thursday'
get_firstday(x, ...)
## S3 method for class 'grates_yearweek_friday'
get_firstday(x, ...)
## S3 method for class 'grates_yearweek_saturday'
get_firstday(x, ...)
## S3 method for class 'grates_yearweek_sunday'
get_firstday(x, ...)
get_week(x, ...)
## Default S3 method:
get_week(x, ...)
## S3 method for class 'grates_yearweek'
get_week(x, ...)
## S3 method for class 'grates_epiweek'
get_week(x, ...)
## S3 method for class 'grates_isoweek'
get_week(x, ...)
get_year(x, ...)
## Default S3 method:
get_year(x, ...)
## S3 method for class 'grates_yearweek'
get_year(x, ...)
## S3 method for class 'grates_epiweek'
get_year(x, ...)
## S3 method for class 'grates_isoweek'
get_year(x, ...)
## S3 method for class 'grates_yearmonth'
get_year(x, ...)
## S3 method for class 'grates_yearquarter'
get_year(x, ...)
## S3 method for class 'grates_year'
get_year(x, ...)
get_n(x, ...)
## Default S3 method:
get_n(x, ...)
## S3 method for class 'grates_month'
get_n(x, ...)
## S3 method for class 'grates_period'
get_n(x, ...)
## S3 method for class 'grates_int_period'
get_n(x, ...)
get_offset(x, ...)
## Default S3 method:
get_offset(x, ...)
## S3 method for class 'grates_period'
get_offset(x, ...)
x |
R object |
... |
Not currently used |
Requested value or an error if no method available.
dates <- as.Date("2020-01-01") + 1:14
dat <- as_isoweek(dates)
get_week(dat)
#> [1] 1 1 1 1 2 2 2 2 2 2 2 3 3 3
get_year(dat)
#> [1] 2020 2020 2020 2020 2020 2020 2020 2020 2020 2020 2020 2020 2020 2020
isoweek()
is a constructor for <grates_isoweek>
objects.
isoweek(year = integer(), week = integer())
year |
Vector representing the year associated with
|
week |
Vector representing the week associated with 'year.
|
isoweeks are defined to start on a Monday and <grates_isoweek>
objects are
stored as the number of weeks (starting at 0) from the first Monday prior to
the Unix Epoch (1970-01-01). That is, the number of seven day periods from
1969-12-29.
Internally they have the same representation as a <grates_yearweek_monday>
object so are akin to an alias but with a marginally more efficient
implementation.
A <grates_isoweek>
object.
as_isoweek()
and new_isoweek()
.
isoweek(year = 2000L, week = 3L)
#> <grates_isoweek[1]>
#> [1] "2000-W03"
new_epiweek()
is a constructor for <grates_epiweek>
objects aimed at
developers.
new_epiweek(x = integer())
is_epiweek(xx)
x |
Vector representing the number of weeks.
|
xx |
R object. |
Epiweeks are defined to start on a Sunday and <grates_epiweek>
objects are
stored as the number of weeks (starting at 0) from the first Sunday after the
Unix Epoch (1970-01-01). That is, the number of seven day periods from
1970-01-04.
Internally they have the same representation as a <grates_yearweek_sunday>
object so are akin to an alias but with a marginally more efficient
implementation.
A <grates_epiweek>
object.
new_yearweek()
and new_isoweek()
.
new_epiweek(1:10)
#> <grates_epiweek[10]>
#> [1] "1970-W02" "1970-W03" "1970-W04" "1970-W05" "1970-W06" "1970-W07"
#> [7] "1970-W08" "1970-W09" "1970-W10" "1970-W11"
new_int_period()
is a constructor for <grates_int_period>
objects aimed
at developers.
new_int_period(x = integer(), n = 1L)
is_int_period(xx)
x |
Vector representing the number of n-integers from 0.
|
n |
Number of integers that are being grouped. Must be greater than 0. |
xx |
R object. |
grates_int_period
objects are stored as the integer number of n-integer
groups from 0. Here n-integer is taken to mean a 'grouping of n consecutive
integers'.
A <grates_int_period>
object.
new_int_period(1:10, 2L)
#> <grates_int_period[10]>
#> [1] [2, 3] [4, 5] [6, 7] [8, 9] [10, 11] [12, 13] [14, 15] [16, 17]
#> [9] [18, 19] [20, 21]
new_isoweek()
is a constructor for <grates_isoweek>
objects aimed at
developers.
new_isoweek(x = integer())
is_isoweek(xx)
x |
Vector representing the number of weeks.
|
xx |
R object. |
isoweeks are defined to start on a Monday and <grates_isoweek>
objects are
stored as the number of weeks (starting at 0) from the first Monday prior to
the Unix Epoch (1970-01-01). That is, the number of seven day periods from
1969-12-29.
Internally they have the same representation as a <grates_yearweek_monday>
object so are akin to an alias but with a marginally more efficient
implementation.
A <grates_isoweek>
object.
new_yearweek()
and new_epiweek()
.
new_isoweek(1:10)
#> <grates_isoweek[10]>
#> [1] "1970-W02" "1970-W03" "1970-W04" "1970-W05" "1970-W06" "1970-W07"
#> [7] "1970-W08" "1970-W09" "1970-W10" "1970-W11"
new_month()
is a constructor for <grates_month>
objects aimed at
developers.
new_month(x = integer(), n)
is_month(xx)
x |
Vector representing the number of n-months since the Unix Epoch (1970-01-01).
|
n |
Number of months that are being grouped. Must be greater than 1 (use
|
xx |
R object. |
grates_month
objects are stored as the integer number (starting at 0), of
n-month groups since the Unix Epoch (1970-01-01). Here n-months is taken to
mean a 'grouping of n consecutive months'.
A <grates_month>
object.
The algorithm to convert between dates and months relative to the UNIX Epoch comes from the work of Davis Vaughan in the unreleased datea package.
new_month(1:10, 2L)
#> <grates_month[10]>
#> [1] "1970-Mar to 1970-Apr" "1970-May to 1970-Jun" "1970-Jul to 1970-Aug"
#> [4] "1970-Sep to 1970-Oct" "1970-Nov to 1970-Dec" "1971-Jan to 1971-Feb"
#> [7] "1971-Mar to 1971-Apr" "1971-May to 1971-Jun" "1971-Jul to 1971-Aug"
#> [10] "1971-Sep to 1971-Oct"
new_period()
is a constructor for <grates_period>
objects aimed at
developers.
new_period(x = integer(), n = 1L, offset = 0L)
is_period(xx)
x |
Vector representing the number of periods since the Unix Epoch (1970-01-01) and a specified offset.
|
n |
Number of days that are being grouped by. |
offset |
Value you wish to start counting groups from relative to the Unix Epoch. |
xx |
R object. |
grates_period
objects are stored as the integer number, starting at 0L, of
periods since the Unix Epoch (1970-01-01) and a specified offset. Here
periods are taken to mean groupings of n
consecutive days.
For storage and calculation purposes, offset
is scaled relative to n
.
I.e. offset <- offset %% n
and values of x
stored relative to this scaled
offset.
A <grates_period>
object.
new_period(1:10)
#> <grates_period[10]>
#> [1] "1970-01-02" "1970-01-03" "1970-01-04" "1970-01-05" "1970-01-06"
#> [6] "1970-01-07" "1970-01-08" "1970-01-09" "1970-01-10" "1970-01-11"
new_yearmonth()
is a constructor for <grates_yearmonth>
objects aimed at
developers.
new_yearmonth(x = integer())
is_yearmonth(xx)
x |
Vector representing the number of months.
|
xx |
R object |
<grates_yearmonth>
objects are stored as the number of months (starting at
0) since the Unix Epoch (1970-01-01). Precision is only to the month level
(i.e. the day of the month is always dropped).
A <grates_yearmonth>
object.
The algorithm to convert between dates and months relative to the UNIX Epoch comes from the work of Davis Vaughan in the unreleased datea package
new_yearmonth(1:10)
#> <grates_yearmonth[10]>
#> [1] "1970-Feb" "1970-Mar" "1970-Apr" "1970-May" "1970-Jun" "1970-Jul"
#> [7] "1970-Aug" "1970-Sep" "1970-Oct" "1970-Nov"
new_yearquarter()
is a constructor for <grates_yearquarter>
objects aimed
at developers.
new_yearquarter(x = integer())
is_yearquarter(xx)
x |
Vector representing the number of quarters.
|
xx |
R object. |
<yearquarter>
objects are stored as the number of quarters (starting at 0)
since the Unix Epoch (1970-01-01).
A <grates_yearquarter>
object.
new_yearquarter(1:10)
#> <grates_yearquarter[10]>
#> [1] "1970-Q2" "1970-Q3" "1970-Q4" "1971-Q1" "1971-Q2" "1971-Q3" "1971-Q4"
#> [8] "1972-Q1" "1972-Q2" "1972-Q3"
new_yearweek()
is a constructor for <grates_yearweek>
objects aimed at
developers.
new_yearweek(x = integer(), firstday = 1L)
is_yearweek(xx)
x |
Vector representing the number of weeks.
|
firstday |
The day the week starts on from 1 (Monday) to 7 (Sunday). |
xx |
R object. |
<grates_yearweek>
objects are stored as the number of weeks
(starting at 0) from the date of the firstday
nearest the Unix Epoch
(1970-01-01). That is, the number of seven day periods from:
- 1969-12-29 for `firstday` equal to 1 (Monday)
- 1969-12-30 for `firstday` equal to 2 (Tuesday)
- 1969-12-31 for `firstday` equal to 3 (Wednesday)
- 1970-01-01 for `firstday` equal to 4 (Thursday)
- 1970-01-02 for `firstday` equal to 5 (Friday)
- 1970-01-03 for `firstday` equal to 6 (Saturday)
- 1970-01-04 for `firstday` equal to 7 (Sunday)
A <grates_yearweek>
object with subclass corresponding to the first
day of the week they represent (e.g. <grates_yearweek_monday>
).
as_yearweek()
, new_isoweek()
and new_epiweek()
.
new_yearweek(1:10)
#> <grates_yearweek_monday[10]>
#> [1] "1970-W02" "1970-W03" "1970-W04" "1970-W05" "1970-W06" "1970-W07"
#> [7] "1970-W08" "1970-W09" "1970-W10" "1970-W11"
Print an int_period object
## S3 method for class 'grates_int_period'
print(x, ...)
## S3 method for class 'grates_int_period'
format(x, ...)
x |
A |
... |
Not currently used. |
Print a month object
## S3 method for class 'grates_month'
print(x, format = "%Y-%b", sep = "to", ...)
## S3 method for class 'grates_month'
format(x, format = "%Y-%b", sep = "to", ...)
x |
A |
format |
The format to use for the bounds of each value. |
sep |
Where more than one month is grouped with others, |
... |
Not currently used. |
Print a period object
## S3 method for class 'grates_period'
print(x, format = "%Y-%m-%d", sep = "to", ...)
## S3 method for class 'grates_period'
format(x, format = "%Y-%m-%d", sep = "to", ...)
x |
A |
format |
The format to use for the bounds of each value. |
sep |
Where more than one day is grouped with others, |
... |
Not currently used. |
Print a year-quarter object
## S3 method for class 'grates_year'
print(x, ...)
## S3 method for class 'grates_year'
format(x, ...)
x |
A |
... |
Not currently used. |
Print a year-month object
## S3 method for class 'grates_yearmonth'
print(x, format = "%Y-%b", ...)
## S3 method for class 'grates_yearmonth'
format(x, format = "%Y-%b", ...)
x |
A |
format |
The format to use for printing. |
... |
Not currently used. |
Print a year-quarter object
## S3 method for class 'grates_yearquarter'
print(x, ...)
## S3 method for class 'grates_yearquarter'
format(x, ...)
x |
A |
... |
Not currently used. |
ggplot2 scale for an <grates_epiweek>
vector.
scale_x_grates_epiweek(
...,
breaks = ggplot2::waiver(),
n.breaks = 6L,
format = NULL
)
... |
Not currently used. |
breaks |
A |
n.breaks |
Approximate number of breaks calculated using Will only have an effect if |
format |
Format to use if "Date" scales are required. If NULL (default) then labels are in the standard epiweek format (YYYY-Www). If "week" then the labels are of the form Www (e.g. W37). Otherwise the value is used by |
A scale for use with ggplot2.
ggplot2 scale for an int_period vector.
scale_x_grates_int_period(
...,
breaks = ggplot2::waiver(),
n.breaks = 6L,
centre = FALSE,
n
)
... |
Not currently used. |
breaks |
A |
n.breaks |
Approximate number of breaks calculated using Will only have an effect if |
centre |
Only applicable to an If FALSE labels are place at the edge of the bounds. If TRUE then labels are centralised and of the form |
n |
Number used for the original grouping. |
A scale for use with ggplot2.
ggplot2 scale for an <grates_isoweek>
vector.
scale_x_grates_isoweek(
...,
breaks = ggplot2::waiver(),
n.breaks = 6L,
format = NULL
)
... |
Not currently used. |
breaks |
A |
n.breaks |
Approximate number of breaks calculated using Will only have an effect if |
format |
Format to use if "Date" scales are required. If NULL (default) then labels are in the standard isoweek format (YYYY-Www). If "week" then the labels are of the form Www (e.g. W37). Otherwise the value is used by |
A scale for use with ggplot2.
ggplot2 scale for a month vector.
scale_x_grates_month(
...,
breaks = ggplot2::waiver(),
n.breaks = 6L,
format = "%Y-%m-%d",
bounds_format = "%Y-%b",
sep = "to",
n
)
... |
Not currently used. |
breaks |
A |
n.breaks |
Approximate number of breaks calculated using Will only have an effect if |
format |
Format to use if "Date" scales are required. If NULL then labels are centralised and of the form "lower category bound to upper category bound". If not NULL then the value is used by |
bounds_format |
Format to use for grouped date labels. Only used if |
sep |
Separator to use for grouped date labels. |
n |
Number of months used for the original grouping. |
A scale for use with ggplot2.
ggplot2 scale for an <grates_period>
vector.
scale_x_grates_period(
...,
breaks = ggplot2::waiver(),
n.breaks = 6L,
format = "%Y-%m-%d",
n,
offset
)
... |
Not currently used. |
breaks |
A |
n.breaks |
Approximate number of breaks calculated using Will only have an effect if |
format |
Format to use for dates. Value is used by |
n |
Number of days in each period. |
offset |
Number of days used in original grouping for the offset from the Unix Epoch. |
A scale for use with ggplot2.
ggplot2 scale for year vector.
scale_x_grates_year(
...,
breaks = ggplot2::waiver(),
n.breaks = 6L,
format = NULL
)
... |
Not currently used. |
breaks |
A |
n.breaks |
Approximate number of breaks calculated using Will only have an effect if |
format |
Format to use if "Date" scales are required. If not NULL then the value is used by |
A scale for use with ggplot2.
ggplot2 scale for a yearmonth vector.
scale_x_grates_yearmonth(
...,
breaks = ggplot2::waiver(),
n.breaks = 6L,
format = NULL
)
... |
Not currently used. |
breaks |
A |
n.breaks |
Approximate number of breaks calculated using Will only have an effect if |
format |
Format to use if "Date" scales are required. If not NULL then the value is used by |
A scale for use with ggplot2.
ggplot2 scale for a yearquarter vector.
scale_x_grates_yearquarter(
...,
breaks = ggplot2::waiver(),
n.breaks = 6L,
format = NULL
)
... |
Not currently used. |
breaks |
A |
n.breaks |
Approximate number of breaks calculated using Will only have an effect if |
format |
Format to use if "Date" scales are required. If not NULL then the value is used by |
A scale for use with ggplot2.
ggplot2 scale for an <grates_yearweek>
vector.
scale_x_grates_yearweek(
...,
breaks = ggplot2::waiver(),
n.breaks = 6L,
firstday,
format = NULL
)
scale_x_grates_yearweek_monday(
...,
breaks = ggplot2::waiver(),
n.breaks = 6,
format = NULL
)
scale_x_grates_yearweek_isoweek(
...,
breaks = ggplot2::waiver(),
n.breaks = 6,
format = NULL
)
scale_x_grates_yearweek_tuesday(
...,
breaks = ggplot2::waiver(),
n.breaks = 6,
format = NULL
)
scale_x_grates_yearweek_wednesday(
...,
breaks = ggplot2::waiver(),
n.breaks = 6,
format = NULL
)
scale_x_grates_yearweek_thursday(
...,
breaks = ggplot2::waiver(),
n.breaks = 6,
format = NULL
)
scale_x_grates_yearweek_friday(
...,
breaks = ggplot2::waiver(),
n.breaks = 6,
format = NULL
)
scale_x_grates_yearweek_saturday(
...,
breaks = ggplot2::waiver(),
n.breaks = 6,
format = NULL
)
scale_x_grates_yearweek_sunday(
...,
breaks = ggplot2::waiver(),
n.breaks = 6,
format = NULL
)
scale_x_grates_yearweek_epiweek(
...,
breaks = ggplot2::waiver(),
n.breaks = 6,
format = NULL
)
... |
Not currently used. |
breaks |
A |
n.breaks |
Approximate number of breaks calculated using Will only have an effect if |
firstday |
Integer value of the first weekday: 1 (Monday) to 7 (Sunday). |
format |
Format to use if "Date" scales are required. If NULL (default) then labels are in the standard yearweek format (YYYY-Www). If "week" then the labels are of the form Www (e.g. W37). Otherwise the value is used by |
A scale for use with ggplot2.
year()
is a constructor for <grates_year>
objects.
year(x = integer())
is_year(object)
x |
Vector representing the years.
|
object |
R object. |
A <grates_year>
object.
year(2011:2020)
#> <grates_year[10]>
#> [1] 2011 2012 2013 2014 2015 2016 2017 2018 2019 2020
yearmonth()
is a constructor for <grates_yearmonth>
objects.
yearmonth(year = integer(), month = integer())
year |
Vector representing the year associated with
|
month |
Vector representing the month associated with 'year.
|
<grates_yearmonth>
objects are stored as the number of months (starting at
0) since the Unix Epoch (1970-01-01).
A <grates_yearmonth>
object.
as_yearmonth()
and new_yearmonth()
.
yearmonth(year = 2000L, month = 3L)
#> <grates_yearmonth[1]>
#> [1] "2000-Mar"
yearquarter()
is a constructor for <grates_yearquarter>
objects.
yearquarter(year = integer(), quarter = integer())
year |
Vector representing the year associated with
|
quarter |
Vector representing the quarter associated with 'year.
|
<grates_yearquarter>
objects are stored as the number of quarters (starting
at 0) since the Unix Epoch (1970-01-01).
A <grates_yearquarter>
object.
as_yearquarter()
and new_yearquarter()
.
yearquarter(year = 2000L, quarter = 3L)
#> <grates_yearquarter[1]>
#> [1] "2000-Q3"
yearweek()
is a constructor for <grates_yearweek>
objects. These are
weeks whose first day can be specified by the user.
yearweek(year = integer(), week = integer(), firstday = 1L)
year |
Vector representing the year associated with
|
week |
Vector representing the week associated with 'year.
|
firstday |
The day the week starts on from 1 (Monday) to 7 (Sunday). |
For yearweek objects the first week of a "year" is considered to be the first yearweek containing 4 days of the given calendar year. This means that the calendar year will sometimes be different to that of the associated yearweek object.
A <grates_yearweek>
object with subclass corresponding to the first day of
the week they represent (e.g. <grates_yearweek_monday>
).
Internally <grates_yearweek>
objects are stored as the number of weeks
(starting at 0) from the date of the firstday
nearest the Unix Epoch
(1970-01-01). That is, the number of seven day periods from:
- 1969-12-29 for `firstday` equal to 1 (Monday)
- 1969-12-30 for `firstday` equal to 2 (Tuesday)
- 1969-12-31 for `firstday` equal to 3 (Wednesday)
- 1970-01-01 for `firstday` equal to 4 (Thursday)
- 1970-01-02 for `firstday` equal to 5 (Friday)
- 1970-01-03 for `firstday` equal to 6 (Saturday)
- 1970-01-04 for `firstday` equal to 7 (Sunday)
as_yearweek()
and new_yearweek()
.
yearweek(year = 2000L, week = 3L)
#> <grates_yearweek_monday[1]>
#> [1] "2000-W03"