<?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 conditionally back-cast based on a counter? in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/How-to-conditionally-back-cast-based-on-a-counter/m-p/888708#M351102</link>
    <description>&lt;P&gt;I have a dataset(example below), with fields Scenarios, Date, Counter, Value and I need to create New Value. For each scenario, New Value takes value from latest counter(first counter from a continuous series) -&lt;/P&gt;&lt;TABLE border="0" cellspacing="0" cellpadding="0"&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;Scenarios&lt;/TD&gt;&lt;TD&gt;Date&lt;/TD&gt;&lt;TD&gt;Counter&lt;/TD&gt;&lt;TD&gt;Value&lt;/TD&gt;&lt;TD&gt;New Value&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;Scn1&lt;/TD&gt;&lt;TD&gt;Jan-22&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;189&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;Scn1&lt;/TD&gt;&lt;TD&gt;Feb-22&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;189&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;Scn1&lt;/TD&gt;&lt;TD&gt;Mar-22&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;189&lt;/TD&gt;&lt;TD&gt;189&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;Scn1&lt;/TD&gt;&lt;TD&gt;Apr-22&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;189&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;Scn1&lt;/TD&gt;&lt;TD&gt;May-22&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;189&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;Scn1&lt;/TD&gt;&lt;TD&gt;Jun-22&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;Scn2&lt;/TD&gt;&lt;TD&gt;Jan-22&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;167&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;Scn2&lt;/TD&gt;&lt;TD&gt;Feb-22&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;167&lt;/TD&gt;&lt;TD&gt;167&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;Scn2&lt;/TD&gt;&lt;TD&gt;Mar-22&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;167&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;Scn2&lt;/TD&gt;&lt;TD&gt;Apr-22&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;256&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;Scn2&lt;/TD&gt;&lt;TD&gt;May-22&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;256&lt;/TD&gt;&lt;TD&gt;256&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;Scn2&lt;/TD&gt;&lt;TD&gt;Jun-22&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;Scn3&lt;/TD&gt;&lt;TD&gt;Jan-22&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;23&lt;/TD&gt;&lt;TD&gt;23&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;Scn3&lt;/TD&gt;&lt;TD&gt;Feb-22&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;23&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;Scn3&lt;/TD&gt;&lt;TD&gt;Mar-22&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;23&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;Scn3&lt;/TD&gt;&lt;TD&gt;Apr-22&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;304&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;Scn3&lt;/TD&gt;&lt;TD&gt;May-22&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;304&lt;/TD&gt;&lt;TD&gt;304&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;Scn3&lt;/TD&gt;&lt;TD&gt;Jun-22&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;304&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;I am not sure how to achieve this conditional back-casting. May I request any help on this?&amp;nbsp;&lt;/P&gt;</description>
    <pubDate>Thu, 10 Aug 2023 02:55:34 GMT</pubDate>
    <dc:creator>thepushkarsingh</dc:creator>
    <dc:date>2023-08-10T02:55:34Z</dc:date>
    <item>
      <title>How to conditionally back-cast based on a counter?</title>
      <link>https://communities.sas.com/t5/SAS-Programming/How-to-conditionally-back-cast-based-on-a-counter/m-p/888708#M351102</link>
      <description>&lt;P&gt;I have a dataset(example below), with fields Scenarios, Date, Counter, Value and I need to create New Value. For each scenario, New Value takes value from latest counter(first counter from a continuous series) -&lt;/P&gt;&lt;TABLE border="0" cellspacing="0" cellpadding="0"&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;Scenarios&lt;/TD&gt;&lt;TD&gt;Date&lt;/TD&gt;&lt;TD&gt;Counter&lt;/TD&gt;&lt;TD&gt;Value&lt;/TD&gt;&lt;TD&gt;New Value&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;Scn1&lt;/TD&gt;&lt;TD&gt;Jan-22&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;189&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;Scn1&lt;/TD&gt;&lt;TD&gt;Feb-22&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;189&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;Scn1&lt;/TD&gt;&lt;TD&gt;Mar-22&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;189&lt;/TD&gt;&lt;TD&gt;189&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;Scn1&lt;/TD&gt;&lt;TD&gt;Apr-22&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;189&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;Scn1&lt;/TD&gt;&lt;TD&gt;May-22&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;189&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;Scn1&lt;/TD&gt;&lt;TD&gt;Jun-22&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;Scn2&lt;/TD&gt;&lt;TD&gt;Jan-22&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;167&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;Scn2&lt;/TD&gt;&lt;TD&gt;Feb-22&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;167&lt;/TD&gt;&lt;TD&gt;167&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;Scn2&lt;/TD&gt;&lt;TD&gt;Mar-22&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;167&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;Scn2&lt;/TD&gt;&lt;TD&gt;Apr-22&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;256&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;Scn2&lt;/TD&gt;&lt;TD&gt;May-22&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;256&lt;/TD&gt;&lt;TD&gt;256&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;Scn2&lt;/TD&gt;&lt;TD&gt;Jun-22&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;Scn3&lt;/TD&gt;&lt;TD&gt;Jan-22&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;23&lt;/TD&gt;&lt;TD&gt;23&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;Scn3&lt;/TD&gt;&lt;TD&gt;Feb-22&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;23&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;Scn3&lt;/TD&gt;&lt;TD&gt;Mar-22&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;23&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;Scn3&lt;/TD&gt;&lt;TD&gt;Apr-22&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;304&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;Scn3&lt;/TD&gt;&lt;TD&gt;May-22&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;304&lt;/TD&gt;&lt;TD&gt;304&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;Scn3&lt;/TD&gt;&lt;TD&gt;Jun-22&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;304&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;I am not sure how to achieve this conditional back-casting. May I request any help on this?&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Thu, 10 Aug 2023 02:55:34 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/How-to-conditionally-back-cast-based-on-a-counter/m-p/888708#M351102</guid>
      <dc:creator>thepushkarsingh</dc:creator>
      <dc:date>2023-08-10T02:55:34Z</dc:date>
    </item>
    <item>
      <title>Re: How to conditionally back-cast based on a counter?</title>
      <link>https://communities.sas.com/t5/SAS-Programming/How-to-conditionally-back-cast-based-on-a-counter/m-p/888709#M351103</link>
      <description>&lt;P&gt;Clarify how you are defining the groups?&lt;/P&gt;
