vg
tools for working with variation graphs
|
#include <graph_caller.hpp>
Public Member Functions | |
SnarlGraph (const HandleGraph *backing_graph, SnarlManager &snarl_manager, vector< const Snarl * > snarls) | |
pair< bool, handle_t > | node_to_snarl (handle_t handle) const |
tuple< bool, handle_t, edge_t > | edge_to_snarl_edge (edge_t edge) const |
void | embed_snarl (Visit &visit) |
void | embed_snarls (SnarlTraversal &traversal) |
void | embed_ref_path_snarls (SnarlTraversal &traversal) |
bool | has_node (nid_t node_id) const |
Method to check if a node exists by ID. More... | |
handle_t | get_handle (const nid_t &node_id, bool is_reverse=false) const |
Look up the handle for the node with the given ID in the given orientation. More... | |
nid_t | get_id (const handle_t &handle) const |
Get the ID from a handle. More... | |
bool | get_is_reverse (const handle_t &handle) const |
Get the orientation of a handle. More... | |
handle_t | flip (const handle_t &handle) const |
Invert the orientation of a handle (potentially without getting its ID) More... | |
size_t | get_length (const handle_t &handle) const |
Get the length of a node. More... | |
std::string | get_sequence (const handle_t &handle) const |
size_t | get_node_count () const |
Return the number of nodes in the graph. More... | |
nid_t | min_node_id () const |
nid_t | max_node_id () const |
Public Member Functions inherited from handlegraph::HandleGraph | |
virtual | ~HandleGraph ()=default |
template<typename Iteratee > | |
bool | follow_edges (const handle_t &handle, bool go_left, const Iteratee &iteratee) const |
template<typename Iteratee > | |
bool | for_each_handle (const Iteratee &iteratee, bool parallel=false) const |
virtual size_t | get_degree (const handle_t &handle, bool go_left) const |
virtual bool | has_edge (const handle_t &left, const handle_t &right) const |
bool | has_edge (const edge_t &edge) const |
Convenient wrapper of has_edge for edge_t argument. More... | |
virtual size_t | get_edge_count () const |
virtual size_t | get_total_length () const |
virtual char | get_base (const handle_t &handle, size_t index) const |
virtual std::string | get_subsequence (const handle_t &handle, size_t index, size_t size) const |
handle_t | forward (const handle_t &handle) const |
Get the locally forward version of a handle. More... | |
edge_t | edge_handle (const handle_t &left, const handle_t &right) const |
handle_t | traverse_edge_handle (const edge_t &edge, const handle_t &left) const |
template<typename Iteratee > | |
bool | for_each_edge (const Iteratee &iteratee, bool parallel=false) const |
Protected Member Functions | |
bool | for_each_handle_impl (const std::function< bool(const handle_t &)> &iteratee, bool parallel=false) const |
bool | follow_edges_impl (const handle_t &handle, bool go_left, const std::function< bool(const handle_t &)> &iteratee) const |
Protected Attributes | |
const HandleGraph * | backing_graph |
the backing graph More... | |
SnarlManager & | snarl_manager |
the snarl manager More... | |
unordered_map< handle_t, pair< handle_t, bool > > | snarls |
the snarls (indexed both ways). flag is true for original orientation More... | |
Simplification of a NetGraph that ignores chains. It is designed only for traversal finding. Todo: generalize NestedFlowCaller to the point where we can remove this and use NetGraph instead
vg::SnarlGraph::SnarlGraph | ( | const HandleGraph * | backing_graph, |
SnarlManager & | snarl_manager, | ||
vector< const Snarl * > | snarls | ||
) |
void vg::SnarlGraph::embed_ref_path_snarls | ( | SnarlTraversal & | traversal | ) |
void vg::SnarlGraph::embed_snarl | ( | Visit & | visit | ) |
void vg::SnarlGraph::embed_snarls | ( | SnarlTraversal & | traversal | ) |
Invert the orientation of a handle (potentially without getting its ID)
Implements handlegraph::HandleGraph.
|
protectedvirtual |
this is the only function that's changed to do anything different from the backing graph: it is changed to "pass through" snarls by pretending there are edges from into snarl starts out of ends and vice versa.
Implements handlegraph::HandleGraph.
|
protectedvirtual |
Loop over all the nodes in the graph in their local forward orientations, in their internal stored order. Stop if the iteratee returns false. Can be told to run in parallel, in which case stopping after a false return value is on a best-effort basis and iteration order is not defined. Returns true if we finished and false if we stopped early.
Implements handlegraph::HandleGraph.
|
virtual |
Look up the handle for the node with the given ID in the given orientation.
Implements handlegraph::HandleGraph.
Get the ID from a handle.
Implements handlegraph::HandleGraph.
|
virtual |
Get the orientation of a handle.
Implements handlegraph::HandleGraph.
|
virtual |
Get the length of a node.
Implements handlegraph::HandleGraph.
|
virtual |
Return the number of nodes in the graph.
Implements handlegraph::HandleGraph.
|
virtual |
Get the sequence of a node, presented in the handle's local forward orientation.
Implements handlegraph::HandleGraph.
|
virtual |
Method to check if a node exists by ID.
Implements handlegraph::HandleGraph.
|
virtual |
Return the largest ID in the graph, or some larger number if the largest ID is unavailable. Return value is unspecified if the graph is empty.
Implements handlegraph::HandleGraph.
|
virtual |
Return the smallest ID in the graph, or some smaller number if the smallest ID is unavailable. Return value is unspecified if the graph is empty.
Implements handlegraph::HandleGraph.
|
protected |
the backing graph
|
protected |
the snarl manager
the snarls (indexed both ways). flag is true for original orientation