16#include "absl/strings/numbers.h"
17#include "absl/strings/str_split.h"
25 : num_dimensions_(-1),
26 load_status_(NOT_STARTED),
32 if (load_status_ != NOT_STARTED) {
38 for (
const std::string& line :
FileLines(file_name)) {
39 ProcessNew2BpLine(line, instance);
40 if (load_status_ == PARSING_FINISHED) {
44 return num_items_ == problem_.
items_size() && num_items_ > 0;
47void BinPacking2dParser::ProcessNew2BpLine(
const std::string& line,
49 const std::vector<std::string> words =
50 absl::StrSplit(line, absl::ByAnyChar(
" :\t\r"), absl::SkipEmpty());
51 if (words.size() == 3 && words[1] ==
"PROBLEM" && words[2] ==
"CLASS") {
54 if (load_status_ == NOT_STARTED && instances_seen_ == instance) {
55 load_status_ = INSTANCE_FOUND;
56 }
else if (instances_seen_ > instance) {
57 load_status_ = PARSING_FINISHED;
61 if (load_status_ == INSTANCE_FOUND) {
64 }
else if (words.size() == 2 || words[2] ==
"H(I),W(I),I=1,...,N") {
68 MultipleDimensionsBinPackingItem* item = problem_.
add_items();
69 MultipleDimensionsBinPackingShape* shape = item->
add_shapes();
71 CHECK(absl::SimpleAtoi(words[0], &dim));
72 shape->add_dimensions(dim);
73 CHECK(absl::SimpleAtoi(words[1], &dim));
74 shape->add_dimensions(dim);
76 }
else if (words[1] ==
"N.") {
77 CHECK(absl::SimpleAtoi(words[0], &num_items_));
78 }
else if (words[2] ==
"RELATIVE") {
81 CHECK(absl::SimpleAtoi(words[0], &local_instance));
82 CHECK_EQ(local_instance, (instance - 1) % 10 + 1);
83 }
else if (words[2] ==
"HBIN,WBIN") {
84 MultipleDimensionsBinPackingShape* box_shape =
87 CHECK(absl::SimpleAtoi(words[0], &dim));
88 box_shape->add_dimensions(dim);
89 CHECK(absl::SimpleAtoi(words[1], &dim));
90 box_shape->add_dimensions(dim);
#define CHECK_LT(val1, val2)
#define CHECK_EQ(val1, val2)
#define CHECK_NE(val1, val2)
bool Load2BPFile(const std::string &file_name, int instance)
::operations_research::packing::MultipleDimensionsBinPackingShape * add_shapes()
::operations_research::packing::MultipleDimensionsBinPackingItem * add_items()
::operations_research::packing::MultipleDimensionsBinPackingShape * mutable_box_shape()
Collection of objects used to extend the Constraint Solver library.