&lt;P&gt;Looks like you want to increment the grouping when counter becomes zero.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;First let's convert your listing into actual data. Lets use a SINGULAR name for that first variable to make the code clearer.&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data have;
  input Scenario $ Date :monyy. Counter Value Expected;
  format date monyy7. ;
cards;
Scn1 Jan-22 0  . 189
Scn1 Feb-22 0  . 189
Scn1 Mar-22 1 189 189
Scn1 Apr-22 1  . 189
Scn1 May-22 1  . 189
Scn1 Jun-22 0  . 0
Scn2 Jan-22 0  . 167
Scn2 Feb-22 1 167 167
Scn2 Mar-22 1  . 167
Scn2 Apr-22 0  . 256
Scn2 May-22 1 256 256
Scn2 Jun-22 0  . 0
Scn3 Jan-22 1 23 23
Scn3 Feb-22 1  . 23
Scn3 Mar-22 1  . 23
Scn3 Apr-22 0  . 304
Scn3 May-22 1 304 304
Scn3 Jun-22 1  . 304
;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;So the data is actually sorted by SCENARIO and DATE, but we can use the NOTSORTED keyword on the BY statement to have SAS calculated FIRST. and LAST. flags for COUNTER within SCENARIO.&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data want;
  set have;
  by scenario counter notsorted;
  if first.scenario then group=1;
  else if first.counter and counter=0 then group+1;
