<?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 Re: Calculation across rows in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/Calculation-across-rows/m-p/724275#M224855</link>
    <description>&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data have;
infile cards expandtabs;
input WEEK $	Units : comma12.;
format units comma12.;
cards;
Week1	81,855
Week2	80,009
Week3	71,972
Week4	68,035
;
run;

data want;
 set have end=last;
 lag=lag(units);
 lag2=lag2(units);
 lag3=lag3(units);
 char_units=put(units,comma12. -l);
 output;
if last then do;
 week='Average'; units=mean(lag,lag2,units);char_units=put(units,comma12. -l);output;
 week='Variance';units=(lag3-units)/units;char_units=put(units,percent8.2 -l);output;
end;
run;&lt;/CODE&gt;&lt;/PRE&gt;</description>
    <pubDate>Sun, 07 Mar 2021 12:54:35 GMT</pubDate>
    <dc:creator>Ksharp</dc:creator>
    <dc:date>2021-03-07T12:54:35Z</dc:date>
    <item>
      <title>Calculation across rows</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Calculation-across-rows/m-p/724273#M224854</link>
      <description>&lt;P&gt;My input dataset (Table 1) has 2 columns and 4 rows. I need to calculate row 5 and row 6 as shows in (table 2). Please help me create Row5 and Row6.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&lt;STRONG&gt;Calculation:&lt;/STRONG&gt;&lt;/P&gt;
&lt;P&gt;Row 5 - Average of row 2, 3, 4&lt;/P&gt;
&lt;P&gt;Row 6 - (Row1 - Row5)/Row5&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&lt;STRONG&gt;Table 1: (INPUT DATASET)&lt;/STRONG&gt;&lt;/P&gt;
&lt;TABLE style="width: 96pt; border-collapse: collapse;" border="0" width="128" cellspacing="0" cellpadding="0"&gt;&lt;COLGROUP&gt;&lt;COL style="width: 48pt;" span="2" width="64" /&gt;&lt;/COLGROUP&gt;
&lt;TBODY&gt;
&lt;TR style="height: 15pt;"&gt;
&lt;TD width="64" height="20" style="border: 0.5pt solid windowtext; width: 48pt; height: 15pt; background-color: transparent;"&gt;&lt;STRONG&gt;&lt;FONT face="Calibri" color="#000000"&gt;WEEK&lt;/FONT&gt;&lt;/STRONG&gt;&lt;/TD&gt;
&lt;TD width="64" style="border-width: 0.5pt 0.5pt 0.5pt 0px; border-style: solid solid solid none; border-color: windowtext windowtext windowtext black; width: 48pt; background-color: transparent;"&gt;&lt;STRONG&gt;&lt;FONT face="Calibri" color="#000000"&gt;Units&lt;/FONT&gt;&lt;/STRONG&gt;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR style="height: 15pt;"&gt;
&lt;TD height="20" style="border-width: 0px 0.5pt 0.5pt; border-style: none solid solid; border-color: black windowtext windowtext; height: 15pt; background-color: transparent;"&gt;&lt;FONT face="Calibri" color="#000000"&gt;Week 1&lt;/FONT&gt;&lt;/TD&gt;
&lt;TD style="border-width: 0px 0.5pt 0.5pt 0px; border-style: none solid solid none; border-color: black windowtext windowtext black; background-color: transparent;"&gt;&lt;FONT face="Calibri" color="#000000"&gt;81,855&lt;/FONT&gt;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR style="height: 15pt;"&gt;
&lt;TD height="20" style="border-width: 0px 0.5pt 0.5pt; border-style: none solid solid; border-color: black windowtext windowtext; height: 15pt; background-color: transparent;"&gt;&lt;FONT face="Calibri" color="#000000"&gt;Week 2&lt;/FONT&gt;&lt;/TD&gt;
&lt;TD style="border-width: 0px 0.5pt 0.5pt 0px; border-style: none solid solid none; border-color: black windowtext windowtext black; background-color: transparent;"&gt;&lt;FONT face="Calibri" color="#000000"&gt;80,009&lt;/FONT&gt;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR style="height: 15pt;"&gt;
&lt;TD height="20" style="border-width: 0px 0.5pt 0.5pt; border-style: none solid solid; border-color: black windowtext windowtext; height: 15pt; background-color: transparent;"&gt;&lt;FONT face="Calibri" color="#000000"&gt;Week 3&lt;/FONT&gt;&lt;/TD&gt;
&lt;TD style="border-width: 0px 0.5pt 0.5pt 0px; border-style: none solid solid none; border-color: black windowtext windowtext black; background-color: transparent;"&gt;&lt;FONT face="Calibri" color="#000000"&gt;71,972&lt;/FONT&gt;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR style="height: 15pt;"&gt;
&lt;TD height="20" style="border-width: 0px 0.5pt 0.5pt; border-style: none solid solid; border-color: black windowtext windowtext; height: 15pt; background-color: transparent;"&gt;&lt;FONT face="Calibri" color="#000000"&gt;Week 4&lt;/FONT&gt;&lt;/TD&gt;
&lt;TD style="border-width: 0px 0.5pt 0.5pt 0px; border-style: none solid solid none; border-color: black windowtext windowtext black; background-color: transparent;"&gt;&lt;FONT face="Calibri" color="#000000"&gt;68,035&lt;/FONT&gt;&lt;/TD&gt;
&lt;/TR&gt;
&lt;/TBODY&gt;
&lt;/TABLE&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&lt;STRONG&gt;Table 2: (OUTPUT DATASET)&lt;/STRONG&gt;&lt;/P&gt;
&lt;TABLE width="293"&gt;
&lt;TBODY&gt;
&lt;TR&gt;
&lt;TD width="177"&gt;&lt;STRONG&gt;WEEK&lt;/STRONG&gt;&lt;/TD&gt;
&lt;TD width="116"&gt;&lt;STRONG&gt;Units&lt;/STRONG&gt;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;Week 1&lt;/TD&gt;
&lt;TD&gt;81,855&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;Week 2&lt;/TD&gt;
&lt;TD&gt;80,009&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;Week 3&lt;/TD&gt;
&lt;TD&gt;71,972&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;Week 4&lt;/TD&gt;
&lt;TD&gt;68,035&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;Average (Week 2 - Week 4)&lt;/TD&gt;
&lt;TD&gt;73,339&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;Variance&lt;/TD&gt;
&lt;TD&gt;12%&lt;/TD&gt;
&lt;/TR&gt;
&lt;/TBODY&gt;
&lt;/TABLE&gt;</description>
      <pubDate>Sun, 07 Mar 2021 12:31:11 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Calculation-across-rows/m-p/724273#M224854</guid>
      <dc:creator>helloSAS</dc:creator>
      <dc:date>2021-03-07T12:31:11Z</dc:date>
    </item>
    <item>
      <title>Re: Calculation across rows</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Calculation-across-rows/m-p/724275#M224855</link>
      <description>&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data have;
