I'm trying to develop an algorithm to solve a specific mixed integer problem in cplex.
When I try to run the algorithm, I get the following text:
Traceback (most recent call last):
Here the log shows the directory of the files of my algorithm for a few lines
.
.
.
.
and finally:
File "/anaconda2/lib/python2.7/site-packages/cplex/__init__.py", line 1099, in solve
_proc.mipopt(self._env._e, self._lp)
File "/anaconda2/lib/python2.7/site-packages/cplex/_internal/_procedural.py", line 629, in mipopt
check_status(env, status)
File "/anaconda2/lib/python2.7/site-packages/cplex/_internal/_procedural.py", line 303, in __call__
raise CplexSolverError(error_string, env, status)
cplex.exceptions.errors.CplexSolverError: CPLEX Error 1006: Error during callback.
Do you have any idea of what could cause error in that files?
I have a few code files:
This is the file where the resolution is launched, it is called G_resoluciones:
import G_Callbacks
import G_Heuristica
import gc
import D2MIPpG
import cplex
import os
def ResolvemosBC_q_C_norm(E,I,J,K,p,R,C):
D2_C_DrBC_C_norm = open(os.path.abspath(os.path.join(os.getcwd(), '..'))+"/G_ResultsD2_C_DrBC_Cp_norm.txt", "a")
tiemposD2_C_DrBC_norm = {}
tiemposRelD2_C_DrBC_norm = {}
nodosD2_C_DrBC_norm = {}
CODD2_C_DrBC_norm={}
ValObjD2_C_DrBC_norm = {}
ValRelD2_C_DrBC_norm = {}
MSJD2_C_DrBC_norm = {}
MIPGAPD2_C_DrBC_norm = {}
OptimalityGapD2_C_DrBC_norm = {}
CutsD2_C_DrBC_norm = {}
IterD2_C_DrBC_norm = {}
BestBoundD2_C_DrBC_norm = {}
IncD2_C_DrBC_norm = {}
LP_GORDO_C_DrBC_norm = {}
sH,thetaH,xH,qH,fobjH={},{},{},{},{}
m1 = D2MIPpG.solveD2(I,J,K,p,R,C)
sH,thetaH,xH,qH,fobjH=G_Heuristica.HeuristicaGeneral(p,I,K,J,R,C)
qHH={}
indi=[]
for k in range(K):
for j in range(J):
qHH[J*k+j]=qH[k,j]
coefi=[]
for i in range(I):
coefi.append(xH[i])
for j in range(I,I+J*K,1):
coefi.append(qHH[j-I])
for j in range(I+J*K,I+J*K+K,1):
coefi.append(sH[j-I-J*K])
for j in range(I+J*K+K,I+J*K+K+K,1):
coefi.append(thetaH[j-I-J*K-K])
for i in range(len(coefi)):
indi.append(i)
m1.MIP_starts.add(cplex.SparsePair(ind=indi, val=coefi), m1.MIP_starts.effort_level.solve_fixed,"primera") # primeros valores
Nodos_cb = m1.register_callback(G_Callbacks.Nodos)
Nodos_cb.times_called = 0
Inc=m1.register_callback(G_Callbacks.Incumbente)
G_Callbacks.Cplex_callback_D2BC_C_norm.model=m1
G_Callbacks.Cplex_callback_D2BC_C_norm.thetaVars=m1._data[3]
G_Callbacks.Cplex_callback_D2BC_C_norm.qVars=m1._data[1]
e=m1.register_callback(G_Callbacks.Cplex_callback_D2BC_C_norm)
e.iterations=0
e.iterationsR=0
m1.parameters.mip.cuts.mircut.set(-1)
m1.parameters.mip.cuts.gomory.set(-1)
m1.parameters.mip.limits.treememory.set(50000)
m1.parameters.mip.strategy.file.set(3)
m1.parameters.workmem.set(10000)
m1.parameters.timelimit.set(18000)
m1.parameters.preprocessing.presolve.set(0)
m1.parameters.preprocessing.numpass.set(0)
m1.parameters.threads.set(1)
m1.parameters.mip.strategy.fpheur.set(-1)
m1.parameters.mip.strategy.heuristicfreq.set(-1)
m1.parameters.mip.strategy.lbheur.set(0)
m1.parameters.mip.strategy.rinsheur.set(-1)
# m5._alpha=alpha
ValorObjetivoMejorado={}
Counter={}
m1._Counter = Counter
m1._ValorObjetivoMejorado = ValorObjetivoMejorado
m1._qH=qH
m1._thetaH=thetaH
m1._fobjH=fobjH
m1._K = K
m1._J = J
m1._p = p
m1._I = I
m1._R = R
m1._C = C
m1._FirstTime=1
start = m1.get_time()
m1.solve() #this is where the spyder says the error is
end = m1.get_time()
elapsed = end - start
solrEC_D=m1.solution
elapsedLP=e.stopic-start
ValObjD2_C_DrBC_norm,tiemposD2_C_DrBC_norm, nodosD2_C_DrBC_norm, MSJD2_C_DrBC_norm, CODD2_C_DrBC_norm,ValRelD2_C_DrBC_norm, tiemposRelD2_C_DrBC_norm, MIPGAPD2_C_DrBC_norm,OptimalityGapD2_C_DrBC_norm, CutsD2_C_DrBC_norm,IterD2_C_DrBC_norm,BestBoundD2_C_DrBC_norm,LP_GORDO_C_DrBC_norm=Escribe_Resultados_CUTANDBRANCH(m1,Nodos_cb,e,elapsed,elapsedLP)
D2_C_DrBC_C_norm.write('G_B&C_q_norm')
D2_C_DrBC_C_norm.write(' %d %d %d %d ' % (E, I, J, K))
D2_C_DrBC_C_norm.write(' %0.4f %0.4f %d %s %d %0.4f %0.4f %0.4f' % (float(ValObjD2_C_DrBC_norm), float(tiemposD2_C_DrBC_norm), nodosD2_C_DrBC_norm, MSJD2_C_DrBC_norm,CODD2_C_DrBC_norm, float(ValRelD2_C_DrBC_norm), float(tiemposRelD2_C_DrBC_norm), float(MIPGAPD2_C_DrBC_norm)))
D2_C_DrBC_C_norm.write(' %0.4f %d %d %0.4f' % (float(OptimalityGapD2_C_DrBC_norm), CutsD2_C_DrBC_norm,IterD2_C_DrBC_norm,float(BestBoundD2_C_DrBC_norm)))
D2_C_DrBC_C_norm.write(' %0.4f ' %(LP_GORDO_C_DrBC_norm))
D2_C_DrBC_C_norm.write(' 1')
D2_C_DrBC_C_norm.write("\n")
del m1
gc.collect()
def Escribe_Resultados_CUTANDBRANCH(modelo, callback1, callback2, elapsed, elapsedLP):
ValObj,tiempos,nodos, MSJ,COD,ValRel,tiemposRel,MIPGAP,OptimalityGap,Cuts,Iter,BestBound,LP_GORDO = {},{},{},{},{},{},{},{},{},{},{},{},{}
solrEC_D=modelo.solution
#OPTIMAL INTEGER SOLUTION FOUND OR OPTIMAL SOLUTION WITH EPGAP OR EPAGAP TOLERANCE FOUND
if solrEC_D.get_status()==101 or solrEC_D.get_status()==102:
ValObj=solrEC_D.get_objective_value()
tiempos=elapsed
nodos=callback2.nodecnt
MSJ=solrEC_D.status[solrEC_D.get_status()]
COD=solrEC_D.get_status()
ValRel=callback2.LPValueWithCuts
tiemposRel=elapsedLP
MIPGAP=((ValRel-ValObj)/ValObj)*100
OptimalityGap=0
Cuts=callback2.cuts+1
Iter=callback2.iterationsR
BestBound=callback2.mipnodeobjbnd
LP_GORDO=callback2.TimeBetweenCalls
#TIMELIMIT REACHED BUT INTEGER SOL EXISTS
if solrEC_D.get_status()==107:
ValObj=solrEC_D.get_objective_value()
tiempos=elapsed
nodos=-1
MSJ=solrEC_D.status[solrEC_D.get_status()]
COD=solrEC_D.get_status()
ValRel=callback2.LPValueWithCuts
tiemposRel=elapsedLP
MIPGAP=-1
OptimalityGap=callback1.MIP_relative_gap
Cuts=callback2.cuts+1
Iter=callback2.iterationsR
BestBound=callback2.mipnodeobjbnd
LP_GORDO=callback2.TimeBetweenCalls
#TIMELIMIT REACHED BUT INTEGER SOL DOES NOT EXIST
if solrEC_D.get_status()==108:
ValObj=-1
tiempos=elapsed
nodos=-1
MSJ=solrEC_D.status[solrEC_D.get_status()]
COD=solrEC_D.get_status()
ValRel=callback2.LPValueWithCuts
tiemposRel=elapsedLP
MIPGAP=-1
OptimalityGap=-1
Cuts=callback2.cuts+1
Iter=callback2.iterationsR
BestBound=callback2.mipnodeobjbnd
LP_GORDO=callback2.TimeBetweenCalls
#INFEASIBLE OR UNBOUNDED
if solrEC_D.get_status()==119:
ValObj=-1
tiempos=elapsed
nodos=-1
MSJ=solrEC_D.status[solrEC_D.get_status()]
COD=solrEC_D.get_status()
ValRel=-1
tiemposRel=-1
MIPGAP=-1
OptimalityGap=-1
Cuts=-1
Iter=-1
BestBound=-1
LP_GORDO=0
return ValObj,tiempos,nodos, MSJ,COD,ValRel,tiemposRel,MIPGAP,OptimalityGap,Cuts,Iter,BestBound,LP_GORDO
Now the other code files that are called for the first:
G_callbacks:
from __future__ import division
import cplex.callbacks
from cplex.callbacks import MIPInfoCallback
import G_SeparationProblems
import numpy
import operator
#MIPInfoCallback
class Nodos(MIPInfoCallback):
num_nodes=-1
best_OBJ=-1
MIP_relative_gap=-1
times_called =0
LPSol= -1
FirstT = 1
stopinc=0
#These values are set in case the problem is solved at the first iteration of the root, because if that happens I guess
#we never even get to call the callback. In any case, that never happens for my instances.
def __call__(self):
self.times_called += 1
self.num_nodes=self.get_num_nodes()
self.best_OBJ=self.get_best_objective_value()
self.MIP_relative_gap=self.get_MIP_relative_gap()
if self.times_called==1 and self.FirstT == 1:
self.LPSol=self.get_best_objective_value()
self.stopinc=self.get_time()
self.FirstT = 0
#IncumbentCallback
class Incumbente(cplex.callbacks.IncumbentCallback):
def __call__(self):
print "El callback Incumbente dice: "
print self.get_solution_source()
class Cplex_callback_D2BC_C_norm(cplex.callbacks.UserCutCallback):
def __init__(self,env):
cplex.callbacks.UserCutCallback.__init__(self,env)
self.env=env
LPValueWithCuts=-1
cuts=-1
iterations=0
lb=-cplex.infinity
ub=cplex.infinity
lbPrimal=-cplex.infinity
iterationsR=0
times_called=0
BeenOptimal=0
alpha = 0
q_sep={}
theta_sep={}
q_in={}
theta_in={}
cbasis={}
vbasis={}
te,ue,ve={},{},{}
tr,ur,vr={},{},{}
startic={}
RepDif= 0
Dif=0
DifAnterior=0
HaHabidoCortes=0
TimeBetweenCalls=-1
UES={}
max_index={}
max_value={}
q_puedeser={}
theta_puedeser={}
fobj_puedeser={}
cambio={}
def __call__(self):
if self.model._Counter == 1:
print "EN EL USER CUT CALLBACK : %s" %self.model._ValorObjetivoMejorado
Vars=sorted(self.thetaVars.values())
coeffs = {}
for k in range(self.model._K):
if not self.thetaVars[k] in coeffs:
coeffs[self.thetaVars[k]]=0
coeffs[self.thetaVars[k]]+=self.model._p[k]
self.add(cut=cplex.SparsePair(ind=coeffs.keys(),val=coeffs.values()),sense="L", rhs=self.model._ValorObjetivoMejorado,use=0)
self.model._Counter = 0
self.ub=self.get_objective_value()
print "ITERACION %s" %(self.times_called)
self.nodecnt=self.get_num_nodes()
print "Callback called %s times" %self.times_called
if self.times_called==0:
for k in range(self.model._K):
for j in range(self.model._J):
self.q_in[k,j]=self.model._qH[k,j]
for k in range(self.model._K):
self.theta_in[k]=self.model._thetaH[k]
self.DifAnterior=self.ub-self.lb
if self.RepDif >= 30:
print "SALTANDO QUE ES GERUNDIO!"
self.lb=self.ub
self.times_called+=1
self.startic[self.times_called] = self.model.get_time()
if self.nodecnt == 0 and self.times_called>=2:
self.TimeBetweenCalls=self.startic[self.times_called]-self.startic[self.times_called-1]
r=1
self.mipnodeobjbnd = self.get_objective_value()
if self.nodecnt == 1 and self.model._FirstTime == 1:
self.stopic = self.model.get_time()
self.model._FirstTime=0
if self.nodecnt >= 0:
self.stopic = self.model.get_time()
Vars2=sorted(self.thetaVars.values())
theta=self.get_values(Vars2)
Vars=sorted(self.qVars.values())
a=self.get_values(Vars)
data=numpy.array(a)
shape=(self.model._K, self.model._J)
q=data.reshape(shape)
sub={}
self.lbPrimal=self.get_incumbent_objective_value()
tr,ur,vr={},{},{}
self.CurrentBestObjBound=self.get_best_objective_value()
self.CurrentBestObj=self.get_incumbent_objective_value()
if self.ub-self.lbPrimal > 1e-4*self.ub:
self.alpha = 1
for k in range(self.model._K):
for j in range(self.model._J):
self.q_sep[k,j]=self.alpha*q[k,j]+(1-self.alpha)*self.q_in[k,j]
for k in range(self.model._K):
self.theta_sep[k]=self.alpha*theta[k]+(1-self.alpha)*self.theta_in[k]
print self.ub
print self.lb
if self.ub-self.lb > 1e-4*self.ub:
self.HaHabidoCortes=0
for k in range(self.model._K):
h=0
sub=G_SeparationProblems.SeparationProblem_q_C_norm(self.model._p,self.q_sep,self.theta_sep,self.model._I,self.model._J,self.model._K,self.model._R,self.model._C)
sub.set_problem_type(sub.problem_type.LP)
print "El Problema es un %s: %s" %(sub.get_problem_type(),sub.problem_type[sub.get_problem_type()])
sub.parameters.preprocessing.presolve.set(sub.parameters.preprocessing.presolve.values.off)
sub.parameters.lpmethod.set(sub.parameters.lpmethod.values.primal)
sub.solve()
if sub.solution.get_status()==sub.solution.status.optimal:
print "Estamos dentro para recuperar vertice"
a,aa={},{}
verticealpha={}
a=sub.solution.get_values(range(0,self.model._K*self.model._I,1))
data=numpy.array(a)
shape=(self.model._K,self.model._I)
aa=data.reshape(shape)
for k in range(self.model._K):
for i in range(self.model._I):
verticealpha[k,g,i]=aa[k,i]
b,bb={},{}
verticebeta={}
b=sub.solution.get_values(range(self.model._K*self.model._I, self.model._K*self.model._I+self.model._K*self.model._J,1))
data=numpy.array(b)
shape=(self.model._K,self.model._J)
bb=data.reshape(shape)
for k in range(self.model._K):
for j in range(self.model._J):
verticebeta[k,g,j]=bb[k,j]
c,cc={},{}
verticegamma={}
c=sub.solution.get_values(range(self.model._K*self.model._I+self.model._K*self.model._J, self.model._K*self.model._I+self.model._K*self.model._J+self.model._K*self.model._J*self.model._J,1))
data=numpy.array(c)
shape=(self.model._K, self.model._J, self.model._J)
cc=data.reshape(shape)
for k in range (self.model._K):
for l in range (self.model._J):
for j in range (self.model._J):
verticegamma[k,g,l,j]=cc[k,l,j]
ll={}
verticelamb={}
ll=sub.solution.get_values(range(self.model._K*self.model._I+self.model._K*self.model._J+self.model._K*self.model._J*self.model._J,self.model._K*self.model._I+self.model._K*self.model._J+self.model._K*self.model._J*self.model._J+self.model._K,1))
for k in range(self.model._K):
verticelamb[k,g]=ll[k]
h=h+1
self.iterations=self.iterations+1
print "h=%s" %h
if h!=0:
for a in range(h-1,h,1):
if(sum(self.theta_sep[k]*(1+self.model._p[k]*verticelamb[k,a]) for k in range(self.model._K))-1e-4> sum(self.q_sep[k,j]*verticebeta[k,a,j] for k in range(self.model._K) for j in range(self.model._J))):
self.HaHabidoCortes=1
r=r+1
coeffs={}
for k in range(self.model._K):
if not self.thetaVars[k] in coeffs:
coeffs[self.thetaVars[k]]=0
coeffs[self.thetaVars[k]]+=(1+self.model._p[k]*verticelamb[k,a])
for k in range(self.model._K):
for j in range(self.model._J):
if not self.qVars[k,j] in coeffs:
coeffs[self.qVars[k,j]]=0
coeffs[self.qVars[k,j]]-=verticebeta[k,a,j] #0 mas eso
self.add(cut=cplex.SparsePair(ind=coeffs.keys(),val=coeffs.values()), sense="L", rhs=0, use=self.use_cut.force)
print "CORTE DE OPTIMALIDAD AÑADIDO"
self.iterationsR += 1
self.lb=sub.solution.get_objective_value()
print "HAHABIDOCORTES: %s" %self.HaHabidoCortes
if self.HaHabidoCortes==0:
for k in range(self.model._K):
for j in range(self.model._J):
self.q_in[k,j]=self.q_sep[k,j]
for k in range(self.model._K):
self.theta_in[k]=self.theta_sep[k]
self.Dif=self.ub-self.lb
if self.DifAnterior-self.Dif==0:
self.RepDif+=1
print "DifAnterior:= %s -- Dif:= %s" %(self.DifAnterior, self.Dif)
else:
self.lb = -cplex.infinity
print "**************************"
print "NODE: %s" %self.nodecnt
print "UPPER BOUND: %s" %self.ub
print "LOWER BOUND D: %s" %self.lb
print "LOWER BOUND P: %s" %self.lbPrimal
print "**************************"
self.cuts=self.get_num_cuts(134) #134 is user cuts
self.startic[self.times_called] = self.model.get_time()
if self.nodecnt>=0:
self.LPValueWithCuts=sum(self.model._p[k]*theta[k] for k in range(self.model._K))
self.model._LPValueWithCuts=self.LPValueWithCuts
G_heuristica
import operator
import RANDUtilidades
import random
def HeuristicaGeneral(p,I,K,J,R,C):
x={}
q={}
UES={}
max_index={}
max_value={}
d={}
s={}
fobj={}
for i in range(I):
x[i]=float(1)
for i in range(I):
x[i]=x[i]/I
for k in range(K):
for j in range(J):
UES[k,j]=sum(C[k,i,j]*x[i] for i in range(I))
for k in range(K):
max_index[k], max_value[k] = max(enumerate(UES[k,j] for j in range(J)), key=operator.itemgetter(1))
for k in range(K):
for j in range(J):
if j == max_index[k]:
q[k,j]=1
else:
q[k,j]=0
for k in range(K):
d[k]=sum(R[k,i,max_index[k]]*x[i] for i in range(I))
for k in range(K):
s[k]=sum(C[k,i,max_index[k]]*x[i] for i in range(I))
fobj=sum(p[k]*d[k] for k in range(K))
return s,d,x,q,fobj
D2MIPG:
import cplex
def solveMIPpG(I,J,K,p,R,C):
model = cplex.Cplex()
#Definition of the variables
x, q, z = {},{},{}
for i in range(I):
x[i]=model.variables.add(obj=[0],lb=[0],ub=[1],types=["C"], names=["x[%s]" %i])[0]
for k in range(K):
for j in range(J):
q[k,j]=model.variables.add(obj=[0],lb=[0], types=["B"], names=["q[%s,%s]" %(k,j)])[0]
for k in range(K):
for j in range(J):
for i in range(I):
z[k,i,j]=model.variables.add(obj=[p[k]*R[k,i,j]], lb=[0], types=["C"], names=["z[%s,%s,%s]" %(k,i,j)])[0]
model.objective.set_sense(model.objective.sense.maximize)
#Model constraints
#Suma qjs igual a 1.
for k in range(K):
model.linear_constraints.add(lin_expr=[cplex.SparsePair(ind=[q[k,j] for j in range(J)],val=[1.0]*J)], senses=["E"], rhs=[1], names=['SumaProbs[%s]' %k])[0]
for k in range(K):
for j in range(J):
coef=[]
for i in range(I):
coef.append(1)
coef.append(-1)
var=[]
for i in range(I):
var.append(z[k,i,j])
var.append(q[k,j])
model.linear_constraints.add(lin_expr=[cplex.SparsePair(ind=var, val=coef)], senses=["E"], rhs=[0], names=['sumazsq[%s,%s]'%(k,j)])[0]
for k in range(K):
for i in range(I):
coef2=[]
for j in range(J):
coef2.append(1)
coef2.append(-1)
var2=[]
for j in range(J):
var2.append(z[k,i,j])
var2.append(x[i])
model.linear_constraints.add(lin_expr=[cplex.SparsePair(ind=var2, val=coef2)], senses=["E"], rhs=[0], names=['sumazsx[%s,%s]'%(k,i)])[0]
for k in range(K):
for j in range(J):
for l in range(J):
if j!=l:
coef3=[]
for i in range(I):
coef3.append(C[k,i,l]-C[k,i,j])
var3=[]
for i in range(I):
var3.append(z[k,i,j])
model.linear_constraints.add(lin_expr=[cplex.SparsePair(ind=var3, val=coef3)], senses=["L"], rhs=[0], names=['bestresp[%s,%s,%s]'%(k,l,j)])[0]
model._data = x, q, z
# model.write("MIPpGHAHA.lp")
return model
#This is the weak formulation D2 #Generador inicial del modelo
def solveD2(I,J,K,p,R,C):
model = cplex.Cplex()
#Definition of the variables
theta, s ,q, x = {},{},{},{}
for i in range(I):
x[i]=model.variables.add(obj=[0],lb=[0],ub=[1],types=["C"], names=["x[%s]" %i])[0]
for k in range(K):
for j in range(J):
q[k,j]=model.variables.add(obj=[0],lb=[0], types=["B"], names=["q[%s,%s]" %(k,j)])[0]
for k in range(K):
s[k] = model.variables.add(obj=[0], types=["C"], names=["s[%s]" % k])[0]
for k in range(K):
theta[k] = model.variables.add(obj=[p[k]], types=["C"], names=["theta[%s]" % k])[0]
model.objective.set_sense(model.objective.sense.maximize)
M1, M2= {}, {}
M1 = 2 * max(R.values()) + 1
M2 = 2 * max(C.values()) + 1
#Constraints of the model
#Suma qjs igual a 1.
for k in range(K):
model.linear_constraints.add(lin_expr=[cplex.SparsePair(ind=[q[k,j] for j in range(J)],val=[1.0]*J)], senses=["E"], rhs=[1], names=['SumaProbs[%s]' %k])[0]
model.linear_constraints.add(lin_expr=[cplex.SparsePair(ind=[x[i] for i in range(I)],val=[1.0]*I)], senses=["E"], rhs=[1], names=['Sumaxs'])[0]
for k in range(K):
for j in range(J):
coef=[]
coef.append(1)
for i in range(I):
coef.append(-R[k,i,j])
coef.append(M1)
vars=[]
vars.append(theta[k])
for i in range(I):
vars.append(x[i])
vars.append(q[k,j])
model.linear_constraints.add(lin_expr=[cplex.SparsePair(ind=vars, val=coef)], senses=["L"], rhs=[M1], names=['Bound_d[%s,%s]' %(k,j)])[0]
for k in range(K):
for j in range(J):
coef2=[]
coef2.append(1)
for i in range(I):
coef2.append(-C[k,i,j])
coef2.append(M2)
vars2=[]
vars2.append(s[k])
for i in range(I):
vars2.append(x[i])
vars2.append(q[k,j])
coef3=[]
coef3.append(1)
for i in range(I):
coef3.append(-C[k,i,j])
vars3=[]
vars3.append(s[k])
for i in range(I):
vars3.append(x[i])
model.linear_constraints.add(lin_expr=[cplex.SparsePair(ind=vars2,val=coef2)],senses=["L"], rhs=[M2], names=['bound_s1[%s,%s]' %(k,j)])[0]
model.linear_constraints.add(lin_expr=[cplex.SparsePair(ind=vars3, val=coef3)], senses=["G"], rhs=[0], names=['bound_s2[%s,%s]' %(k,j)])[0]
model._data = x, q, s, theta
# model.write("D2HAHA.lp")
return model
G_SeparationProblems
def SeparationProblem_q_C_norm(p,q,theta,I,J,K,R,C):
model=cplex.Cplex()
alpha,beta,gamma,lamb={},{},{},{}
for k in range(K):
for i in range(I):
alpha[k,i]=model.variables.add(obj=[0], lb=[-cplex.infinity], ub=[cplex.infinity], types=["C"], names=["alpha[%s,%s]"%(k,i)])[0]
for k in range(K):
for j in range(J):
beta[k,j]=model.variables.add(obj=[q[k,j]], lb=[-cplex.infinity], ub=[cplex.infinity], types=["C"], names=["beta[%s,%s]"%(k,j)])[0]
for k in range(K):
for l in range(J):
for j in range(J):
gamma[k,l,j]=model.variables.add(obj=[0], lb=[0], ub=[cplex.infinity], types=["C"], names=["gamma[%s,%s,%s]"%(k,l,j)])[0]
for k in range(K):
lamb[k]=model.variables.add(obj=[p[k]*theta[k]], lb=[0], ub=[cplex.infinity], types=["C"], names=["lambda[%s]"%(k)])[0]
model.objective.set_sense(model.objective.sense.minimize)
#Restricciones
for k in range(K):
for i in range(I):
for j in range(J):
var=[]
var.append(alpha[k,i])
var.append(beta[k,j])
var.apend(lamb[k])
for l in range(J):
if l!=j:
var.append(gamma[k,l,j])
coef=[]
coef.append(1)
coef.append(1)
coef.append(p[k]*R[k,i,j])
for l in range(J):
if l!=j:
coef.append(C[k,i,l]-C[k,i,j])
model.linear_constraints.add(lin_expr=[cplex.SparsePair(ind=var,val=coef)], senses=["G"], rhs=[0], names=['1era[%s,%s,%s]'%(k,i,j)])[0]
for i in range(I):
var=[]
for k in range(K):
var.append(alpha[k,i])
coef=[]
for k in range(K):
coef.append(-1)
model.linear_constraints.add(lin_expr=[cplex.SparsePair(ind=var,val=coef)], senses=["G"], rhs=[0], names=['2a[%s]'%(i)])[0]
var=[]
for k in range(K):
var.append(lamb[k])
for j in range(J):
for k in range(K):
var.append(beta[k,j])
coef=[]
for k in range(K):
coef.append(-1)
for j in range(J):
for k in range(K):
coef.append(1)
model.linear_constraints.add(lin_expr=[cplex.SparsePair(ind=var,val=coef)], senses=["E"], rhs=[-1], names=['norm'])[0]
model._data = alpha,beta,gamma,lamb
return model
My instances are ok and running with other algorithms without problems.
The best way to debug errors in callbacks is to wrap your callback code into a try/except
block, print the actual exception from that and then re-raise it:
try:
# callback code here
...
except:
print(sys.exc_info()[0])
raise
That will tell you what exactly went wrong.