run;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;Now we can see that your expected new variable aligns with this new grouping variable.&lt;/P&gt;
&lt;PRE&gt;Obs    Scenario       Date    Counter    Value    Expected    group

  1      Scn1      JAN2022       0          .        189        1
  2      Scn1      FEB2022       0          .        189        1
  3      Scn1      MAR2022       1        189        189        1
  4      Scn1      APR2022       1          .        189        1
  5      Scn1      MAY2022       1          .        189        1
  6      Scn1      JUN2022       0          .          0        2
  7      Scn2      JAN2022       0          .        167        1
  8      Scn2      FEB2022       1        167        167        1
  9      Scn2      MAR2022       1          .        167        1
 10      Scn2      APR2022       0          .        256        2
 11      Scn2      MAY2022       1        256        256        2
 12      Scn2      JUN2022       0          .          0        3
 13      Scn3      JAN2022       1         23         23        1
 14      Scn3      FEB2022       1          .         23        1
 15      Scn3      MAR2022       1          .         23        1
 16      Scn3      APR2022       0          .        304        2
 17      Scn3      MAY2022       1        304        304        2
 18      Scn3      JUN2022       1          .        304        2
&lt;/PRE&gt;
&lt;P&gt;So we could use a double DOW loop to find the first non-missing value per GROUP and attach it to each observation in the GROUP.&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data want;
  do until(last.group);
    set want;
    by scenario group;
    new_value=coalesce(new_value,value);
  end;
  new_value=coalesce(new_value,0);
  do until(last.group);
    set want;
    by scenario group;
    output;
  end;
run;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;Result&lt;/P&gt;
&lt;PRE&gt;                                                                        new_
Obs    Scenario       Date    Counter    Value    Expected    group    value

  1      Scn1      JAN2022       0          .        189        1       189
  2      Scn1      FEB2022       0          .        189        1       189
  3      Scn1      MAR2022       1        189        189        1       189
  4      Scn1      APR2022       1          .        189        1       189
  5      Scn1      MAY2022       1          .        189        1       189
  6      Scn1      JUN2022       0          .          0        2         0
  7      Scn2      JAN2022       0          .        167        1       167
  8      Scn2      FEB2022       1        167        167        1       167
  9      Scn2      MAR2022       1          .        167        1       167
 10      Scn2      APR2022       0          .        256        2       256
 11      Scn2      MAY2022       1        256        256        2       256
 12      Scn2      JUN2022       0          .          0        3         0
 13      Scn3      JAN2022       1         23         23        1        23
 14      Scn3      FEB2022       1          .         23        1        23
 15      Scn3      MAR2022       1          .         23        1        23
 16      Scn3      APR2022       0          .        304        2       304
 17      Scn3      MAY2022       1        304        304        2       304
 18      Scn3      JUN2022       1          .        304        2       304

&lt;/PRE&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Thu, 10 Aug 2023 03:16:17 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/How-to-conditionally-back-cast-based-on-a-counter/m-p/888709#M351103</guid>
      <dc:creator>Tom</dc:creator>
      <dc:date>2023-08-10T03:16:17Z</dc:date>
    </item>
    <item>
      <title>Re: How to conditionally back-cast based on a counter?</title>
      <link>https://communities.sas.com/t5/SAS-Programming/How-to-conditionally-back-cast-based-on-a-counter/m-p/888710#M351104</link>
      <description>&lt;P&gt;Too many things to learn, in one single solution! Many thanks Tom.&lt;/P&gt;</description>
      <pubDate>Thu, 10 Aug 2023 03:22:44 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/How-to-conditionally-back-cast-based-on-a-counter/m-p/888710#M351104</guid>
      <dc:creator>thepushkarsingh</dc:creator>
      <dc:date>2023-08-10T03:22:44Z</dc:date>
    </item>
    <item>
      <title>Re: How to conditionally back-cast based on a counter?</title>
      <link>https://communities.sas.com/t5/SAS-Programming/How-to-conditionally-back-cast-based-on-a-counter/m-p/888712#M351106</link>
      <description>May I ask one follow up please? What if Value isn't missing in other cases, is there a neater way to pick only the relevant "Value"s in to New Value?</description>
      <pubDate>Thu, 10 Aug 2023 04:22:49 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/How-to-conditionally-back-cast-based-on-a-counter/m-p/888712#M351106</guid>
      <dc:creator>thepushkarsingh</dc:creator>
      <dc:date>2023-08-10T04:22:49Z</dc:date>
    </item>
    <item>
      <title>Re: How to conditionally back-cast based on a counter?</title>
      <link>https://communities.sas.com/t5/SAS-Programming/How-to-conditionally-back-cast-based-on-a-counter/m-p/888787#M351113</link>
      <description>&lt;BLOCKQUOTE&gt;&lt;HR /&gt;&lt;a href="https://communities.sas.com/t5/user/viewprofilepage/user-id/194934"&gt;@thepushkarsingh&lt;/a&gt;&amp;nbsp;wrote:&lt;BR /&gt;May I ask one follow up please? What if Value isn't missing in other cases, is there a neater way to pick only the relevant "Value"s in to New Value?&lt;HR /&gt;&lt;/BLOCKQUOTE&gt;
