| Copyright | (c) Andrey Mokhov 2016-2017 |
|---|---|
| License | MIT (see the file LICENSE) |
| Maintainer | andrey.mokhov@gmail.com |
| Stability | unstable |
| Safe Haskell | None |
| Language | Haskell2010 |
Algebra.Graph.IntAdjacencyMap.Internal
Description
This module exposes the implementation of adjacency maps. The API is unstable and unsafe. Where possible use non-internal module Algebra.Graph.IntAdjacencyMap instead.
- newtype IntAdjacencyMap = IntAdjacencyMap {}
- consistent :: IntAdjacencyMap -> Bool
- empty :: IntAdjacencyMap
- vertex :: Int -> IntAdjacencyMap
- overlay :: IntAdjacencyMap -> IntAdjacencyMap -> IntAdjacencyMap
- connect :: IntAdjacencyMap -> IntAdjacencyMap -> IntAdjacencyMap
- vertices :: [Int] -> IntAdjacencyMap
- edges :: [(Int, Int)] -> IntAdjacencyMap
- fromAdjacencyList :: [(Int, [Int])] -> IntAdjacencyMap
- edgeList :: IntAdjacencyMap -> [(Int, Int)]
- adjacencyList :: IntAdjacencyMap -> [(Int, [Int])]
- removeVertex :: Int -> IntAdjacencyMap -> IntAdjacencyMap
- removeEdge :: Int -> Int -> IntAdjacencyMap -> IntAdjacencyMap
- gmap :: (Int -> Int) -> IntAdjacencyMap -> IntAdjacencyMap
- induce :: (Int -> Bool) -> IntAdjacencyMap -> IntAdjacencyMap
Adjacency map
newtype IntAdjacencyMap Source #
The IntAdjacencyMap data type represents a graph by a map of vertices to
their adjacency sets. We define a law-abiding Num instance as a convenient
notation for working with graphs:
0 == vertex 0 1 + 2 == overlay (vertex 1) (vertex 2) 1 * 2 == connect (vertex 1) (vertex 2) 1 + 2 * 3 == overlay (vertex 1) (connect (vertex 2) (vertex 3)) 1 * (2 + 3) == connect (vertex 1) (overlay (vertex 2) (vertex 3))
The Show instance is defined using basic graph construction primitives:
show (empty :: IntAdjacencyMap Int) == "empty"
show (1 :: IntAdjacencyMap Int) == "vertex 1"
show (1 + 2 :: IntAdjacencyMap Int) == "vertices [1,2]"
show (1 * 2 :: IntAdjacencyMap Int) == "edge 1 2"
show (1 * 2 * 3 :: IntAdjacencyMap Int) == "edges [(1,2),(1,3),(2,3)]"
show (1 * 2 + 3 :: IntAdjacencyMap Int) == "graph [1,2,3] [(1,2)]"The Eq instance satisfies all axioms of algebraic graphs:
overlayis commutative and associative:x + y == y + x x + (y + z) == (x + y) + z
connectis associative and hasemptyas the identity:x * empty == x empty * x == x x * (y * z) == (x * y) * z
connectdistributes overoverlay:x * (y + z) == x * y + x * z (x + y) * z == x * z + y * z
connectcan be decomposed:x * y * z == x * y + x * z + y * z
The following useful theorems can be proved from the above set of axioms.
overlayhasemptyas the identity and is idempotent:x + empty == x empty + x == x x + x == xAbsorption and saturation of
connect:x * y + x + y == x * y x * x * x == x * x
When specifying the time and memory complexity of graph algorithms, n and m will denote the number of vertices and edges in the graph, respectively.
Constructors
| IntAdjacencyMap | |
Fields
| |
Instances
consistent :: IntAdjacencyMap -> Bool Source #
Check if the internal graph representation is consistent, i.e. that all edges refer to existing vertices. It should be impossible to create an inconsistent adjacency map, and we use this function in testing.
consistentempty== True consistent (vertexx) == True consistent (overlayx y) == True consistent (connectx y) == True consistent (edgex y) == True consistent (edgesxs) == True consistent (graphxs ys) == True consistent (fromAdjacencyListxs) == True
Basic graph construction primitives
empty :: IntAdjacencyMap Source #
Construct the empty graph. Complexity: O(1) time and memory.
isEmptyempty == TruehasVertexx empty == FalsevertexCountempty == 0edgeCountempty == 0
vertex :: Int -> IntAdjacencyMap Source #
Construct the graph comprising a single isolated vertex. Complexity: O(1) time and memory.
isEmpty(vertex x) == FalsehasVertexx (vertex x) == TruehasVertex1 (vertex 2) == FalsevertexCount(vertex x) == 1edgeCount(vertex x) == 0
overlay :: IntAdjacencyMap -> IntAdjacencyMap -> IntAdjacencyMap Source #
Overlay two graphs. This is an idempotent, commutative and associative
operation with the identity empty.
Complexity: O((n + m) * log(n)) time and O(n + m) memory.
isEmpty(overlay x y) ==isEmptyx &&isEmptyyhasVertexz (overlay x y) ==hasVertexz x ||hasVertexz yvertexCount(overlay x y) >=vertexCountxvertexCount(overlay x y) <=vertexCountx +vertexCountyedgeCount(overlay x y) >=edgeCountxedgeCount(overlay x y) <=edgeCountx +edgeCountyvertexCount(overlay 1 2) == 2edgeCount(overlay 1 2) == 0
connect :: IntAdjacencyMap -> IntAdjacencyMap -> IntAdjacencyMap Source #
Connect two graphs. This is an associative operation with the identity
empty, which distributes over the overlay and obeys the decomposition axiom.
Complexity: O((n + m) * log(n)) time and O(n + m) memory. Note that the
number of edges in the resulting graph is quadratic with respect to the number
of vertices of the arguments: m = O(m1 + m2 + n1 * n2).
isEmpty(connect x y) ==isEmptyx &&isEmptyyhasVertexz (connect x y) ==hasVertexz x ||hasVertexz yvertexCount(connect x y) >=vertexCountxvertexCount(connect x y) <=vertexCountx +vertexCountyedgeCount(connect x y) >=edgeCountxedgeCount(connect x y) >=edgeCountyedgeCount(connect x y) >=vertexCountx *vertexCountyedgeCount(connect x y) <=vertexCountx *vertexCounty +edgeCountx +edgeCountyvertexCount(connect 1 2) == 2edgeCount(connect 1 2) == 1
vertices :: [Int] -> IntAdjacencyMap Source #
Construct the graph comprising a given list of isolated vertices. Complexity: O(L * log(L)) time and O(L) memory, where L is the length of the given list.
vertices [] ==emptyvertices [x] ==vertexxhasVertexx . vertices ==elemxvertexCount. vertices ==length.nubvertexIntSet. vertices == IntSet.fromList
fromAdjacencyList :: [(Int, [Int])] -> IntAdjacencyMap Source #
Construct a graph from an adjacency list. Complexity: O((n + m) * log(n)) time and O(n + m) memory.
fromAdjacencyList [] ==emptyfromAdjacencyList [(x, [])] ==vertexx fromAdjacencyList [(x, [y])] ==edgex y fromAdjacencyList .adjacencyList== idoverlay(fromAdjacencyList xs) (fromAdjacencyList ys) == fromAdjacencyList (xs ++ ys)
Graph properties
adjacencyList :: IntAdjacencyMap -> [(Int, [Int])] Source #
The sorted adjacency list of a graph. Complexity: O(n + m) time and O(m) memory.
adjacencyListempty== [] adjacencyList (vertexx) == [(x, [])] adjacencyList (edge1 2) == [(1, [2]), (2, [])] adjacencyList (star2 [1,3]) == [(1, []), (2, [1,3]), (3, [])]fromAdjacencyList. adjacencyList == id
Graph transformation
removeVertex :: Int -> IntAdjacencyMap -> IntAdjacencyMap Source #
removeEdge :: Int -> Int -> IntAdjacencyMap -> IntAdjacencyMap Source #
Remove an edge from a given graph. Complexity: O(log(n)) time.
removeEdge x y (edgex y) ==vertices[x, y] removeEdge x y . removeEdge x y == removeEdge x y removeEdge x y .removeVertexx ==removeVertexx removeEdge 1 1 (1 * 1 * 2 * 2) == 1 * 2 * 2 removeEdge 1 2 (1 * 1 * 2 * 2) == 1 * 1 + 2 * 2
gmap :: (Int -> Int) -> IntAdjacencyMap -> IntAdjacencyMap Source #
Transform a graph by applying a function to each of its vertices. This is
similar to Functor's fmap but can be used with non-fully-parametric
IntAdjacencyMap.
Complexity: O((n + m) * log(n)) time.
gmap fempty==emptygmap f (vertexx) ==vertex(f x) gmap f (edgex y) ==edge(f x) (f y) gmap id == id gmap f . gmap g == gmap (f . g)
induce :: (Int -> Bool) -> IntAdjacencyMap -> IntAdjacencyMap Source #
Construct the induced subgraph of a given graph by removing the vertices that do not satisfy a given predicate. Complexity: O(m) time, assuming that the predicate takes O(1) to be evaluated.
induce (const True) x == x induce (const False) x ==emptyinduce (/= x) ==removeVertexx induce p . induce q == induce (\x -> p x && q x)isSubgraphOf(induce p x) x == True