The DO Loop
Statistical programming in SAS with an emphasis on SAS/IML programsdata:image/s3,"s3://crabby-images/a73c6/a73c6da1b21593c7be63fc671b5bed042a4f5e5f" alt="Create dummy variables in SAS"
A dummy variable (also known as indicator variable) is a numeric variable that indicates the presence or absence of some level of a categorical variable. The word "dummy" does not imply that these variables are not smart. Rather, dummy variables serve as a substitute or a proxy for a categorical
data:image/s3,"s3://crabby-images/35ffd/35ffded62c9ff1f7a5f37cedcd4ea8a89c61cbc1" alt="Read data into vectors or into a matrix: Which is better?"
In the SAS/IML language, you can read data from a SAS data set into a set of vectors (each with their own name) or into a single matrix. Beginning programmers might wonder about the advantages of each approach. When should you read data into vectors? When should you read data
data:image/s3,"s3://crabby-images/c56cf/c56cfeb1bcde6174ec594304d23eadd6fda404aa" alt="Rolling statistics in SAS/IML"
Last week I showed how to use PROC EXPAND to compute moving averages and other rolling statistics in SAS. Unfortunately, PROC EXPAND is part of SAS/ETS software and not every SAS site has a license for SAS/ETS. For simple moving averages, you can write a DATA step program, as discussed
data:image/s3,"s3://crabby-images/c26fe/c26fe56a562fd5d3ce2b2c36945dd92dfca23dfc" alt="Group processing in SAS: The NOTSORTED option"
Novice SAS programmers quickly learn the advantages of using PROC SORT to sort data, followed by a BY-group analysis of the sorted data. A typical example is to analyze demographic data by state or by ZIP code. A BY statement enables you to produce multiple analyses from a single procedure
data:image/s3,"s3://crabby-images/3a47d/3a47d30577db969fb6e835d407369d15169b62c3" alt="What is a moving average?"
A moving average (also called a rolling average) is a statistical technique that is used to smooth a time series. Moving averages are used in finance, economics, and quality control. You can overlay a moving average curve on a time series to visualize how each value compares to a rolling
data:image/s3,"s3://crabby-images/5bd7e/5bd7ed23d64b1ee5a5b20f00935901a58836c3e2" alt="Banking to 45 degrees: Aspect ratios for time series plots"
In SAS, the aspect ratio of a graph is the physical height of the graph divided by the physical width. Recently I demonstrated how to set the aspect ratio of graphs in SAS by using the ASPECT= option in PROC SGPLOT or by using the OVERLAYEQUATED statement in the Graph