&lt;P&gt;Sure. But you have to have a rule.&lt;/P&gt;
&lt;P&gt;Is it the MIN value? The MAX value?&lt;/P&gt;
&lt;P&gt;The value where "counter" variable first becomes 1?&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;All of those a easy.&lt;/P&gt;</description>
      <pubDate>Thu, 10 Aug 2023 12:30:17 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/How-to-conditionally-back-cast-based-on-a-counter/m-p/888787#M351113</guid>
      <dc:creator>Tom</dc:creator>
      <dc:date>2023-08-10T12:30:17Z</dc:date>
    </item>
    <item>
      <title>Re: How to conditionally back-cast based on a counter?</title>
      <link>https://communities.sas.com/t5/SAS-Programming/How-to-conditionally-back-cast-based-on-a-counter/m-p/888788#M351114</link>
      <description>The value where counter becomes 1 at first in the series of 1s.</description>
      <pubDate>Thu, 10 Aug 2023 12:33:33 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/How-to-conditionally-back-cast-based-on-a-counter/m-p/888788#M351114</guid>
      <dc:creator>thepushkarsingh</dc:creator>
      <dc:date>2023-08-10T12:33:33Z</dc:date>
    </item>
    <item>
      <title>Re: How to conditionally back-cast based on a counter?</title>
      <link>https://communities.sas.com/t5/SAS-Programming/How-to-conditionally-back-cast-based-on-a-counter/m-p/888791#M351115</link>
      <description>&lt;P&gt;So use the same NOTSORTED trick.&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data want;
  do until(last.group);
    set want;
    by scenario group counter notsorted;
    if first.counter and counter=1 then new_value=value;
  end;
  new_value=coalesce(new_value,0);
  do until(last.group);
    set want;
    by scenario group;
    output;
  end;
run;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;You might be able to do it all in one step without adding the GROUP number.&lt;/P&gt;</description>
      <pubDate>Thu, 10 Aug 2023 13:07:27 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/How-to-conditionally-back-cast-based-on-a-counter/m-p/888791#M351115</guid>
      <dc:creator>Tom</dc:creator>
      <dc:date>2023-08-10T13:07:27Z</dc:date>
    </item>
    <item>
      <title>Re: How to conditionally back-cast based on a counter?</title>
      <link>https://communities.sas.com/t5/SAS-Programming/How-to-conditionally-back-cast-based-on-a-counter/m-p/888792#M351116</link>
      <description>Thank you so much! You're a genius!</description>
      <pubDate>Thu, 10 Aug 2023 13:09:20 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/How-to-conditionally-back-cast-based-on-a-counter/m-p/888792#M351116</guid>
      <dc:creator>thepushkarsingh</dc:creator>
      <dc:date>2023-08-10T13:09:20Z</dc:date>
    </item>
  </channel>
</rss>

