<ahref="count__cst_8cc.html">Go to the documentation of this file.</a><divclass="fragment"><divclass="line"><aname="l00001"></a><spanclass="lineno"> 1</span> <spanclass="comment">// Copyright 2010-2021 Google LLC</span></div><divclass="line"><aname="l00002"></a><spanclass="lineno"> 2</span> <spanclass="comment">// Licensed under the Apache License, Version 2.0 (the "License");</span></div><divclass="line"><aname="l00003"></a><spanclass="lineno"> 3</span> <spanclass="comment">// you may not use this file except in compliance with the License.</span></div><divclass="line"><aname="l00004"></a><spanclass="lineno"> 4</span> <spanclass="comment">// You may obtain a copy of the License at</span></div><divclass="line"><aname="l00005"></a><spanclass="lineno"> 5</span> <spanclass="comment">//</span></div><divclass="line"><aname="l00006"></a><spanclass="lineno"> 6</span> <spanclass="comment">// http://www.apache.org/licenses/LICENSE-2.0</span></div><divclass="line"><aname="l00007"></a><spanclass="lineno"> 7</span> <spanclass="comment">//</span></div><divclass="line"><aname="l00008"></a><spanclass="lineno"> 8</span> <spanclass="comment">// Unless required by applicable law or agreed to in writing, software</span></div><divclass="line"><aname="l00009"></a><spanclass="lineno"> 9</span> <spanclass="comment">// distributed under the License is distributed on an "AS IS" BASIS,</span></div><divclass="line"><aname="l00010"></a><spanclass="lineno"> 10</span> <spanclass="comment">// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.</span></div><divclass="line"><aname="l00011"></a><spanclass="lineno"> 11</span> <spanclass="comment">// See the License for the specific language governing permissions and</span></div><divclass="line"><aname="l00012"></a><spanclass="lineno"> 12</span> <spanclass="comment">// limitations under the License.</span></div><divclass="line"><aname="l00013"></a><spanclass="lineno"> 13</span> </div><divclass="line"><aname="l00014"></a><spanclass="lineno"> 14</span> <spanclass="comment">//</span></div><divclass="line"><aname="l00015"></a><spanclass="lineno"> 15</span> <spanclass="comment">// Count constraints</span></div><divclass="line"><aname="l00016"></a><spanclass="lineno"> 16</span> </div><divclass="line"><aname="l00017"></a><spanclass="lineno"> 17</span> <spanclass="preprocessor">#include <algorithm></span></div><divclass="line"><aname="l00018"></a><spanclass="lineno"> 18</span> <spanclass="preprocessor">#include <cstdint></span></div><divclass="line"><aname="l00019"></a><spanclass="lineno"> 19</span> <spanclass="preprocessor">#include <limits></span></div><divclass="line"><aname="l00020"></a><spanclass="lineno"> 20</span> <spanclass="preprocessor">#include <string></span></div><divclass="line"><aname="l00021"></a><spanclass="lineno"> 21</span> <spanclass="preprocessor">#include <vector></span></div><divclass="line"><aname="l00022"></a><spanclass="lineno"> 22</span> </div><divclass="line"><aname="l00023"></a><spanclass="lineno"> 23</span> <spanclass="preprocessor">#include "absl/strings/str_format.h"</span></div><divclass="line"><aname="l00024"></a><spanclass="lineno"> 24</span> <spanclass="preprocessor">#include "absl/strings/str_join.h"</span></div><divclass="line"><aname="l00025"></a><spanclass="lineno"> 25</span> <spanclass="preprocessor">#include "<aclass="code"href="integral__types_8h.html">ortools/base/integral_types.h</a>"</span></div><divclass="line"><aname="l00026"></a><spanclass="lineno"> 26</span> <spanclass="preprocessor">#include "<aclass="code"href="base_2logging_8h.html">ortools/base/logging.h</a>"</span></div><divclass="line"><aname="l00027"></a><spanclass="lineno"> 27</span> <span
<divclass="ttc"id="classoperations__research_1_1_solver_html_aecc1416849d286531c1820b42d2292fc"><divclass="ttname"><ahref="classoperations__research_1_1_solver.html#aecc1416849d286531c1820b42d2292fc">operations_research::Solver::MakeIsEqualCstVar</a></div><divclass="ttdeci">IntVar * MakeIsEqualCstVar(IntExpr *const var, int64_t value)</div><divclass="ttdoc">status var of (var == value)</div><divclass="ttdef"><b>Definition:</b><ahref="expr__cst_8cc_source.html#l00462">expr_cst.cc:462</a></div></div>
<divclass="ttc"id="classoperations__research_1_1_int_var_html_a6e33a313eaf507bae0eb7068455a5bdc"><divclass="ttname"><ahref="classoperations__research_1_1_int_var.html#a6e33a313eaf507bae0eb7068455a5bdc">operations_research::IntVar::WhenBound</a></div><divclass="ttdeci">virtual void WhenBound(Demon *d)=0</div><divclass="ttdoc">This method attaches a demon that will be awakened when the variable is bound.</div></div>
<divclass="ttc"id="classoperations__research_1_1_int_var_html_a0723abf37f7a5a8a604fd1bcd96a7be0"><divclass="ttname"><ahref="classoperations__research_1_1_int_var.html#a0723abf37f7a5a8a604fd1bcd96a7be0">operations_research::IntVar::Contains</a></div><divclass="ttdeci">virtual bool Contains(int64_t v) const =0</div><divclass="ttdoc">This method returns whether the value 'v' is in the domain of the variable.</div></div>
<divclass="ttc"id="classoperations__research_1_1_int_var_html_a3173e28151b3e04888127961cacc42b1"><divclass="ttname"><ahref="classoperations__research_1_1_int_var.html#a3173e28151b3e04888127961cacc42b1">operations_research::IntVar::OldMax</a></div><divclass="ttdeci">virtual int64_t OldMax() const =0</div><divclass="ttdoc">Returns the previous max.</div></div>
<divclass="ttc"id="classoperations__research_1_1_constraint_html"><divclass="ttname"><ahref="classoperations__research_1_1_constraint.html">operations_research::Constraint</a></div><divclass="ttdoc">A constraint is the main modeling object.</div><divclass="ttdef"><b>Definition:</b><ahref="constraint__solver_8h_source.html#l03626">constraint_solver.h:3626</a></div></div>
<divclass="ttc"id="classoperations__research_1_1_rev_bit_matrix_html_a35395dc664c7939e68c29390a8591e1c"><divclass="ttname"><ahref="classoperations__research_1_1_rev_bit_matrix.html#a35395dc664c7939e68c29390a8591e1c">operations_research::RevBitMatrix::IsSet</a></div><divclass="ttdeci">bool IsSet(int64_t row, int64_t column) const</div><divclass="ttdoc">Returns whether the 'column' bit in the 'row' row is set.</div><divclass="ttdef"><b>Definition:</b><ahref="constraint__solveri_8h_source.html#l00467">constraint_solveri.h:467</a></div></div>
<divclass="ttc"id="namespaceoperations__research_html_adf2aea6c68fe502389c9264b971b2f85"><divclass="ttname"><ahref="namespaceoperations__research.html#adf2aea6c68fe502389c9264b971b2f85">operations_research::IsArrayInRange</a></div><divclass="ttdeci">bool IsArrayInRange(const std::vector< IntVar * >&vars, T range_min, T range_max)</div><divclass="ttdef"><b>Definition:</b><ahref="constraint__solveri_8h_source.html#l02936">constraint_solveri.h:2936</a></div></div>
<divclass="ttc"id="classoperations__research_1_1_rev_bit_matrix_html_ab1f7d7749ed4799119614efc507ebc64"><divclass="ttname"><ahref="classoperations__research_1_1_rev_bit_matrix.html#ab1f7d7749ed4799119614efc507ebc64">operations_research::RevBitMatrix::SetToOne</a></div><divclass="ttdeci">void SetToOne(Solver *const solver, int64_t row, int64_t column)</div><divclass="ttdoc">Sets the 'column' bit in the 'row' row.</div><divclass="ttdef"><b>Definition:</b><ahref="utilities_8cc_source.html#l00170">utilities.cc:170</a></div></div>
<divclass="ttc"id="classoperations__research_1_1_rev_html_affc0b3b0a5efa3efc9d0d86344d4a29f"><divclass="ttname"><ahref="classoperations__research_1_1_rev.html#affc0b3b0a5efa3efc9d0d86344d4a29f">operations_research::Rev::Value</a></div><divclass="ttdeci">const T & Value() const</div><divclass="ttdef"><b>Definition:</b><ahref="constraint__solver_8h_source.html#l03781">constraint_solver.h:3781</a></div></div>
<divclass="ttc"id="classoperations__research_1_1_int_expr_html_a1d04569b37cb7fe6ed0956ab71e08bc9"><divclass="ttname"><ahref="classoperations__research_1_1_int_expr.html#a1d04569b37cb7fe6ed0956ab71e08bc9">operations_research::IntExpr::Bound</a></div><divclass="ttdeci">virtual bool Bound() const</div><divclass="ttdoc">Returns true if the min and the max of the expression are equal.</div><divclass="ttdef"><b>Definition:</b><ahref="constraint__solver_8h_source.html#l03904">constraint_solver.h:3904</a></div></div>
<divclass="ttc"id="classoperations__research_1_1_rev_bit_matrix_html_a0bbb89e6f783ea950b5bd38049428b4c"><divclass="ttname"><ahref="classoperations__research_1_1_rev_bit_matrix.html#a0bbb89e6f783ea950b5bd38049428b4c">operations_research::RevBitMatrix::SetToZero</a></div><divclass="ttdeci">void SetToZero(Solver *const solver, int64_t row, int64_t column)</div><divclass="ttdoc">Erases the 'column' bit in the 'row' row.</div><divclass="ttdef"><b>Definition:</b><ahref="utilities_8cc_source.html#l00178">utilities.cc:178</a></div></div>
<divclass="ttc"id="namespaceoperations__research_html_aafac7375c23337f25821aa6f86ca627c"><divclass="ttname"><ahref="namespaceoperations__research.html#aafac7375c23337f25821aa6f86ca627c">operations_research::IsIncreasingContiguous</a></div><divclass="ttdeci">bool IsIncreasingContiguous(const std::vector< T >&values)</div><divclass="ttdef"><b>Definition:</b><ahref="constraint__solveri_8h_source.html#l02916">constraint_solveri.h:2916</a></div></div>
<divclass="ttc"id="classoperations__research_1_1_int_var_html"><divclass="ttname"><ahref="classoperations__research_1_1_int_var.html">operations_research::IntVar</a></div><divclass="ttdoc">The class IntVar is a subset of IntExpr.</div><divclass="ttdef"><b>Definition:</b><ahref="constraint__solver_8h_source.html#l04040">constraint_solver.h:4040</a></div></div>
<divclass="ttc"id="namespaceoperations__research_html_ae3e4f71c4c79e0b4ec00c4e715a7c298"><divclass="ttname"><ahref="namespaceoperations__research.html#ae3e4f71c4c79e0b4ec00c4e715a7c298">operations_research::AreAllOnes</a></div><divclass="ttdeci">bool AreAllOnes(const std::vector< T >&values)</div><divclass="ttdef"><b>Definition:</b><ahref="constraint__solveri_8h_source.html#l02866">constraint_solveri.h:2866</a></div></div>
<divclass="ttc"id="classoperations__research_1_1_solver_html_ab741cb25dd32d1cbe02fbfb36337d9bb"><divclass="ttname"><ahref="classoperations__research_1_1_solver.html#ab741cb25dd32d1cbe02fbfb36337d9bb">operations_research::Solver::RevAlloc</a></div><divclass="ttdeci">T * RevAlloc(T *object)</div><divclass="ttdoc">Registers the given object as being reversible.</div><divclass="ttdef"><b>Definition:</b><ahref="constraint__solver_8h_source.html#l00791">constraint_solver.h:791</a></div></div>
<divclass="ttc"id="classoperations__research_1_1_int_var_html_ab36f6f122cb3e8554b160ba67608b1c0"><divclass="ttname"><ahref="classoperations__research_1_1_int_var.html#ab36f6f122cb3e8554b160ba67608b1c0">operations_research::IntVar::WhenDomain</a></div><divclass="ttdeci">virtual void WhenDomain(Demon *d)=0</div><divclass="ttdoc">This method attaches a demon that will watch any domain modification of the domain of the variable.</div></div>
<divclass="ttc"id="namespaceoperations__research_html"><divclass="ttname"><ahref="namespaceoperations__research.html">operations_research</a></div><divclass="ttdoc">Collection of objects used to extend the Constraint Solver library.</div><divclass="ttdef"><b>Definition:</b><ahref="dense__doubly__linked__list_8h_source.html#l00021">dense_doubly_linked_list.h:21</a></div></div>
<divclass="ttc"id="namespaceoperations__research_html_a9be76edcbd5ccb982d92c8d90421a73c"><divclass="ttname"><ahref="namespaceoperations__research.html#a9be76edcbd5ccb982d92c8d90421a73c">operations_research::JoinDebugStringPtr</a></div><divclass="ttdeci">std::string JoinDebugStringPtr(const std::vector< T >&v, const std::string &separator)</div><divclass="ttdef"><b>Definition:</b><ahref="string__array_8h_source.html#l00045">string_array.h:45</a></div></div>