<?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: Filling gaps of missing data across arrays in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/Filling-gaps-of-missing-data-across-arrays/m-p/281909#M57210</link>
    <description>&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;* reverse sort of an aaray;

data have;
input ID num1 num2 num3 num4;
cards;
1 1 2 . 4
2 1 . . 4
3 1 . 3 4
;
run;

Up to 40 obs WORK.HAVE total obs=3

Obs    ID    NUM1    NUM2    NUM3    NUM4

 1      1      1       2       .       4
 2      2      1       .       .       4
 3      3      1       .       3       4


WANT

Up to 40 obs WORK.WANT total obs=3

Obs    ID    NUM1    NUM2    NUM3    NUM4

 1      1      4       2       1       .
 2      2      4       1       .       .
 3      3      4       3       1       .


SOLUTION

data want;
    set have;
    array arr[*] num1-num4;
    array rev[*] num4-num1;
    call sortn(of rev[*]);
  run;

&lt;/CODE&gt;&lt;/PRE&gt;</description>
    <pubDate>Sun, 03 Jul 2016 16:59:08 GMT</pubDate>
    <dc:creator>rogerjdeangelis</dc:creator>
    <dc:date>2016-07-03T16:59:08Z</dc:date>
    <item>
      <title>Filling gaps of missing data across arrays</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Filling-gaps-of-missing-data-across-arrays/m-p/281905#M57207</link>
      <description>&lt;P&gt;Hi,&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;I have a data set with missing data which I'd like to fill in with the next nonmissing value across the array. Or it's like moving values across the array.&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;data have;&lt;/P&gt;
&lt;P&gt;input ID num1 num2 num3 num4;&lt;/P&gt;
&lt;P&gt;cards;&lt;/P&gt;
&lt;P&gt;1 1 2 . 4&lt;/P&gt;
&lt;P&gt;2 1 . . 4&lt;/P&gt;
&lt;P&gt;3 1. 3 4&lt;/P&gt;
&lt;P&gt;;&lt;/P&gt;
&lt;P&gt;run;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;data want;&lt;/P&gt;
&lt;P&gt;input ID num1 num2 num3 num4;&lt;/P&gt;
&lt;P&gt;cards;&lt;/P&gt;
&lt;P&gt;1 1 2 4 .&lt;/P&gt;
&lt;P&gt;2 1 4 . .&lt;/P&gt;
&lt;P&gt;3 1 3 4 .&lt;/P&gt;
&lt;P&gt;;&lt;/P&gt;
&lt;P&gt;run;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Can I produce the want data without transposing?&lt;/P&gt;</description>
      <pubDate>Sun, 03 Jul 2016 15:45:01 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Filling-gaps-of-missing-data-across-arrays/m-p/281905#M57207</guid>
      <dc:creator>angeliquec</dc:creator>
      <dc:date>2016-07-03T15:45:01Z</dc:date>
    </item>
    <item>
      <title>Re: Filling gaps of missing data across arrays</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Filling-gaps-of-missing-data-across-arrays/m-p/281909#M57210</link>
      <description>&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;* reverse sort of an aaray;

data have;
input ID num1 num2 num3 num4;
cards;
1 1 2 . 4
2 1 . . 4
3 1 . 3 4
;
run;

Up to 40 obs WORK.HAVE total obs=3

Obs    ID    NUM1    NUM2    NUM3    NUM4

 1      1      1       2       .       4
 2      2      1       .       .       4
 3      3      1       .       3       4


WANT

Up to 40 obs WORK.WANT total obs=3

Obs    ID    NUM1    NUM2    NUM3    NUM4

 1      1      4       2       1       .
 2      2      4       1       .       .
 3      3      4       3       1       .


SOLUTION

data want;
    set have;
    array arr[*] num1-num4;
    array rev[*] num4-num1;
    call sortn(of rev[*]);
  run;

