The DO Loop
Statistical programming in SAS with an emphasis on SAS/IML programsdata:image/s3,"s3://crabby-images/143e5/143e5c068ece43bb68ff39b29025c2ff950dbae7" alt="Computing 200 factorial: Using PROC IML as a really BIG calculator"
Have you ever wanted to compute the exact value of a really big number such as 200! = 200*199*...*2*1? You can do it—if you're willing to put forth some programming effort. This blog post shows you how. Jiangtang Hu's recent blog discusses his quest to compute large factorials in many programming languages.
data:image/s3,"s3://crabby-images/0651b/0651b067d821ed827f4ebd584060ab1d48b365b5" alt="Test whether a sequence is increasing"
The other day I needed to check that a sequence of numerical values was in strictly increasing order. My first thought was to sort the values and compare the sorted and original values, but I quickly discarded that approach because it does not detect duplicate values in a montonic (nondecreasing)
data:image/s3,"s3://crabby-images/9999c/9999cf0fde05206e630c15fc2a28747908ed36c2" alt="How to create a grid of values?"
In a previous post, I described ways to create SAS/IML vectors that contain uniformly spaced values. The methods did not involve writing any loops. This post describes how to perform a similar operation: creating evenly spaced values on a two-dimensional grid. The DATA step solution is simple, but an efficient
data:image/s3,"s3://crabby-images/4a4f2/4a4f2651ed8fa46abb2abc6134a185c2c435b385" alt="Hey! Those two people have the same initials!"
"What is the chance that two people in a room of 20 share initials?" This was the question posed to me by a colleague who had been taking notes at a meeting with 20 people. He recorded each person's initials next to their comments and, upon editing the notes, was
data:image/s3,"s3://crabby-images/17525/175252c38e09841cb9b824a8c8a1e88157b76bfa" alt="Visualizing trends in the US mobile phone industry"
A colleague posted some data on his internal SAS blog about key trends in the US Mobile phone industry, as reported by comScore. He graciously shared the data so that I could create a graph that visualizes the trends. The plot visualizes trends in the data: the Android phone is
data:image/s3,"s3://crabby-images/d59ef/d59ef9b59c2aca33f9205b6892b3a51632d8c2bb" alt="On the flip side: Exchanging rows and columns"
When your data are in rows, but you need them in columns, use the matrix transpose function or operator. The same advice applies to data in columns that you want to be in rows. For example, the vectors created by the DO function and the index creation operator are row