The DO Loop
Statistical programming in SAS with an emphasis on SAS/IML programsdata:image/s3,"s3://crabby-images/7e153/7e15399ce30c891cc98fa71e0d4956b68c1791a4" alt="An introduction to genetic algorithms in SAS"
A genetic algorithm (GA) is a heuristic optimization technique. The method tries to mimic natural selection and evolution by starting with a population of random candidates. Candidates are evaluated for "fitness" by plugging them into the objective function. The characteristics of the better candidates are combined to create a new
data:image/s3,"s3://crabby-images/45eba/45eba9f55e98b82ac2ce266ab7f645939a7aa41d" alt="Crossover and mutation: An introduction to two operations in genetic algorithms"
This article uses an example to introduce to genetic algorithms (GAs) for optimization. It discusses two operators (mutation and crossover) that are important in implementing a genetic algorithm. It discusses choices that you must make when you implement these operations. Some programmers love using genetic algorithms. Genetic algorithms are heuristic
data:image/s3,"s3://crabby-images/7a641/7a64180789566f589fb0333d9db812764fa904d6" alt="Penalties versus constraints in optimization problems"
Sometimes we can learn as much from our mistakes as we do from our successes. Recently, I needed to solve an optimization problem for which the solution vector was a binary vector subject to a constraint. I was in a hurry. Without thinking much about what I was doing, I
data:image/s3,"s3://crabby-images/7e153/7e15399ce30c891cc98fa71e0d4956b68c1791a4" alt="The knapsack problem: Binary integer programming in SAS/IML"
Many optimization problems in statistics and machine learning involve continuous parameters. For example, maximum likelihood estimation involves optimizing a log-likelihood function over a continuous domain, possibly with constraints. Recently, however, I had to solve an optimization problem for which the solution vector was a 0/1 binary variable. To solve the
data:image/s3,"s3://crabby-images/7e153/7e15399ce30c891cc98fa71e0d4956b68c1791a4" alt="Logical negation of vectors"
In a matrix-vector language such as SAS/IML, it is useful to always remember that the fundamental objects are matrices and that all operations are designed to work on matrices. (And vectors, which are matrices that have only one row or one column.) By using matrix operations, you can often eliminate
data:image/s3,"s3://crabby-images/364cb/364cb71e79ec05cf33bbfecad07c60a0bdc0c5d0" alt="Choose samples with specified statistical properties"
A reader asked whether it is possible to find a bootstrap sample that has some desirable properties. I am using the term "bootstrap sample" to refer to the result of randomly resampling with replacement from a data set. Specifically, he wanted to find a bootstrap sample that has a specific