An open API service indexing awesome lists of open source software.

https://github.com/mazamascience/mazamarollutils

Fast rolling functions for R written in C++
https://github.com/mazamascience/mazamarollutils

cpp r rcpp

Last synced: 4 months ago
JSON representation

Fast rolling functions for R written in C++

Awesome Lists containing this project

README

          

[![CRAN\_Status\_Badge](https://www.r-pkg.org/badges/version/MazamaRollUtils)](https://cran.r-project.org/package=MazamaRollUtils)
[![Downloads](https://cranlogs.r-pkg.org/badges/MazamaRollUtils)](https://cran.r-project.org/package=MazamaRollUtils)

A dedicated Slack channel has been created for announcements, support and to help
build a community of practice around this open source package. You may request an
invitation to join from jonathan.callahan@dri.com.

# MazamaRollUtils

```
A suite of compiled functions calculating rolling mins, means,
maxes and other statistics. This package is designed to meet the needs of
data processing systems for environmental time series.
```

## Background

Analysis of time series data often involves applying "rolling" functions to calculate,
_e.g._ a "moving average". These functions are straightforward to write in any language
and it makes sense to have C++ versions of common rolling functions available
to R as they dramatically speed up calculations. Several packages exist that
provide some version of this functionality:

* [zoo](https://cran.r-project.org/package=zoo) --
core R package with a specific data model
* [seismicRoll](https://cran.r-project.org/package=seismicRoll) -- rolling functions focused on seismology
* [RcppRoll](https://cran.r-project.org/package=RcppRoll) --
rolling functions for basic statistics

Our goal in creating a new package of C++ rolling functions is to build up a
suite of functions useful in environmental time series analysis. We want these
functions to be available in a neutral environment with no underlying data model.
The functions are as straightforward to use as is reasonably possible with a
target audience of data analysts at any level of R expertise.

## Installation

Install from CRAN with:

```
install.packages('MazamaRollUtils')
```

Install the latest version from GitHub with:

```
devtools::install_github("MazamaScience/MazamaRollUtils")
```

## Examples

```
library(MazamaRollUtils)

# Example air quality time series
t <- example_pm25$datetime
x <- example_pm25$pm25

plot(t, x)
lines(t, roll_max(x, width = 12), col = 'salmon')
lines(t, roll_min(x, width = 12), col = 'light blue')
```
------------------------------------------------------------------------

This project is supported by the [USFS AirFire](https://www.airfire.org) team.