2019-06-26 07:59:17 +02:00
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
< html xmlns = "http://www.w3.org/1999/xhtml" >
< head >
< title > OR-Tools< / title >
< meta http-equiv = "Content-Type" content = "text/html;" / >
< meta charset = "utf-8" / >
<!-- <link rel='stylesheet' type='text/css' href="https://fonts.googleapis.com/css?family=Ubuntu:400,700,400italic"/> -->
< script type = "text/javascript" src = "jquery.js" > < / script >
< script type = "text/javascript" src = "dynsections.js" > < / script >
2020-09-01 16:00:33 +02:00
< link href = "doxygen.css" rel = "stylesheet" type = "text/css" / >
< link href = "styleSheet.tmp.css" rel = "stylesheet" type = "text/css" / >
2019-06-26 07:59:17 +02:00
< / head >
< body >
< div id = "banner-container" >
< div id = "banner" >
2022-03-04 00:11:33 +01:00
< span id = "sfml" > Google OR-Tools 9.3< / span >
2019-06-26 07:59:17 +02:00
< / div >
< / div >
2019-08-07 18:01:08 -07:00
< div id = "content" style = "width: 100%; overflow: hidden;" >
< div style = "margin-left: 15px; margin-top: 5px; float: left; color: #145A32;" >
2019-08-12 09:16:03 -07:00
< h2 > C++ Reference< / h2 >
2019-08-07 18:01:08 -07:00
< ul >
< li > < a href = "../cpp_algorithms/annotated.html" > Algorithms< / a > < / li >
2019-08-12 09:16:03 -07:00
< li > < a href = "../cpp_sat/annotated.html" > CP-SAT< / a > < / li >
2019-08-07 18:01:08 -07:00
< li > < a href = "../cpp_graph/annotated.html" > Graph< / a > < / li >
< li > < a href = "../cpp_routing/annotated.html" > Routing< / a > < / li >
< li > < a href = "../cpp_linear/annotated.html" > Linear solver< / a > < / li >
< / ul >
< / div >
2019-06-26 07:59:17 +02:00
< div id = "content" >
2019-08-07 18:01:08 -07:00
< div align = "center" >
< h1 style = "color: #145A32;" > C++ Reference: Algorithms< / h1 >
< / div >
2022-01-17 21:42:14 +01:00
<!-- Generated by Doxygen 1.9.3 -->
2020-09-01 16:00:33 +02:00
< script type = "text/javascript" >
2022-01-17 21:42:14 +01:00
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699& dn=expat.txt MIT */
var searchBox = new SearchBox("searchBox", "search",'Search','.html');
2020-09-01 16:00:33 +02:00
/* @license-end */
< / script >
< script type = "text/javascript" src = "menudata.js" > < / script >
< script type = "text/javascript" src = "menu.js" > < / script >
< script type = "text/javascript" >
2022-01-17 21:42:14 +01:00
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699& dn=expat.txt MIT */
2020-09-01 16:00:33 +02:00
$(function() {
initMenu('',true,false,'search.php','Search');
$(document).ready(function() { init_search(); });
});
2022-01-17 21:42:14 +01:00
/* @license-end */
< / script >
2020-09-01 16:00:33 +02:00
< div id = "main-nav" > < / div >
2019-08-07 18:01:08 -07:00
< / div > <!-- top -->
2020-09-01 16:00:33 +02:00
< div id = "side-nav" class = "ui-resizable side-nav-resizable" >
< div id = "nav-tree" >
< div id = "nav-tree-contents" >
< div id = "nav-sync" class = "sync" > < / div >
< / div >
< / div >
< div id = "splitbar" style = "-moz-user-select:none;"
class="ui-resizable-handle">
< / div >
< / div >
< script type = "text/javascript" >
2022-01-17 21:42:14 +01:00
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699& dn=expat.txt MIT */
$(document).ready(function(){initNavTree('namespaceoperations__research.html',''); initResizable(); });
2020-09-01 16:00:33 +02:00
/* @license-end */
< / script >
< div id = "doc-content" >
<!-- window showing the filter options -->
< div id = "MSearchSelectWindow"
onmouseover="return searchBox.OnSearchSelectShow()"
onmouseout="return searchBox.OnSearchSelectHide()"
onkeydown="return searchBox.OnSearchSelectKey(event)">
< / div >
<!-- iframe showing the search results (closed by default) -->
< div id = "MSearchResultsWindow" >
< iframe src = "javascript:void(0)" frameborder = "0"
name="MSearchResults" id="MSearchResults">
< / iframe >
< / div >
2019-06-26 07:59:17 +02:00
< div class = "header" >
< div class = "summary" >
< a href = "#nested-classes" > Classes< / a > |
2019-08-07 18:01:08 -07:00
< a href = "#typedef-members" > Typedefs< / a > |
2019-06-26 07:59:17 +02:00
< a href = "#func-members" > Functions< / a > < / div >
2022-01-17 21:42:14 +01:00
< div class = "headertitle" > < div class = "title" > operations_research Namespace Reference< / div > < / div >
2019-06-26 07:59:17 +02:00
< / div > <!-- header -->
< div class = "contents" >
< table class = "memberdecls" >
2022-01-17 21:42:14 +01:00
< tr class = "heading" > < td colspan = "2" > < h2 class = "groupheader" > < a id = "nested-classes" name = "nested-classes" > < / a >
2019-06-26 07:59:17 +02:00
Classes< / h2 > < / td > < / tr >
2021-09-20 15:57:27 +02:00
< tr class = "memitem:" > < td class = "memItemLeft" align = "right" valign = "top" > class   < / td > < td class = "memItemRight" valign = "bottom" > < a class = "el" href = "classoperations__research_1_1_base_knapsack_solver.html" > BaseKnapsackSolver< / a > < / td > < / tr >
< tr class = "separator:" > < td class = "memSeparator" colspan = "2" >   < / td > < / tr >
2020-10-09 12:00:09 +02:00
< tr class = "memitem:" > < td class = "memItemLeft" align = "right" valign = "top" > class   < / td > < td class = "memItemRight" valign = "bottom" > < a class = "el" href = "classoperations__research_1_1_dense_doubly_linked_list.html" > DenseDoublyLinkedList< / a > < / td > < / tr >
2019-08-07 18:01:08 -07:00
< tr class = "separator:" > < td class = "memSeparator" colspan = "2" >   < / td > < / tr >
2020-10-09 12:00:09 +02:00
< tr class = "memitem:" > < td class = "memItemLeft" align = "right" valign = "top" > class   < / td > < td class = "memItemRight" valign = "bottom" > < a class = "el" href = "classoperations__research_1_1_dynamic_partition.html" > DynamicPartition< / a > < / td > < / tr >
2019-08-07 18:01:08 -07:00
< tr class = "separator:" > < td class = "memSeparator" colspan = "2" >   < / td > < / tr >
2020-10-09 12:00:09 +02:00
< tr class = "memitem:" > < td class = "memItemLeft" align = "right" valign = "top" > class   < / td > < td class = "memItemRight" valign = "bottom" > < a class = "el" href = "classoperations__research_1_1_dynamic_permutation.html" > DynamicPermutation< / a > < / td > < / tr >
2019-08-07 18:01:08 -07:00
< tr class = "separator:" > < td class = "memSeparator" colspan = "2" >   < / td > < / tr >
2020-10-09 12:00:09 +02:00
< tr class = "memitem:" > < td class = "memItemLeft" align = "right" valign = "top" > class   < / td > < td class = "memItemRight" valign = "bottom" > < a class = "el" href = "classoperations__research_1_1_graph_symmetry_finder.html" > GraphSymmetryFinder< / a > < / td > < / tr >
2019-08-07 18:01:08 -07:00
< tr class = "separator:" > < td class = "memSeparator" colspan = "2" >   < / td > < / tr >
2021-01-26 11:28:50 +01:00
< tr class = "memitem:" > < td class = "memItemLeft" align = "right" valign = "top" > struct   < / td > < td class = "memItemRight" valign = "bottom" > < a class = "el" href = "structoperations__research_1_1_knapsack_assignment.html" > KnapsackAssignment< / a > < / td > < / tr >
2019-08-07 18:01:08 -07:00
< tr class = "separator:" > < td class = "memSeparator" colspan = "2" >   < / td > < / tr >
2021-09-20 15:57:27 +02:00
< tr class = "memitem:" > < td class = "memItemLeft" align = "right" valign = "top" > class   < / td > < td class = "memItemRight" valign = "bottom" > < a class = "el" href = "classoperations__research_1_1_knapsack_capacity_propagator.html" > KnapsackCapacityPropagator< / a > < / td > < / tr >
< tr class = "separator:" > < td class = "memSeparator" colspan = "2" >   < / td > < / tr >
< tr class = "memitem:" > < td class = "memItemLeft" align = "right" valign = "top" > class   < / td > < td class = "memItemRight" valign = "bottom" > < a class = "el" href = "classoperations__research_1_1_knapsack_generic_solver.html" > KnapsackGenericSolver< / a > < / td > < / tr >
< tr class = "separator:" > < td class = "memSeparator" colspan = "2" >   < / td > < / tr >
2020-10-09 12:00:09 +02:00
< tr class = "memitem:" > < td class = "memItemLeft" align = "right" valign = "top" > struct   < / td > < td class = "memItemRight" valign = "bottom" > < a class = "el" href = "structoperations__research_1_1_knapsack_item.html" > KnapsackItem< / a > < / td > < / tr >
2019-08-07 18:01:08 -07:00
< tr class = "separator:" > < td class = "memSeparator" colspan = "2" >   < / td > < / tr >
2021-09-20 15:57:27 +02:00
< tr class = "memitem:" > < td class = "memItemLeft" align = "right" valign = "top" > class   < / td > < td class = "memItemRight" valign = "bottom" > < a class = "el" href = "classoperations__research_1_1_knapsack_propagator.html" > KnapsackPropagator< / a > < / td > < / tr >
< tr class = "separator:" > < td class = "memSeparator" colspan = "2" >   < / td > < / tr >
2020-10-09 12:00:09 +02:00
< tr class = "memitem:" > < td class = "memItemLeft" align = "right" valign = "top" > class   < / td > < td class = "memItemRight" valign = "bottom" > < a class = "el" href = "classoperations__research_1_1_knapsack_search_node.html" > KnapsackSearchNode< / a > < / td > < / tr >
2019-08-07 18:01:08 -07:00
< tr class = "separator:" > < td class = "memSeparator" colspan = "2" >   < / td > < / tr >
2020-10-09 12:00:09 +02:00
< tr class = "memitem:" > < td class = "memItemLeft" align = "right" valign = "top" > class   < / td > < td class = "memItemRight" valign = "bottom" > < a class = "el" href = "classoperations__research_1_1_knapsack_search_path.html" > KnapsackSearchPath< / a > < / td > < / tr >
2019-08-07 18:01:08 -07:00
< tr class = "separator:" > < td class = "memSeparator" colspan = "2" >   < / td > < / tr >
2021-09-20 15:57:27 +02:00
< tr class = "memitem:" > < td class = "memItemLeft" align = "right" valign = "top" > class   < / td > < td class = "memItemRight" valign = "bottom" > < a class = "el" href = "classoperations__research_1_1_knapsack_solver.html" > KnapsackSolver< / a > < / td > < / tr >
< tr class = "memdesc:" > < td class = "mdescLeft" >   < / td > < td class = "mdescRight" > This library solves knapsack problems. < a href = "classoperations__research_1_1_knapsack_solver.html#details" > More...< / a > < br / > < / td > < / tr >
2021-01-26 11:28:50 +01:00
< tr class = "separator:" > < td class = "memSeparator" colspan = "2" >   < / td > < / tr >
2021-09-20 15:57:27 +02:00
< tr class = "memitem:" > < td class = "memItemLeft" align = "right" valign = "top" > class   < / td > < td class = "memItemRight" valign = "bottom" > < a class = "el" href = "classoperations__research_1_1_knapsack_state.html" > KnapsackState< / a > < / td > < / tr >
2021-01-26 11:28:50 +01:00
< tr class = "separator:" > < td class = "memSeparator" colspan = "2" >   < / td > < / tr >
2021-09-20 15:57:27 +02:00
< tr class = "memitem:" > < td class = "memItemLeft" align = "right" valign = "top" > class   < / td > < td class = "memItemRight" valign = "bottom" > < a class = "el" href = "classoperations__research_1_1_merging_partition.html" > MergingPartition< / a > < / td > < / tr >
2019-08-07 18:01:08 -07:00
< tr class = "separator:" > < td class = "memSeparator" colspan = "2" >   < / td > < / tr >
2020-10-09 12:00:09 +02:00
< tr class = "memitem:" > < td class = "memItemLeft" align = "right" valign = "top" > class   < / td > < td class = "memItemRight" valign = "bottom" > < a class = "el" href = "classoperations__research_1_1_sparse_permutation.html" > SparsePermutation< / a > < / td > < / tr >
2020-09-01 16:00:33 +02:00
< tr class = "separator:" > < td class = "memSeparator" colspan = "2" >   < / td > < / tr >
2019-08-07 18:01:08 -07:00
< / table > < table class = "memberdecls" >
2022-01-17 21:42:14 +01:00
< tr class = "heading" > < td colspan = "2" > < h2 class = "groupheader" > < a id = "typedef-members" name = "typedef-members" > < / a >
2019-08-07 18:01:08 -07:00
Typedefs< / h2 > < / td > < / tr >
2020-10-09 12:00:09 +02:00
< tr class = "memitem:ada7d9b46f657c6053a197273a85043a7" > < td class = "memItemLeft" align = "right" valign = "top" > typedef < a class = "el" href = "structoperations__research_1_1_knapsack_item.html" > KnapsackItem< / a > *  < / td > < td class = "memItemRight" valign = "bottom" > < a class = "el" href = "namespaceoperations__research.html#ada7d9b46f657c6053a197273a85043a7" > KnapsackItemPtr< / a > < / td > < / tr >
2019-08-07 18:01:08 -07:00
< tr class = "separator:ada7d9b46f657c6053a197273a85043a7" > < td class = "memSeparator" colspan = "2" >   < / td > < / tr >
2019-06-26 07:59:17 +02:00
< / table > < table class = "memberdecls" >
2022-01-17 21:42:14 +01:00
< tr class = "heading" > < td colspan = "2" > < h2 class = "groupheader" > < a id = "func-members" name = "func-members" > < / a >
2019-06-26 07:59:17 +02:00
Functions< / h2 > < / td > < / tr >
< tr class = "memitem:a9c61bb2d6de0894f19675e2110458877" > < td class = "memItemLeft" align = "right" valign = "top" > void  < / td > < td class = "memItemRight" valign = "bottom" > < a class = "el" href = "namespaceoperations__research.html#a9c61bb2d6de0894f19675e2110458877" > MinimizeLinearAssignment< / a > (const std::vector< std::vector< double > > & cost, absl::flat_hash_map< int, int > *direct_assignment, absl::flat_hash_map< int, int > *reverse_assignment)< / td > < / tr >
< tr class = "separator:a9c61bb2d6de0894f19675e2110458877" > < td class = "memSeparator" colspan = "2" >   < / td > < / tr >
< tr class = "memitem:ada8ccc36ef736b10ce389fbd347c4282" > < td class = "memItemLeft" align = "right" valign = "top" > void  < / td > < td class = "memItemRight" valign = "bottom" > < a class = "el" href = "namespaceoperations__research.html#ada8ccc36ef736b10ce389fbd347c4282" > MaximizeLinearAssignment< / a > (const std::vector< std::vector< double > > & cost, absl::flat_hash_map< int, int > *direct_assignment, absl::flat_hash_map< int, int > *reverse_assignment)< / td > < / tr >
< tr class = "separator:ada8ccc36ef736b10ce389fbd347c4282" > < td class = "memSeparator" colspan = "2" >   < / td > < / tr >
< / table >
2019-08-07 18:01:08 -07:00
< h2 class = "groupheader" > Typedef Documentation< / h2 >
2022-01-17 21:42:14 +01:00
< a id = "ada7d9b46f657c6053a197273a85043a7" name = "ada7d9b46f657c6053a197273a85043a7" > < / a >
2019-08-07 18:01:08 -07:00
< h2 class = "memtitle" > < span class = "permalink" > < a href = "#ada7d9b46f657c6053a197273a85043a7" > ◆ < / a > < / span > KnapsackItemPtr< / h2 >
< div class = "memitem" >
< div class = "memproto" >
< table class = "memname" >
< tr >
2020-10-09 12:00:09 +02:00
< td class = "memname" > typedef < a class = "el" href = "structoperations__research_1_1_knapsack_item.html" > KnapsackItem< / a > * < a class = "el" href = "namespaceoperations__research.html#ada7d9b46f657c6053a197273a85043a7" > KnapsackItemPtr< / a > < / td >
2019-08-07 18:01:08 -07:00
< / tr >
< / table >
< / div > < div class = "memdoc" >
2021-04-27 23:00:03 +02:00
< p class = "definition" > Definition at line < a class = "el" href = "knapsack__solver_8h_source.html#l00329" > 329< / a > of file < a class = "el" href = "knapsack__solver_8h_source.html" > knapsack_solver.h< / a > .< / p >
2019-08-07 18:01:08 -07:00
< / div >
< / div >
2019-06-26 07:59:17 +02:00
< h2 class = "groupheader" > Function Documentation< / h2 >
2022-01-17 21:42:14 +01:00
< a id = "ada8ccc36ef736b10ce389fbd347c4282" name = "ada8ccc36ef736b10ce389fbd347c4282" > < / a >
2019-06-26 07:59:17 +02:00
< h2 class = "memtitle" > < span class = "permalink" > < a href = "#ada8ccc36ef736b10ce389fbd347c4282" > ◆ < / a > < / span > MaximizeLinearAssignment()< / h2 >
< div class = "memitem" >
< div class = "memproto" >
< table class = "memname" >
< tr >
< td class = "memname" > void operations_research::MaximizeLinearAssignment < / td >
< td > (< / td >
< td class = "paramtype" > const std::vector< std::vector< double > > &   < / td >
< td class = "paramname" > < em > cost< / em > , < / td >
< / tr >
< tr >
< td class = "paramkey" > < / td >
< td > < / td >
< td class = "paramtype" > absl::flat_hash_map< int, int > *  < / td >
< td class = "paramname" > < em > direct_assignment< / em > , < / td >
< / tr >
< tr >
< td class = "paramkey" > < / td >
< td > < / td >
< td class = "paramtype" > absl::flat_hash_map< int, int > *  < / td >
< td class = "paramname" > < em > reverse_assignment< / em >   < / td >
< / tr >
< tr >
< td > < / td >
< td > )< / td >
< td > < / td > < td > < / td >
< / tr >
< / table >
< / div > < div class = "memdoc" >
< / div >
< / div >
2022-01-17 21:42:14 +01:00
< a id = "a9c61bb2d6de0894f19675e2110458877" name = "a9c61bb2d6de0894f19675e2110458877" > < / a >
2019-06-26 07:59:17 +02:00
< h2 class = "memtitle" > < span class = "permalink" > < a href = "#a9c61bb2d6de0894f19675e2110458877" > ◆ < / a > < / span > MinimizeLinearAssignment()< / h2 >
< div class = "memitem" >
< div class = "memproto" >
< table class = "memname" >
< tr >
< td class = "memname" > void operations_research::MinimizeLinearAssignment < / td >
< td > (< / td >
< td class = "paramtype" > const std::vector< std::vector< double > > &   < / td >
< td class = "paramname" > < em > cost< / em > , < / td >
< / tr >
< tr >
< td class = "paramkey" > < / td >
< td > < / td >
< td class = "paramtype" > absl::flat_hash_map< int, int > *  < / td >
< td class = "paramname" > < em > direct_assignment< / em > , < / td >
< / tr >
< tr >
< td class = "paramkey" > < / td >
< td > < / td >
< td class = "paramtype" > absl::flat_hash_map< int, int > *  < / td >
< td class = "paramname" > < em > reverse_assignment< / em >   < / td >
< / tr >
< tr >
< td > < / td >
< td > )< / td >
< td > < / td > < td > < / td >
< / tr >
< / table >
< / div > < div class = "memdoc" >
< / div >
< / div >
< / div > <!-- contents -->
2020-09-01 16:00:33 +02:00
< / div > <!-- doc - content -->
2019-08-07 18:01:08 -07:00
< / div >
2019-06-26 07:59:17 +02:00
< / div >
< div id = "footer-container" >
< div id = "footer" >
< / div >
< / div >
< / body >
< / html >