2014-02-26 07:49:54 +00:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2014 Cisco Systems, Inc. All rights reserved.
|
2019-08-23 22:22:37 +00:00
|
|
|
* Copyright (c) 2017-2019 Amazon.com, Inc. or its affiliates. All Rights
|
2017-09-14 18:36:48 +00:00
|
|
|
* reserved.
|
2014-02-26 07:49:54 +00:00
|
|
|
* $COPYRIGHT$
|
|
|
|
*
|
|
|
|
* Additional copyrights may follow
|
|
|
|
*
|
|
|
|
* $HEADER$
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* Implements an adjacency-list-based weighted directed graph (digraph),
|
|
|
|
* focused on supporting bipartite digraphs and flow-network problems.
|
|
|
|
*
|
|
|
|
* Note that some operations might be more efficient if this structure were
|
|
|
|
* converted to use an adjacency matrix instead of an adjacency list. OTOH
|
|
|
|
* that complicates other pieces of the implementation (specifically, adding
|
|
|
|
* and removing edges). */
|
|
|
|
|
2017-09-14 18:36:48 +00:00
|
|
|
#ifndef OPAL_BP_GRAPH_H
|
|
|
|
#define OPAL_BP_GRAPH_H
|
2014-02-26 07:49:54 +00:00
|
|
|
|
2017-09-14 18:36:48 +00:00
|
|
|
struct opal_bp_graph_vertex_t;
|
|
|
|
struct opal_bp_graph_edge_t;
|
|
|
|
struct opal_bp_graph_t;
|
2014-02-26 07:49:54 +00:00
|
|
|
|
2017-09-14 18:36:48 +00:00
|
|
|
typedef struct opal_bp_graph_vertex_t opal_bp_graph_vertex_t;
|
|
|
|
typedef struct opal_bp_graph_edge_t opal_bp_graph_edge_t;
|
|
|
|
typedef struct opal_bp_graph_t opal_bp_graph_t;
|
2014-02-26 07:49:54 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* callback function pointer type for cleaning up user data associated with a
|
|
|
|
* vertex or edge */
|
2017-09-14 18:36:48 +00:00
|
|
|
typedef void (*opal_bp_graph_cleanup_fn_t)(void *user_data);
|
2014-02-26 07:49:54 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* create a new empty graph
|
|
|
|
*
|
|
|
|
* Any new vertices will have NULL user data associated.
|
|
|
|
*
|
|
|
|
* @param[in] v_data_cleanup_fn cleanup function to use for vertex user data
|
|
|
|
* @param[in] e_data_cleanup_fn cleanup function to use for edge user data
|
|
|
|
* @param[out] g_out the created graph
|
|
|
|
*
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
* @returns OPAL_SUCCESS or an OMPI error code
|
2014-02-26 07:49:54 +00:00
|
|
|
*/
|
2017-09-14 18:36:48 +00:00
|
|
|
int opal_bp_graph_create(opal_bp_graph_cleanup_fn_t v_data_cleanup_fn,
|
|
|
|
opal_bp_graph_cleanup_fn_t e_data_cleanup_fn,
|
|
|
|
opal_bp_graph_t **g_out);
|
2014-02-26 07:49:54 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* free the given graph
|
|
|
|
*
|
|
|
|
* Any user data associated with vertices or edges in the graph will have
|
|
|
|
* the given edge/vertex cleanup callback invoked in some arbitrary order.
|
|
|
|
*
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
* @returns OPAL_SUCCESS or an OMPI error code
|
2014-02-26 07:49:54 +00:00
|
|
|
*/
|
2017-09-14 18:36:48 +00:00
|
|
|
int opal_bp_graph_free(opal_bp_graph_t *g);
|
2014-02-26 07:49:54 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* clone (deep copy) the given graph
|
|
|
|
*
|
|
|
|
* Note that copy_user_data==true is not currently supported (requires the
|
|
|
|
* addition of a copy callback for user data).
|
|
|
|
*
|
|
|
|
* @param[in] g the graph to clone
|
|
|
|
* @param[in] copy_user_data if true, copy vertex/edge user data to the new
|
|
|
|
* graph
|
|
|
|
* @param[in] g_clone_out the resulting cloned graph
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
* @returns OPAL_SUCCESS or an OMPI error code
|
2014-02-26 07:49:54 +00:00
|
|
|
*/
|
2017-09-14 18:36:48 +00:00
|
|
|
int opal_bp_graph_clone(const opal_bp_graph_t *g,
|
|
|
|
bool copy_user_data,
|
|
|
|
opal_bp_graph_t **g_clone_out);
|
2014-02-26 07:49:54 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* return the number of edges for which this vertex is a destination
|
|
|
|
*
|
|
|
|
* @param[in] g the graph to query
|
|
|
|
* @param[in] vertex the vertex id to query
|
|
|
|
* @returns the number of edges for which this vertex is a destination
|
|
|
|
*/
|
2017-09-14 18:36:48 +00:00
|
|
|
int opal_bp_graph_indegree(const opal_bp_graph_t *g,
|
|
|
|
int vertex);
|
2014-02-26 07:49:54 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* return the number of edges for which this vertex is a source
|
|
|
|
*
|
|
|
|
* @param[in] g the graph to query
|
|
|
|
* @param[in] vertex the vertex id to query
|
|
|
|
* @returns the number of edges for which this vertex is a source
|
|
|
|
*/
|
2017-09-14 18:36:48 +00:00
|
|
|
int opal_bp_graph_outdegree(const opal_bp_graph_t *g,
|
|
|
|
int vertex);
|
2014-02-26 07:49:54 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* add an edge to the given graph
|
|
|
|
*
|
|
|
|
* @param[in] from source vertex ID
|
|
|
|
* @param[in] to target vertex ID
|
|
|
|
* @param[in] cost cost value for this edge (lower is better)
|
|
|
|
* @param[in] capacity maximum flow transmissible on this edge
|
|
|
|
* @param[in] e_data caller data to associate with this edge, useful for
|
|
|
|
* debugging or minimizing state shared across components
|
|
|
|
*
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
* @returns OPAL_SUCCESS or an OMPI error code
|
2014-02-26 07:49:54 +00:00
|
|
|
*/
|
2017-09-14 18:36:48 +00:00
|
|
|
int opal_bp_graph_add_edge(opal_bp_graph_t *g,
|
|
|
|
int from,
|
|
|
|
int to,
|
|
|
|
int64_t cost,
|
|
|
|
int capacity,
|
|
|
|
void *e_data);
|
2014-02-26 07:49:54 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* add a vertex to the given graph
|
|
|
|
*
|
|
|
|
* @param[in] g graph to manipulate
|
|
|
|
* @param[in] v_data data to associate with the new vertex
|
|
|
|
* @param[out] index_out integer index of the new vertex. May be NULL.
|
|
|
|
*
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
* @returns OPAL_SUCCESS or an OMPI error code
|
2014-02-26 07:49:54 +00:00
|
|
|
*/
|
2017-09-14 18:36:48 +00:00
|
|
|
int opal_bp_graph_add_vertex(opal_bp_graph_t *g,
|
|
|
|
void *v_data,
|
|
|
|
int *index_out);
|
2014-02-26 07:49:54 +00:00
|
|
|
|
2019-08-23 22:22:37 +00:00
|
|
|
/**
|
|
|
|
* Get a pointer to the vertex data given the graph and vertex index
|
|
|
|
* associated with the vertex.
|
|
|
|
*
|
|
|
|
* @param[in] g graph the vertex belongs to
|
|
|
|
* @param[in] v_index integer index of the vertex
|
|
|
|
* @param[out] v_data_out data associated with the new vertex, may be NULL.
|
|
|
|
*
|
|
|
|
* @returns OPAL_SUCCESS or an OMPI error code
|
|
|
|
*/
|
|
|
|
int opal_bp_graph_get_vertex_data(opal_bp_graph_t *g,
|
|
|
|
int v_index,
|
|
|
|
void** v_data_out);
|
|
|
|
|
2014-02-26 07:49:54 +00:00
|
|
|
/**
|
|
|
|
* compute the order of a graph (number of vertices)
|
|
|
|
*
|
|
|
|
* @param[in] g the graph to query
|
|
|
|
*/
|
2017-09-14 18:36:48 +00:00
|
|
|
int opal_bp_graph_order(const opal_bp_graph_t *g);
|
2014-02-26 07:49:54 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* This function solves the "assignment problem":
|
|
|
|
* http://en.wikipedia.org/wiki/Assignment_problem
|
|
|
|
*
|
|
|
|
* The goal is to find a maximum cardinality, minimum cost matching in a
|
|
|
|
* weighted bipartite graph. Maximum cardinality takes priority over minimum
|
|
|
|
* cost.
|
|
|
|
*
|
|
|
|
* Capacities in the given graph are ignored (assumed to be 1 at the start).
|
|
|
|
* It is also assumed that the graph only contains edges from one vertex set
|
|
|
|
* to the other and that no edges exist in the reverse direction ("forward"
|
|
|
|
* edges only).
|
|
|
|
*
|
|
|
|
* The algorithm(s) used will be deterministic. That is, given the exact same
|
|
|
|
* graph, two calls to this routine will result in the same matching result.
|
|
|
|
*
|
|
|
|
* @param[in] g an acyclic bipartite directed graph for
|
|
|
|
* which a matching is sought
|
|
|
|
* @param[out] num_match_edges_out number edges found in the matching
|
|
|
|
* @param[out] match_edges_out an array of (u,v) vertex pairs indicating
|
|
|
|
* which edges are in the matching
|
|
|
|
*
|
George did the work and deserves all the credit for it. Ralph did the merge, and deserves whatever blame results from errors in it :-)
WHAT: Open our low-level communication infrastructure by moving all necessary components (btl/rcache/allocator/mpool) down in OPAL
All the components required for inter-process communications are currently deeply integrated in the OMPI layer. Several groups/institutions have express interest in having a more generic communication infrastructure, without all the OMPI layer dependencies. This communication layer should be made available at a different software level, available to all layers in the Open MPI software stack. As an example, our ORTE layer could replace the current OOB and instead use the BTL directly, gaining access to more reactive network interfaces than TCP. Similarly, external software libraries could take advantage of our highly optimized AM (active message) communication layer for their own purpose. UTK with support from Sandia, developped a version of Open MPI where the entire communication infrastucture has been moved down to OPAL (btl/rcache/allocator/mpool). Most of the moved components have been updated to match the new schema, with few exceptions (mainly BTLs where I have no way of compiling/testing them). Thus, the completion of this RFC is tied to being able to completing this move for all BTLs. For this we need help from the rest of the Open MPI community, especially those supporting some of the BTLs. A non-exhaustive list of BTLs that qualify here is: mx, portals4, scif, udapl, ugni, usnic.
This commit was SVN r32317.
2014-07-26 00:47:28 +00:00
|
|
|
* @returns OPAL_SUCCESS or an OMPI error code
|
2014-02-26 07:49:54 +00:00
|
|
|
*/
|
2017-09-14 18:36:48 +00:00
|
|
|
int opal_bp_graph_solve_bipartite_assignment(const opal_bp_graph_t *g,
|
|
|
|
int *num_match_edges_out,
|
|
|
|
int **match_edges_out);
|
|
|
|
|
|
|
|
#endif /* OPAL_BP_GRAPH_H */
|