<?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: using fist.id for generating baseline value in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/using-fist-id-for-generating-baseline-value/m-p/509341#M136921</link>
    <description>&lt;P&gt;Yes, your DO loop is endless.&amp;nbsp; Nothing inside the loop reads in any observations, so you can never get to the last.hpbpid observation.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;The solution is simple.&amp;nbsp; Get rid of the DO loop and everything related to it.&amp;nbsp; The last statement in the DATA step should be:&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE class=" language-sas"&gt;&lt;CODE class="  language-sas"&gt;&lt;SPAN class="token keyword"&gt;if&lt;/SPAN&gt; &lt;SPAN class="token function"&gt;first&lt;/SPAN&gt;&lt;SPAN class="token punctuation"&gt;.&lt;/SPAN&gt;hpbpid &lt;SPAN class="token keyword"&gt;then&lt;/SPAN&gt; baseline_value  &lt;SPAN class="token operator"&gt;=&lt;/SPAN&gt; glucose&lt;SPAN class="token punctuation"&gt;;&lt;/SPAN&gt;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;(Don't remove the RUN statement, however.)&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
    <pubDate>Wed, 31 Oct 2018 21:10:51 GMT</pubDate>
    <dc:creator>Astounding</dc:creator>
    <dc:date>2018-10-31T21:10:51Z</dc:date>
    <item>
      <title>using fist.id for generating baseline value</title>
      <link>https://communities.sas.com/t5/SAS-Programming/using-fist-id-for-generating-baseline-value/m-p/509334#M136918</link>
      <description>&lt;PRE&gt;&amp;nbsp;&lt;/PRE&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Hi Friends,&lt;/P&gt;&lt;P&gt;I have been trying to find the baseline value (say glucose) within one ID (hpbpid) using retain, by, etc. I am using SAS studio. The program just kept running without producing an output. I am wondering if there is endless loop in the code as below.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;I have searched the sas communities, google, etc. I know there&amp;nbsp;are many other&amp;nbsp;ways to get the baseline value such as pro sql. I just want to know why my method does not work.&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Thank you.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;TABLE cellspacing="0" cellpadding="0"&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;&lt;P class="p1"&gt;&lt;SPAN class="s1"&gt;&lt;STRONG&gt;Obs&lt;/STRONG&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P class="p1"&gt;&lt;SPAN class="s1"&gt;&lt;STRONG&gt;hpbpid&lt;/STRONG&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P class="p1"&gt;&lt;SPAN class="s1"&gt;&lt;STRONG&gt;date&lt;/STRONG&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P class="p1"&gt;&lt;SPAN class="s1"&gt;&lt;STRONG&gt;glucose&lt;/STRONG&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P class="p1"&gt;&lt;SPAN class="s1"&gt;&lt;STRONG&gt;1&lt;/STRONG&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P class="p1"&gt;&lt;SPAN class="s1"&gt;19270818FM-B&lt;/SPAN&gt;&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P class="p1"&gt;&lt;SPAN class="s1"&gt;16MAR2009&lt;/SPAN&gt;&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P class="p1"&gt;&lt;SPAN class="s1"&gt;5&lt;/SPAN&gt;&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P class="p1"&gt;&lt;SPAN class="s1"&gt;&lt;STRONG&gt;2&lt;/STRONG&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P class="p1"&gt;&lt;SPAN class="s1"&gt;19270818FM-B&lt;/SPAN&gt;&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P class="p1"&gt;&lt;SPAN class="s1"&gt;18JAN2011&lt;/SPAN&gt;&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P class="p1"&gt;&lt;SPAN class="s1"&gt;5&lt;/SPAN&gt;&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P class="p1"&gt;&lt;SPAN class="s1"&gt;&lt;STRONG&gt;3&lt;/STRONG&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P class="p1"&gt;&lt;SPAN class="s1"&gt;19390310FMGL&lt;/SPAN&gt;&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P class="p1"&gt;&lt;SPAN class="s1"&gt;07APR2008&lt;/SPAN&gt;&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P class="p1"&gt;&lt;SPAN class="s1"&gt;5&lt;/SPAN&gt;&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P class="p1"&gt;&lt;SPAN class="s1"&gt;&lt;STRONG&gt;4&lt;/STRONG&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P class="p1"&gt;&lt;SPAN class="s1"&gt;19390310FMGL&lt;/SPAN&gt;&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P class="p1"&gt;&lt;SPAN class="s1"&gt;24NOV2008&lt;/SPAN&gt;&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P class="p1"&gt;&lt;SPAN class="s1"&gt;5&lt;/SPAN&gt;&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P class="p1"&gt;&lt;SPAN class="s1"&gt;&lt;STRONG&gt;5&lt;/STRONG&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P class="p1"&gt;&lt;SPAN class="s1"&gt;19390310FMGL&lt;/SPAN&gt;&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P class="p1"&gt;&lt;SPAN class="s1"&gt;11MAR2009&lt;/SPAN&gt;&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P class="p1"&gt;&lt;SPAN class="s1"&gt;6&lt;/SPAN&gt;&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P class="p1"&gt;&lt;SPAN class="s1"&gt;&lt;STRONG&gt;6&lt;/STRONG&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P class="p1"&gt;&lt;SPAN class="s1"&gt;19390325FCLB&lt;/SPAN&gt;&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P class="p1"&gt;&lt;SPAN class="s1"&gt;01MAY2008&lt;/SPAN&gt;&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P class="p1"&gt;&lt;SPAN class="s1"&gt;5&lt;/SPAN&gt;&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P class="p1"&gt;&lt;SPAN class="s1"&gt;&lt;STRONG&gt;7&lt;/STRONG&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P class="p1"&gt;&lt;SPAN class="s1"&gt;19390325FCLB&lt;/SPAN&gt;&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P class="p1"&gt;&lt;SPAN class="s1"&gt;17MAR2009&lt;/SPAN&gt;&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P class="p1"&gt;&lt;SPAN class="s1"&gt;5&lt;/SPAN&gt;&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P class="p1"&gt;&lt;SPAN class="s1"&gt;&lt;STRONG&gt;8&lt;/STRONG&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P class="p1"&gt;&lt;SPAN class="s1"&gt;19390507MJEM&lt;/SPAN&gt;&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P class="p1"&gt;&lt;SPAN class="s1"&gt;14MAY2008&lt;/SPAN&gt;&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P class="p1"&gt;&lt;SPAN class="s1"&gt;5&lt;/SPAN&gt;&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P class="p1"&gt;&lt;SPAN class="s1"&gt;&lt;STRONG&gt;9&lt;/STRONG&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P class="p1"&gt;&lt;SPAN class="s1"&gt;19390507MJEM&lt;/SPAN&gt;&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P class="p1"&gt;&lt;SPAN class="s1"&gt;22SEP2008&lt;/SPAN&gt;&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P class="p1"&gt;&lt;SPAN class="s1"&gt;0&lt;/SPAN&gt;&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P class="p1"&gt;&lt;SPAN class="s1"&gt;&lt;STRONG&gt;10&lt;/STRONG&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P class="p1"&gt;&lt;SPAN class="s1"&gt;19391013ME-D&lt;/SPAN&gt;&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P class="p1"&gt;&lt;SPAN class="s1"&gt;11MAR2008&lt;/SPAN&gt;&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P class="p1"&gt;&lt;SPAN class="s1"&gt;5&lt;/SPAN&gt;&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;proc sort data = hpbp.lab_bio_demo;
by hpbpid date;
run;


data visit;
set hpbp.lab_bio_demo;
by hpbpid;
retain baseline_value;
if first.hpbpid then baseline_value  = glucose;
do until (last.hpbpid = 1);
baseline_value +0;
end;
run;

&lt;/CODE&gt;&lt;/PRE&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Wed, 31 Oct 2018 21:06:29 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/using-fist-id-for-generating-baseline-value/m-p/509334#M136918</guid>
      <dc:creator>superbibi</dc:creator>
      <dc:date>2018-10-31T21:06:29Z</dc:date>
    </item>
    <item>
      <title>Re: using fist.id for generating baseline value</title>
      <link>https://communities.sas.com/t5/SAS-Programming/using-fist-id-for-generating-baseline-value/m-p/509336#M136919</link>
      <description>&lt;P&gt;what is your expected/wanted output for the sample? plz&lt;/P&gt;</description>
      <pubDate>Wed, 31 Oct 2018 21:07:04 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/using-fist-id-for-generating-baseline-value/m-p/509336#M136919</guid>
      <dc:creator>novinosrin</dc:creator>
      <dc:date>2018-10-31T21:07:04Z</dc:date>
    </item>
    <item>
      <title>Re: using fist.id for generating baseline value</title>
      <link>https://communities.sas.com/t5/SAS-Programming/using-fist-id-for-generating-baseline-value/m-p/509341#M136921</link>
      <description>&lt;P&gt;Yes, your DO loop is endless.&amp;nbsp; Nothing inside the loop reads in any observations, so you can never get to the last.hpbpid observation.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;The solution is simple.&amp;nbsp; Get rid of the DO loop and everything related to it.&amp;nbsp; The last statement in the DATA step should be:&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE class=" language-sas"&gt;&lt;CODE class="  language-sas"&gt;&lt;SPAN class="token keyword"&gt;if&lt;/SPAN&gt; &lt;SPAN class="token function"&gt;first&lt;/SPAN&gt;&lt;SPAN class="token punctuation"&gt;.&lt;/SPAN&gt;hpbpid &lt;SPAN class="token keyword"&gt;then&lt;/SPAN&gt; baseline_value  &lt;SPAN class="token operator"&gt;=&lt;/SPAN&gt; glucose&lt;SPAN class="token punctuation"&gt;;&lt;/SPAN&gt;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;(Don't remove the RUN statement, however.)&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Wed, 31 Oct 2018 21:10:51 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/using-fist-id-for-generating-baseline-value/m-p/509341#M136921</guid>
      <dc:creator>Astounding</dc:creator>
      <dc:date>2018-10-31T21:10:51Z</dc:date>
    </item>
    <item>
      <title>Re: using fist.id for generating baseline value</title>
      <link>https://communities.sas.com/t5/SAS-Programming/using-fist-id-for-generating-baseline-value/m-p/509401#M136949</link>
      <description>&lt;P&gt;Hi Astounding,&amp;nbsp;&lt;/P&gt;&lt;P&gt;The code works great! Thank you so so much!&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;May I ask one more question regarding the do loop? If I want to generate a count column from 1 to the number of the last.id using the do loop, how should I&amp;nbsp;modify&amp;nbsp;the do loop code? For example, in the example dateset, there are two duplicates in the first ID, then the count&amp;nbsp;should be 1 and 2. Thank you.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Thu, 01 Nov 2018 02:57:35 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/using-fist-id-for-generating-baseline-value/m-p/509401#M136949</guid>
      <dc:creator>superbibi</dc:creator>
      <dc:date>2018-11-01T02:57:35Z</dc:date>
    </item>
    <item>
      <title>Re: using fist.id for generating baseline value</title>
      <link>https://communities.sas.com/t5/SAS-Programming/using-fist-id-for-generating-baseline-value/m-p/509403#M136950</link>
      <description>&lt;P&gt;One way to handle that:&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;if first.hpbpid then do;
   baseline_value = glucose;
   count = 1;
end;
else count + 1;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Thu, 01 Nov 2018 03:09:03 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/using-fist-id-for-generating-baseline-value/m-p/509403#M136950</guid>
      <dc:creator>Astounding</dc:creator>
      <dc:date>2018-11-01T03:09:03Z</dc:date>
    </item>
    <item>
      <title>Re: using fist.id for generating baseline value</title>
      <link>https://communities.sas.com/t5/SAS-Programming/using-fist-id-for-generating-baseline-value/m-p/509404#M136951</link>
      <description>&lt;P&gt;Excellent! Thank you very much!&lt;/P&gt;</description>
      <pubDate>Thu, 01 Nov 2018 03:11:35 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/using-fist-id-for-generating-baseline-value/m-p/509404#M136951</guid>
      <dc:creator>superbibi</dc:creator>
      <dc:date>2018-11-01T03:11:35Z</dc:date>
    </item>
  </channel>
</rss>

