MathGroup Archive 1999

[Date Index] [Thread Index] [Author Index]

Search the Archive

Re: Moving average type process


Hi Virgil,

In 4.0 they put this in the kernel:

In[1]:=
ListCorrelate[{w1, w2, w3}, {a, b, c, d, e, f}]

Out[1]=
{a w1 + b w2 + c w3, b w1 + c w2 + d w3, c w1 + d w2 + e w3,
  d w1 + e w2 + f w3}

-- Dave



Virgil Stokes wrote in message <7kpbdq$4at at smc.vnet.net>...
>I wish to perform the following "moving average" type process on
>a list to generate a new list:
>
>Inputs:
>  wtlist = {w1,w2,w3}     -- weight list
>  inlist = {a,b,c,d,e,f}  -- any other list (>= 3 elements)
>
>Output:
>  outlist = {w1*a+w2*b+w3*c, w1*b+w2*c+w3*d, w1*c+w2*d+w3*e,
w1*d+w2*e+w3*f}
>
>Note, outlist will always contain 2 less (Length[wtlist]/2) elements
>than in the input list (inlist).
>
>If w1=w2=w3=x, then
>the following works fine:
>
>outlist = x*Drop[Plus@@NestList[RotateRight,inlist,2],2]
>
>This is a weighted (from wtlist) sum over another list of arbitrary
>length (inlist). I would like to get a "fast" function for doing this when
>the weights are not equal.
>
>-- Virgil
>
>
>




  • Prev by Date: Re: Forcing Re[]'s to be Real
  • Next by Date: Re: quartiles
  • Previous by thread: Re: Moving average type process
  • Next by thread: Re: Moving average type process