<?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: Multiplying Opservations in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/Multiplying-Opservations/m-p/166482#M263812</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;I should note ... this solution might be overkill.&amp;nbsp; It assumes that you have other variables (not shown in your example) that you need to preserve.&amp;nbsp; If the only variables are the ones that you show, you don't need a second DO UNTIL loop.&amp;nbsp; Instead, it could be replaced with:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;* IF/THEN statements to adjust the 8 new variables;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Then reverse the transposition in the same DATA step:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Scenarios = 'Budget';&lt;/P&gt;&lt;P&gt;Measure = 'Sales Volume';&lt;/P&gt;&lt;P&gt;_201101_ = budget_sales_volume;&lt;/P&gt;&lt;P&gt;output;&lt;/P&gt;&lt;P&gt;Measure = 'Sales Value';&lt;/P&gt;&lt;P&gt;_201101_ = budget_sales_value;&lt;/P&gt;&lt;P&gt;output;&lt;/P&gt;&lt;P&gt;Measure = 'Sales Value Variance';&lt;/P&gt;&lt;P&gt;_201101_ = budget_sales_variance;&lt;/P&gt;&lt;P&gt;output;&lt;/P&gt;&lt;P&gt;Measure = 'Price';&lt;/P&gt;&lt;P&gt;_201101_ = budget_sales_price;&lt;/P&gt;&lt;P&gt;output;&lt;/P&gt;&lt;P&gt;Scenarios = 'Actual';&lt;/P&gt;&lt;P&gt;* same idea for the 4 "actual" variables;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Fri, 07 Feb 2014 15:36:11 GMT</pubDate>
    <dc:creator>Astounding</dc:creator>
    <dc:date>2014-02-07T15:36:11Z</dc:date>
    <item>
      <title>Multiplying Opservations</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Multiplying-Opservations/m-p/166478#M263808</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hi everybody,&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;my table looks like:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;TABLE border="0" cellpadding="0" cellspacing="0" style="width: 440px;"&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD class="xl75" height="18" width="62"&gt;Product&lt;/TD&gt;&lt;TD class="xl76" width="79"&gt;Scenarios&lt;/TD&gt;&lt;TD class="xl76" width="151"&gt;Measure&lt;/TD&gt;&lt;TD class="xl76" width="84"&gt;201101&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD class="xl64" height="17"&gt;xxx&lt;/TD&gt;&lt;TD class="xl65"&gt;Budget&lt;/TD&gt;&lt;TD class="xl65"&gt;Sales Volume&lt;/TD&gt;&lt;TD align="right" class="xl65"&gt;110&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD class="xl72" height="17"&gt;xxx&lt;/TD&gt;&lt;TD class="xl73"&gt;Budget&lt;/TD&gt;&lt;TD class="xl73"&gt;Sales Value&lt;/TD&gt;&lt;TD align="right" class="xl73"&gt;???&lt;/TD&gt;&lt;TD class="xl78"&gt;A&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD class="xl67" height="17"&gt;xxx&lt;/TD&gt;&lt;TD class="xl63"&gt;Budget&lt;/TD&gt;&lt;TD class="xl63"&gt;Sales Value Variance&lt;/TD&gt;&lt;TD align="right" class="xl63"&gt;0&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD class="xl69" height="18"&gt;xxx&lt;/TD&gt;&lt;TD class="xl70"&gt;Budget&lt;/TD&gt;&lt;TD class="xl70"&gt;Price&lt;/TD&gt;&lt;TD align="right" class="xl70"&gt;5&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD class="xl64" height="17" style="border-top: none;"&gt;xxx&lt;/TD&gt;&lt;TD class="xl65" style="border-top: none;"&gt;Actual&lt;/TD&gt;&lt;TD class="xl65" style="border-top: none;"&gt;Sales Volume&lt;/TD&gt;&lt;TD align="right" class="xl65" style="border-top: none;"&gt;200&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD class="xl72" height="17"&gt;xxx&lt;/TD&gt;&lt;TD class="xl73"&gt;Actual&lt;/TD&gt;&lt;TD class="xl73"&gt;Sales Value&lt;/TD&gt;&lt;TD align="right" class="xl73"&gt;???&lt;/TD&gt;&lt;TD class="xl78"&gt;B&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD class="xl72" height="17"&gt;xxx&lt;/TD&gt;&lt;TD class="xl73"&gt;Actual&lt;/TD&gt;&lt;TD class="xl73"&gt;Sales Value Variance&lt;/TD&gt;&lt;TD align="right" class="xl73"&gt;???&lt;/TD&gt;&lt;TD class="xl78"&gt;C&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD class="xl69" height="18"&gt;xxx&lt;/TD&gt;&lt;TD class="xl70"&gt;Actual&lt;/TD&gt;&lt;TD class="xl70"&gt;Price&lt;/TD&gt;&lt;TD align="right" class="xl70"&gt;10&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I want to create a simple code that calculates the items A, B and C for each and every product and Scenario where :&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;A:&amp;nbsp; For Product= X and Scenario= Budget ==&amp;gt; Sales Value = Sales Volume*Price&lt;/P&gt;&lt;P&gt;B:&amp;nbsp; For Product= X and Scenario= Actual&amp;nbsp; ==&amp;gt; Sales Value = Sales Volume*Price&lt;/P&gt;&lt;P&gt;C:&amp;nbsp; For Product= X and Scenario= Actual&amp;nbsp; ==&amp;gt; Sales Value Variance (For Actual Scenario) =&amp;nbsp; Sales Value (For Actual Scenario) - Sales Value (For Budget Scenario) &lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;TABLE border="0" cellpadding="0" cellspacing="0" style="width: 440px;"&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD class="xl77" height="18" width="62"&gt;Product&lt;/TD&gt;&lt;TD class="xl78" width="79"&gt;Scenarios&lt;/TD&gt;&lt;TD class="xl78" width="151"&gt;Measure&lt;/TD&gt;&lt;TD class="xl78" width="84"&gt;201101&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD class="xl66" height="17"&gt;xxx&lt;/TD&gt;&lt;TD class="xl67"&gt;Budget&lt;/TD&gt;&lt;TD class="xl67"&gt;Sales Volume&lt;/TD&gt;&lt;TD align="right" class="xl67"&gt;110&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD class="xl74" height="17"&gt;xxx&lt;/TD&gt;&lt;TD class="xl75"&gt;Budget&lt;/TD&gt;&lt;TD class="xl75"&gt;Sales Value&lt;/TD&gt;&lt;TD align="right" class="xl75"&gt;550&lt;/TD&gt;&lt;TD class="xl80"&gt;A&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD class="xl69" height="17"&gt;xxx&lt;/TD&gt;&lt;TD class="xl65"&gt;Budget&lt;/TD&gt;&lt;TD class="xl65"&gt;Sales Value Variance&lt;/TD&gt;&lt;TD align="right" class="xl65"&gt;0&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD class="xl71" height="18"&gt;xxx&lt;/TD&gt;&lt;TD class="xl72"&gt;Budget&lt;/TD&gt;&lt;TD class="xl72"&gt;Price&lt;/TD&gt;&lt;TD align="right" class="xl72"&gt;5&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD class="xl66" height="17" style="border-top: none;"&gt;xxx&lt;/TD&gt;&lt;TD class="xl67" style="border-top: none;"&gt;Actual&lt;/TD&gt;&lt;TD class="xl67" style="border-top: none;"&gt;Sales Volume&lt;/TD&gt;&lt;TD align="right" class="xl67" style="border-top: none;"&gt;200&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD class="xl74" height="17"&gt;xxx&lt;/TD&gt;&lt;TD class="xl75"&gt;Actual&lt;/TD&gt;&lt;TD class="xl75"&gt;Sales Value&lt;/TD&gt;&lt;TD align="right" class="xl75"&gt;2000&lt;/TD&gt;&lt;TD class="xl80"&gt;B&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD class="xl74" height="17"&gt;xxx&lt;/TD&gt;&lt;TD class="xl75"&gt;Actual&lt;/TD&gt;&lt;TD class="xl75"&gt;Sales Value Variance&lt;/TD&gt;&lt;TD align="right" class="xl75"&gt;1450&lt;/TD&gt;&lt;TD class="xl80"&gt;C&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD class="xl71" height="18"&gt;xxx&lt;/TD&gt;&lt;TD class="xl72"&gt;Actual&lt;/TD&gt;&lt;TD class="xl72"&gt;Price&lt;/TD&gt;&lt;TD align="right" class="xl72"&gt;10&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;thank you for your help.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Kind regards.&lt;/P&gt;&lt;P&gt;Toufik&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Fri, 07 Feb 2014 09:22:00 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Multiplying-Opservations/m-p/166478#M263808</guid>
      <dc:creator>SASSAMA</dc:creator>
      <dc:date>2014-02-07T09:22:00Z</dc:date>
    </item>
    <item>
      <title>Re: Multiplying Opservations</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Multiplying-Opservations/m-p/166479#M263809</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Just transpose the dataset and apply formula based on PRODUCT and BUDGET.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Tell me if you can't fix it.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;-Urvish&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Fri, 07 Feb 2014 09:33:19 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Multiplying-Opservations/m-p/166479#M263809</guid>
      <dc:creator>UrvishShah</dc:creator>
      <dc:date>2014-02-07T09:33:19Z</dc:date>
    </item>
    <item>
      <title>Re: Multiplying Opservations</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Multiplying-Opservations/m-p/166480#M263810</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hi Urvish,&lt;/P&gt;&lt;P&gt;I already tried the Transpose solution which consist to:&lt;/P&gt;&lt;P&gt;-Transpose first the column Measure to calculate A and B;&lt;/P&gt;&lt;P&gt;-Then Transpose the column Scenario to calculate C.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;however my aim is to optimize the program by using a simple code (as for Cube queries) because my table contains millions of observations.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;thank you.&lt;/P&gt;&lt;P&gt;Regards.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Fri, 07 Feb 2014 10:22:52 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Multiplying-Opservations/m-p/166480#M263810</guid>
      <dc:creator>SASSAMA</dc:creator>
      <dc:date>2014-02-07T10:22:52Z</dc:date>
    </item>
    <item>
      <title>Re: Multiplying Opservations</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Multiplying-Opservations/m-p/166481#M263811</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Here's another approach.&amp;nbsp; The first half of the DATA step accomplishes the equivalent of transposing the data:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;data want;&lt;/P&gt;&lt;P&gt;&amp;nbsp; do until (last.product);&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; set have;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; by product;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; if scenarios='Budget' then do;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; if measure='Sales Volume' then budget_sales_volume = _201101_;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; else if measure='Sales Value' then budget_sales_value = _201101_;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; else if measure='Sales Value Variance' then budget_sales_variance = _201101_;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; else if measure='Price' then budget_sales_price = _201101_;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; end;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; else if scenarios='Actual' then do;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; * same idea, create 4 new variables;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; end;&lt;/P&gt;&lt;P&gt;&amp;nbsp; end;&lt;/P&gt;&lt;P&gt;&amp;nbsp; drop /* all 8 newly created variables */ ;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Then the second half of the DATA step can make all the necessary calculations.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; do until (last.product);&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; set have;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; by product;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; * whatever IF/THEN statements you need to adjust the values;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; output;&lt;/P&gt;&lt;P&gt;&amp;nbsp; end;&lt;/P&gt;&lt;P&gt;run;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Good luck.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Fri, 07 Feb 2014 15:02:15 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Multiplying-Opservations/m-p/166481#M263811</guid>
      <dc:creator>Astounding</dc:creator>
      <dc:date>2014-02-07T15:02:15Z</dc:date>
    </item>
    <item>
      <title>Re: Multiplying Opservations</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Multiplying-Opservations/m-p/166482#M263812</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;I should note ... this solution might be overkill.&amp;nbsp; It assumes that you have other variables (not shown in your example) that you need to preserve.&amp;nbsp; If the only variables are the ones that you show, you don't need a second DO UNTIL loop.&amp;nbsp; Instead, it could be replaced with:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;* IF/THEN statements to adjust the 8 new variables;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Then reverse the transposition in the same DATA step:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Scenarios = 'Budget';&lt;/P&gt;&lt;P&gt;Measure = 'Sales Volume';&lt;/P&gt;&lt;P&gt;_201101_ = budget_sales_volume;&lt;/P&gt;&lt;P&gt;output;&lt;/P&gt;&lt;P&gt;Measure = 'Sales Value';&lt;/P&gt;&lt;P&gt;_201101_ = budget_sales_value;&lt;/P&gt;&lt;P&gt;output;&lt;/P&gt;&lt;P&gt;Measure = 'Sales Value Variance';&lt;/P&gt;&lt;P&gt;_201101_ = budget_sales_variance;&lt;/P&gt;&lt;P&gt;output;&lt;/P&gt;&lt;P&gt;Measure = 'Price';&lt;/P&gt;&lt;P&gt;_201101_ = budget_sales_price;&lt;/P&gt;&lt;P&gt;output;&lt;/P&gt;&lt;P&gt;Scenarios = 'Actual';&lt;/P&gt;&lt;P&gt;* same idea for the 4 "actual" variables;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Fri, 07 Feb 2014 15:36:11 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Multiplying-Opservations/m-p/166482#M263812</guid>
      <dc:creator>Astounding</dc:creator>
      <dc:date>2014-02-07T15:36:11Z</dc:date>
    </item>
    <item>
      <title>Re: Multiplying Opservations</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Multiplying-Opservations/m-p/166483#M263813</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hi Astouding,&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;thanks a lot for your help, you idea is very good but unfortunately my table contain monthly data for 8 years (201101-201801), which makes the code too long,&lt;/P&gt;&lt;P&gt;I have found a simpler method: &lt;/P&gt;&lt;P&gt;create a Key=Scenario||Measure (concatenate), then I dropped the scenario variable and performed a transpose to have the measures in coulmns and applied my formulas.&lt;/P&gt;&lt;P&gt;I transposed back my data.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;thank you very much for your help.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Kind regards.&lt;/P&gt;&lt;P&gt;Toufik&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Sat, 08 Feb 2014 09:10:20 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Multiplying-Opservations/m-p/166483#M263813</guid>
      <dc:creator>SASSAMA</dc:creator>
      <dc:date>2014-02-08T09:10:20Z</dc:date>
    </item>
  </channel>
</rss>

