CbcCutSubsetModifier.hpp 1.57 KB
Newer Older
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
// $Id$
// Copyright (C) 2003, International Business Machines
// Corporation and others.  All Rights Reserved.
// This code is licensed under the terms of the Eclipse Public License (EPL).

//Edwin 11/25/09 carved out of CbcCutGenerator

#ifndef CbcCutSubsetModifier_H
#define CbcCutSubsetModifier_H

#include "OsiSolverInterface.hpp"
#include "OsiCuts.hpp"
#include "CglCutGenerator.hpp"
#include "CbcCutModifier.hpp"

class CbcModel;
class OsiRowCut;
class OsiRowCutDebugger;
/** Simple cut modifier base class

    In exotic circumstances - cuts may need to be modified
    a) strengthened - changed
    b) weakened - changed
    c) deleted - set to NULL
    d) unchanged

    initially get rid of cuts with variables >= k
    could weaken
*/

class CbcCutSubsetModifier : public CbcCutModifier {
public:
  /// Default Constructor
  CbcCutSubsetModifier();

  /// Useful Constructor
  CbcCutSubsetModifier(int firstOdd);

  // Copy constructor
  CbcCutSubsetModifier(const CbcCutSubsetModifier &);

  /// Destructor
  virtual ~CbcCutSubsetModifier();

  /// Assignment
  CbcCutSubsetModifier &operator=(const CbcCutSubsetModifier &rhs);
  /// Clone
  virtual CbcCutModifier *clone() const;

  /** Returns
        0 unchanged
        1 strengthened
        2 weakened
        3 deleted
    */
  virtual int modify(const OsiSolverInterface *solver, OsiRowCut &cut);
  /// Create C++ lines to get to current state
  virtual void generateCpp(FILE *) {}

protected:
  /// data
  /// First odd variable
  int firstOdd_;
};

#endif //CbcCutSubsetModifier_H

/* vi: softtabstop=2 shiftwidth=2 expandtab tabstop=2
*/