Awesome - thanks! Paolo
On 17 November 2010 19:44, Ray Brownrigg <ray.brownr...@ecs.vuw.ac.nz>wrote: > On Thu, 18 Nov 2010, Paolo Rossi wrote: > > I sent a post to find a clever way to compute a Rolling Average of > columns > > in a matrix and I was given the solution below which I am very pleased > > with. > > > > > > RollingAverage <- function(x, RollingObs) { > > cx <- cumsum(x); > > N <- length(x); > > Temp <- (cx[RollingObs:N] - c(0, cx[1:(N-RollingObs)]))/RollingObs > > Output <- array(NA, N) > > Output[RollingObs:N] <- Temp; > > Output > > } > > > > > > The only drawback is that in order to use apply to iterate over columns > one > > needs to write a fucntion for any RollingObs unless one is able to pass a > > parameter through an apply call. > > > > Example: > > a= array(1:100, dim = c(17,2)) > > RollingAverage(a[, 1], 7) # works fine > > apply(a, 2, RollingAverage) # this doesnt work as it doesnt see > > RollingObs > > > > Is there a way to pass an additional parameter to apply? > > > RTFM. Thats what the ... option of apply() is for. > > apply(a, 2, RollingAverage, RollingObs=7) > > Ray > > > Thanks > > > > Paolo > > > > On 16 November 2010 20:05, Ray Brownrigg <ray.brownr...@ecs.vuw.ac.nz > >wrote: > > > On Wed, 17 Nov 2010, Paolo Rossi wrote: > > > > Hi, > > > > Can anyone suggest a clever way to compute a rolling weekly average > of > > > > > > the > > > > > > > columns in a matrix? The column bit is straightforward use apply > > > > given > > > > > > a > > > > > > > function which does what you want on a column. With regard to a > > > > > > particular > > > > > > > column, the obvious way is to run a for loop indexing the last 7 days > > > > and computing the average . I simply would like to know if there is a > > > > better > > > > > > / > > > > > > > quicker way. > > > > > > > > > > > > > > > > Code: > > > > Given a, > > > > > > > > > a= array(1:100, dim = c(17,2)) > > > > > a > > > > > > > > [,1] [,2] > > > > [1,] 1 18 > > > > [2,] 2 19 > > > > [3,] 3 20 > > > > [4,] 4 21 > > > > [5,] 5 22 > > > > [6,] 6 23 > > > > [7,] 7 24 > > > > [8,] 8 25 > > > > [9,] 9 26 > > > > [10,] 10 27 > > > > [11,] 11 28 > > > > [12,] 12 29 > > > > [13,] 13 30 > > > > [14,] 14 31 > > > > [15,] 15 32 > > > > [16,] 16 33 > > > > [17,] 17 34 > > > > one needs to start computing the average from obs 7 s (at obs 7 you > > > > have > > > > > > a > > > > > > > full week to compute the average) and compute the rolling weekly > > > > average from day 7 onwards > > > > Results will look like b > > > > [,1] [,2] > > > > [1,] 4 14 > > > > [2,] 5 21 > > > > [3,] 6 22 > > > > [4,] 7 23 > > > > [5,] 8 24 > > > > [6,] 9 25 > > > > [7,] 10 26 > > > > [8,] 11 27 > > > > [9,] 12 28 > > > > [10,] 13 29 > > > > Thanks in advance, > > > > > > I don't see how an average of 7 numbers all 18 or greater can be 14, as > > > in your > > > result[1, 2], unless you have mis-stated the question. > > > > > > Anyway, try: > > > apply(a, 2, function(x) {cx <- cumsum(x); N <- length(x); (cx[7:N] - > c(0, > > > cx[1:(N-7)]))/7} > > > > > > HTH > > > Ray Brownrigg > > > > > > > Paolo > > > [[alternative HTML version deleted]]
______________________________________________ R-help@r-project.org mailing list https://stat.ethz.ch/mailman/listinfo/r-help PLEASE do read the posting guide http://www.R-project.org/posting-guide.html and provide commented, minimal, self-contained, reproducible code.