Initializing help system before first use

problem.addcbprenode

problem.addcbprenode


Purpose
Declares a preprocess node callback function, called before the LP relaxation of a node has been optimized, so the solution at the node will not be available. This callback function will be called in addition to any callbacks already added by addcbprenode.
Synopsis

problem.addcbprenode (callback, data, priority)

nodinfeas = callback (my_prob, my_object)


Arguments
callback 
The callback function, which takes three arguments, my_prob, my_object and nodinfeas, and has no return value. This function is called before a node is reoptimized and the node may be made infeasible by setting *nodinfeas to 1.
my_prob 
The problem passed to the callback function, callback.
my_object 
The user-defined object passed as object when setting up the callback with addcbprenode.
nodinfeas 
The feasibility status. If set to a nonzero value by the user, the current node will be declared infeasible by the Optimizer.
data 
A user-defined object to be passed to the callback function, callback.
priority 
An integer that determines the order in which multiple preprocess node callbacks will be invoked. The callback added with a higher priority will be called before a callback with a lower priority. Set to 0 if not required.
Example
The following example notifies the user before each node is processed:
prob.addcbprenode (preNode, None, 0)
prob.mipoptimize ("")
The callback function might resemble:
def preNode (prob, object):

    return 0 # set to 1 if node is infeasible
Related topics