The DO Loop
Statistical programming in SAS with an emphasis on SAS/IML programsdata:image/s3,"s3://crabby-images/7456b/7456b8daf8705c5b4e6536c96acba2b971edc67f" alt="Sum a series in SAS"
A customer asked: How do we go about summing a finite series in SAS? For example, I want to compute for various integers n ≥ 3. I want to output two columns, one for the natural numbers and one for the summation of the series. Summations arise often in statistical
data:image/s3,"s3://crabby-images/e046a/e046a4ebcd5d197be73cd33d7ee1d483e03b7489" alt="Vectors that have a fractional number of elements"
The title of this article makes no sense. How can the number of elements (in fact, the number of anything!) not be a whole number? In fact, it can't. However, the title refers to the fact that you might compute a quantity that ought to be an integer, but is
data:image/s3,"s3://crabby-images/63eeb/63eeb943f2ebf3d6ca06a4929e34ee75e506c4a8" alt="Matrix multiplication with missing values in SAS"
Sometimes I get contacted by SAS/IML programmers who discover that the SAS/IML language does not provide built-in support for multiplication of matrices that have missing values. (SAS/IML does support elementwise operations with missing values.) I usually respond by asking what they are trying to accomplish, because mathematically matrix multiplication with
data:image/s3,"s3://crabby-images/0679e/0679e722bc09c5c25db81d660cc01dce1bcc659b" alt="Writing data in chunks: Does the chunk size matter?"
I often blog about the usefulness of vectorization in the SAS/IML language. A one-sentence summary of vectorization is "execute a small number of statements that each analyze a lot of data." In general, for matrix languages (SAS/IML, MATLAB, R, ...) vectorization is more efficient than the alternative, which is to
data:image/s3,"s3://crabby-images/d5d76/d5d7696ab97561bdc765ae8b0c102a9732c38c5a" alt="Avoid loops, avoid the APPLY function, vectorize!"
Last week I received a message from SAS Technical Support saying that a customer's IML program was running slowly. Could I look at it to see whether it could be improved? What I discovered is a good reminder about the importance of vectorizing user-defined modules. The program in this blog
data:image/s3,"s3://crabby-images/26b74/26b74af9496b70bdf33ac9fee74a0082df4320a3" alt="Complete cases: How to perform listwise deletion in SAS"
SAS procedures usually handle missing values automatically. Univariate procedures such as PROC MEANS automatically delete missing values when computing basic descriptive statistics. Many multivariate procedures such as PROC REG delete an entire observation if any variable in the analysis has a missing value. This is called listwise deletion or using