Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
sagemath
GitHub Repository: sagemath/sagelib
Path: blob/master/sage/numerical/backends/cplex_backend.pxd
4057 views
##############################################################################
#       Copyright (C) 2010 Nathann Cohen <[email protected]>
#  Distributed under the terms of the GNU General Public License (GPL)
#  The full text of the GPL is available at:
#                  http://www.gnu.org/licenses/
##############################################################################

from sage.numerical.backends.generic_backend cimport GenericBackend

include '../../../../../devel/sage/sage/ext/stdsage.pxi'
include '../../ext/cdefs.pxi'            

cdef struct c_cpxlp

cdef extern from *:
    ctypedef double* const_double_ptr "double*"


cdef class CPLEXBackend(GenericBackend):
    cdef bint _mixed
    cdef c_cpxlp * env
    cdef c_cpxlp * lp
    cdef current_sol
    cpdef CPLEXBackend copy(self)

cdef extern from "../../local/include/cplex.h":

     # Create problem
     c_cpxlp * CPXcreateprob (c_cpxlp *  env, int *status_p,
                              char *probname_str)

     # Add constraints
     int CPXaddrows (c_cpxlp * env, c_cpxlp *  lp, int ccnt, int rcnt,
                   int nzcnt, double *rhs, char *sense,
                   int *rmatbeg, int *rmatind,
                   double *rmatval, char **colname,
                   char **rowname)

     # Remove constraints
     int CPXdelrows(c_cpxlp * env, c_cpxlp * lp, int begin, int end)

     # Solve MILP
     int CPXmipopt (c_cpxlp * env, c_cpxlp * lp)

     # Solve LP
     int CPXlpopt (c_cpxlp * env, c_cpxlp * lp)

     # Solve MILP through filling the solution pool
     int CPXpopulate (c_cpxlp * env, c_cpxlp * lp)

     # Number of solutions in the pool
     int CPXgetsolnpoolx (c_cpxlp * env, c_cpxlp * lp, int id, double * x, int beg, int end)

     # Set the sense of the optimization problem
     int CPXchgobjsen(c_cpxlp * env, c_cpxlp * lp, int)

     # Gets the sense of the optimization problem
     int CPXgetobjsen(c_cpxlp * env, c_cpxlp * lp)

     # Change the coefficient of a variable in the objective function
     int CPXchgobj(c_cpxlp * env, c_cpxlp * lp, int cnt, int * indices, double * values)

     # Sets the problem's name
     int CPXchgprobname(c_cpxlp * env, c_cpxlp * lp, char * probname_str)

     # Gets the problem's name
     int CPXgetprobname(c_cpxlp * env, c_cpxlp * lp, char * buf_str, int bufspace, int * surplus_p)

     # Get a col's name
     int CPXgetcolname(c_cpxlp * env, c_cpxlp * lp, char ** name, char * namestore, int storespace, int * surplus_p, int begin, int end)

     # Get a row's name
     int CPXgetrowname(c_cpxlp * env, c_cpxlp * lp, char ** name, char * namestore, int storespace, int * surplus_p, int begin, int end)

     # Sets a row's name
     int CPXchgrowname(c_cpxlp * env, c_cpxlp * lp, int cnt, int * indices, char ** newname)

     # Sets a col's name
     int CPXchgcolname(c_cpxlp * env, c_cpxlp * lp, int cnt, int * indices, char ** newname)

     # Set a "double" parameter
     int CPXsetdblparam (c_cpxlp * env, int, double)

     # Set an integer parameter
     int CPXsetintparam  (c_cpxlp * env, int whichparam, int newvalue)

     # Number of solutions in the pool
     int CPXgetsolnpoolnumsolns (c_cpxlp * env, c_cpxlp * lp)

     # Number of replaces solutions in the pool
     int CPXgetsolnpoolnumreplaced(c_cpxlp * env, c_cpxlp * lp)
     
     # Remove a solution from the pool
     int CPXdelsolnpoolsolns (c_cpxlp * env, c_cpxlp * lp, int begin, int end)

     int CPXgetsubstat (c_cpxlp * env, c_cpxlp * lp)

     # Get the objective value
     int CPXgetobjval (c_cpxlp *, c_cpxlp *, double *)

     # Add columns
     int CPXnewcols(c_cpxlp * env, c_cpxlp * lp, int, double *, double *, double *, char *, char **)

     # Add rows
     int CPXnewrows(c_cpxlp * env, c_cpxlp * lp, int rcnt, double * rhs, char * sense, double * rngval, char ** rowname)

     # Get the right hand side of a row
     int CPXgetrhs(c_cpxlp * env, c_cpxlp * lp, double * rhs, int begin, int end)

     # Get the sense of a constraint
     int CPXgetsense(c_cpxlp * env, c_cpxlp * lp, char * sense, int begin, int end)
     
     # Get rows
     int CPXgetrows(c_cpxlp * env, c_cpxlp * lp, int * nzcnt_p, int * rmatbeg, int * rmatind, double * rmatval, int rmatspace, int * surplus_p, int begin, int end)

     # Get a variable's maximum value
     int CPXgetub(c_cpxlp * env, c_cpxlp * lp, double * ub, int begin, int end)

     # Get a variable's minimum value
     int CPXgetlb(c_cpxlp * env, c_cpxlp * lp, double * lb, int begin, int end)
     
     # Changes the bounds of a variable
     int CPXchgbds(c_cpxlp * env, c_cpxlp * lp, int cnt, int * indices, char * lu, double * bd)

     # Get a coefficient of the objective function
     int CPXgetobj(c_cpxlp * env, c_cpxlp * lp, double * obj, int begin, int end)

     # Change coefficients in the matrix
     int CPXchgcoeflist(c_cpxlp * env, c_cpxlp * lp, int numcoefs, int * rowlist, int * collist, double * vallist)

     # get solution of a MILP
     int CPXsolution(c_cpxlp * env, c_cpxlp * lp, int * lpstat, double * obj, double * x, double *, double *, double *)

     # get the value of some variables in the solution of a LP
     int CPXgetx(c_cpxlp * env, c_cpxlp * lp, double * x, int begin, int end)

     # Create a CPLEX enviromnment
     c_cpxlp * CPXopenCPLEX (int *status_p)

     # Close a CPLEX enviromnment
     int CPXcloseCPLEX (c_cpxlp ** env)

     # Free the problem's ressources
     int CPXfreeprob (c_cpxlp * env, c_cpxlp ** lp)

     # Change the type of a variable
     int CPXchgctype(c_cpxlp * env, c_cpxlp * lp, int cnt, int * indices, char * xctype)

     # Gets the type of a variable
     int CPXgetctype(c_cpxlp * env, c_cpxlp * lp, char * xctype, int begin, int end)

     # Get information about the solution computed
     int CPXsolninfo(c_cpxlp * env, c_cpxlp * lp, int * solnmethod_p, int * solntype_p, int * pfeasind_p, int * dfeasind_p)

     # Returns the number of rows
     int CPXgetnumrows(c_cpxlp * env, c_cpxlp * lp)

     # Returns the number of columns
     int CPXgetnumcols(c_cpxlp * env, c_cpxlp * lp)
     
     # Write the problem to a file
     int CPXwriteprob(c_cpxlp * env, c_cpxlp * lp, char * filename_str, char * filetype_str)

     # Get the problem's type
     int CPXgetprobtype(c_cpxlp * env, c_cpxlp * lp)

     # Set the problem's type
     int CPXchgprobtype(c_cpxlp * env, c_cpxlp * lp, int type)

     # Change a row's range
     int CPXchgrngval(c_cpxlp * env, c_cpxlp * lp, int cnt, int * indices, double * values)

     # Get a row's range
     int CPXgetrngval(c_cpxlp * env, c_cpxlp * lp, double * rngval, int begin, int end)

     # Copy a LP
     c_cpxlp * CPXcloneprob(c_cpxlp * env, c_cpxlp * lp, int * status_p)

     # Gets the type of a CPLEX parameter
     int CPXgetparamtype(c_cpxlp * env, int paramid, int * paramtype)

     # returns the value of an integer prameter
     int CPXgetintparam(c_cpxlp * env, int paramid, int * intv)

     # returns the value of a double prameter
     int CPXgetdblparam(c_cpxlp * env, int paramid, double * doublev)

     # returns the value of a string prameter
     int CPXgetstrparam(c_cpxlp * env, int paramid, char * strv)

     # sets the value of an integer parameter
     int CPXsetintparam(c_cpxlp * env, int paramid, int value)

     # sets the value of a double parameter
     int CPXsetdblparam(c_cpxlp * env, int paramid, double value)

     # sets the value of a string parameter
     int CPXsetstrparam(c_cpxlp * env, int paramid, char * value)

     # CONSTANTS
     int CPX_ON = 1
     int CPX_PARAM_SCRIND = 1035
     int CPX_INFBOUND = 1.0E+20
     int CPX_PARAM_POPULATELIM = 2108
     int CPX_PARAM_SOLNPOOLGAP = 2105
     int CPX_PARAM_SOLNPOOLINTENSITY = 2107
     int CPX_MAX = -1
     int CPX_MIN = 1