summaryrefslogtreecommitdiff
path: root/thirdparty/linux/include/coin1/IpMuUpdate.hpp
blob: b6c1d9c1cecf85ae6fd7a3b717cd152803fa271f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
// Copyright (C) 2004, 2006 International Business Machines and others.
// All Rights Reserved.
// This code is published under the Eclipse Public License.
//
// $Id: IpMuUpdate.hpp 1861 2010-12-21 21:34:47Z andreasw $
//
// Authors:  Carl Laird, Andreas Waechter     IBM    2004-08-13

#ifndef __IPMUUPDATE_HPP__
#define __IPMUUPDATE_HPP__

#include "IpAlgStrategy.hpp"

namespace Ipopt
{
  /** Abstract Base Class for classes that implement methods for computing
   *  the barrier and fraction-to-the-boundary rule parameter for the
   *  current iteration.
   */
  class MuUpdate : public AlgorithmStrategyObject
  {
  public:
    /**@name Constructors/Destructors */
    //@{
    /** Default Constructor */
    MuUpdate()
    {}

    /** Default destructor */
    virtual ~MuUpdate()
    {}
    //@}

    /** Initialize method - overloaded from AlgorithmStrategyObject */
    virtual bool InitializeImpl(const OptionsList& options,
                                const std::string& prefix) = 0;

    /** Method for determining the barrier parameter for the next
     *  iteration.  A LineSearch object is passed, so that this method
     *  can call the Reset method in the LineSearch object, for
     *  example when then barrier parameter is changed. This method is
     *  also responsible for setting the fraction-to-the-boundary
     *  parameter tau.  This method returns false if the update could
     *  not be performed and the algorithm should revert to an
     *  emergency fallback mechanism. */
    virtual bool UpdateBarrierParameter() = 0;

  private:
    /**@name Default Compiler Generated Methods
     * (Hidden to avoid implicit creation/calling).
     * These methods are not implemented and 
     * we do not want the compiler to implement
     * them for us, so we declare them private
     * and do not define them. This ensures that
     * they will not be implicitly created/called. */
    //@{

    /** Copy Constructor */
    MuUpdate(const MuUpdate&);

    /** Overloaded Equals Operator */
    void operator=(const MuUpdate&);
    //@}

  };

} // namespace Ipopt

#endif