<?xml version="1.0" encoding="UTF-8"?>
<rss xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:taxo="http://purl.org/rss/1.0/modules/taxonomy/" version="2.0">
  <channel>
    <title>topic Calculating moving average in sas in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/Calculating-moving-average-in-sas/m-p/626403#M184752</link>
    <description>&lt;P&gt;Good day&lt;/P&gt;&lt;P&gt;I have a task in creating a sum given the followng&lt;/P&gt;&lt;P&gt;ColA ColB&lt;/P&gt;&lt;P&gt;1&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;4&lt;/P&gt;&lt;P&gt;2&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;8&lt;/P&gt;&lt;P&gt;3&amp;nbsp; &amp;nbsp; &amp;nbsp; 12&lt;/P&gt;&lt;P&gt;4&amp;nbsp; &amp;nbsp; &amp;nbsp; 10&lt;/P&gt;&lt;P&gt;5&amp;nbsp; &amp;nbsp; &amp;nbsp; 20&lt;/P&gt;&lt;P&gt;6&amp;nbsp; &amp;nbsp; &amp;nbsp; 30&lt;/P&gt;&lt;P&gt;7&amp;nbsp; &amp;nbsp; &amp;nbsp;11&lt;/P&gt;&lt;P&gt;8&amp;nbsp; &amp;nbsp; &amp;nbsp;13&lt;/P&gt;&lt;P&gt;9&amp;nbsp; &amp;nbsp; &amp;nbsp;14&lt;/P&gt;&lt;P&gt;10&amp;nbsp; &amp;nbsp; 60&lt;/P&gt;&lt;P&gt;11&amp;nbsp; &amp;nbsp;70&lt;/P&gt;&lt;P&gt;12&amp;nbsp; &amp;nbsp;100&lt;/P&gt;&lt;P&gt;Frist i want to calculate from ColA frist 4 rows but on b from the 5th row in a manner below.&lt;/P&gt;&lt;P&gt;ColB&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; divided by ColA&lt;/P&gt;&lt;P&gt;Sum(20,30,11,13)/Sum(1,2,3,4)&lt;/P&gt;&lt;P&gt;Sum(30,11,13,14)/Sum(2,3,4,5)&lt;/P&gt;&lt;P&gt;Sum(11,13,14,60)/Sum(3,4,5,6) and so forth.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;however i want to do this regardless of the number of row i also need a trigger to show the last row and it should stop.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Your help will be highly appreciated.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
    <pubDate>Fri, 21 Feb 2020 07:06:45 GMT</pubDate>
    <dc:creator>langalife</dc:creator>
    <dc:date>2020-02-21T07:06:45Z</dc:date>
    <item>
      <title>Calculating moving average in sas</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Calculating-moving-average-in-sas/m-p/626403#M184752</link>
      <description>&lt;P&gt;Good day&lt;/P&gt;&lt;P&gt;I have a task in creating a sum given the followng&lt;/P&gt;&lt;P&gt;ColA ColB&lt;/P&gt;&lt;P&gt;1&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;4&lt;/P&gt;&lt;P&gt;2&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;8&lt;/P&gt;&lt;P&gt;3&amp;nbsp; &amp;nbsp; &amp;nbsp; 12&lt;/P&gt;&lt;P&gt;4&amp;nbsp; &amp;nbsp; &amp;nbsp; 10&lt;/P&gt;&lt;P&gt;5&amp;nbsp; &amp;nbsp; &amp;nbsp; 20&lt;/P&gt;&lt;P&gt;6&amp;nbsp; &amp;nbsp; &amp;nbsp; 30&lt;/P&gt;&lt;P&gt;7&amp;nbsp; &amp;nbsp; &amp;nbsp;11&lt;/P&gt;&lt;P&gt;8&amp;nbsp; &amp;nbsp; &amp;nbsp;13&lt;/P&gt;&lt;P&gt;9&amp;nbsp; &amp;nbsp; &amp;nbsp;14&lt;/P&gt;&lt;P&gt;10&amp;nbsp; &amp;nbsp; 60&lt;/P&gt;&lt;P&gt;11&amp;nbsp; &amp;nbsp;70&lt;/P&gt;&lt;P&gt;12&amp;nbsp; &amp;nbsp;100&lt;/P&gt;&lt;P&gt;Frist i want to calculate from ColA frist 4 rows but on b from the 5th row in a manner below.&lt;/P&gt;&lt;P&gt;ColB&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; divided by ColA&lt;/P&gt;&lt;P&gt;Sum(20,30,11,13)/Sum(1,2,3,4)&lt;/P&gt;&lt;P&gt;Sum(30,11,13,14)/Sum(2,3,4,5)&lt;/P&gt;&lt;P&gt;Sum(11,13,14,60)/Sum(3,4,5,6) and so forth.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;however i want to do this regardless of the number of row i also need a trigger to show the last row and it should stop.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Your help will be highly appreciated.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Fri, 21 Feb 2020 07:06:45 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Calculating-moving-average-in-sas/m-p/626403#M184752</guid>
      <dc:creator>langalife</dc:creator>
      <dc:date>2020-02-21T07:06:45Z</dc:date>
    </item>
    <item>
      <title>Re: Calculating moving average in sas</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Calculating-moving-average-in-sas/m-p/626404#M184753</link>
      <description>&lt;P&gt;&lt;a href="https://communities.sas.com/t5/user/viewprofilepage/user-id/293682"&gt;@langalife&lt;/a&gt;&amp;nbsp;Hi and welcome to the SAS Community &lt;span class="lia-unicode-emoji" title=":slightly_smiling_face:"&gt;🙂&lt;/span&gt;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Do you need this to handle By-Groups? And do you have a SAS/ETS license?&lt;/P&gt;</description>
      <pubDate>Fri, 21 Feb 2020 07:08:35 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Calculating-moving-average-in-sas/m-p/626404#M184753</guid>
      <dc:creator>PeterClemmensen</dc:creator>
      <dc:date>2020-02-21T07:08:35Z</dc:date>
    </item>
    <item>
      <title>Re: Calculating moving average in sas</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Calculating-moving-average-in-sas/m-p/626406#M184754</link>
      <description>&lt;P&gt;Hi&amp;nbsp;&lt;a href="https://communities.sas.com/t5/user/viewprofilepage/user-id/293682"&gt;@langalife&lt;/a&gt;&amp;nbsp;,&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;do you mean something like below:&lt;/P&gt;&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data have;
