The DO Loop
Statistical programming in SAS with an emphasis on SAS/IML programsdata:image/s3,"s3://crabby-images/20413/2041303e6b4e1df9edd0f17b48f9a45aa6f77df1" alt="Is a value in a vector? Use the ELEMENT function"
In SAS, DATA step programmers use the IN operator to determine whether a value is contained in a set of target values. Did you know that there is a similar functionality in the SAS IML language? The ELEMENT function in the SAS IML language is similar to the IN operator
data:image/s3,"s3://crabby-images/e2f0b/e2f0b35841190aef54a085ece0cdfd435166c3e5" alt="Efficient recursion: Store values that will be reused"
A previous article shows how to implement recursive formulas in SAS. The article points out that you can often avoid recursion by using an iterative algorithm, which is more efficient. An example is the Fibonacci sequence, which is usually defined recursively as F(n) = F(n-1) + F(n-2) for n
data:image/s3,"s3://crabby-images/149db/149db39b6c9100bb2ec2cbaeea311d9896caad25" alt="An exact formula for the probability distribution for the sum of n dice"
Many well-known distributions become more and more "normal looking" for large values of a parameter. Famously, the binomial distribution, Binom(p, N), can be approximated by a normal distribution when N (the sample size) is large. Similarly, the Poisson(λ) distribution is well approximated by the normal distribution when λ is large.
data:image/s3,"s3://crabby-images/e2f0b/e2f0b35841190aef54a085ece0cdfd435166c3e5" alt="How to write a SAS macro to emulate recursion (and why you shouldn't)"
There are two programming tools that I rarely use: the SAS macro language and recursion. The SAS macro language is a tool that enables you to generate SAS statements. I rarely use the SAS macro language because the SAS IML language supports all the functionality required to write complex programs,
data:image/s3,"s3://crabby-images/7e153/7e15399ce30c891cc98fa71e0d4956b68c1791a4" alt="How to define a SAS IML function that has no arguments"
The SAS IML Language has a quirk with regards to functions that take no arguments. As discussed in the documentation, "modules with arguments are given a local symbol table." This is the usual behavior that programmers expect. However, the documentation goes on to state that "a module that has no
data:image/s3,"s3://crabby-images/62bea/62beae7f6c9cd34a408d28fe4d15c7417007cceb" alt="Implement five sampling methods in the SAS DATA step"
In SAS, the easiest way to draw random sampling from data is to use PROC SURVEYSELECT or the SAMPLE function in SAS IML software. I have previously written about how to implement four common sampling schemes by using PROC SURVEYSELECT and the SAMPLE function. The DATA step in SAS is