The DO Loop
Statistical programming in SAS with an emphasis on SAS/IML programsdata:image/s3,"s3://crabby-images/95c90/95c90cdc27f7a68eade4d64f6df09190ddb3d52b" alt="Sorting rows of a matrix"
Sorting is a fundamental operation in statistical programming, and most SAS programmers are familiar with PROC SORT for sorting data sets. But did you know that you can also sort rows of a SAS/IML matrix according to the value of one or more columns? This post shows how. Sorting a
data:image/s3,"s3://crabby-images/807a3/807a31928634a2daa3f740ac97c5cca833db6d38" alt="Simulating a random walk"
In my spare time, I enjoy browsing the StackOverflow discussion forum to see what questions people are asking about SAS, SAS/IML, and statistics. Last week, a statistics student asked for help with the following homework problem: I need to generate a one-dimensional random walk in which the step length and
data:image/s3,"s3://crabby-images/f1d97/f1d9722bcb41edd9cc4fab8bb4d772ae11484d60" alt="Cuzick's Test for Trend: A case study in translating a MATLAB program into the SAS/IML language"
Several times a year, I am contacted by a SAS account manager who tells me that a customer has asked whether it is possible to convert a MATLAB program to the SAS/IML language. Often the customer has an existing MATLAB program and wants to include the computation as part of
data:image/s3,"s3://crabby-images/6f532/6f5323861ccc28b1737f73b7663208d743060aa4" alt="Need case-insensitive string comparisons? UPCASE!"
String comparisons in SAS software are case-sensitive. For example, the uppercase letter "F" and lowercase letter "f" are treated as unique characters. When these two letters represent the same condition (for example, a female patient), the strings need to be handled in a case-insensitive manner, and a SAS programmer might
data:image/s3,"s3://crabby-images/d899a/d899a16d27711b84a0ebcf11b16b54b438c12392" alt="How to use transparency to overcome overplotting"
Do you have many points in your scatter plots that overlap each other? If so, your graph exhibits overplotting. Overplotting occurs when many points have similar coordinates. For example, the following scatter plot (which is produced by using the ODS statistical graphics procedure, SGPLOT) displays 12,000 points, many of which
data:image/s3,"s3://crabby-images/f1d97/f1d9722bcb41edd9cc4fab8bb4d772ae11484d60" alt="The macro loop that vanished: How to simplify your SAS/IML programs"
I don't use the SAS macro language very often. Because the SAS/IML language has statements for looping and evaluating expressions, I rarely write a macro function as part of a SAS/IML programs. Oh, sure, I use the %LET statement to define global constants, but I seldom use the %DO and