Scippy

SCIP

Solving Constraint Integer Programs

objeventhdlr.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 objeventhdlr.cpp
26 * @brief C++ wrapper for event handlers
27 * @author Tobias Achterberg
28 */
29
30/*---+----1----+----2----+----3----+----4----+----5----+----6----+----7----+----8----+----9----+----0----+----1----+----2*/
31
32#include <cassert>
33
34#include "objeventhdlr.h"
35
36
37
38
39/*
40 * Data structures
41 */
42
43/** event handler data */
44struct SCIP_EventhdlrData
45{
46 scip::ObjEventhdlr* objeventhdlr; /**< event handler object */
47 SCIP_Bool deleteobject; /**< should the event handler object be deleted when eventhdlr is freed? */
48};
49
50
51
52
53/*
54 * Callback methods of event handler
55 */
56
57extern "C"
58{
59
60/** copy method for event handler plugins (called when SCIP copies plugins) */
61static
62SCIP_DECL_EVENTCOPY(eventhdlrCopyObj)
63{ /*lint --e{715}*/
64 SCIP_EVENTHDLRDATA* eventhdlrdata;
65
66 assert(scip != NULL);
67
68 eventhdlrdata = SCIPeventhdlrGetData(eventhdlr);
69 assert(eventhdlrdata != NULL);
70 assert(eventhdlrdata->objeventhdlr != NULL);
71 assert(eventhdlrdata->objeventhdlr->scip_ != scip);
72
73 if( eventhdlrdata->objeventhdlr->iscloneable() )
74 {
75 scip::ObjEventhdlr* newobjeventhdlr;
76 newobjeventhdlr = dynamic_cast<scip::ObjEventhdlr*> (eventhdlrdata->objeventhdlr->clone(scip));
77
78 /* call include method of event handler object */
79 SCIP_CALL( SCIPincludeObjEventhdlr(scip, newobjeventhdlr, TRUE) );
80 }
81
82 return SCIP_OKAY;
83}
84
85/** destructor of event handler to free user data (called when SCIP is exiting) */
86static
87SCIP_DECL_EVENTFREE(eventhdlrFreeObj)
88{ /*lint --e{715}*/
89 SCIP_EVENTHDLRDATA* eventhdlrdata;
90
91 eventhdlrdata = SCIPeventhdlrGetData(eventhdlr);
92 assert(eventhdlrdata != NULL);
93 assert(eventhdlrdata->objeventhdlr != NULL);
94 assert(eventhdlrdata->objeventhdlr->scip_ == scip);
95
96 /* call virtual method of eventhdlr object */
97 SCIP_CALL( eventhdlrdata->objeventhdlr->scip_free(scip, eventhdlr) );
98
99 /* free eventhdlr object */
100 if( eventhdlrdata->deleteobject )
101 delete eventhdlrdata->objeventhdlr;
102
103 /* free eventhdlr data */
104 delete eventhdlrdata;
105 SCIPeventhdlrSetData(eventhdlr, NULL); /*lint !e64*/
106
107 return SCIP_OKAY;
108}
109
110
111/** initialization method of event handler (called after problem was transformed) */
112static
113SCIP_DECL_EVENTINIT(eventhdlrInitObj)
114{ /*lint --e{715}*/
115 SCIP_EVENTHDLRDATA* eventhdlrdata;
116
117 eventhdlrdata = SCIPeventhdlrGetData(eventhdlr);
118 assert(eventhdlrdata != NULL);
119 assert(eventhdlrdata->objeventhdlr != NULL);
120 assert(eventhdlrdata->objeventhdlr->scip_ == scip);
121
122 /* call virtual method of eventhdlr object */
123 SCIP_CALL( eventhdlrdata->objeventhdlr->scip_init(scip, eventhdlr) );
124
125 return SCIP_OKAY;
126}
127
128
129/** deinitialization method of event handler (called before transformed problem is freed) */
130static
131SCIP_DECL_EVENTEXIT(eventhdlrExitObj)
132{ /*lint --e{715}*/
133 SCIP_EVENTHDLRDATA* eventhdlrdata;
134
135 eventhdlrdata = SCIPeventhdlrGetData(eventhdlr);
136 assert(eventhdlrdata != NULL);
137 assert(eventhdlrdata->objeventhdlr != NULL);
138
139 /* call virtual method of eventhdlr object */
140 SCIP_CALL( eventhdlrdata->objeventhdlr->scip_exit(scip, eventhdlr) );
141
142 return SCIP_OKAY;
143}
144
145
146/** solving process initialization method of event handler (called when branch and bound process is about to begin) */
147static
148SCIP_DECL_EVENTINITSOL(eventhdlrInitsolObj)
149{ /*lint --e{715}*/
150 SCIP_EVENTHDLRDATA* eventhdlrdata;
151
152 eventhdlrdata = SCIPeventhdlrGetData(eventhdlr);
153 assert(eventhdlrdata != NULL);
154 assert(eventhdlrdata->objeventhdlr != NULL);
155
156 /* call virtual method of eventhdlr object */
157 SCIP_CALL( eventhdlrdata->objeventhdlr->scip_initsol(scip, eventhdlr) );
158
159 return SCIP_OKAY;
160}
161
162
163/** solving process deinitialization method of event handler (called before branch and bound process data is freed) */
164static
165SCIP_DECL_EVENTEXITSOL(eventhdlrExitsolObj)
166{ /*lint --e{715}*/
167 SCIP_EVENTHDLRDATA* eventhdlrdata;
168
169 eventhdlrdata = SCIPeventhdlrGetData(eventhdlr);
170 assert(eventhdlrdata != NULL);
171 assert(eventhdlrdata->objeventhdlr != NULL);
172
173 /* call virtual method of eventhdlr object */
174 SCIP_CALL( eventhdlrdata->objeventhdlr->scip_exitsol(scip, eventhdlr) );
175
176 return SCIP_OKAY;
177}
178
179
180/** frees specific constraint data */
181static
182SCIP_DECL_EVENTDELETE(eventhdlrDeleteObj)
183{ /*lint --e{715}*/
184 SCIP_EVENTHDLRDATA* eventhdlrdata;
185
186 eventhdlrdata = SCIPeventhdlrGetData(eventhdlr);
187 assert(eventhdlrdata != NULL);
188 assert(eventhdlrdata->objeventhdlr != NULL);
189
190 /* call virtual method of eventhdlr object */
191 SCIP_CALL( eventhdlrdata->objeventhdlr->scip_delete(scip, eventhdlr, eventdata) );
192
193 return SCIP_OKAY;
194}
195
196
197/** execution method of event handler */
198static
199SCIP_DECL_EVENTEXEC(eventhdlrExecObj)
200{ /*lint --e{715}*/
201 SCIP_EVENTHDLRDATA* eventhdlrdata;
202
203 eventhdlrdata = SCIPeventhdlrGetData(eventhdlr);
204 assert(eventhdlrdata != NULL);
205 assert(eventhdlrdata->objeventhdlr != NULL);
206
207 /* call virtual method of eventhdlr object */
208 SCIP_CALL( eventhdlrdata->objeventhdlr->scip_exec(scip, eventhdlr, event, eventdata) );
209
210 return SCIP_OKAY;
211}
212}
213
214
215
216/*
217 * event handler specific interface methods
218 */
219
220/** creates the event handler for the given event handler object and includes it in SCIP */
222 SCIP* scip, /**< SCIP data structure */
223 scip::ObjEventhdlr* objeventhdlr, /**< event handler object */
224 SCIP_Bool deleteobject /**< should the event handler object be deleted when eventhdlr is freed? */
225 )
226{
227 SCIP_EVENTHDLRDATA* eventhdlrdata;
228
229 assert(scip != NULL);
230 assert(objeventhdlr != NULL);
231
232 /* create event handler data */
233 eventhdlrdata = new SCIP_EVENTHDLRDATA;
234 eventhdlrdata->objeventhdlr = objeventhdlr;
235 eventhdlrdata->deleteobject = deleteobject;
236
237 /* include event handler */
238 SCIP_CALL( SCIPincludeEventhdlr(scip, objeventhdlr->scip_name_, objeventhdlr->scip_desc_,
239 eventhdlrCopyObj,
240 eventhdlrFreeObj, eventhdlrInitObj, eventhdlrExitObj,
241 eventhdlrInitsolObj, eventhdlrExitsolObj, eventhdlrDeleteObj, eventhdlrExecObj,
242 eventhdlrdata) ); /*lint !e429*/
243
244 return SCIP_OKAY; /*lint !e429*/
245}
246
247/** returns the eventhdlr object of the given name, or 0 if not existing */
249 SCIP* scip, /**< SCIP data structure */
250 const char* name /**< name of event handler */
251 )
252{
253 SCIP_EVENTHDLR* eventhdlr;
254 SCIP_EVENTHDLRDATA* eventhdlrdata;
255
256 eventhdlr = SCIPfindEventhdlr(scip, name);
257 if( eventhdlr == NULL )
258 return 0;
259
260 eventhdlrdata = SCIPeventhdlrGetData(eventhdlr);
261 assert(eventhdlrdata != NULL);
262
263 return eventhdlrdata->objeventhdlr;
264}
265
266/** returns the eventhdlr object for the given event handler */
268 SCIP* scip, /**< SCIP data structure */
269 SCIP_EVENTHDLR* eventhdlr /**< event handler */
270 )
271{
272 SCIP_EVENTHDLRDATA* eventhdlrdata;
273
274 assert(scip != NULL);
275 eventhdlrdata = SCIPeventhdlrGetData(eventhdlr);
276 assert(eventhdlrdata != NULL);
277
278 return eventhdlrdata->objeventhdlr;
279}
C++ wrapper for event handlers.
Definition: objeventhdlr.h:53
#define NULL
Definition: def.h:266
#define SCIP_Bool
Definition: def.h:91
#define TRUE
Definition: def.h:93
#define SCIP_CALL(x)
Definition: def.h:373
SCIP_RETCODE SCIPincludeEventhdlr(SCIP *scip, const char *name, const char *desc, SCIP_DECL_EVENTCOPY((*eventcopy)), SCIP_DECL_EVENTFREE((*eventfree)), SCIP_DECL_EVENTINIT((*eventinit)), SCIP_DECL_EVENTEXIT((*eventexit)), SCIP_DECL_EVENTINITSOL((*eventinitsol)), SCIP_DECL_EVENTEXITSOL((*eventexitsol)), SCIP_DECL_EVENTDELETE((*eventdelete)), SCIP_DECL_EVENTEXEC((*eventexec)), SCIP_EVENTHDLRDATA *eventhdlrdata)
Definition: scip_event.c:63
SCIP_EVENTHDLR * SCIPfindEventhdlr(SCIP *scip, const char *name)
Definition: scip_event.c:234
SCIP_EVENTHDLRDATA * SCIPeventhdlrGetData(SCIP_EVENTHDLR *eventhdlr)
Definition: event.c:334
void SCIPeventhdlrSetData(SCIP_EVENTHDLR *eventhdlr, SCIP_EVENTHDLRDATA *eventhdlrdata)
Definition: event.c:344
scip::ObjEventhdlr * SCIPfindObjEventhdlr(SCIP *scip, const char *name)
static SCIP_DECL_EVENTEXIT(eventhdlrExitObj)
static SCIP_DECL_EVENTINITSOL(eventhdlrInitsolObj)
static SCIP_DECL_EVENTINIT(eventhdlrInitObj)
scip::ObjEventhdlr * SCIPgetObjEventhdlr(SCIP *scip, SCIP_EVENTHDLR *eventhdlr)
static SCIP_DECL_EVENTDELETE(eventhdlrDeleteObj)
static SCIP_DECL_EVENTFREE(eventhdlrFreeObj)
static SCIP_DECL_EVENTEXITSOL(eventhdlrExitsolObj)
SCIP_RETCODE SCIPincludeObjEventhdlr(SCIP *scip, scip::ObjEventhdlr *objeventhdlr, SCIP_Bool deleteobject)
static SCIP_DECL_EVENTCOPY(eventhdlrCopyObj)
static SCIP_DECL_EVENTEXEC(eventhdlrExecObj)
C++ wrapper for event handlers.
struct SCIP_EventhdlrData SCIP_EVENTHDLRDATA
Definition: type_event.h:155
@ SCIP_OKAY
Definition: type_retcode.h:42
enum SCIP_Retcode SCIP_RETCODE
Definition: type_retcode.h:63