OR-Tools  9.3
mps_reader.h
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
14// A reader for files in the MPS format.
15// see http://lpsolve.sourceforge.net/5.5/mps-format.htm
16// and http://www.ici.ro/camo/language/ml11.htm.
17//
18// MPS stands for Mathematical Programming System.
19//
20// The format was invented by IBM in the 60's, and has become the de facto
21// standard. We developed this reader to be able to read benchmark data files.
22// Using the MPS file format for new models is discouraged.
23
24#ifndef OR_TOOLS_LP_DATA_MPS_READER_H_
25#define OR_TOOLS_LP_DATA_MPS_READER_H_
26
27#include <limits>
28#include <memory>
29#include <string>
30#include <vector>
31
32#include "absl/container/flat_hash_map.h"
33#include "absl/container/flat_hash_set.h"
34#include "absl/flags/declare.h"
35#include "absl/status/status.h"
36#include "absl/status/statusor.h"
37#include "absl/strings/numbers.h"
38#include "ortools/base/hash.h"
40#include "ortools/base/macros.h" // for DISALLOW_COPY_AND_ASSIGN, NULL
44#include "ortools/linear_solver/linear_solver.pb.h"
48
49namespace operations_research {
50namespace glop {
51
52// Parses an MPS model from a string.
53absl::StatusOr<MPModelProto> MpsDataToMPModelProto(const std::string& mps_data);
54
55// Parses an MPS model from a file.
56absl::StatusOr<MPModelProto> MpsFileToMPModelProto(const std::string& mps_file);
57
58// Implementation class. Please use the 2 functions above.
59//
60// Reads a linear program in the mps format.
61//
62// All Parse() methods clear the previously parsed instance and store the result
63// in the given Data class.
64//
65// TODO(user): Remove the MPSReader class.
66class ABSL_DEPRECATED("Use the direct methods instead") MPSReader {
67 public:
68 enum Form { AUTO_DETECT, FREE, FIXED };
69
70 // Parses instance from a file.
71 absl::Status ParseFile(const std::string& file_name, LinearProgram* data,
72 Form form = AUTO_DETECT);
73
74 absl::Status ParseFile(const std::string& file_name, MPModelProto* data,
75 Form form = AUTO_DETECT);
76 // Loads instance from string. Useful with MapReduce. Automatically detects
77 // the file's format (free or fixed).
78 absl::Status ParseProblemFromString(const std::string& source,
79 LinearProgram* data,
80 MPSReader::Form form = AUTO_DETECT);
81 absl::Status ParseProblemFromString(const std::string& source,
82 MPModelProto* data,
83 MPSReader::Form form = AUTO_DETECT);
84};
85
86} // namespace glop
87} // namespace operations_research
88
89#endif // OR_TOOLS_LP_DATA_MPS_READER_H_
void ParseFile(const std::string &filename, bool presolve)
Definition: parser_main.cc:36
absl::StatusOr< MPModelProto > MpsDataToMPModelProto(const std::string &mps_data)
Definition: mps_reader.cc:1170
absl::StatusOr< MPModelProto > MpsFileToMPModelProto(const std::string &mps_file)
Definition: mps_reader.cc:1178
class ABSL_DEPRECATED("Use the direct methods instead") MPSReader
Definition: mps_reader.h:66
Collection of objects used to extend the Constraint Solver library.