https://github.com/poissonconsulting/hmstimer
An R package to track elapsed clock time using a `hms::hms()` scalar.
https://github.com/poissonconsulting/hmstimer
cran hms r rstats timer
Last synced: 4 months ago
JSON representation
An R package to track elapsed clock time using a `hms::hms()` scalar.
- Host: GitHub
- URL: https://github.com/poissonconsulting/hmstimer
- Owner: poissonconsulting
- License: other
- Created: 2019-05-10T19:38:48.000Z (almost 6 years ago)
- Default Branch: main
- Last Pushed: 2024-10-27T05:35:36.000Z (4 months ago)
- Last Synced: 2024-10-27T06:22:11.081Z (4 months ago)
- Topics: cran, hms, r, rstats, timer
- Language: R
- Homepage: https://poissonconsulting.github.io/hmstimer/
- Size: 1.49 MB
- Stars: 2
- Watchers: 5
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.Rmd
- Changelog: NEWS.md
- Contributing: .github/CONTRIBUTING.md
- License: LICENSE
- Code of conduct: .github/CODE_OF_CONDUCT.md
- Support: .github/SUPPORT.md
Awesome Lists containing this project
- jimsghstars - poissonconsulting/hmstimer - An R package to track elapsed clock time using a `hms::hms()` scalar. (R)
README
---
output: github_document
---```{r, include = FALSE}
knitr::opts_chunk$set(
collapse = TRUE,
comment = "#>",
fig.path = "man/figures/README-",
out.width = "100%"
)
```# ssdtools
[data:image/s3,"s3://crabby-images/d47ec/d47ec1157ea15a7fb737e0f94ec675a5c193c843" alt="Lifecycle: stable"](https://lifecycle.r-lib.org/articles/stages.html#stable)
[data:image/s3,"s3://crabby-images/d293c/d293c2ae2fe302b07d629e868dc89e87f623e7a7" alt="R-CMD-check"](https://github.com/poissonconsulting/hmstimer/actions/workflows/R-CMD-check.yaml)
[data:image/s3,"s3://crabby-images/7b522/7b522830707b015dedcdb74d1a6b6f06d8ce96c2" alt="Codecov test coverage"](https://app.codecov.io/gh/poissonconsulting/hmstimer)
[data:image/s3,"s3://crabby-images/8fe25/8fe252f76dc2a000f81c31eb23c03acd6799638b" alt="License: MIT"](https://opensource.org/licenses/MIT)
[data:image/s3,"s3://crabby-images/8e76d/8e76d485b9e91cda1132331b5b49605ded856173" alt="CRAN status"](https://cran.r-project.org/package=hmstimer)
data:image/s3,"s3://crabby-images/a9fe0/a9fe0f6bf10cd2c24749e5ef9efe652035a087e7" alt="CRAN downloads"`hmstimer` is an R package to
track elapsed clock time using a [hms::hms](https://github.com/tidyverse/hms) scalar.`hmstimer` was originally developed to time Bayesian model runs. It should not be used to estimate how long extremely fast code takes to execute as the package code adds a small time cost.
Create and start a timer with `tmr_timer(start = TRUE)`.
```{r}
library(hmstimer)tmr <- tmr_timer(start = TRUE)
Sys.sleep(0.1)
str(tmr)
hms::as_hms(tmr)
```Get the elapsed time with `tmr_elapsed()`.
The title is optional.
```{r}
tmr <- tmr_timer(start = TRUE, title = "my timer")Sys.sleep(0.1)
tmr_elapsed(tmr)Sys.sleep(0.1)
tmr_elapsed(tmr)
```Stop the timer with `tmr_stop()`.
```{r}
tmr <- tmr_stop(tmr)
tmr_elapsed(tmr)Sys.sleep(1)
tmr_elapsed(tmr)
```Restart the timer with `tmr_start()`.
```{r}
tmr <- tmr_start(tmr)
tmr_elapsed(tmr)
Sys.sleep(0.1)
tmr_elapsed(tmr)
```There are several options for printing and formatting including coercing to a hms object.
```{r}
tmr <- tmr_stop(tmr)
print(tmr)
tmr_print(tmr)
tmr_format(tmr, digits = 5)
```If running `tmr_print()` behaves differently.
```{r}
tmr <- tmr_start(tmr)
tmr_print(tmr)
```The time for a block of code to complete can be printed using `with_timer()`.
```{r}
with_timer({
Sys.sleep(0.1)
Sys.sleep(0.1)
1 + 1
})
```## Installation
To install the latest release version from CRAN.
```r
install.packages("hmstimer")
```To install the latest development version from [r-universe](https://poissonconsulting.r-universe.dev/hmstimer).
```r
install.packages("hmstimer", repos = c("https://poissonconsulting.r-universe.dev", "https://cloud.r-project.org"))
```To install the latest development version from [GitHub](https://github.com/poissonconsulting/hmstimer)
```r
# install.packages("pak", repos = sprintf("https://r-lib.github.io/p/pak/stable/%s/%s/%s", .Platform$pkgType, R.Version()$os, R.Version()$arch))
pak::pak("poissonconsulting/hmstimer")
```## Contribution
Please report any [issues](https://github.com/poissonconsulting/hmstimer/issues).
[Pull requests](https://github.com/poissonconsulting/hmstimer/pulls) are always welcome.
## Code of Conduct
Please note that the hmstimer project is released with a [Contributor Code of Conduct](https://contributor-covenant.org/version/2/0/CODE_OF_CONDUCT.html). By contributing to this project, you agree to abide by its terms.