|  | // Ceres Solver - A fast non-linear least squares minimizer | 
|  | // Copyright 2016 Google Inc. All rights reserved. | 
|  | // http://ceres-solver.org/ | 
|  | // | 
|  | // Redistribution and use in source and binary forms, with or without | 
|  | // modification, are permitted provided that the following conditions are met: | 
|  | // | 
|  | // * Redistributions of source code must retain the above copyright notice, | 
|  | //   this list of conditions and the following disclaimer. | 
|  | // * Redistributions in binary form must reproduce the above copyright notice, | 
|  | //   this list of conditions and the following disclaimer in the documentation | 
|  | //   and/or other materials provided with the distribution. | 
|  | // * Neither the name of Google Inc. nor the names of its contributors may be | 
|  | //   used to endorse or promote products derived from this software without | 
|  | //   specific prior written permission. | 
|  | // | 
|  | // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | 
|  | // AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | 
|  | // IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE | 
|  | // ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE | 
|  | // LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR | 
|  | // CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF | 
|  | // SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS | 
|  | // INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN | 
|  | // CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) | 
|  | // ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE | 
|  | // POSSIBILITY OF SUCH DAMAGE. | 
|  | // | 
|  | // Author: sameeragarwal@google.com (Sameer Agarwal) | 
|  |  | 
|  | #ifndef CERES_INTERNAL_TRUST_REGION_STEP_EVALUATOR_H_ | 
|  | #define CERES_INTERNAL_TRUST_REGION_STEP_EVALUATOR_H_ | 
|  |  | 
|  | namespace ceres { | 
|  | namespace internal { | 
|  |  | 
|  | // The job of the TrustRegionStepEvaluator is to evaluate the quality | 
|  | // of a step, i.e., how the cost of a step compares with the reduction | 
|  | // in the objective of the trust region problem. | 
|  | // | 
|  | // Classic trust region methods are descent methods, in that they only | 
|  | // accept a point if it strictly reduces the value of the objective | 
|  | // function. They do this by measuring the quality of a step as | 
|  | // | 
|  | //   cost_change / model_cost_change. | 
|  | // | 
|  | // Relaxing the monotonic descent requirement allows the algorithm to | 
|  | // be more efficient in the long term at the cost of some local | 
|  | // increase in the value of the objective function. | 
|  | // | 
|  | // This is because allowing for non-decreasing objective function | 
|  | // values in a principled manner allows the algorithm to "jump over | 
|  | // boulders" as the method is not restricted to move into narrow | 
|  | // valleys while preserving its convergence properties. | 
|  | // | 
|  | // The parameter max_consecutive_nonmonotonic_steps controls the | 
|  | // window size used by the step selection algorithm to accept | 
|  | // non-monotonic steps. Setting this parameter to zero, recovers the | 
|  | // classic monotonic descent algorithm. | 
|  | // | 
|  | // Based on algorithm 10.1.2 (page 357) of "Trust Region | 
|  | // Methods" by Conn Gould & Toint, or equations 33-40 of | 
|  | // "Non-monotone trust-region algorithms for nonlinear | 
|  | // optimization subject to convex constraints" by Phil Toint, | 
|  | // Mathematical Programming, 77, 1997. | 
|  | // | 
|  | // Example usage: | 
|  | // | 
|  | // TrustRegionStepEvaluator* step_evaluator = ... | 
|  | // | 
|  | // cost = ... // Compute the non-linear objective function value. | 
|  | // model_cost_change = ... // Change in the value of the trust region objective. | 
|  | // if (step_evaluator->StepQuality(cost, model_cost_change) > threshold) { | 
|  | //   x = x + delta; | 
|  | //   step_evaluator->StepAccepted(cost, model_cost_change); | 
|  | // } | 
|  | class TrustRegionStepEvaluator { | 
|  | public: | 
|  | // initial_cost is as the name implies the cost of the starting | 
|  | // state of the trust region minimizer. | 
|  | // | 
|  | // max_consecutive_nonmonotonic_steps controls the window size used | 
|  | // by the step selection algorithm to accept non-monotonic | 
|  | // steps. Setting this parameter to zero, recovers the classic | 
|  | // monotonic descent algorithm. | 
|  | TrustRegionStepEvaluator(double initial_cost, | 
|  | int max_consecutive_nonmonotonic_steps); | 
|  |  | 
|  | // Return the quality of the step given its cost and the decrease in | 
|  | // the cost of the model. model_cost_change has to be positive. | 
|  | double StepQuality(double cost, double model_cost_change) const; | 
|  |  | 
|  | // Inform the step evaluator that a step with the given cost and | 
|  | // model_cost_change has been accepted by the trust region | 
|  | // minimizer. | 
|  | void StepAccepted(double cost, double model_cost_change); | 
|  |  | 
|  | private: | 
|  | const int max_consecutive_nonmonotonic_steps_; | 
|  | // The minimum cost encountered up till now. | 
|  | double minimum_cost_; | 
|  | // The current cost of the trust region minimizer as informed by the | 
|  | // last call to StepAccepted. | 
|  | double current_cost_; | 
|  | double reference_cost_; | 
|  | double candidate_cost_; | 
|  | // Accumulated model cost since the last time the reference model | 
|  | // cost was updated, i.e., when a step with cost less than the | 
|  | // current known minimum cost is accepted. | 
|  | double accumulated_reference_model_cost_change_; | 
|  | // Accumulated model cost since the last time the candidate model | 
|  | // cost was updated, i.e., a non-monotonic step was taken with a | 
|  | // cost that was greater than the current candidate cost. | 
|  | double accumulated_candidate_model_cost_change_; | 
|  | // Number of steps taken since the last time minimum_cost was updated. | 
|  | int num_consecutive_nonmonotonic_steps_; | 
|  | }; | 
|  |  | 
|  | }  // namespace internal | 
|  | }  // namespace ceres | 
|  |  | 
|  | #endif  // CERES_INTERNAL_TRUST_REGION_STEP_EVALUATOR_H_ |