The DO Loop
Statistical programming in SAS with an emphasis on SAS/IML programsdata:image/s3,"s3://crabby-images/7a9e3/7a9e3ac522a1387ad9c17f23b8007066e3a175b3" alt="How to compute Mahalanobis distance in SAS"
I recently blogged about Mahalanobis distance and what it means geometrically. I also previously showed how Mahalanobis distance can be used to compute outliers in multivariate data. But how do you compute Mahalanobis distance in SAS? Computing Mahalanobis distance with built-in SAS procedures and functions There are several ways to
data:image/s3,"s3://crabby-images/c0141/c014113cf49cf547ded29ec28f90c64dbbf1b506" alt="What is Mahalanobis distance? What is Mahalanobis distance?"
I previously described how to use Mahalanobis distance to find outliers in multivariate data. This article takes a closer look at Mahalanobis distance. A subsequent article will describe how you can compute Mahalanobis distance. Distance in standard units In statistics, we sometimes measure "nearness" or "farness" in terms of the
data:image/s3,"s3://crabby-images/25ec3/25ec388300805666d27c7dda95ec18f707fefa5b" alt="Use the Cholesky transformation to correlate and uncorrelate variables Use the Cholesky transformation to correlate and uncorrelate variables"
A variance-covariance matrix expresses linear relationships between variables. Given the covariances between variables, did you know that you can write down an invertible linear transformation that "uncorrelates" the variables? Conversely, you can transform a set of uncorrelated variables into variables with given covariances. The transformation that works this magic is
data:image/s3,"s3://crabby-images/3346b/3346b3ac02fd66e1ad6df4fc881cb681e9bbdd83" alt="Rounding up, rounding down Rounding up and rounding down in SAS"
SAS has several ways to round a number to an integer. You can round a number up, round it down, or round it to the nearest integer. If your data contain both positive and negative values, you can also round numbers toward zero, or away from zero. The functions that
data:image/s3,"s3://crabby-images/daa43/daa43083fc26fd8456124f74df0209ab58d3d8c1" alt="Count the number of missing values for each variable Count the number of missing values in each variable in SAS"
The other day I encountered a SAS Knowledge Base article that shows how to count the number of missing and nonmissing values for each variable in a data set. However, the code is a complicated macro that is difficult for a beginning SAS programmer to understand. (Well, it was hard
data:image/s3,"s3://crabby-images/70b09/70b0916fcdf06eddc90bd97e909a3929af44d66a" alt="Loops in SAS Schematic flow of a DO loop in SAS"
Looping is essential to statistical programming. Whether you need to iterate over parameters in an algorithm or indices in an array, a loop is often one of the first programming constructs that a beginning programmer learns. Today is the first anniversary of this blog, which is named The DO Loop,