Google OR-Tools v9.12
a fast and portable software suite for combinatorial optimization
Loading...
Searching...
No Matches
second_order_cone_constraint.h
Go to the documentation of this file.
1// Copyright 2010-2025 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// IWYU pragma: private, include "ortools/math_opt/cpp/math_opt.h"
15// IWYU pragma: friend "ortools/math_opt/cpp/.*"
16#ifndef OR_TOOLS_MATH_OPT_CONSTRAINTS_SECOND_ORDER_CONE_SECOND_ORDER_CONE_CONSTRAINT_H_
17#define OR_TOOLS_MATH_OPT_CONSTRAINTS_SECOND_ORDER_CONE_SECOND_ORDER_CONE_CONSTRAINT_H_
18
19#include <cstdint>
20#include <optional>
21#include <ostream>
22#include <string>
23#include <vector>
24
25#include "absl/strings/string_view.h"
27#include "ortools/math_opt/constraints/second_order_cone/storage.h" // IWYU pragma: keep (`AtomicConstraintTraits<SecondOrderConeConstraintId>`)
32
34
35// A value type that references a second-order cone constraint from
36// ModelStorage. Usually this type is passed by copy.
37//
38// This type implements https://abseil.io/docs/cpp/guides/hash.
40 public:
41 // The typed integer used for ids.
42 using IdType = SecondOrderConeConstraintId;
43
44 inline SecondOrderConeConstraint(const ModelStorage* storage,
45 SecondOrderConeConstraintId id);
46
47 inline int64_t id() const;
48
49 inline SecondOrderConeConstraintId typed_id() const;
50 inline const ModelStorage* storage() const;
51
52 inline absl::string_view name() const;
53
54 // Returns "upper_bound" with respect to a constraint of the form
55 // ||arguments_to_norm||₂ ≤ upper_bound.
57
58 // Returns "arguments_to_norm" with respect to a constraint of the form
59 // ||arguments_to_norm||₂ ≤ upper_bound.
60 std::vector<LinearExpression> ArgumentsToNorm() const;
61
62 // Returns all variables that appear in the second-order cone constraint with
63 // a nonzero coefficient. Order is not defined.
64 inline std::vector<Variable> NonzeroVariables() const;
65
66 // Returns a detailed string description of the contents of the constraint
67 // (not its name, use `<<` for that instead).
68 std::string ToString() const;
69
70 friend inline bool operator==(const SecondOrderConeConstraint& lhs,
71 const SecondOrderConeConstraint& rhs);
72 friend inline bool operator!=(const SecondOrderConeConstraint& lhs,
73 const SecondOrderConeConstraint& rhs);
74 template <typename H>
75 friend H AbslHashValue(H h, const SecondOrderConeConstraint& constraint);
76 friend std::ostream& operator<<(std::ostream& ostr,
77 const SecondOrderConeConstraint& constraint);
78
79 private:
80 const ModelStorage* storage_;
81 SecondOrderConeConstraintId id_;
82};
83
84// Streams the name of the constraint, as registered upon constraint creation,
85// or a short default if none was provided.
86inline std::ostream& operator<<(std::ostream& ostr,
87 const SecondOrderConeConstraint& constraint);
88
90// Inline function implementations
92
93int64_t SecondOrderConeConstraint::id() const { return id_.value(); }
94
95SecondOrderConeConstraintId SecondOrderConeConstraint::typed_id() const {
96 return id_;
98
99const ModelStorage* SecondOrderConeConstraint::storage() const {
100 return storage_;
102
103absl::string_view SecondOrderConeConstraint::name() const {
104 if (storage_->has_constraint(id_)) {
105 return storage_->constraint_data(id_).name;
106 }
108}
109
110std::vector<Variable> SecondOrderConeConstraint::NonzeroVariables() const {
111 return AtomicConstraintNonzeroVariables(*storage_, id_);
113
115 const SecondOrderConeConstraint& rhs) {
116 return lhs.id_ == rhs.id_ && lhs.storage_ == rhs.storage_;
117}
118
120 const SecondOrderConeConstraint& rhs) {
121 return !(lhs == rhs);
122}
123
124template <typename H>
125H AbslHashValue(H h, const SecondOrderConeConstraint& constraint) {
126 return H::combine(std::move(h), constraint.id_.value(), constraint.storage_);
128
129std::ostream& operator<<(std::ostream& ostr,
130 const SecondOrderConeConstraint& constraint) {
131 // TODO(b/170992529): handle quoting of invalid characters in the name.
132 const absl::string_view name = constraint.name();
133 if (name.empty()) {
134 ostr << "__soc_con#" << constraint.id() << "__";
135 } else {
136 ostr << name;
137 }
138 return ostr;
139}
140
142 const ModelStorage* const storage, const SecondOrderConeConstraintId id)
143 : storage_(storage), id_(id) {}
144
145} // namespace operations_research::math_opt
146
147#endif // OR_TOOLS_MATH_OPT_CONSTRAINTS_SECOND_ORDER_CONE_SECOND_ORDER_CONE_CONSTRAINT_H_
friend H AbslHashValue(H h, const SecondOrderConeConstraint &constraint)
friend std::ostream & operator<<(std::ostream &ostr, const SecondOrderConeConstraint &constraint)
friend bool operator!=(const SecondOrderConeConstraint &lhs, const SecondOrderConeConstraint &rhs)
SecondOrderConeConstraint(const ModelStorage *storage, SecondOrderConeConstraintId id)
friend bool operator==(const SecondOrderConeConstraint &lhs, const SecondOrderConeConstraint &rhs)
SecondOrderConeConstraintId IdType
The typed integer used for ids.
An object oriented wrapper for quadratic constraints in ModelStorage.
Definition gurobi_isv.cc:28
constexpr absl::string_view kDeletedConstraintDefaultDescription
Definition model_util.h:30
std::ostream & operator<<(std::ostream &ostr, const IndicatorConstraint &constraint)
bool operator==(const IndicatorConstraint &lhs, const IndicatorConstraint &rhs)
bool operator!=(const IndicatorConstraint &lhs, const IndicatorConstraint &rhs)
std::vector< Variable > AtomicConstraintNonzeroVariables(const ModelStorage &storage, const IdType id)
Definition model_util.h:42
H AbslHashValue(H h, const IndicatorConstraint &constraint)