The DO Loop
Statistical programming in SAS with an emphasis on SAS/IML programsdata:image/s3,"s3://crabby-images/cf7ba/cf7ba14ce46b23f3969a52031eb0e7f2363eb8cd" alt="Jackknife estimates in SAS Jackknife"
One way to assess the precision of a statistic (a point estimate) is to compute the standard error, which is the standard deviation of the statistic's sampling distribution. A relatively large standard error indicates that the point estimate should be viewed with skepticism, either because the sample size is small
data:image/s3,"s3://crabby-images/21e40/21e40871353ff46427038ebab3bca7a9c86376d5" alt="How to find a feasible point for a constrained optimization in SAS"
Most numerical optimization routines require that the user provides an initial guess for the solution. I have previously described a method for choosing an initial guess for an optimization, which works well for low-dimensional optimization problems. Recently a SAS programmer asked how to find an initial guess when there are
data:image/s3,"s3://crabby-images/62c17/62c179e209afd08941e02e9e32fddb5f3ffc4c3b" alt="Two ways to compute maximum likelihood estimates in SAS"
In a previous article, I showed two ways to define a log-likelihood function in SAS. This article shows two ways to compute maximum likelihood estimates (MLEs) in SAS: the nonlinear optimization subroutines in SAS/IML and the NLMIXED procedure in SAS/STAT. To illustrate these methods, I will use the same data
data:image/s3,"s3://crabby-images/50282/50282803922484218715d59b9ca40a513dd29a46" alt="Two simple ways to construct a log-likelihood function in SAS Log-likelihood function for the binomial distribution"
Maximum likelihood estimation (MLE) is a powerful statistical technique that uses optimization techniques to fit parametric models. The technique finds the parameters that are "most likely" to have produced the observed data. SAS provides many tools for nonlinear optimization, so often the hardest part of maximum likelihood is writing down
data:image/s3,"s3://crabby-images/8f5af/8f5af738809279ab1ae9e2dc0684e5997714a92c" alt="The IFN function versus the IF-THEN/ELSE statement in SAS"
I have previously discussed how to define functions that safely evaluate their arguments and return a missing value if the argument is not in the domain of the function. The canonical example is the LOG function, which is defined only for positive arguments. For example, to evaluate the LOG function
data:image/s3,"s3://crabby-images/acc54/acc5475bb45b38c47b96495803f4ce3544fa735c" alt="Runs in coin tosses; patterns in random seating"
If you toss a coin 28 times, you would not be surprised to see three heads in a row, such as ...THHHTH.... But what about eight heads in a row? Would a sequence such as THHHHHHHHTH... be a rare event? This question popped into my head last weekend as I