| 
 | ||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||
public interface Preconditioner
This interface represents a preconditioner for differentiable scalar objective function optimizers.
| Method Summary | |
|---|---|
|  double[] | precondition(double[] point,
                         double[] r)Precondition a search direction. | 
| Method Detail | 
|---|
double[] precondition(double[] point,
                      double[] r)
                      throws FunctionEvaluationException,
                             IllegalArgumentException
The returned preconditioned search direction must be computed fast or the algorithm performances will drop drastically. A classical approach is to compute only the diagonal elements of the hessian and to divide the raw search direction by these elements if they are all positive. If at least one of them is negative, it is safer to return a clone of the raw search direction as if the hessian was the identity matrix. The rationale for this simplified choice is that a negative diagonal element means the current point is far from the optimum and preconditioning will not be efficient anyway in this case.
point - current point at which the search direction was computedr - raw search direction (i.e. opposite of the gradient)
FunctionEvaluationException - if no cost can be computed for the parameters
IllegalArgumentException - if point dimension is wrong| 
 | ||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||