input ColA ColB;
cards;
1 4
2 8
3 12
4 10
5 20
6 30
7 11
8 13
9 14
10 60
11 70
12 100
;
run;

data want;

  set have;
  sum_a = 0;
  sum_a + (colA + lag1(colA) + lag2(colA) + lag3(colA));

  if _N_ &amp;gt;= 4;
  merge
    have(keep=colB rename=(colB=colNB)firstobs=5)
    have(keep=colB rename=(colB=colNBB)firstobs=6)
    have(keep=colB rename=(colB=colNBBB)firstobs=7)
    have(keep=colB rename=(colB=colNBBBB)firstobs=8)
  ;
  sum_b = sum(of colNB:);  
  drop colNB:;
  avg = sum_b / sum_a; 

run;
proc print;
run;

data want2;
  set have(obs=3) want;
run;
proc print;
run;

&lt;/CODE&gt;&lt;/PRE&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;?&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;All the best&lt;/P&gt;&lt;P&gt;Bart&lt;/P&gt;</description>
      <pubDate>Fri, 21 Feb 2020 07:42:16 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Calculating-moving-average-in-sas/m-p/626406#M184754</guid>
      <dc:creator>yabwon</dc:creator>
      <dc:date>2020-02-21T07:42:16Z</dc:date>
    </item>
    <item>
      <title>Re: Calculating moving average in sas</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Calculating-moving-average-in-sas/m-p/626410#M184756</link>
      <description>&lt;P&gt;One way ..&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data have;
input ColA ColB;
datalines;
1  4
2  8
3  12
4  10
5  20
6  30
7  11
8  13
9  14
10 60
11 70
12 100
;

data want(keep=colA colB avg);
    array l [0:3] _temporary_;          
    
    do obs=1 by 1 until (lr);       
        merge have
              have(keep=colB rename=(colB=colB2)firstobs=2)
              have(keep=colB rename=(colB=colB3)firstobs=3)
              have(keep=colB rename=(colB=colB4)firstobs=4) end=lr;
        l [mod(obs, 4)] = lag1(ColA);         
        avg = sum(of colB:) / sum(of l [*]);              
        output;
    end;
run;&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Fri, 21 Feb 2020 08:23:52 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Calculating-moving-average-in-sas/m-p/626410#M184756</guid>
      <dc:creator>PeterClemmensen</dc:creator>
      <dc:date>2020-02-21T08:23:52Z</dc:date>
    </item>
    <item>
      <title>Re: Calculating moving average in sas</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Calculating-moving-average-in-sas/m-p/626411#M184757</link>
      <description>&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data have;
input ColA ColB;
cards;
1 4
2 8
3 12
4 10
5 20
6 30
7 11
8 13
9 14
10 60
11 70
12 100
;
run;

data want;
set have;
runing_averae=sum(colB,lag(colB),lag2(colB),lag3(colB))/sum(colA,lag(colA),lag2(colA),lag3(colA));
run;&lt;/CODE&gt;&lt;/PRE&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Please let us know if this worked for you.&lt;/P&gt;</description>
      <pubDate>Fri, 21 Feb 2020 08:25:57 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Calculating-moving-average-in-sas/m-p/626411#M184757</guid>
      <dc:creator>Satish_Parida</dc:creator>
      <dc:date>2020-02-21T08:25:57Z</dc:date>
    </item>
    <item>
      <title>Re: Calculating moving average in sas</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Calculating-moving-average-in-sas/m-p/626610#M184851</link>
      <description>&lt;P&gt;Better post then output you want see.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;data have;
input ColA ColB;
cards;
1 4
2 8
3 12
4 10
5 20
6 30
7 11
8 13
9 14
10 60
11 70
12 100
;
run;
data want;
 merge have have(keep=colb rename=(colb=_colb) firstobs=5);
 laga=lag(cola);laga2=lag2(cola);laga3=lag3(cola);laga4=lag4(cola);
 lagb=lag(_colb);lagb2=lag2(_colb);lagb3=lag3(_colb);lagb4=lag4(_colb);
 if _n_&amp;gt;4 then want=sum(lagb,lagb2,lagb3,lagb4)/sum(laga,laga2,laga3,laga4);
run;&lt;/PRE&gt;</description>
      <pubDate>Sat, 22 Feb 2020 06:33:09 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Calculating-moving-average-in-sas/m-p/626610#M184851</guid>
      <dc:creator>Ksharp</dc:creator>
      <dc:date>2020-02-22T06:33:09Z</dc:date>
    </item>
  </channel>
</rss>

