<?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: retain value until last.id if treshold excedeed in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/retain-value-until-last-id-if-treshold-excedeed/m-p/765537#M242490</link>
    <description>&lt;P&gt;Worked perfectly!!&amp;nbsp;Just made a change and included "by id":&lt;/P&gt;&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data want;
   set have;
   by id;
   retain flag;
   if first.id then do;
      flag=0;
      cumulative_value=0;
   end;
   cumulative_value + value;
   if cumulative_value &amp;lt; -150 then flag=1;
run;&lt;/CODE&gt;&lt;/PRE&gt;&lt;P&gt;thanks&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
    <pubDate>Thu, 02 Sep 2021 03:27:49 GMT</pubDate>
    <dc:creator>goularts</dc:creator>
    <dc:date>2021-09-02T03:27:49Z</dc:date>
    <item>
      <title>retain value until last.id if treshold excedeed</title>
      <link>https://communities.sas.com/t5/SAS-Programming/retain-value-until-last-id-if-treshold-excedeed/m-p/765528#M242483</link>
      <description>&lt;P&gt;I have the following table that cumulate value along the day by id and when the treshold (-150) is exceeded i need a flag and keep it until last.id&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;TABLE border="1"&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;ID&lt;/TD&gt;&lt;TD&gt;value&lt;/TD&gt;&lt;TD&gt;cumulative_value&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;flag&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;1&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;35&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;35&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;35&lt;/TD&gt;&lt;TD&gt;70&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;100&lt;/TD&gt;&lt;TD&gt;170&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;-110&lt;/TD&gt;&lt;TD&gt;60&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;35&lt;/TD&gt;&lt;TD&gt;95&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;2&lt;/TD&gt;&lt;TD&gt;15&lt;/TD&gt;&lt;TD&gt;15&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;2&lt;/TD&gt;&lt;TD&gt;35&lt;/TD&gt;&lt;TD&gt;50&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;2&lt;/TD&gt;&lt;TD&gt;-130&lt;/TD&gt;&lt;TD&gt;-80&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;3&lt;/TD&gt;&lt;TD&gt;40&lt;/TD&gt;&lt;TD&gt;40&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;3&lt;/TD&gt;&lt;TD&gt;-125&lt;/TD&gt;&lt;TD&gt;-85&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;3&lt;/TD&gt;&lt;TD&gt;-90&lt;/TD&gt;&lt;TD&gt;-175&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;3&lt;/TD&gt;&lt;TD&gt;35&lt;/TD&gt;&lt;TD&gt;-140&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;3&lt;/TD&gt;&lt;TD&gt;35&lt;/TD&gt;&lt;TD&gt;-105&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;3&lt;/TD&gt;&lt;TD&gt;35&lt;/TD&gt;&lt;TD&gt;-70&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;I've tried a lot of lag and retains structures but it doesn't work.&lt;/P&gt;</description>
      <pubDate>Thu, 02 Sep 2021 02:16:56 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/retain-value-until-last-id-if-treshold-excedeed/m-p/765528#M242483</guid>
      <dc:creator>goularts</dc:creator>
      <dc:date>2021-09-02T02:16:56Z</dc:date>
    </item>
    <item>
      <title>Re: retain value until last.id if treshold excedeed</title>
      <link>https://communities.sas.com/t5/SAS-Programming/retain-value-until-last-id-if-treshold-excedeed/m-p/765530#M242484</link>
      <description>&lt;P&gt;A straightforward approach could work as follows:&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data want;
   set have;
   by id;
   retain flag;
   if first.id then flag=0;
   if cumulative_value &amp;lt; -150 then flag=1;
run;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;&amp;nbsp;This assumes you know how to get the cumulative value (or perhaps it is already in your data.)&amp;nbsp; If you need to compute it along the way, here's a modification that would do that:&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data want;
   set have;
   retain flag;
   if first.id then do;
      flag=0;
      cumulative_value=0;
   end;
   cumulative_value + value;
   if cumulative_value &amp;lt; -150 then flag=1;
run;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Thu, 02 Sep 2021 02:29:35 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/retain-value-until-last-id-if-treshold-excedeed/m-p/765530#M242484</guid>
      <dc:creator>Astounding</dc:creator>
      <dc:date>2021-09-02T02:29:35Z</dc:date>
    </item>
    <item>
      <title>Re: retain value until last.id if treshold excedeed</title>
      <link>https://communities.sas.com/t5/SAS-Programming/retain-value-until-last-id-if-treshold-excedeed/m-p/765537#M242490</link>
      <description>&lt;P&gt;Worked perfectly!!&amp;nbsp;Just made a change and included "by id":&lt;/P&gt;&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data want;
   set have;
   by id;
   retain flag;
   if first.id then do;
      flag=0;
      cumulative_value=0;
   end;
   cumulative_value + value;
   if cumulative_value &amp;lt; -150 then flag=1;
run;&lt;/CODE&gt;&lt;/PRE&gt;&lt;P&gt;thanks&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Thu, 02 Sep 2021 03:27:49 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/retain-value-until-last-id-if-treshold-excedeed/m-p/765537#M242490</guid>
      <dc:creator>goularts</dc:creator>
      <dc:date>2021-09-02T03:27:49Z</dc:date>
    </item>
  </channel>
</rss>

