This is a utility function mostly designed to calculate rolling mean statistics relevant to some pollutant limits, e.g., 8 hour rolling means for ozone and 24 hour rolling means for PM10. However, the function has a more general use in helping to display rolling mean values in flexible ways with the rolling window width left, right or centre aligned. The function will try and fill in missing time gaps to get a full time sequence but return a data frame with the same number of rows supplied.
Usage
rollingMean(
  mydata,
  pollutant = "o3",
  width = 8L,
  type = "default",
  data.thresh = 75,
  align = c("centre", "center", "left", "right"),
  new.name = NULL,
  ...
)Arguments
- mydata
- A data frame containing a - datefield.- mydatamust contain a- datefield in- Dateor- POSIXctformat. The input time series must be regular, e.g., hourly, daily.
- pollutant
- The name of a pollutant, e.g., - pollutant = "o3".
- width
- The averaging period (rolling window width) to use, e.g., - width = 8will generate 8-hour rolling mean values when hourly data are analysed.
- type
- Used for splitting the data further. Passed to - cutData().
- data.thresh
- The % data capture threshold. No values are calculated if data capture over the period of interest is less than this value. For example, with - width = 8and- data.thresh = 75at least 6 hours are required to calculate the mean, else- NAis returned.
- align
- Specifies how the moving window should be aligned. - "right"means that the previous hours (including the current) are averaged.- "left"means that the forward hours are averaged.- "centre"(or- "center"- the default) centres the current hour in the window.
- new.name
- The name given to the new column. If not supplied it will create a name based on the name of the pollutant and the averaging period used. 
- ...
- Additional parameters passed to - cutData(). For use with- type.
