https://github.com/cran/season
Tip revision: 466309ca9e5da1f5aa56158716fee479535c50be authored by Adrian Barnett on 03 June 2021, 09:50:02 UTC
version 0.3.13
version 0.3.13
Tip revision: 466309c
monthmean.R
# monthmean.R
# function to calculate monthly mean or adjusted monthly mean for count data
# Assumes that data contains two variables: month and year
# November 2009
monthmean<-function(data,resp,offsetpop=NULL,adjmonth=FALSE){
# checks
if (is.null(data)==TRUE){stop("must have an input data set (data)")}
if (is.null(resp)==TRUE){stop("must have an input variable (resp)")}
nnn<-names(data)
if (any(nnn=='year')==FALSE){stop("data set must contain a variable with the 4 digit year called 'year'")}
if (any(nnn=='month')==FALSE){stop("data set must contain a variable with the numeric month called 'month'")}
# calculations
days<-flagleap(data) # get the number of days in each month
mean<-vector(length=12,mode='numeric')
if (adjmonth=='thirty') adjf=30
if (adjmonth=='average') adjf=365.25/12
if (is.null(offsetpop)==TRUE) adjp=1 else adjp=with(data,eval(offsetpop)) # population adjustment
xxxx=subset(data,select=resp)[,1] # instead of with
for (i in 1:12){
if (adjmonth!=FALSE) mean[i]<-mean(xxxx[data$month==i]*(adjf/days$ndaysmonth[i])/adjp)
else mean[i]<-mean(xxxx[data$month==i]/adjp) # no monthly adjustment
}
# return
toret<-list()
toret$mean<-as.vector(mean)
class(toret)<-'Monthmean'
return(toret)
}
# example
# mmean<-monthmean(data=CVD,resp=cvd,offsetpop=expression(pop/100000))
# adjmean<-monthmean(data=elderly,resp=cvd,adjmonth='average',offsetpop=expression(pop/100000))