summaryrefslogtreecommitdiff
path: root/thirdparty/linux/include/coin/coin/BonHeuristicRINS.hpp
blob: 5dcc68b6633c241b9936e3335f4b8fbcce58ba22 (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
// (C) Copyright CNRS and International Business Machines Corporation
// All Rights Reserved.
// This code is published under the Eclipse Public License.
//
// Authors :
// Pierre Bonami, LIF Université de la Méditérannée-CNRS
// Joao Goncalves, International Business Machines Corporation
//
// Date : 06/18/2008

#ifndef BonHeuristicRINS_H
#define BonHeuristicRINS_H
#include "BonLocalSolverBasedHeuristic.hpp"

namespace Bonmin {
  class HeuristicRINS:public LocalSolverBasedHeuristic {
    public:
     /** Default constructor*/
     HeuristicRINS();
    /** Constructor with setup.*/
    HeuristicRINS(BonminSetup * setup);

     /** Copy constructor.*/
     HeuristicRINS(const HeuristicRINS &other);
     /** Virtual constructor.*/
     virtual CbcHeuristic * clone() const{
      return new HeuristicRINS(*this);
     }

     /** Destructor*/
     virtual ~HeuristicRINS();

     /** Runs heuristic*/
     int solution(double & objectiveValue,
                  double * newSolution);
   /** Register the options common to all local search based heuristics.*/
   static void registerOptions(Ipopt::SmartPtr<Bonmin::RegisteredOptions> roptions);

   /** Initiaize using passed options.*/
   void Initialize(Ipopt::SmartPtr<Ipopt::OptionsList> options);

    /// Sets how often to do it
    inline void setHowOften(int value)
    { howOften_=value;}

  private:
    /// How often to do (code can change)
    int howOften_;
    /// Number of solutions so we can do something at solution
    int numberSolutions_;

  };

}/* Ends Bonmin namepace.*/
#endif