problemreductions/models/graph/
mod.rs1pub(crate) mod acyclic_partition;
87pub(crate) mod balanced_complete_bipartite_subgraph;
88pub(crate) mod biclique_cover;
89pub(crate) mod biconnectivity_augmentation;
90pub(crate) mod bottleneck_traveling_salesman;
91pub(crate) mod bounded_component_spanning_forest;
92pub(crate) mod bounded_diameter_spanning_tree;
93pub(crate) mod degree_constrained_spanning_tree;
94pub(crate) mod directed_hamiltonian_path;
95pub(crate) mod directed_two_commodity_integral_flow;
96pub(crate) mod disjoint_connecting_paths;
97pub(crate) mod eulerian_path;
98pub(crate) mod generalized_hex;
99pub(crate) mod graph_partitioning;
100pub(crate) mod hamiltonian_circuit;
101pub(crate) mod hamiltonian_path;
102pub(crate) mod hamiltonian_path_between_two_vertices;
103pub(crate) mod highly_connected_deletion;
104pub(crate) mod integral_flow_bundles;
105pub(crate) mod integral_flow_homologous_arcs;
106pub(crate) mod integral_flow_with_multipliers;
107pub(crate) mod isomorphic_spanning_tree;
108pub(crate) mod kclique;
109pub(crate) mod kcoloring;
110pub(crate) mod kernel;
111pub(crate) mod kth_best_spanning_tree;
112pub(crate) mod length_bounded_disjoint_paths;
113pub(crate) mod longest_circuit;
114pub(crate) mod longest_path;
115pub(crate) mod max_cut;
116pub(crate) mod maximal_is;
117pub(crate) mod maximum_achromatic_number;
118pub(crate) mod maximum_clique;
119pub(crate) mod maximum_co_k_plex;
120pub(crate) mod maximum_common_edge_subgraph;
121pub(crate) mod maximum_contact_map_overlap;
122pub(crate) mod maximum_domatic_number;
123pub(crate) mod maximum_edge_weighted_k_clique;
124pub(crate) mod maximum_independent_set;
125pub(crate) mod maximum_leaf_spanning_tree;
126pub(crate) mod maximum_matching;
127pub(crate) mod min_max_multicenter;
128pub(crate) mod minimum_capacitated_spanning_tree;
129pub(crate) mod minimum_cost_circulation;
130pub(crate) mod minimum_cost_maximum_flow;
131pub(crate) mod minimum_covering_by_cliques;
132pub(crate) mod minimum_cut_into_bounded_sets;
133pub(crate) mod minimum_dominating_set;
134pub(crate) mod minimum_dummy_activities_pert;
135pub(crate) mod minimum_edge_cost_flow;
136pub(crate) mod minimum_feedback_arc_set;
137pub(crate) mod minimum_feedback_vertex_set;
138pub(crate) mod minimum_geometric_connected_dominating_set;
139pub(crate) mod minimum_graph_bandwidth;
140pub(crate) mod minimum_intersection_graph_basis;
141pub(crate) mod minimum_maximal_matching;
142pub(crate) mod minimum_metric_dimension;
143pub(crate) mod minimum_multiway_cut;
144pub(crate) mod minimum_sum_multicenter;
145pub(crate) mod minimum_vertex_cover;
146pub(crate) mod mixed_chinese_postman;
147pub(crate) mod monochromatic_triangle;
148pub(crate) mod multiple_choice_branching;
149pub(crate) mod multiple_copy_file_allocation;
150pub(crate) mod optimal_linear_arrangement;
151pub(crate) mod partial_feedback_edge_set;
152pub(crate) mod partition_into_cliques;
153pub(crate) mod partition_into_forests;
154pub(crate) mod partition_into_paths_of_length_2;
155pub(crate) mod partition_into_perfect_matchings;
156pub(crate) mod partition_into_triangles;
157pub(crate) mod path_constrained_network_flow;
158pub(crate) mod prize_collecting_steiner_forest;
159pub(crate) mod rooted_tree_arrangement;
160pub(crate) mod rural_postman;
161pub(crate) mod shortest_weight_constrained_path;
162pub(crate) mod spin_glass;
163pub(crate) mod steiner_tree;
164pub(crate) mod steiner_tree_in_graphs;
165pub(crate) mod strong_connectivity_augmentation;
166pub(crate) mod subgraph_isomorphism;
167pub(crate) mod traveling_salesman;
168pub(crate) mod undirected_flow_lower_bounds;
169pub(crate) mod undirected_two_commodity_integral_flow;
170pub use acyclic_partition::AcyclicPartition;
171pub use balanced_complete_bipartite_subgraph::BalancedCompleteBipartiteSubgraph;
172pub use biclique_cover::BicliqueCover;
173pub use biconnectivity_augmentation::BiconnectivityAugmentation;
174pub use bottleneck_traveling_salesman::BottleneckTravelingSalesman;
175pub use bounded_component_spanning_forest::BoundedComponentSpanningForest;
176pub use bounded_diameter_spanning_tree::BoundedDiameterSpanningTree;
177pub use degree_constrained_spanning_tree::DegreeConstrainedSpanningTree;
178pub use directed_hamiltonian_path::DirectedHamiltonianPath;
179pub use directed_two_commodity_integral_flow::DirectedTwoCommodityIntegralFlow;
180pub use disjoint_connecting_paths::DisjointConnectingPaths;
181pub use eulerian_path::EulerianPath;
182pub use generalized_hex::GeneralizedHex;
183pub use graph_partitioning::GraphPartitioning;
184pub use hamiltonian_circuit::HamiltonianCircuit;
185pub use hamiltonian_path::HamiltonianPath;
186pub use hamiltonian_path_between_two_vertices::HamiltonianPathBetweenTwoVertices;
187pub use highly_connected_deletion::HighlyConnectedDeletion;
188pub use integral_flow_bundles::IntegralFlowBundles;
189pub use integral_flow_homologous_arcs::IntegralFlowHomologousArcs;
190pub use integral_flow_with_multipliers::IntegralFlowWithMultipliers;
191pub use isomorphic_spanning_tree::IsomorphicSpanningTree;
192pub use kclique::KClique;
193pub use kcoloring::KColoring;
194pub use kernel::Kernel;
195pub use kth_best_spanning_tree::KthBestSpanningTree;
196pub use length_bounded_disjoint_paths::LengthBoundedDisjointPaths;
197pub use longest_circuit::LongestCircuit;
198pub use longest_path::LongestPath;
199pub use max_cut::MaxCut;
200pub use maximal_is::MaximalIS;
201pub use maximum_achromatic_number::MaximumAchromaticNumber;
202pub use maximum_clique::MaximumClique;
203pub use maximum_co_k_plex::MaximumCoKPlex;
204pub use maximum_common_edge_subgraph::{LabelledArc, LabelledDigraph, MaximumCommonEdgeSubgraph};
205pub use maximum_contact_map_overlap::MaximumContactMapOverlap;
206pub use maximum_domatic_number::MaximumDomaticNumber;
207pub use maximum_edge_weighted_k_clique::MaximumEdgeWeightedKClique;
208pub use maximum_independent_set::MaximumIndependentSet;
209pub use maximum_leaf_spanning_tree::MaximumLeafSpanningTree;
210pub use maximum_matching::MaximumMatching;
211pub use min_max_multicenter::MinMaxMulticenter;
212pub use minimum_capacitated_spanning_tree::MinimumCapacitatedSpanningTree;
213pub use minimum_cost_circulation::MinimumCostCirculation;
214pub use minimum_cost_maximum_flow::MinimumCostMaximumFlow;
215pub use minimum_covering_by_cliques::MinimumCoveringByCliques;
216pub use minimum_cut_into_bounded_sets::MinimumCutIntoBoundedSets;
217pub use minimum_dominating_set::MinimumDominatingSet;
218pub use minimum_dummy_activities_pert::MinimumDummyActivitiesPert;
219pub use minimum_edge_cost_flow::MinimumEdgeCostFlow;
220pub use minimum_feedback_arc_set::MinimumFeedbackArcSet;
221pub use minimum_feedback_vertex_set::MinimumFeedbackVertexSet;
222pub use minimum_geometric_connected_dominating_set::MinimumGeometricConnectedDominatingSet;
223pub use minimum_graph_bandwidth::MinimumGraphBandwidth;
224pub use minimum_intersection_graph_basis::MinimumIntersectionGraphBasis;
225pub use minimum_maximal_matching::MinimumMaximalMatching;
226pub use minimum_metric_dimension::MinimumMetricDimension;
227pub use minimum_multiway_cut::MinimumMultiwayCut;
228pub use minimum_sum_multicenter::MinimumSumMulticenter;
229pub use minimum_vertex_cover::MinimumVertexCover;
230pub use mixed_chinese_postman::MixedChinesePostman;
231pub use monochromatic_triangle::MonochromaticTriangle;
232pub use multiple_choice_branching::MultipleChoiceBranching;
233pub use multiple_copy_file_allocation::MultipleCopyFileAllocation;
234pub use optimal_linear_arrangement::OptimalLinearArrangement;
235pub use partial_feedback_edge_set::PartialFeedbackEdgeSet;
236pub use partition_into_cliques::PartitionIntoCliques;
237pub use partition_into_forests::PartitionIntoForests;
238pub use partition_into_paths_of_length_2::PartitionIntoPathsOfLength2;
239pub use partition_into_perfect_matchings::PartitionIntoPerfectMatchings;
240pub use partition_into_triangles::PartitionIntoTriangles;
241pub use path_constrained_network_flow::PathConstrainedNetworkFlow;
242pub use prize_collecting_steiner_forest::PrizeCollectingSteinerForest;
243pub use rooted_tree_arrangement::RootedTreeArrangement;
244pub use rural_postman::RuralPostman;
245pub use shortest_weight_constrained_path::ShortestWeightConstrainedPath;
246pub use spin_glass::SpinGlass;
247pub use steiner_tree::SteinerTree;
248pub use steiner_tree_in_graphs::SteinerTreeInGraphs;
249pub use strong_connectivity_augmentation::StrongConnectivityAugmentation;
250pub use subgraph_isomorphism::SubgraphIsomorphism;
251pub use traveling_salesman::TravelingSalesman;
252pub use undirected_flow_lower_bounds::UndirectedFlowLowerBounds;
253pub use undirected_two_commodity_integral_flow::UndirectedTwoCommodityIntegralFlow;
254#[cfg(feature = "example-db")]
255pub(crate) fn canonical_model_example_specs() -> Vec<crate::example_db::specs::ModelExampleSpec> {
256 let mut specs = Vec::new();
257 specs.extend(acyclic_partition::canonical_model_example_specs());
258 specs.extend(bounded_diameter_spanning_tree::canonical_model_example_specs());
259 specs.extend(degree_constrained_spanning_tree::canonical_model_example_specs());
260 specs.extend(directed_hamiltonian_path::canonical_model_example_specs());
261 specs.extend(eulerian_path::canonical_model_example_specs());
262 specs.extend(maximum_independent_set::canonical_model_example_specs());
263 specs.extend(maximum_leaf_spanning_tree::canonical_model_example_specs());
264 specs.extend(minimum_vertex_cover::canonical_model_example_specs());
265 specs.extend(minimum_vertex_cover::decision_canonical_model_example_specs());
266 specs.extend(max_cut::canonical_model_example_specs());
267 specs.extend(generalized_hex::canonical_model_example_specs());
268 specs.extend(hamiltonian_circuit::canonical_model_example_specs());
269 specs.extend(hamiltonian_path::canonical_model_example_specs());
270 specs.extend(hamiltonian_path_between_two_vertices::canonical_model_example_specs());
271 specs.extend(highly_connected_deletion::canonical_model_example_specs());
272 specs.extend(integral_flow_bundles::canonical_model_example_specs());
273 specs.extend(integral_flow_with_multipliers::canonical_model_example_specs());
274 specs.extend(isomorphic_spanning_tree::canonical_model_example_specs());
275 specs.extend(kclique::canonical_model_example_specs());
276 specs.extend(kernel::canonical_model_example_specs());
277 specs.extend(kcoloring::canonical_model_example_specs());
278 specs.extend(kth_best_spanning_tree::canonical_model_example_specs());
279 specs.extend(length_bounded_disjoint_paths::canonical_model_example_specs());
280 specs.extend(longest_circuit::canonical_model_example_specs());
281 specs.extend(longest_path::canonical_model_example_specs());
282 specs.extend(minimum_covering_by_cliques::canonical_model_example_specs());
283 specs.extend(monochromatic_triangle::canonical_model_example_specs());
284 specs.extend(minimum_intersection_graph_basis::canonical_model_example_specs());
285 specs.extend(minimum_dominating_set::canonical_model_example_specs());
286 specs.extend(minimum_dominating_set::decision_canonical_model_example_specs());
287 specs.extend(minimum_metric_dimension::canonical_model_example_specs());
288 specs.extend(minimum_geometric_connected_dominating_set::canonical_model_example_specs());
289 specs.extend(maximum_matching::canonical_model_example_specs());
290 specs.extend(minimum_maximal_matching::canonical_model_example_specs());
291 specs.extend(traveling_salesman::canonical_model_example_specs());
292 specs.extend(maximum_achromatic_number::canonical_model_example_specs());
293 specs.extend(maximum_domatic_number::canonical_model_example_specs());
294 specs.extend(maximum_clique::canonical_model_example_specs());
295 specs.extend(maximum_co_k_plex::canonical_model_example_specs());
296 specs.extend(maximum_common_edge_subgraph::canonical_model_example_specs());
297 specs.extend(maximum_contact_map_overlap::canonical_model_example_specs());
298 specs.extend(maximum_edge_weighted_k_clique::canonical_model_example_specs());
299 specs.extend(maximal_is::canonical_model_example_specs());
300 specs.extend(minimum_cut_into_bounded_sets::canonical_model_example_specs());
301 specs.extend(minimum_dummy_activities_pert::canonical_model_example_specs());
302 specs.extend(multiple_copy_file_allocation::canonical_model_example_specs());
303 specs.extend(minimum_feedback_vertex_set::canonical_model_example_specs());
304 specs.extend(min_max_multicenter::canonical_model_example_specs());
305 specs.extend(minimum_multiway_cut::canonical_model_example_specs());
306 specs.extend(minimum_sum_multicenter::canonical_model_example_specs());
307 specs.extend(shortest_weight_constrained_path::canonical_model_example_specs());
308 specs.extend(multiple_choice_branching::canonical_model_example_specs());
309 specs.extend(spin_glass::canonical_model_example_specs());
310 specs.extend(biclique_cover::canonical_model_example_specs());
311 specs.extend(balanced_complete_bipartite_subgraph::canonical_model_example_specs());
312 specs.extend(biconnectivity_augmentation::canonical_model_example_specs());
313 specs.extend(bottleneck_traveling_salesman::canonical_model_example_specs());
314 specs.extend(bounded_component_spanning_forest::canonical_model_example_specs());
315 specs.extend(partition_into_triangles::canonical_model_example_specs());
316 specs.extend(partition_into_cliques::canonical_model_example_specs());
317 specs.extend(partition_into_forests::canonical_model_example_specs());
318 specs.extend(partition_into_perfect_matchings::canonical_model_example_specs());
319 specs.extend(partition_into_paths_of_length_2::canonical_model_example_specs());
320 specs.extend(path_constrained_network_flow::canonical_model_example_specs());
321 specs.extend(prize_collecting_steiner_forest::canonical_model_example_specs());
322 specs.extend(rooted_tree_arrangement::canonical_model_example_specs());
323 specs.extend(steiner_tree::canonical_model_example_specs());
324 specs.extend(steiner_tree_in_graphs::canonical_model_example_specs());
325 specs.extend(directed_two_commodity_integral_flow::canonical_model_example_specs());
326 specs.extend(disjoint_connecting_paths::canonical_model_example_specs());
327 specs.extend(undirected_flow_lower_bounds::canonical_model_example_specs());
328 specs.extend(undirected_two_commodity_integral_flow::canonical_model_example_specs());
329 specs.extend(strong_connectivity_augmentation::canonical_model_example_specs());
330 specs.extend(rural_postman::canonical_model_example_specs());
331 specs.extend(integral_flow_homologous_arcs::canonical_model_example_specs());
332 specs.extend(minimum_capacitated_spanning_tree::canonical_model_example_specs());
333 specs.extend(minimum_cost_circulation::canonical_model_example_specs());
334 specs.extend(minimum_cost_maximum_flow::canonical_model_example_specs());
335 specs.extend(minimum_edge_cost_flow::canonical_model_example_specs());
336 specs.extend(minimum_graph_bandwidth::canonical_model_example_specs());
337 specs.extend(minimum_feedback_arc_set::canonical_model_example_specs());
338 specs.extend(optimal_linear_arrangement::canonical_model_example_specs());
339 specs.extend(optimal_linear_arrangement::decision_canonical_model_example_specs());
340 specs.extend(partial_feedback_edge_set::canonical_model_example_specs());
341 specs.extend(mixed_chinese_postman::canonical_model_example_specs());
342 specs.extend(subgraph_isomorphism::canonical_model_example_specs());
343 specs.extend(graph_partitioning::canonical_model_example_specs());
344 specs
345}