NAME
Graph::AdjacencyMap - map of graph vertices or edges
SYNOPSIS
Internal.
DESCRIPTION
This module is meant for internal use by the Graph module.
OBJECT METHODS
del_path(\@seq)
Delete a Map path.
del_path_by_multi_id(\@seq, $id)
Delete a Map path by a multi(vertex) id.
get_multi_ids(\@seq)
Return the multi ids.
has_path(\@seq)
Returns the integer ID of the path, or undef if Map doesn't have it.
has_any_paths
Return true if the Map has any paths, false if not.
has_path_by_multi_id(\@seq, $id)
Return true if the Map has the path by a multi(vertex) id, false if not.
paths
Return all the paths of the Map.
set_paths(\@seq1, \@seq2, ...)
@ids = set_paths($seq1, $seq2, ...)
Create/identify the path of $seq*
. Returns the integer ID of each path. For arity other than 1, the sequence items must be integers. For arity 1, do not wrap the item in an array. For _UNORD
, you must give the sequence already sorted.
set_path_by_multi_id(\@seq, $id)
($integer_ID, $multi_ID) = $m->set_path_by_multi_id(\@seq, $id)
Set the path in the Map by the multi id.
get_paths_by_ids([ \@idlist1, \@idlist2... ], $deep)
Given an array-ref of array-refs of vertex IDs, returns a list of array-refs of vertex-names. This is to look up vertex paths for use in edges. Only useful for arity 1. The $deep
option is useful with directed hyperedges.
get_ids_by_paths
@ids = $m->get_ids_by_paths([ \@seq1, \@seq2... ], $ensure, 0);
@id_lists = $m->get_ids_by_paths([ \@seq1, \@seq2... ], $ensure, 1);
This is to look up vertex IDs for use in edges. Only useful for arity 1. Given an array-ref of array-refs with paths, returns a list of IDs of existing paths.
If $ensure
is true, will first create paths that do not already exist. If it is not, any non-existing paths will cause an empty list to be returned.
If $deep is true, each sequence will be treated as a list of paths, and IDs filled in for the return values. This can have a value up to 2.
rename_path($from, $to)
Rename the path.
stringify
Return a string describing the object in a human-friendly(ish) way.
successors
@successors = $m->successors(@v)
Only valid for a map of arity other than 1.
predecessors
@predecessors = $m->predecessors($v)
Only valid for a non-_UNORD
map of arity other than 1.
paths_from
@paths = $m->paths_from(@v)
Only valid for a map of arity other than 1.
paths_to
@paths = $m->paths_to($v)
Only valid for a non-_UNORD
map of arity other than 1.
has_successor
$bool = $m->has_successor($u, $v)
Only valid for a map of arity other than 1.
reindex
Will recreate the mapping from paths to indexes. Intended for use after a deep copy.
AUTHOR AND COPYRIGHT
Jarkko Hietaniemi jhi@iki.fi
LICENSE
This module is licensed under the same terms as Perl itself.