&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Sun, 03 Jul 2016 16:59:08 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Filling-gaps-of-missing-data-across-arrays/m-p/281909#M57210</guid>
      <dc:creator>rogerjdeangelis</dc:creator>
      <dc:date>2016-07-03T16:59:08Z</dc:date>
    </item>
    <item>
      <title>Re: Filling gaps of missing data across arrays</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Filling-gaps-of-missing-data-across-arrays/m-p/281910#M57211</link>
      <description>&lt;P&gt;CORREC&lt;/P&gt;&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data want;
    set have;
    array arr[*] num1-num4;
    do i=1 to 4;
      if arr[i]=. then arr[i]=constant('BIG');
    end;
    call sortn(of arr[*]);
    do i=1 to 4;
      if arr[i]=constant('BIG') then arr[i]=.;
    end;
    drop i;
  run;


Up to 40 obs WORK.WANT total obs=3

Obs    ID    NUM1    NUM2    NUM3    NUM4

 1      1      1       2       4       .
 2      2      1       4       .       .
 3      3      1       3       4       .

&lt;/CODE&gt;&lt;/PRE&gt;&lt;P&gt;TION&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Sun, 03 Jul 2016 17:09:19 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Filling-gaps-of-missing-data-across-arrays/m-p/281910#M57211</guid>
      <dc:creator>rogerjdeangelis</dc:creator>
      <dc:date>2016-07-03T17:09:19Z</dc:date>
    </item>
    <item>
      <title>Re: Filling gaps of missing data across arrays</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Filling-gaps-of-missing-data-across-arrays/m-p/281912#M57212</link>
      <description>&lt;P&gt;No tricks; just simple programming:&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data want;
set have;
array num num:;
j = 0;
do i = 1 to dim(num);
    if not missing(num{i}) then do;
        j + 1;
        num{j} = num{i};
        end;
    end;
do i = j + 1 to dim(num);
    call missing(num{i});
    end;
drop i j;
run;&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Sun, 03 Jul 2016 17:45:32 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Filling-gaps-of-missing-data-across-arrays/m-p/281912#M57212</guid>
      <dc:creator>PGStats</dc:creator>
      <dc:date>2016-07-03T17:45:32Z</dc:date>
    </item>
    <item>
      <title>Re: Filling gaps of missing data across arrays</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Filling-gaps-of-missing-data-across-arrays/m-p/281916#M57214</link>
      <description>&lt;P&gt;Another way:&lt;/P&gt;&lt;P&gt;Look for a missing value, note the position(i). Then move forward to find the next non-missing value to replace the i-th value while marking the j-th value as missing. Skip the check. Repeat the above step for the next i-th value.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data need;
   set have;
      array num num: ;
      do i = 1 to dim(num) - 1;
         if missing(num[i]) then 
         do j = i + 1  to dim(num);
            if not missing(num[j]) then do; 
               num[i] = num[j]; num[j] = .; leave; 
            end;
         end;
      end;
drop i j;
run;&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Sun, 03 Jul 2016 20:03:16 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Filling-gaps-of-missing-data-across-arrays/m-p/281916#M57214</guid>
      <dc:creator>KachiM</dc:creator>
      <dc:date>2016-07-03T20:03:16Z</dc:date>
    </item>
    <item>
      <title>Re: Filling gaps of missing data across arrays</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Filling-gaps-of-missing-data-across-arrays/m-p/281945#M57228</link>
      <description>&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data have;
input ID num1 num2 num3 num4;
cards;
1 1 2 . 4
2 1 . . 4
3 1 . 3 4
;
run;
data want;
 set have;
 array x{4} _num1-_num4;
 array y{4} num1-num4;

 n=0;
 do i=1 to dim(y);
  if not missing(y{i}) then do;
   n+1;x{n}=y{i};
  end;
 end;
drop i n num:;
run;&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Mon, 04 Jul 2016 04:57:24 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Filling-gaps-of-missing-data-across-arrays/m-p/281945#M57228</guid>
      <dc:creator>Ksharp</dc:creator>
      <dc:date>2016-07-04T04:57:24Z</dc:date>
    </item>
  </channel>
</rss>

