Scippy

GCG

Branch-and-Price & Column Generation for Everyone

bipartitegraph.h
Go to the documentation of this file.
1 /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2 /* */
3 /* This file is part of the program */
4 /* GCG --- Generic Column Generation */
5 /* a Dantzig-Wolfe decomposition based extension */
6 /* of the branch-cut-and-price framework */
7 /* SCIP --- Solving Constraint Integer Programs */
8 /* */
9 /* Copyright (C) 2010-2021 Operations Research, RWTH Aachen University */
10 /* Zuse Institute Berlin (ZIB) */
11 /* */
12 /* This program is free software; you can redistribute it and/or */
13 /* modify it under the terms of the GNU Lesser General Public License */
14 /* as published by the Free Software Foundation; either version 3 */
15 /* of the License, or (at your option) any later version. */
16 /* */
17 /* This program is distributed in the hope that it will be useful, */
18 /* but WITHOUT ANY WARRANTY; without even the implied warranty of */
19 /* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the */
20 /* GNU Lesser General Public License for more details. */
21 /* */
22 /* You should have received a copy of the GNU Lesser General Public License */
23 /* along with this program; if not, write to the Free Software */
24 /* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.*/
25 /* */
26 /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
27 
28 /**@file graph.h
29  * @brief miscellaneous graph methods for structure detection
30  * @author Martin Bergner
31  */
32 
33 /*---+----1----+----2----+----3----+----4----+----5----+----6----+----7----+----8----+----9----+----0----+----1----+----2*/
34 
35 #ifndef GCG_BIPARTITEGRAPH_H_
36 #define GCG_BIPARTITEGRAPH_H_
37 
38 #include "matrixgraph.h"
39 #include "graph.h"
40 
41 namespace gcg {
42 
43 template <class T>
44 class BipartiteGraph : public MatrixGraph<T>
45 {
46 private:
47  Graph<T> graph;
48 public:
50  SCIP* scip, /**< SCIP data structure */
51  Weights w /**< weights for the given graph */
52  );
53  virtual ~BipartiteGraph();
54  virtual SCIP_RETCODE createFromMatrix(
55  SCIP_CONS** conss, /**< constraints for which graph should be created */
56  SCIP_VAR** vars, /**< variables for which graph should be created */
57  int nconss_, /**< number of constraints */
58  int nvars_ /**< number of variables */
59  );
60 
61 
62  virtual SCIP_RETCODE createFromPartialMatrix(
63  DETPROBDATA* detprobdata,
64  PARTIALDECOMP* partialdec
65  );
66 
67  int getNConsNodes();
68  int getNVarNodes();
69 };
70 
71 } /* namespace gcg */
72 #endif /* GCG_BIPARTITEGRAPH_H_ */
virtual SCIP_RETCODE createFromPartialMatrix(DETPROBDATA *detprobdata, PARTIALDECOMP *partialdec)
miscellaneous matrixgraph methods for structure detection
BipartiteGraph(SCIP *scip, Weights w)
virtual SCIP_RETCODE createFromMatrix(SCIP_CONS **conss, SCIP_VAR **vars, int nconss_, int nvars_)
class to manage partial decompositions
miscellaneous graph methods for structure detection