Skip to content

Commit

Permalink
[issue1111] Change how data is passed to CPLEX to avoid crashes.
Browse files Browse the repository at this point in the history
We fix a bug where CPLEX crashed when provided with an empty constraint system.
  • Loading branch information
ClemensBuechner authored Jul 9, 2024
1 parent 54e8669 commit ba7f864
Showing 1 changed file with 27 additions and 12 deletions.
39 changes: 27 additions & 12 deletions src/search/lp/cplex_solver_interface.h
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,21 @@
#include <cplex.h>

namespace lp {
template<typename T>
static T *to_cplex_array(std::vector<T> &v) {
/*
CPLEX expects a non-nullptr even for empty arrays but the C++ standard
does not guarantee any particular value for data for empty vectors (see
issue1111).
*/
if (v.empty()) {
static T dummy;
return &dummy;
} else {
return v.data();
}
}

class CplexSolverInterface : public SolverInterface {
CPXENVptr env;
CPXLPptr problem;
Expand Down Expand Up @@ -90,10 +105,10 @@ class CplexSolverInterface : public SolverInterface {
void assign_row_by_row(
const named_vector::NamedVector<LPConstraint> &constraints);

double *get_coefficients() {return coefficients.data();}
int *get_indices() {return indices.data();}
int *get_starts() {return starts.data();}
int *get_counts() {return counts.data();}
double *get_coefficients() {return to_cplex_array(coefficients);}
int *get_indices() {return to_cplex_array(indices);}
int *get_starts() {return to_cplex_array(starts);}
int *get_counts() {return to_cplex_array(counts);}
int get_num_nonzeros() {return coefficients.size();}
};

Expand All @@ -108,10 +123,10 @@ class CplexSolverInterface : public SolverInterface {
std::vector<double> objective;
public:
void assign(const named_vector::NamedVector<LPVariable> &variables);
double *get_lb() {return lb.data();}
double *get_ub() {return ub.data();}
char *get_type() {return type.data();}
double *get_objective() {return objective.data();}
double *get_lb() {return to_cplex_array(lb);}
double *get_ub() {return to_cplex_array(ub);}
char *get_type() {return to_cplex_array(type);}
double *get_objective() {return to_cplex_array(objective);}
};

class CplexRowsInfo {
Expand All @@ -131,10 +146,10 @@ class CplexSolverInterface : public SolverInterface {
std::vector<int> range_indices;
public:
void assign(const named_vector::NamedVector<LPConstraint> &constraints, int offset = 0, bool dense_range_values = true);
double *get_rhs() {return rhs.data();}
char *get_sense() {return sense.data();}
double *get_range_values() {return range_values.data();}
int *get_range_indices() {return range_indices.data();}
double *get_rhs() {return to_cplex_array(rhs);}
char *get_sense() {return to_cplex_array(sense);}
double *get_range_values() {return to_cplex_array(range_values);}
int *get_range_indices() {return to_cplex_array(range_indices);}
int get_num_ranged_rows() {return range_indices.size();}
};

Expand Down

0 comments on commit ba7f864

Please sign in to comment.