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.