infile cards expandtabs;
input WEEK $	Units : comma12.;
format units comma12.;
cards;
Week1	81,855
Week2	80,009
Week3	71,972
Week4	68,035
;
run;

data want;
 set have end=last;
 lag=lag(units);
 lag2=lag2(units);
 lag3=lag3(units);
 char_units=put(units,comma12. -l);
 output;
if last then do;
 week='Average'; units=mean(lag,lag2,units);char_units=put(units,comma12. -l);output;
 week='Variance';units=(lag3-units)/units;char_units=put(units,percent8.2 -l);output;
end;
run;&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Sun, 07 Mar 2021 12:54:35 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Calculation-across-rows/m-p/724275#M224855</guid>
      <dc:creator>Ksharp</dc:creator>
      <dc:date>2021-03-07T12:54:35Z</dc:date>
    </item>
    <item>
      <title>Re: Calculation across rows</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Calculation-across-rows/m-p/724276#M224856</link>
      <description>&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data have;
input text $ &amp;amp; units :comma6.0;
cards;
Week 1  81,855
Week 2  80,009
Week 3  71,972
Week 4  68,035
;

data want;
    set have end=eof;
    retain row1 average;
    if _n_=1 then row1=units;
    if 2&amp;lt;=_n_&amp;lt;=4 then sum+units;
    if _n_&amp;lt;4 then output;
    else if _n_=4 then do;
        output;
        text='Average';
        units=sum/3;
        average=units;
        output;
        text='Variance';
        units=(row1-average)/row1;
        output;
    end;
    keep text units;
run;&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Sun, 07 Mar 2021 13:05:08 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Calculation-across-rows/m-p/724276#M224856</guid>
      <dc:creator>PaigeMiller</dc:creator>
      <dc:date>2021-03-07T13:05:08Z</dc:date>
    </item>
  </channel>
</rss>

