<?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 How to use maximum and minimum in further calculation? in SAS Procedures</title>
    <link>https://communities.sas.com/t5/SAS-Procedures/How-to-use-maximum-and-minimum-in-further-calculation/m-p/8576#M391</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt; I'm sure you can.&lt;/P&gt;&lt;P&gt;Have I understood you right: in a table have columns X, Y. For each row, you want to multiply the row value of Y with the table's maximum value of X?&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Y&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; X&lt;/P&gt;&lt;P&gt;10&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 3&lt;/P&gt;&lt;P&gt;12&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 5&lt;/P&gt;&lt;P&gt;8&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 6&lt;/P&gt;&lt;P&gt;10&amp;nbsp;&amp;nbsp; 10&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Will result in&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Y&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; X&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Z&lt;/P&gt;&lt;P&gt;10&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 3&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 100&lt;/P&gt;&lt;P&gt;12&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 5&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 120&lt;/P&gt;&lt;P&gt;8&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 6&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 80&lt;/P&gt;&lt;P&gt;10&amp;nbsp;&amp;nbsp; 10&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 100&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;If this is the case SQL will do it for you in on step.&lt;/P&gt;&lt;P&gt;If you for some reason want to use the value of max(x) for processing in another step, you can store that value in a macro variable (see the into construct in SQL), or have the max(x) calculated in a join or in asub-query.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;proc sql;&lt;/P&gt;&lt;P&gt;select y * max(x) as z&lt;/P&gt;&lt;P&gt;from inputTable;&lt;/P&gt;&lt;P&gt;quit;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Mon, 05 Dec 2011 11:18:15 GMT</pubDate>
    <dc:creator>LinusH</dc:creator>
    <dc:date>2011-12-05T11:18:15Z</dc:date>
    <item>
      <title>How to use maximum and minimum in further calculation?</title>
      <link>https://communities.sas.com/t5/SAS-Procedures/How-to-use-maximum-and-minimum-in-further-calculation/m-p/8575#M390</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;hi everyone,&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I want to know how to use a minimum or maximum value of a variable in further calculations. I am able to find out maximum or minimum values of a variable, say X, using proc univariate or proc sql. now i want to use it for further calculation say, a new variable y =&amp;nbsp; (maximum of x)* observation in variable Z. I can do it putting values of minimum and maximum into the program. but i dont want to copy and paste the values from output to program. Is there any way i can do that?&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Mon, 05 Dec 2011 10:00:44 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Procedures/How-to-use-maximum-and-minimum-in-further-calculation/m-p/8575#M390</guid>
      <dc:creator>M_K</dc:creator>
      <dc:date>2011-12-05T10:00:44Z</dc:date>
    </item>
    <item>
      <title>How to use maximum and minimum in further calculation?</title>
      <link>https://communities.sas.com/t5/SAS-Procedures/How-to-use-maximum-and-minimum-in-further-calculation/m-p/8576#M391</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt; I'm sure you can.&lt;/P&gt;&lt;P&gt;Have I understood you right: in a table have columns X, Y. For each row, you want to multiply the row value of Y with the table's maximum value of X?&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Y&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; X&lt;/P&gt;&lt;P&gt;10&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 3&lt;/P&gt;&lt;P&gt;12&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 5&lt;/P&gt;&lt;P&gt;8&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 6&lt;/P&gt;&lt;P&gt;10&amp;nbsp;&amp;nbsp; 10&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Will result in&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Y&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; X&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Z&lt;/P&gt;&lt;P&gt;10&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 3&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 100&lt;/P&gt;&lt;P&gt;12&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 5&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 120&lt;/P&gt;&lt;P&gt;8&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 6&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 80&lt;/P&gt;&lt;P&gt;10&amp;nbsp;&amp;nbsp; 10&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 100&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;If this is the case SQL will do it for you in on step.&lt;/P&gt;&lt;P&gt;If you for some reason want to use the value of max(x) for processing in another step, you can store that value in a macro variable (see the into construct in SQL), or have the max(x) calculated in a join or in asub-query.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;proc sql;&lt;/P&gt;&lt;P&gt;select y * max(x) as z&lt;/P&gt;&lt;P&gt;from inputTable;&lt;/P&gt;&lt;P&gt;quit;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Mon, 05 Dec 2011 11:18:15 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Procedures/How-to-use-maximum-and-minimum-in-further-calculation/m-p/8576#M391</guid>
      <dc:creator>LinusH</dc:creator>
      <dc:date>2011-12-05T11:18:15Z</dc:date>
    </item>
    <item>
      <title>How to use maximum and minimum in further calculation?</title>
      <link>https://communities.sas.com/t5/SAS-Procedures/How-to-use-maximum-and-minimum-in-further-calculation/m-p/8577#M392</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt; Hi LinusH, I am able to create Z this way, thanks for your help! Can you also tell me how do you save it in data file?&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Mon, 05 Dec 2011 11:37:52 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Procedures/How-to-use-maximum-and-minimum-in-further-calculation/m-p/8577#M392</guid>
      <dc:creator>M_K</dc:creator>
      <dc:date>2011-12-05T11:37:52Z</dc:date>
    </item>
    <item>
      <title>Re: How to use maximum and minimum in further calculation?</title>
      <link>https://communities.sas.com/t5/SAS-Procedures/How-to-use-maximum-and-minimum-in-further-calculation/m-p/8578#M393</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;If you are using PROC SQL you can use the CREATE TABLE clause to create a table (dataset).&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;PRE __default_attr="plain" __jive_macro_name="code" class="jive_text_macro jive_macro_code"&gt;&lt;P&gt;proc sql ;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; create table WANT as&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; select x,y,y*max(x) as z&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; from HAVE&lt;/P&gt;&lt;P&gt;&amp;nbsp; ;&lt;/P&gt;&lt;P&gt;quit;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;/PRE&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;You should also learn how to use SAS Procs to product output tables.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;PRE __default_attr="plain" __jive_macro_name="code" class="jive_text_macro jive_macro_code"&gt;&lt;P&gt;proc summary data=HAVE ;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; var x;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; output out=xmean mean=xmean ;&lt;/P&gt;&lt;P&gt;run;&lt;/P&gt;&lt;/PRE&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;And how to manipulate data using DATA steps.&amp;nbsp; Here is a trick to copy values from a dataset with only one observation onto all observations of another dataset.&amp;nbsp; _N_ is the automatic loop counter for the data step.&amp;nbsp; So the record from the dataset XMEAN will only be read the first time SAS runs through the data step code.&amp;nbsp; Since XMEAN variable is never overwritten again it will stay the same for all iterations of the data step.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;PRE __default_attr="plain" __jive_macro_name="code" class="jive_text_macro jive_macro_code"&gt;&lt;P&gt;data want;&lt;/P&gt;&lt;P&gt;&amp;nbsp; set have ;&lt;/P&gt;&lt;P&gt;&amp;nbsp; if _n_=1 then set xmean;&lt;/P&gt;&lt;P&gt;&amp;nbsp; z=y*xmean;&lt;/P&gt;&lt;P&gt;run;&lt;/P&gt;&lt;/PRE&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Mon, 05 Dec 2011 13:06:47 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Procedures/How-to-use-maximum-and-minimum-in-further-calculation/m-p/8578#M393</guid>
      <dc:creator>Tom</dc:creator>
      <dc:date>2011-12-05T13:06:47Z</dc:date>
    </item>
    <item>
      <title>How to use maximum and minimum in further calculation?</title>
      <link>https://communities.sas.com/t5/SAS-Procedures/How-to-use-maximum-and-minimum-in-further-calculation/m-p/8579#M394</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Thanks for your reply, Tom!&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I did use similar code as you have given - &lt;/P&gt;&lt;P&gt;&lt;STRONG&gt;﻿proc sql;&lt;/STRONG&gt;&lt;/P&gt;&lt;P&gt;&lt;STRONG&gt;﻿﻿&amp;nbsp;&amp;nbsp; create table WANT as&lt;/STRONG&gt;&lt;/P&gt;&lt;P&gt;&lt;STRONG&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; select x, y, y*max(x) as z&lt;/STRONG&gt;&lt;/P&gt;&lt;P&gt;&lt;STRONG&gt;&amp;nbsp;&amp;nbsp; from HAVE;&lt;/STRONG&gt;&lt;/P&gt;&lt;P&gt;&lt;STRONG&gt;quit;&lt;/STRONG&gt;&lt;/P&gt;&lt;P&gt;&lt;STRONG&gt; &lt;/STRONG&gt;&lt;/P&gt;&lt;P&gt;But doing this I am just able to export x, y and z to WANT. But I want to have all of the variables from HAVE and add z to it to get WANT. Can this be done? &lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Mon, 05 Dec 2011 13:18:18 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Procedures/How-to-use-maximum-and-minimum-in-further-calculation/m-p/8579#M394</guid>
      <dc:creator>M_K</dc:creator>
      <dc:date>2011-12-05T13:18:18Z</dc:date>
    </item>
    <item>
      <title>How to use maximum and minimum in further calculation?</title>
      <link>https://communities.sas.com/t5/SAS-Procedures/How-to-use-maximum-and-minimum-in-further-calculation/m-p/8580#M395</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P style="background-color: #eef4f9;"&gt;&lt;STRONG&gt;﻿proc sql;&lt;/STRONG&gt;&lt;/P&gt;&lt;P style="background-color: #eef4f9;"&gt;&lt;STRONG&gt;﻿﻿&amp;nbsp;&amp;nbsp; create table WANT as&lt;/STRONG&gt;&lt;/P&gt;&lt;P style="background-color: #eef4f9;"&gt;&lt;STRONG&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; select *, y*max(x) as z&lt;/STRONG&gt;&lt;/P&gt;&lt;P style="background-color: #eef4f9;"&gt;&lt;STRONG&gt;&amp;nbsp;&amp;nbsp; from HAVE;&lt;/STRONG&gt;&lt;/P&gt;&lt;P style="background-color: #eef4f9;"&gt;&lt;STRONG&gt;quit;&lt;/STRONG&gt;&lt;/P&gt;&lt;P&gt;&lt;STRONG&gt;&lt;BR /&gt;&lt;/STRONG&gt;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Mon, 05 Dec 2011 13:20:33 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Procedures/How-to-use-maximum-and-minimum-in-further-calculation/m-p/8580#M395</guid>
      <dc:creator>art297</dc:creator>
      <dc:date>2011-12-05T13:20:33Z</dc:date>
    </item>
    <item>
      <title>How to use maximum and minimum in further calculation?</title>
      <link>https://communities.sas.com/t5/SAS-Procedures/How-to-use-maximum-and-minimum-in-further-calculation/m-p/8581#M396</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt; Thank you so much Art! Its such a simple code and worked as well! &lt;img id="smileyhappy" class="emoticon emoticon-smileyhappy" src="https://communities.sas.com/i/smilies/16x16_smiley-happy.png" alt="Smiley Happy" title="Smiley Happy" /&gt;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Mon, 05 Dec 2011 13:27:46 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Procedures/How-to-use-maximum-and-minimum-in-further-calculation/m-p/8581#M396</guid>
      <dc:creator>M_K</dc:creator>
      <dc:date>2011-12-05T13:27:46Z</dc:date>
    </item>
  </channel>
</rss>

