OR-Tools  9.3
quadratic_program_io.cc
Go to the documentation of this file.
1// Copyright 2010-2021 Google LLC
2// Licensed under the Apache License, Version 2.0 (the "License");
3// you may not use this file except in compliance with the License.
4// You may obtain a copy of the License at
5//
6// http://www.apache.org/licenses/LICENSE-2.0
7//
8// Unless required by applicable law or agreed to in writing, software
9// distributed under the License is distributed on an "AS IS" BASIS,
10// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
11// See the License for the specific language governing permissions and
12// limitations under the License.
13
15
16#include <algorithm>
17#include <cmath>
18#include <cstdint>
19#include <limits>
20#include <string>
21#include <utility>
22#include <vector>
23
24#include "Eigen/Core"
25#include "Eigen/SparseCore"
26#include "absl/base/casts.h"
27#include "absl/container/flat_hash_map.h"
28#include "absl/status/status.h"
29#include "absl/status/statusor.h"
30#include "absl/strings/match.h"
31#include "absl/types/optional.h"
33#include "ortools/base/file.h"
37#include "ortools/linear_solver/linear_solver.pb.h"
42
44
45// TODO(user): Update internal helper functions to use references instead of
46// pointers.
47
48using ::operations_research::glop::MPSReader;
49
50QuadraticProgram ReadQuadraticProgramOrDie(const std::string& filename,
51 bool include_names) {
52 if (absl::EndsWith(filename, ".mps") || absl::EndsWith(filename, ".mps.gz") ||
53 absl::EndsWith(filename, ".mps.bz2")) {
54 return ReadMpsLinearProgramOrDie(filename, include_names);
55 }
56 if (absl::EndsWith(filename, ".pb") ||
57 absl::EndsWith(filename, ".textproto") ||
58 absl::EndsWith(filename, ".json") ||
59 absl::EndsWith(filename, ".json.gz")) {
60 return ReadMPModelProtoFileOrDie(filename, include_names);
61 }
62 LOG(QFATAL) << "Invalid filename suffix in " << filename
63 << ". Valid suffixes are .mps, .mps.gz, .pb, .textproto,"
64 << ".json, and .json.gz";
65}
66
68 bool include_names) {
69 MPModelProto lp_proto;
70 LOG(INFO) << "Reading " << lp_file;
71 QCHECK_OK(MPSReader().ParseFile(lp_file, &lp_proto));
72 // MPSReader sometimes fails silently if the file isn't read properly.
73 QCHECK_GT(lp_proto.variable_size(), 0)
74 << "No variables in LP. Error reading file? " << lp_file;
75 auto result = QpFromMpModelProto(lp_proto, /*relax_integer_variables=*/true,
76 include_names);
77 QCHECK_OK(result);
78 return *std::move(result);
79}
80
82 const std::string& mpmodel_proto_file, bool include_names) {
83 MPModelProto lp_proto;
84 QCHECK(ReadFileToProto(mpmodel_proto_file, &lp_proto)) << mpmodel_proto_file;
85 auto result = QpFromMpModelProto(lp_proto, /*relax_integer_variables=*/true,
86 include_names);
87 QCHECK_OK(result);
88 return *std::move(result);
89}
90
91absl::Status WriteLinearProgramToMps(const QuadraticProgram& linear_program,
92 const std::string& mps_file) {
93 if (!IsLinearProgram(linear_program)) {
94 return absl::InvalidArgumentError(
95 "'linear_program' has a quadratic objective");
96 }
97 ASSIGN_OR_RETURN(MPModelProto proto, QpToMpModelProto(linear_program));
98 ASSIGN_OR_RETURN(std::string mps_export, ExportModelAsMpsFormat(proto));
99 File* file;
100 RETURN_IF_ERROR(file::Open(mps_file, "w", &file, file::Defaults()));
101 auto status = file::WriteString(file, mps_export, file::Defaults());
102 status.Update(file->Close(file::Defaults()));
103 return status;
104}
105
107 const QuadraticProgram& quadratic_program,
108 const std::string& mpmodel_proto_file) {
109 ASSIGN_OR_RETURN(MPModelProto proto, QpToMpModelProto(quadratic_program));
110
111 return file::SetBinaryProto(mpmodel_proto_file, proto, file::Defaults());
112}
113
114} // namespace operations_research::pdlp
#define QCHECK_GT
Definition: base/logging.h:42
#define QCHECK_OK
Definition: base/logging.h:45
#define QCHECK
Definition: base/logging.h:39
#define LOG(severity)
Definition: base/logging.h:420
#define ASSIGN_OR_RETURN(lhs, rexpr)
#define RETURN_IF_ERROR(expr)
Definition: base/file.h:33
CpModelProto proto
absl::Status status
Definition: g_gurobi.cc:35
const int INFO
Definition: log_severity.h:31
absl::Status WriteString(File *file, const absl::string_view &contents, int flags)
Definition: base/file.cc:184
int Defaults()
Definition: base/file.h:120
absl::Status SetBinaryProto(const absl::string_view &filename, const google::protobuf::Message &proto, int flags)
Definition: base/file.cc:308
absl::Status Open(const absl::string_view &filename, const absl::string_view &mode, File **f, int flags)
Definition: base/file.cc:142
void ParseFile(const std::string &filename, bool presolve)
Definition: parser_main.cc:36
absl::StatusOr< QuadraticProgram > QpFromMpModelProto(const MPModelProto &proto, bool relax_integer_variables, bool include_names)
absl::Status WriteQuadraticProgramToMPModelProto(const QuadraticProgram &quadratic_program, const std::string &mpmodel_proto_file)
absl::StatusOr< MPModelProto > QpToMpModelProto(const QuadraticProgram &qp)
bool IsLinearProgram(const QuadraticProgram &qp)
absl::Status WriteLinearProgramToMps(const QuadraticProgram &linear_program, const std::string &mps_file)
QuadraticProgram ReadMPModelProtoFileOrDie(const std::string &mpmodel_proto_file, bool include_names)
QuadraticProgram ReadQuadraticProgramOrDie(const std::string &filename, bool include_names)
QuadraticProgram ReadMpsLinearProgramOrDie(const std::string &lp_file, bool include_names)
absl::StatusOr< std::string > ExportModelAsMpsFormat(const MPModelProto &model, const MPModelExportOptions &options)
Outputs the current model (variables, constraints, objective) as a string encoded in MPS file format,...
bool ReadFileToProto(absl::string_view filename, google::protobuf::Message *proto)
Definition: file_util.cc:45