Scippy

SCIP

Solving Constraint Integer Programs

objbenderscut.cpp
Go to the documentation of this file.
1/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2/* */
3/* This file is part of the program and library */
4/* SCIP --- Solving Constraint Integer Programs */
5/* */
6/* Copyright (c) 2002-2024 Zuse Institute Berlin (ZIB) */
7/* */
8/* Licensed under the Apache License, Version 2.0 (the "License"); */
9/* you may not use this file except in compliance with the License. */
10/* You may obtain a copy of the License at */
11/* */
12/* http://www.apache.org/licenses/LICENSE-2.0 */
13/* */
14/* Unless required by applicable law or agreed to in writing, software */
15/* distributed under the License is distributed on an "AS IS" BASIS, */
16/* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. */
17/* See the License for the specific language governing permissions and */
18/* limitations under the License. */
19/* */
20/* You should have received a copy of the Apache-2.0 license */
21/* along with SCIP; see the file LICENSE. If not visit scipopt.org. */
22/* */
23/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
24
25/**@file objbenderscut.cpp
26 * @brief C++ wrapper for the Benders' decomposition cut plugins
27 * @author Stephen J. Maher
28 */
29
30/*---+----1----+----2----+----3----+----4----+----5----+----6----+----7----+----8----+----9----+----0----+----1----+----2*/
31
32#include <cassert>
33
34#include "objbenderscut.h"
35
36
37
38
39/*
40 * Data structures
41 */
42
43/** Benders' decomposition data */
44struct SCIP_BenderscutData
45{
46 scip::ObjBenderscut* objbenderscut; /**< the Benders' decomposition object */
47 SCIP_Bool deleteobject; /**< should the Benders' decomposition object be deleted when benders is freed? */
48};
49
50
51
52
53/*
54 * Callback methods of the Benders' decomposition framework
55 */
56
57extern "C"
58{
59
60/** copy method for Benders' decomposition cuts (called when SCIP copies plugins) */
61static
62SCIP_DECL_BENDERSCUTCOPY(benderscutCopyObj)
63{ /*lint --e{715}*/
64 SCIP_BENDERSCUTDATA* benderscutdata;
65
66 assert(scip != NULL);
67
68 benderscutdata = SCIPbenderscutGetData(benderscut);
69 assert(benderscutdata != NULL);
70 assert(benderscutdata->objbenderscut != NULL);
71 assert(benderscutdata->objbenderscut->scip_ != scip);
72
73 if( benderscutdata->objbenderscut->iscloneable() )
74 {
75 scip::ObjBenderscut* newobjbenderscut;
76 newobjbenderscut = dynamic_cast<scip::ObjBenderscut*> (benderscutdata->objbenderscut->clone(scip));
77
78 /* call include method of Benders' decomposition object */
79 SCIP_CALL( SCIPincludeObjBenderscut(scip, SCIPgetObjBenders(scip, benders), newobjbenderscut, TRUE) );
80 }
81
82 return SCIP_OKAY;
83}
84
85/** destructor of Benders' decomposition cut to free user data (called when SCIP is exiting) */
86static
87SCIP_DECL_BENDERSCUTFREE(benderscutFreeObj)
88{ /*lint --e{715}*/
89 SCIP_BENDERSCUTDATA* benderscutdata;
90
91 benderscutdata = SCIPbenderscutGetData(benderscut);
92 assert(benderscutdata != NULL);
93 assert(benderscutdata->objbenderscut != NULL);
94 assert(benderscutdata->objbenderscut->scip_ == scip);
95
96 /* call virtual method of benderscut object */
97 SCIP_CALL( benderscutdata->objbenderscut->scip_free(scip, benderscut) );
98
99 /* free benderscut object */
100 if( benderscutdata->deleteobject )
101 delete benderscutdata->objbenderscut;
102
103 /* free benderscut data */
104 delete benderscutdata;
105 SCIPbenderscutSetData(benderscut, NULL); /*lint !e64*/
106
107 return SCIP_OKAY;
108}
109
110
111/** initialization method of Benders' decomposition cut (called after problem was transformed) */
112static
113SCIP_DECL_BENDERSCUTINIT(benderscutInitObj)
114{ /*lint --e{715}*/
115 SCIP_BENDERSCUTDATA* benderscutdata;
116
117 benderscutdata = SCIPbenderscutGetData(benderscut);
118 assert(benderscutdata != NULL);
119 assert(benderscutdata->objbenderscut != NULL);
120 assert(benderscutdata->objbenderscut->scip_ == scip);
121
122 /* call virtual method of benderscut object */
123 SCIP_CALL( benderscutdata->objbenderscut->scip_init(scip, benderscut) );
124
125 return SCIP_OKAY;
126}
127
128
129/** deinitialization method of Benders' decomposition cut (called before transformed problem is freed) */
130static
131SCIP_DECL_BENDERSCUTEXIT(benderscutExitObj)
132{ /*lint --e{715}*/
133 SCIP_BENDERSCUTDATA* benderscutdata;
134
135 benderscutdata = SCIPbenderscutGetData(benderscut);
136 assert(benderscutdata != NULL);
137 assert(benderscutdata->objbenderscut != NULL);
138
139 /* call virtual method of benderscut object */
140 SCIP_CALL( benderscutdata->objbenderscut->scip_exit(scip, benderscut) );
141
142 return SCIP_OKAY;
143}
144
145
146/** solving process initialization method of Benders' decomposition cut (called when branch and bound process is about to begin) */
147static
148SCIP_DECL_BENDERSCUTINITSOL(benderscutInitsolObj)
149{ /*lint --e{715}*/
150 SCIP_BENDERSCUTDATA* benderscutdata;
151
152 benderscutdata = SCIPbenderscutGetData(benderscut);
153 assert(benderscutdata != NULL);
154 assert(benderscutdata->objbenderscut != NULL);
155
156 /* call virtual method of benderscut object */
157 SCIP_CALL( benderscutdata->objbenderscut->scip_initsol(scip, benderscut) );
158
159 return SCIP_OKAY;
160}
161
162
163/** solving process deinitialization method of Benders' decomposition cut (called before branch and bound process data is freed) */
164static
165SCIP_DECL_BENDERSCUTEXITSOL(benderscutExitsolObj)
166{ /*lint --e{715}*/
167 SCIP_BENDERSCUTDATA* benderscutdata;
168
169 benderscutdata = SCIPbenderscutGetData(benderscut);
170 assert(benderscutdata != NULL);
171 assert(benderscutdata->objbenderscut != NULL);
172
173 /* call virtual method of benderscut object */
174 SCIP_CALL( benderscutdata->objbenderscut->scip_exitsol(scip, benderscut) );
175
176 return SCIP_OKAY;
177}
178
179
180/** execution method of the Benders' decomposition cuts */
181static
182SCIP_DECL_BENDERSCUTEXEC(benderscutExecObj)
183{ /*lint --e{715}*/
184 SCIP_BENDERSCUTDATA* benderscutdata;
185
186 benderscutdata = SCIPbenderscutGetData(benderscut);
187 assert(benderscutdata != NULL);
188 assert(benderscutdata->objbenderscut != NULL);
189
190 /* call virtual method of benderscut object */
191 SCIP_CALL( benderscutdata->objbenderscut->scip_exec(scip, benders, benderscut, sol, probnumber, type, result) );
192
193 return SCIP_OKAY;
194}
195
196
197}
198
199
200/*
201 * Benders' decomposition cut specific interface methods
202 */
203
204/** creates the Benders' decomposition cut for the given Benders' decomposition cut object and includes it in SCIP */
206 SCIP* scip, /**< SCIP data structure */
207 scip::ObjBenders* objbenders, /**< Benders' decomposition object */
208 scip::ObjBenderscut* objbenderscut, /**< Benders' decomposition cut object */
209 SCIP_Bool deleteobject /**< should the Benders' decomposition cut object be deleted when benderscut is freed? */
210 )
211{
212 SCIP_BENDERS* benders;
213 SCIP_BENDERSCUTDATA* benderscutdata;
214
215 assert(scip != NULL);
216 assert(objbenderscut != NULL);
217 assert(objbenderscut->scip_ == scip);
218
219 /* create obj Benderscut' decomposition data */
220 benderscutdata = new SCIP_BENDERSCUTDATA;
221 benderscutdata->objbenderscut = objbenderscut;
222 benderscutdata->deleteobject = deleteobject;
223
224 benders = SCIPfindBenders(scip, objbenders->scip_name_);
225 assert(benders != NULL);
226
227 /* include Benderscut' decomposition */
228 SCIP_CALL( SCIPincludeBenderscut(scip, benders, objbenderscut->scip_name_, objbenderscut->scip_desc_,
229 objbenderscut->scip_priority_, objbenderscut->scip_islpcut_, benderscutCopyObj, benderscutFreeObj,
230 benderscutInitObj, benderscutExitObj, benderscutInitsolObj, benderscutExitsolObj, benderscutExecObj,
231 benderscutdata) ); /*lint !e429*/
232
233 return SCIP_OKAY; /*lint !e429*/
234}
235
236/** returns the benderscut object of the given name, or 0 if not existing */
238 scip::ObjBenders* objbenders, /**< Benders' decomposition object */
239 const char* name /**< name of Benderscut' decomposition */
240 )
241{
242 SCIP_BENDERS* benders;
243 SCIP_BENDERSCUT* benderscut;
244 SCIP_BENDERSCUTDATA* benderscutdata;
245
246 benders = SCIPfindBenders(objbenders->scip_, objbenders->scip_name_);
247 assert(benders != NULL);
248
249 benderscut = SCIPfindBenderscut(benders, name);
250 if( benderscut == NULL )
251 return 0;
252
253 benderscutdata = SCIPbenderscutGetData(benderscut);
254 assert(benderscutdata != NULL);
255
256 return benderscutdata->objbenderscut;
257}
258
259/** returns the benderscut object for the given Benderscut' decomposition */
261 SCIP* scip, /**< SCIP data structure */
262 SCIP_BENDERSCUT* benderscut /**< Benderscut' decomposition */
263 )
264{
265 SCIP_BENDERSCUTDATA* benderscutdata;
266
267 assert(scip != NULL);
268 benderscutdata = SCIPbenderscutGetData(benderscut);
269 assert(benderscutdata != NULL);
270
271 return benderscutdata->objbenderscut;
272}
C++ wrapper for Benders' decomposition plugins.
Definition: objbenders.h:57
char * scip_name_
Definition: objbenders.h:65
C++ wrapper for Benders' decomposition cut plugin.
Definition: objbenderscut.h:57
const SCIP_Bool scip_islpcut_
Definition: objbenderscut.h:74
const int scip_priority_
Definition: objbenderscut.h:71
#define NULL
Definition: def.h:267
#define SCIP_Bool
Definition: def.h:91
#define TRUE
Definition: def.h:93
#define SCIP_CALL(x)
Definition: def.h:374
SCIP_BENDERS * SCIPfindBenders(SCIP *scip, const char *name)
Definition: scip_benders.c:493
SCIP_BENDERSCUT * SCIPfindBenderscut(SCIP_BENDERS *benders, const char *name)
Definition: benders.c:6917
SCIP_RETCODE SCIPincludeBenderscut(SCIP *scip, SCIP_BENDERS *benders, const char *name, const char *desc, int priority, SCIP_Bool islpcut, SCIP_DECL_BENDERSCUTCOPY((*benderscutcopy)), SCIP_DECL_BENDERSCUTFREE((*benderscutfree)), SCIP_DECL_BENDERSCUTINIT((*benderscutinit)), SCIP_DECL_BENDERSCUTEXIT((*benderscutexit)), SCIP_DECL_BENDERSCUTINITSOL((*benderscutinitsol)), SCIP_DECL_BENDERSCUTEXITSOL((*benderscutexitsol)), SCIP_DECL_BENDERSCUTEXEC((*benderscutexec)), SCIP_BENDERSCUTDATA *benderscutdata)
void SCIPbenderscutSetData(SCIP_BENDERSCUT *benderscut, SCIP_BENDERSCUTDATA *benderscutdata)
Definition: benderscut.c:413
SCIP_BENDERSCUTDATA * SCIPbenderscutGetData(SCIP_BENDERSCUT *benderscut)
Definition: benderscut.c:403
scip::ObjBenders * SCIPgetObjBenders(SCIP *scip, SCIP_BENDERS *benders)
Definition: objbenders.cpp:392
static SCIP_DECL_BENDERSCUTINIT(benderscutInitObj)
static SCIP_DECL_BENDERSCUTEXIT(benderscutExitObj)
static SCIP_DECL_BENDERSCUTEXITSOL(benderscutExitsolObj)
SCIP_RETCODE SCIPincludeObjBenderscut(SCIP *scip, scip::ObjBenders *objbenders, scip::ObjBenderscut *objbenderscut, SCIP_Bool deleteobject)
static SCIP_DECL_BENDERSCUTEXEC(benderscutExecObj)
scip::ObjBenderscut * SCIPgetObjBenderscut(SCIP *scip, SCIP_BENDERSCUT *benderscut)
scip::ObjBenderscut * SCIPfindObjBenderscut(scip::ObjBenders *objbenders, const char *name)
static SCIP_DECL_BENDERSCUTCOPY(benderscutCopyObj)
static SCIP_DECL_BENDERSCUTFREE(benderscutFreeObj)
static SCIP_DECL_BENDERSCUTINITSOL(benderscutInitsolObj)
C++ wrapper for the Benders' decomposition cut plugins.
struct SCIP_BenderscutData SCIP_BENDERSCUTDATA
@ SCIP_OKAY
Definition: type_retcode.h:42
enum SCIP_Retcode SCIP_RETCODE
Definition: type_retcode.h:63