<?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 CODE EXPLANATION PLEASE in Statistical Procedures</title>
    <link>https://communities.sas.com/t5/Statistical-Procedures/CODE-EXPLANATION-PLEASE/m-p/77120#M3661</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Could you please explain the codes &lt;STRONG&gt; Interlace stacking&lt;/STRONG&gt; and the classic &lt;STRONG&gt;2X DOW&lt;/STRONG&gt;&lt;/P&gt;&lt;P&gt;How did they get the names?&lt;/P&gt;&lt;P&gt;Whats the benifit of setting the same dataset twice?&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;eg:&lt;/P&gt;&lt;P&gt;data want;&lt;/P&gt;&lt;P&gt;set have have; etc etc&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;THANKS IN ADVANCE&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;*QUESTION;&lt;BR /&gt;*HOW TO SEPERATE SUBJECTS WITH MULTIPLE OCCURANCES THAT SATISFY A CERTAIN CONDITION?????;&lt;BR /&gt;*I NEED TO SEPERATE THE RECORDS WHERE ARRERS_BAND(VARIABLE NAME) ATLEAST ONCE HAD "WRITOFF" VALUE;&lt;/P&gt;&lt;P&gt;data have;&lt;/P&gt;&lt;P&gt;informat Current_date date9.;&lt;/P&gt;&lt;P&gt;Input Current_date&amp;nbsp;&amp;nbsp; Account_number Arrears_Band :$15.;&lt;/P&gt;&lt;P&gt;Format Current_date date9.;&lt;/P&gt;&lt;P&gt;cards;&lt;/P&gt;&lt;P&gt;31MAY2011&amp;nbsp; 111&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;30JUN2011&amp;nbsp; 111&amp;nbsp; writoff&lt;/P&gt;&lt;P&gt;31JUL2011&amp;nbsp; 111&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;31AUG2011&amp;nbsp; 111&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;30SEP2011&amp;nbsp; 111&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;31OCT2011&amp;nbsp; 111&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;30NOV2011&amp;nbsp; 111&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;31DEC2011&amp;nbsp; 111&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;31JAN2012&amp;nbsp; 111&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;31DEC2011&amp;nbsp; 222&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;31JAN2012&amp;nbsp; 222&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;30NOV2010&amp;nbsp; 333&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;31DEC2010&amp;nbsp; 333&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;31JAN2011&amp;nbsp; 333&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;28FEB2011&amp;nbsp; 333&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;31MAR2011&amp;nbsp; 333&amp;nbsp; writoff&lt;/P&gt;&lt;P&gt;30APR2011&amp;nbsp; 333&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;31MAY2011&amp;nbsp; 333&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;30JUN2011&amp;nbsp; 333&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;31JUL2011&amp;nbsp; 333&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;31AUG2011&amp;nbsp; 333&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;30SEP2011&amp;nbsp; 333&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;31OCT2011&amp;nbsp; 333&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;30NOV2011&amp;nbsp; 333&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;31DEC2011&amp;nbsp; 333&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;31JAN2012&amp;nbsp; 333&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;28FEB2010&amp;nbsp; 444&amp;nbsp; Current&lt;/P&gt;&lt;P&gt;31MAR2010&amp;nbsp; 444&amp;nbsp; 30 - 60&lt;/P&gt;&lt;P&gt;30APR2010&amp;nbsp; 444&amp;nbsp; 30 - 60&lt;/P&gt;&lt;P&gt;31MAY2010&amp;nbsp; 444&amp;nbsp; Current&lt;/P&gt;&lt;P&gt;30JUN2010&amp;nbsp; 444&amp;nbsp; Current&lt;/P&gt;&lt;P&gt;31JUL2010&amp;nbsp; 444&amp;nbsp; Current&lt;/P&gt;&lt;P&gt;31AUG2010&amp;nbsp; 444&amp;nbsp; Current&lt;/P&gt;&lt;P&gt;30SEP2010&amp;nbsp; 444&amp;nbsp; Current&lt;/P&gt;&lt;P&gt;31OCT2010&amp;nbsp; 444&amp;nbsp; Current&lt;/P&gt;&lt;P&gt;30NOV2010&amp;nbsp; 444&amp;nbsp; Current&lt;/P&gt;&lt;P&gt;31DEC2010&amp;nbsp; 444&amp;nbsp; Current&lt;/P&gt;&lt;P&gt;31JAN2011&amp;nbsp; 444&amp;nbsp; 1 - 30&lt;/P&gt;&lt;P&gt;28FEB2011&amp;nbsp; 444&amp;nbsp; 30 - 60&lt;/P&gt;&lt;P&gt;31MAR2011&amp;nbsp; 444&amp;nbsp; 60 - 90&lt;/P&gt;&lt;P&gt;30APR2011&amp;nbsp; 444&amp;nbsp; 90 +&lt;/P&gt;&lt;P&gt;31MAY2011&amp;nbsp; 444&amp;nbsp; 90 +&lt;/P&gt;&lt;P&gt;30JUN2011&amp;nbsp; 444&amp;nbsp; 90 +&lt;/P&gt;&lt;P&gt;31JUL2011&amp;nbsp; 444&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;31AUG2011&amp;nbsp; 444&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;30SEP2011&amp;nbsp; 444&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;31OCT2011&amp;nbsp; 444&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;30NOV2011&amp;nbsp; 444&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;31DEC2011&amp;nbsp; 444&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;31JAN2012&amp;nbsp; 444&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;28FEB2010&amp;nbsp; 555&amp;nbsp; 30 - 60&lt;/P&gt;&lt;P&gt;31MAR2010&amp;nbsp; 555&amp;nbsp; 30 - 60&lt;/P&gt;&lt;P&gt;30APR2010&amp;nbsp; 555&amp;nbsp; 60 - 90&lt;/P&gt;&lt;P&gt;31MAY2010&amp;nbsp; 555&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;31JAN2012&amp;nbsp; 666&amp;nbsp; writoff&lt;/P&gt;&lt;P&gt;31JAN2012&amp;nbsp; 777&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;;&lt;/P&gt;&lt;P&gt;run;&lt;/P&gt;&lt;P&gt;&lt;STRONG&gt;/*Interlace Stacking*/&lt;/STRONG&gt;&lt;BR /&gt;data want;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; set have (in=up) have;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; by account_number;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; if first.account_number then call missing(flag);&lt;BR /&gt;&amp;nbsp; &lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; if up and Arrears_Band='writoff' then flag+1;&lt;BR /&gt;&amp;nbsp; run;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; if not up and flag&amp;gt;=1 then output;&lt;/P&gt;&lt;P&gt; drop flag;&lt;/P&gt;&lt;P&gt;run;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;STRONG&gt;/*Classic 2X DOW*/&lt;/STRONG&gt;&lt;BR /&gt;data want;&lt;/P&gt;&lt;P&gt;&amp;nbsp; do until (last.account_number);&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; set have;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; by account_number;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; if Arrears_Band='writoff' then flag+1;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; end;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; do until (last.account_number);&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; set have;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; by account_number;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; if flag &amp;gt;=1 then output;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; end;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; call missing(flag);&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; drop flag;&lt;/P&gt;&lt;P&gt;run;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;STRONG&gt;/*Merge*/&lt;/STRONG&gt;&lt;/P&gt;&lt;P&gt;data want;&lt;/P&gt;&lt;P&gt;&amp;nbsp; merge have (where=(Arrears_Band='writoff') in=a) have (in=b);&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; by account_number;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; if a and b;&lt;/P&gt;&lt;P&gt;run;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;STRONG&gt;/*Hash()*/&lt;/STRONG&gt;&lt;/P&gt;&lt;P&gt;data want;&lt;/P&gt;&lt;P&gt;&amp;nbsp; if _n_=1 then do;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; if 0 then set have;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; dcl hash h(dataset:'have', multidata:'y');&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; h.definekey('account_number');&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; h.definedata(all:'y');&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; h.definedone();&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; end;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; do until (last.account_number);&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;&amp;nbsp;&amp;nbsp; by account_number;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; if Arrears_Band='writoff' then flag+1;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; end;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; if flag&amp;gt;=1 then do;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; rc=h.find();&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; do rc=0 by 0 while (rc=0);&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; output;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; rc=h.find_next();&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; end;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; end;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; call missing(flag);&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; drop flag rc;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; run;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Tue, 25 Sep 2012 19:36:46 GMT</pubDate>
    <dc:creator>robertrao</dc:creator>
    <dc:date>2012-09-25T19:36:46Z</dc:date>
    <item>
      <title>CODE EXPLANATION PLEASE</title>
      <link>https://communities.sas.com/t5/Statistical-Procedures/CODE-EXPLANATION-PLEASE/m-p/77120#M3661</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Could you please explain the codes &lt;STRONG&gt; Interlace stacking&lt;/STRONG&gt; and the classic &lt;STRONG&gt;2X DOW&lt;/STRONG&gt;&lt;/P&gt;&lt;P&gt;How did they get the names?&lt;/P&gt;&lt;P&gt;Whats the benifit of setting the same dataset twice?&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;eg:&lt;/P&gt;&lt;P&gt;data want;&lt;/P&gt;&lt;P&gt;set have have; etc etc&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;THANKS IN ADVANCE&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;*QUESTION;&lt;BR /&gt;*HOW TO SEPERATE SUBJECTS WITH MULTIPLE OCCURANCES THAT SATISFY A CERTAIN CONDITION?????;&lt;BR /&gt;*I NEED TO SEPERATE THE RECORDS WHERE ARRERS_BAND(VARIABLE NAME) ATLEAST ONCE HAD "WRITOFF" VALUE;&lt;/P&gt;&lt;P&gt;data have;&lt;/P&gt;&lt;P&gt;informat Current_date date9.;&lt;/P&gt;&lt;P&gt;Input Current_date&amp;nbsp;&amp;nbsp; Account_number Arrears_Band :$15.;&lt;/P&gt;&lt;P&gt;Format Current_date date9.;&lt;/P&gt;&lt;P&gt;cards;&lt;/P&gt;&lt;P&gt;31MAY2011&amp;nbsp; 111&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;30JUN2011&amp;nbsp; 111&amp;nbsp; writoff&lt;/P&gt;&lt;P&gt;31JUL2011&amp;nbsp; 111&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;31AUG2011&amp;nbsp; 111&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;30SEP2011&amp;nbsp; 111&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;31OCT2011&amp;nbsp; 111&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;30NOV2011&amp;nbsp; 111&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;31DEC2011&amp;nbsp; 111&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;31JAN2012&amp;nbsp; 111&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;31DEC2011&amp;nbsp; 222&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;31JAN2012&amp;nbsp; 222&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;30NOV2010&amp;nbsp; 333&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;31DEC2010&amp;nbsp; 333&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;31JAN2011&amp;nbsp; 333&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;28FEB2011&amp;nbsp; 333&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;31MAR2011&amp;nbsp; 333&amp;nbsp; writoff&lt;/P&gt;&lt;P&gt;30APR2011&amp;nbsp; 333&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;31MAY2011&amp;nbsp; 333&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;30JUN2011&amp;nbsp; 333&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;31JUL2011&amp;nbsp; 333&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;31AUG2011&amp;nbsp; 333&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;30SEP2011&amp;nbsp; 333&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;31OCT2011&amp;nbsp; 333&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;30NOV2011&amp;nbsp; 333&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;31DEC2011&amp;nbsp; 333&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;31JAN2012&amp;nbsp; 333&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;28FEB2010&amp;nbsp; 444&amp;nbsp; Current&lt;/P&gt;&lt;P&gt;31MAR2010&amp;nbsp; 444&amp;nbsp; 30 - 60&lt;/P&gt;&lt;P&gt;30APR2010&amp;nbsp; 444&amp;nbsp; 30 - 60&lt;/P&gt;&lt;P&gt;31MAY2010&amp;nbsp; 444&amp;nbsp; Current&lt;/P&gt;&lt;P&gt;30JUN2010&amp;nbsp; 444&amp;nbsp; Current&lt;/P&gt;&lt;P&gt;31JUL2010&amp;nbsp; 444&amp;nbsp; Current&lt;/P&gt;&lt;P&gt;31AUG2010&amp;nbsp; 444&amp;nbsp; Current&lt;/P&gt;&lt;P&gt;30SEP2010&amp;nbsp; 444&amp;nbsp; Current&lt;/P&gt;&lt;P&gt;31OCT2010&amp;nbsp; 444&amp;nbsp; Current&lt;/P&gt;&lt;P&gt;30NOV2010&amp;nbsp; 444&amp;nbsp; Current&lt;/P&gt;&lt;P&gt;31DEC2010&amp;nbsp; 444&amp;nbsp; Current&lt;/P&gt;&lt;P&gt;31JAN2011&amp;nbsp; 444&amp;nbsp; 1 - 30&lt;/P&gt;&lt;P&gt;28FEB2011&amp;nbsp; 444&amp;nbsp; 30 - 60&lt;/P&gt;&lt;P&gt;31MAR2011&amp;nbsp; 444&amp;nbsp; 60 - 90&lt;/P&gt;&lt;P&gt;30APR2011&amp;nbsp; 444&amp;nbsp; 90 +&lt;/P&gt;&lt;P&gt;31MAY2011&amp;nbsp; 444&amp;nbsp; 90 +&lt;/P&gt;&lt;P&gt;30JUN2011&amp;nbsp; 444&amp;nbsp; 90 +&lt;/P&gt;&lt;P&gt;31JUL2011&amp;nbsp; 444&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;31AUG2011&amp;nbsp; 444&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;30SEP2011&amp;nbsp; 444&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;31OCT2011&amp;nbsp; 444&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;30NOV2011&amp;nbsp; 444&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;31DEC2011&amp;nbsp; 444&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;31JAN2012&amp;nbsp; 444&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;28FEB2010&amp;nbsp; 555&amp;nbsp; 30 - 60&lt;/P&gt;&lt;P&gt;31MAR2010&amp;nbsp; 555&amp;nbsp; 30 - 60&lt;/P&gt;&lt;P&gt;30APR2010&amp;nbsp; 555&amp;nbsp; 60 - 90&lt;/P&gt;&lt;P&gt;31MAY2010&amp;nbsp; 555&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;31JAN2012&amp;nbsp; 666&amp;nbsp; writoff&lt;/P&gt;&lt;P&gt;31JAN2012&amp;nbsp; 777&amp;nbsp; NPNA&lt;/P&gt;&lt;P&gt;;&lt;/P&gt;&lt;P&gt;run;&lt;/P&gt;&lt;P&gt;&lt;STRONG&gt;/*Interlace Stacking*/&lt;/STRONG&gt;&lt;BR /&gt;data want;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; set have (in=up) have;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; by account_number;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; if first.account_number then call missing(flag);&lt;BR /&gt;&amp;nbsp; &lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; if up and Arrears_Band='writoff' then flag+1;&lt;BR /&gt;&amp;nbsp; run;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; if not up and flag&amp;gt;=1 then output;&lt;/P&gt;&lt;P&gt; drop flag;&lt;/P&gt;&lt;P&gt;run;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;STRONG&gt;/*Classic 2X DOW*/&lt;/STRONG&gt;&lt;BR /&gt;data want;&lt;/P&gt;&lt;P&gt;&amp;nbsp; do until (last.account_number);&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; set have;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; by account_number;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; if Arrears_Band='writoff' then flag+1;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; end;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; do until (last.account_number);&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; set have;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; by account_number;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; if flag &amp;gt;=1 then output;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; end;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; call missing(flag);&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; drop flag;&lt;/P&gt;&lt;P&gt;run;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;STRONG&gt;/*Merge*/&lt;/STRONG&gt;&lt;/P&gt;&lt;P&gt;data want;&lt;/P&gt;&lt;P&gt;&amp;nbsp; merge have (where=(Arrears_Band='writoff') in=a) have (in=b);&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; by account_number;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; if a and b;&lt;/P&gt;&lt;P&gt;run;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;STRONG&gt;/*Hash()*/&lt;/STRONG&gt;&lt;/P&gt;&lt;P&gt;data want;&lt;/P&gt;&lt;P&gt;&amp;nbsp; if _n_=1 then do;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; if 0 then set have;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; dcl hash h(dataset:'have', multidata:'y');&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; h.definekey('account_number');&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; h.definedata(all:'y');&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; h.definedone();&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; end;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; do until (last.account_number);&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;&amp;nbsp;&amp;nbsp; by account_number;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; if Arrears_Band='writoff' then flag+1;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; end;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; if flag&amp;gt;=1 then do;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; rc=h.find();&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; do rc=0 by 0 while (rc=0);&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; output;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; rc=h.find_next();&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; end;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; end;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; call missing(flag);&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; drop flag rc;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; run;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Tue, 25 Sep 2012 19:36:46 GMT</pubDate>
      <guid>https://communities.sas.com/t5/Statistical-Procedures/CODE-EXPLANATION-PLEASE/m-p/77120#M3661</guid>
      <dc:creator>robertrao</dc:creator>
      <dc:date>2012-09-25T19:36:46Z</dc:date>
    </item>
    <item>
      <title>Re: CODE EXPLANATION PLEASE</title>
      <link>https://communities.sas.com/t5/Statistical-Procedures/CODE-EXPLANATION-PLEASE/m-p/77121#M3662</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;I think you're better off reading up on the generalities of DOW loops and seeing how it applies to your code. &lt;/P&gt;&lt;P&gt;You can find useful papers at lexjansen.com, for example here's a paper that explains a double dow loop:&lt;/P&gt;&lt;P&gt;&lt;A class="active_link" href="http://www.lexjansen.com/wuss/2009/tut/TUT-Allen.pdf" title="http://www.lexjansen.com/wuss/2009/tut/TUT-Allen.pdf"&gt;http://www.lexjansen.com/wuss/2009/tut/TUT-Allen.pdf&lt;/A&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Did you mean interleaving or interlacing? I'm not familiar with interlacing term...so no help there &lt;img id="smileysad" class="emoticon emoticon-smileysad" src="https://communities.sas.com/i/smilies/16x16_smiley-sad.png" alt="Smiley Sad" title="Smiley Sad" /&gt;.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Tue, 25 Sep 2012 19:51:01 GMT</pubDate>
      <guid>https://communities.sas.com/t5/Statistical-Procedures/CODE-EXPLANATION-PLEASE/m-p/77121#M3662</guid>
      <dc:creator>Reeza</dc:creator>
      <dc:date>2012-09-25T19:51:01Z</dc:date>
    </item>
    <item>
      <title>Re: CODE EXPLANATION PLEASE</title>
      <link>https://communities.sas.com/t5/Statistical-Procedures/CODE-EXPLANATION-PLEASE/m-p/77122#M3663</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Firstly thanks for the reply.&lt;/P&gt;&lt;P&gt;If you look below the data the code is already posted with various names. First of the codes is&amp;nbsp; written as&lt;STRONG&gt; Interlace stacking. I do not know it myself why that piece of code&amp;nbsp; is called by that name&lt;/STRONG&gt;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Tue, 25 Sep 2012 19:56:37 GMT</pubDate>
      <guid>https://communities.sas.com/t5/Statistical-Procedures/CODE-EXPLANATION-PLEASE/m-p/77122#M3663</guid>
      <dc:creator>robertrao</dc:creator>
      <dc:date>2012-09-25T19:56:37Z</dc:date>
    </item>
    <item>
      <title>Re: CODE EXPLANATION PLEASE</title>
      <link>https://communities.sas.com/t5/Statistical-Procedures/CODE-EXPLANATION-PLEASE/m-p/77123#M3664</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;It is really called interleaving.&amp;nbsp; Take a look at: &lt;A href="http://support.sas.com/documentation/cdl/en/basess/58133/HTML/default/viewer.htm#a001293111.htm"&gt;http://support.sas.com/documentation/cdl/en/basess/58133/HTML/default/viewer.htm#a001293111.htm&lt;/A&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I responded to your earlier post with a brief explanation of how a DOW loop works.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Tue, 25 Sep 2012 20:21:59 GMT</pubDate>
      <guid>https://communities.sas.com/t5/Statistical-Procedures/CODE-EXPLANATION-PLEASE/m-p/77123#M3664</guid>
      <dc:creator>art297</dc:creator>
      <dc:date>2012-09-25T20:21:59Z</dc:date>
    </item>
    <item>
      <title>Re: CODE EXPLANATION PLEASE</title>
      <link>https://communities.sas.com/t5/Statistical-Procedures/CODE-EXPLANATION-PLEASE/m-p/77124#M3665</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Yes Sir,&lt;/P&gt;&lt;P&gt;Great Help&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Thanks a ton&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Tue, 25 Sep 2012 20:25:23 GMT</pubDate>
      <guid>https://communities.sas.com/t5/Statistical-Procedures/CODE-EXPLANATION-PLEASE/m-p/77124#M3665</guid>
      <dc:creator>robertrao</dc:creator>
      <dc:date>2012-09-25T20:25:23Z</dc:date>
    </item>
  </channel>
</rss>

