Coverage Report

Created: 2026-01-25 06:59

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/quantlib/ql/math/optimization/linesearchbasedmethod.hpp
Line
Count
Source
1
/* -*- mode: c++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2
3
/*
4
 Copyright (C) 2006 Ferdinando Ametrano
5
 Copyright (C) 2009 Frédéric Degraeve
6
7
 This file is part of QuantLib, a free-software/open-source library
8
 for financial quantitative analysts and developers - http://quantlib.org/
9
10
 QuantLib is free software: you can redistribute it and/or modify it
11
 under the terms of the QuantLib license.  You should have received a
12
 copy of the license along with this program; if not, please email
13
 <quantlib-dev@lists.sf.net>. The license is also available online at
14
 <https://www.quantlib.org/license.shtml>.
15
16
 This program is distributed in the hope that it will be useful, but WITHOUT
17
 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
18
 FOR A PARTICULAR PURPOSE.  See the license for more details.
19
*/
20
21
/*! \file linesearchbasedmethod.hpp
22
    \brief Abstract optimization method class
23
*/
24
25
#ifndef quantlib_line_search_based_optimization_method_h
26
#define quantlib_line_search_based_optimization_method_h
27
28
#include <ql/math/optimization/method.hpp>
29
#include <ql/math/array.hpp>
30
#include <ql/shared_ptr.hpp>
31
32
namespace QuantLib {
33
34
    class LineSearch;
35
36
    //! Line search based method
37
    class LineSearchBasedMethod : public OptimizationMethod {
38
      public:
39
        explicit LineSearchBasedMethod(
40
            ext::shared_ptr<LineSearch> lSearch = ext::shared_ptr<LineSearch>());
41
0
        ~LineSearchBasedMethod() override = default;
42
43
        EndCriteria::Type minimize(Problem& P, const EndCriteria& endCriteria) override;
44
45
      protected:
46
        //! computes the new search direction
47
        virtual Array getUpdatedDirection(const Problem &P,
48
                                          Real gold2,
49
                                          const Array& gradient) = 0;
50
        //! line search
51
        ext::shared_ptr<LineSearch> lineSearch_;
52
    };
53
54
}
55
56
#endif