From 80249aeabccb06af90d98f1d85f31f30c65b66a9 Mon Sep 17 00:00:00 2001 From: Katharine Hyatt Date: Mon, 20 Aug 2018 11:17:37 -0400 Subject: [PATCH] Lots more doctests (#995) --- src/connectivity.jl | 180 ++++++++++++++++++++++++++++++++++++++++++- src/distance.jl | 18 +++++ src/edit_distance.jl | 12 ++- src/interface.jl | 27 +++++++ src/operators.jl | 119 ++++++++++++++++++++++++++-- 5 files changed, 348 insertions(+), 8 deletions(-) diff --git a/src/connectivity.jl b/src/connectivity.jl index 8329af026..a5184b789 100644 --- a/src/connectivity.jl +++ b/src/connectivity.jl @@ -80,6 +80,22 @@ belonging to the component. For directed graphs, see [`strongly_connected_components`](@ref) and [`weakly_connected_components`](@ref). + +# Examples +```jldoctest +julia> g = SimpleGraph([0 1 0; 1 0 1; 0 1 0]); + +julia> connected_components(g) +1-element Array{Array{Int64,1},1}: + [1, 2, 3] + +julia> g = SimpleGraph([0 1 0 0 0; 1 0 1 0 0; 0 1 0 0 0; 0 0 0 0 1; 0 0 0 1 0]); + +julia> connected_components(g) +2-element Array{Array{Int64,1},1}: + [1, 2, 3] + [4, 5] +``` """ function connected_components(g::AbstractGraph{T}) where T label = zeros(T, nv(g)) @@ -93,6 +109,24 @@ end Return `true` if graph `g` is connected. For directed graphs, return `true` if graph `g` is weakly connected. + +# Examples +```jldoctest +julia> g = SimpleGraph([0 1 0; 1 0 1; 0 1 0]); + +julia> is_connected(g) +true + +julia> g = SimpleGraph([0 1 0 0 0; 1 0 1 0 0; 0 1 0 0 0; 0 0 0 0 1; 0 0 0 1 0]); + +julia> is_connected(g) +false + +julia> g = SimpleDiGraph([0 1 0; 0 0 1; 1 0 0]); + +julia> is_connected(g) +true +``` """ function is_connected(g::AbstractGraph) mult = is_directed(g) ? 2 : 1 @@ -104,7 +138,16 @@ end Return the weakly connected components of the graph `g`. This is equivalent to the connected components of the undirected equivalent of `g`. -For undirected graphs this is equivalent to the connected components of `g`. +For undirected graphs this is equivalent to the [`connected_components`](@ref) of `g`. + +# Examples +```jldoctest +julia> g = SimpleDiGraph([0 1 0; 1 0 1; 0 0 0]); + +julia> weakly_connected_components(g) +1-element Array{Array{Int64,1},1}: + [1, 2, 3] +``` """ weakly_connected_components(g) = connected_components(g) @@ -112,7 +155,26 @@ weakly_connected_components(g) = connected_components(g) is_weakly_connected(g) Return `true` if the graph `g` is weakly connected. If `g` is undirected, -this function is equivalent to `is_connected(g)`. +this function is equivalent to [`is_connected(g)`](@ref). + +# Examples +```jldoctest +julia> g = SimpleDiGraph([0 1 0; 0 0 1; 1 0 0]); + +julia> is_weakly_connected(g) +true + +julia> g = SimpleDiGraph([0 1 0; 1 0 1; 0 0 0]); + +julia> is_connected(g) +true + +julia> is_strongly_connected(g) +false + +julia> is_weakly_connected(g) +true +``` """ is_weakly_connected(g) = is_connected(g) @@ -125,6 +187,16 @@ Return an array of arrays, each of which is the entire connected component. ### Implementation Notes The order of the components is not part of the API contract. + +# Examples +```jldoctest +julia> g = SimpleDiGraph([0 1 0; 1 0 1; 0 0 0]); + +julia> strongly_connected_components(g) +2-element Array{Array{Int64,1},1}: + [3] + [1, 2] +``` """ function strongly_connected_components end # see https://github.com/mauro3/SimpleTraits.jl/issues/47#issuecomment-327880153 for syntax @@ -216,6 +288,14 @@ end is_strongly_connected(g) Return `true` if directed graph `g` is strongly connected. + +# Examples +```jldoctest +julia> g = SimpleDiGraph([0 1 0; 0 0 1; 1 0 0]); + +julia> is_strongly_connected(g) +true +``` """ function is_strongly_connected end @traitfn is_strongly_connected(g::::IsDirected) = length(strongly_connected_components(g)) == 1 @@ -225,6 +305,14 @@ function is_strongly_connected end Return the (common) period for all vertices in a strongly connected directed graph. Will throw an error if the graph is not strongly connected. + +# Examples +```jldoctest +julia> g = SimpleDiGraph([0 1 0; 0 0 1; 1 0 0]); + +julia> period(g) +3 +``` """ function period end # see https://github.com/mauro3/SimpleTraits.jl/issues/47#issuecomment-327880153 for syntax @@ -255,6 +343,20 @@ end Return the condensation graph of the strongly connected components `scc` in the directed graph `g`. If `scc` is missing, generate the strongly connected components first. + +# Examples +```jldoctest +julia> g = SimpleDiGraph([0 1 0 0 0; 0 0 1 0 0; 1 0 0 1 0; 0 0 0 0 1; 0 0 0 1 0]) +{5, 6} directed simple Int64 graph + +julia> strongly_connected_components(g) +2-element Array{Array{Int64,1},1}: + [4, 5] + [1, 2, 3] + +julia> foreach(println, edges(condensation(g))) +Edge 2 => 1 +``` """ function condensation end @traitfn function condensation(g::::IsDirected, scc::Vector{Vector{T}}) where T <: Integer @@ -284,6 +386,21 @@ components in the directed graph `g`. The attracting components are a subset of the strongly connected components in which the components do not have any leaving edges. + +# Examples +```jldoctest +julia> g = SimpleDiGraph([0 1 0 0 0; 0 0 1 0 0; 1 0 0 1 0; 0 0 0 0 1; 0 0 0 1 0]) +{5, 6} directed simple Int64 graph + +julia> strongly_connected_components(g) +2-element Array{Array{Int64,1},1}: + [4, 5] + [1, 2, 3] + +julia> attracting_components(g) +1-element Array{Array{Int64,1},1}: + [4, 5] +``` """ function attracting_components end # see https://github.com/mauro3/SimpleTraits.jl/issues/47#issuecomment-327880153 for syntax @@ -311,6 +428,32 @@ may be specified by `distmx`. ### Optional Arguments - `dir=:out`: If `g` is directed, this argument specifies the edge direction with respect to `v` of the edges to be considered. Possible values: `:in` or `:out`. + +# Examples +```jldoctest +julia> g = SimpleDiGraph([0 1 0 0 0; 0 0 1 0 0; 1 0 0 1 0; 0 0 0 0 1; 0 0 0 1 0]); + +julia> neighborhood(g, 1, 2) +3-element Array{Int64,1}: + 1 + 2 + 3 + +julia> neighborhood(g, 1, 3) +4-element Array{Int64,1}: + 1 + 2 + 3 + 4 + +julia> neighborhood(g, 1, 3, [0 1 0 0 0; 0 0 1 0 0; 1 0 0 0.25 0; 0 0 0 0 0.25; 0 0 0 0.25 0]) +5-element Array{Int64,1}: + 1 + 2 + 3 + 4 + 5 +``` """ neighborhood(g::AbstractGraph{T}, v::Integer, d, distmx::AbstractMatrix{U}=weights(g); dir=:out) where T <: Integer where U <: Real = first.(neighborhood_dists(g, v, d, distmx; dir=dir)) @@ -324,6 +467,39 @@ may be specified by `distmx`, along with its distance from `v`. ### Optional Arguments - `dir=:out`: If `g` is directed, this argument specifies the edge direction with respect to `v` of the edges to be considered. Possible values: `:in` or `:out`. + +# Examples +```jldoctest +julia> g = SimpleDiGraph([0 1 0 0 0; 0 0 1 0 0; 1 0 0 1 0; 0 0 0 0 1; 0 0 0 1 0]); + +julia> neighborhood_dists(g, 1, 3) +4-element Array{Tuple{Int64,Int64},1}: + (1, 0) + (2, 1) + (3, 2) + (4, 3) + +julia> neighborhood_dists(g, 1, 3, [0 1 0 0 0; 0 0 1 0 0; 1 0 0 0.25 0; 0 0 0 0 0.25; 0 0 0 0.25 0]) +5-element Array{Tuple{Int64,Float64},1}: + (1, 0.0) + (2, 1.0) + (3, 2.0) + (4, 2.25) + (5, 2.5) + +julia> neighborhood_dists(g, 4, 3) +2-element Array{Tuple{Int64,Int64},1}: + (4, 0) + (5, 1) + +julia> neighborhood_dists(g, 4, 3, dir=:in) +5-element Array{Tuple{Int64,Int64},1}: + (4, 0) + (3, 1) + (5, 1) + (2, 2) + (1, 3) +``` """ neighborhood_dists(g::AbstractGraph{T}, v::Integer, d, distmx::AbstractMatrix{U}=weights(g); dir=:out) where T <: Integer where U <: Real = (dir == :out) ? _neighborhood(g, v, d, distmx, outneighbors) : _neighborhood(g, v, d, distmx, inneighbors) diff --git a/src/distance.jl b/src/distance.jl index 088cfa9ec..82e9844fb 100644 --- a/src/distance.jl +++ b/src/distance.jl @@ -48,6 +48,24 @@ for each call to the function. It may therefore be more efficient to calculate, store, and pass the eccentricities if multiple distance measures are desired. An infinite path length is represented by the `typemax` of the distance matrix. + +# Examples +```jldoctest +julia> g = SimpleGraph([0 1 0; 1 0 1; 0 1 0]); + +julia> eccentricity(g, 1) +2 + +julia> eccentricity(g, [1; 2]) +2-element Array{Int64,1}: + 2 + 1 + +julia> eccentricity(g, [1; 2], [0 2 0; 0.5 0 0.5; 0 2 0]) +2-element Array{Float64,1}: + 2.5 + 0.5 +``` """ function eccentricity(g::AbstractGraph, v::Integer, diff --git a/src/edit_distance.jl b/src/edit_distance.jl index e7bcf422a..ee67e7cb7 100644 --- a/src/edit_distance.jl +++ b/src/edit_distance.jl @@ -39,6 +39,16 @@ if involved costs are equivalent. ### Author - Júlio Hoffimann Mendes (juliohm@stanford.edu) + +# Examples +```jldoctest +julia> g1 = SimpleDiGraph([0 1 0 0 0; 0 0 1 0 0; 1 0 0 1 0; 0 0 0 0 1; 0 0 0 1 0]); + +julia> g2 = SimpleDiGraph([0 1 0; 0 0 1; 1 0 0]); + +julia> edit_distance(g1, g2) +(3.5, Tuple[(1, 2), (2, 1), (3, 0), (4, 3), (5, 0)]) +``` """ function edit_distance(G₁::AbstractGraph, G₂::AbstractGraph; insert_cost::Function=v -> 1.0, @@ -125,7 +135,7 @@ end """ BoundedMinkowskiCost(μ₁, μ₂) -Return value similar to `MinkowskiCost`, but ensure costs smaller than 2τ. +Return value similar to [`MinkowskiCost`](@ref), but ensure costs smaller than 2τ. ### Optional Arguments `p=1`: the p value for p-norm calculation. diff --git a/src/interface.jl b/src/interface.jl index 922d09697..779ee2119 100644 --- a/src/interface.jl +++ b/src/interface.jl @@ -153,6 +153,16 @@ Return a list of all neighbors connected to vertex `v` by an incoming edge. ### Implementation Notes Returns a reference, not a copy. Do not modify result. + +# Examples +```jldoctest +julia> g = SimpleDiGraph([0 1 0 0 0; 0 0 1 0 0; 1 0 0 1 0; 0 0 0 0 1; 0 0 0 1 0]); + +julia> inneighbors(g, 4) +2-element Array{Int64,1}: + 3 + 5 +``` """ inneighbors(x, v) = _NI("inneighbors") @@ -163,6 +173,15 @@ Return a list of all neighbors connected to vertex `v` by an outgoing edge. # Implementation Notes Returns a reference, not a copy. Do not modify result. + +# Examples +```jldoctest +julia> g = SimpleDiGraph([0 1 0 0 0; 0 0 1 0 0; 1 0 0 1 0; 0 0 0 0 1; 0 0 0 1 0]); + +julia> outneighbors(g, 4) +1-element Array{Int64,1}: + 5 +``` """ outneighbors(x, v) = _NI("outneighbors") @@ -170,5 +189,13 @@ outneighbors(x, v) = _NI("outneighbors") zero(g) Return a zero-vertex, zero-edge version of the same type of graph as `g`. + +# Examples +```jldoctest +julia> g = SimpleDiGraph([0 1 0 0 0; 0 0 1 0 0; 1 0 0 1 0; 0 0 0 0 1; 0 0 0 1 0]); + +julia> zero(g) +{0, 0} directed simple Int64 graph +``` """ zero(g::AbstractGraph) = _NI("zero") diff --git a/src/operators.jl b/src/operators.jl index 257bd79fd..90f645ee4 100644 --- a/src/operators.jl +++ b/src/operators.jl @@ -5,7 +5,28 @@ Return the [graph complement](https://en.wikipedia.org/wiki/Complement_graph) of a graph ### Implementation Notes -Preserves the eltype of the input graph. +Preserves the `eltype` of the input graph. + +# Examples +```jldoctest +julia> g = SimpleDiGraph([0 1 0 0 0; 0 0 1 0 0; 1 0 0 1 0; 0 0 0 0 1; 0 0 0 1 0]); + +julia> foreach(println, edges(complement(g))) +Edge 1 => 3 +Edge 1 => 4 +Edge 1 => 5 +Edge 2 => 1 +Edge 2 => 4 +Edge 2 => 5 +Edge 3 => 2 +Edge 3 => 5 +Edge 4 => 1 +Edge 4 => 2 +Edge 4 => 3 +Edge 5 => 1 +Edge 5 => 2 +Edge 5 => 3 +``` """ function complement(g::Graph) gnv = nv(g) @@ -39,6 +60,19 @@ original directed graph. ### Implementation Notes Preserves the eltype of the input graph. + +# Examples +```jldoctest +julia> g = SimpleDiGraph([0 1 0 0 0; 0 0 1 0 0; 1 0 0 1 0; 0 0 0 0 1; 0 0 0 1 0]); + +julia> foreach(println, edges(reverse(g))) +Edge 1 => 3 +Edge 2 => 1 +Edge 3 => 2 +Edge 4 => 3 +Edge 4 => 5 +Edge 5 => 4 +``` """ function reverse end @traitfn function reverse(g::G::IsDirected) where G<:AbstractSimpleGraph @@ -55,6 +89,7 @@ end reverse!(g) In-place reverse of a directed graph (modifies the original graph). +See [`reverse`](@ref) for a non-modifying version. """ function reverse! end @traitfn function reverse!(g::G::IsDirected) where G<:AbstractSimpleGraph @@ -66,11 +101,32 @@ end blockdiag(g, h) Return a graph with ``|V(g)| + |V(h)|`` vertices and ``|E(g)| + |E(h)|`` -edges where the vertices an edges from graph `h` are appended to graph `g`. +edges where the vertices and edges from graph `h` are appended to graph `g`. ### Implementation Notes Preserves the eltype of the input graph. Will error if the -number of vertices in the generated graph exceeds the eltype. +number of vertices in the generated graph exceeds the `eltype`. + +# Examples +```jldoctest +julia> g1 = SimpleDiGraph([0 1 0 0 0; 0 0 1 0 0; 1 0 0 1 0; 0 0 0 0 1; 0 0 0 1 0]); + +julia> g2 = SimpleDiGraph([0 1 0; 0 0 1; 1 0 0]); + +julia> blockdiag(g1, g2) +{8, 9} directed simple Int64 graph + +julia> foreach(println, edges(blockdiag(g1, g2))) +Edge 1 => 2 +Edge 2 => 3 +Edge 3 => 1 +Edge 3 => 4 +Edge 4 => 5 +Edge 5 => 4 +Edge 6 => 7 +Edge 7 => 8 +Edge 8 => 6 +``` """ function blockdiag(g::T, h::T) where T <: AbstractGraph gnv = nv(g) @@ -92,6 +148,18 @@ Return a graph with edges that are only in both graph `g` and graph `h`. ### Implementation Notes This function may produce a graph with 0-degree vertices. Preserves the eltype of the input graph. + +# Examples +```jldoctest +julia> g1 = SimpleDiGraph([0 1 0 0 0; 0 0 1 0 0; 1 0 0 1 0; 0 0 0 0 1; 0 0 0 1 0]); + +julia> g2 = SimpleDiGraph([0 1 0; 0 0 1; 1 0 0]); + +julia> foreach(println, edges(intersect(g1, g2))) +Edge 1 => 2 +Edge 2 => 3 +Edge 3 => 1 +``` """ function intersect(g::T, h::T) where T <: AbstractGraph gnv = nv(g) @@ -111,7 +179,19 @@ Return a graph with edges in graph `g` that are not in graph `h`. ### Implementation Notes Note that this function may produce a graph with 0-degree vertices. -Preserves the eltype of the input graph. +Preserves the `eltype` of the input graph. + +# Examples +```jldoctest +julia> g1 = SimpleDiGraph([0 1 0 0 0; 0 0 1 0 0; 1 0 0 1 0; 0 0 0 0 1; 0 0 0 1 0]); + +julia> g2 = SimpleDiGraph([0 1 0; 0 0 1; 1 0 0]); + +julia> foreach(println, edges(difference(g1, g2))) +Edge 3 => 4 +Edge 4 => 5 +Edge 5 => 4 +``` """ function difference(g::T, h::T) where T <: AbstractGraph gnv = nv(g) @@ -248,6 +328,27 @@ end sum(g, i) Return a vector of indegree (`i`=1) or outdegree (`i`=2) values for graph `g`. + +# Examples +```jldoctest +julia> g = SimpleDiGraph([0 1 0 0 0; 0 0 1 0 0; 1 0 0 1 0; 0 0 0 0 1; 0 0 0 1 0]); + +julia> sum(g, 2) +5-element Array{Int64,1}: + 1 + 1 + 2 + 1 + 1 + +julia> sum(g, 1) +5-element Array{Int64,1}: + 1 + 1 + 1 + 2 + 1 +``` """ function sum(g::AbstractGraph, dim::Int) dim == 1 && return indegree(g, vertices(g)) @@ -267,7 +368,15 @@ size(g::Graph, dim::Int) = (dim == 1 || dim == 2) ? nv(g) : 1 """ sum(g) -Return the number of edges in `g` +Return the number of edges in `g`. + +# Examples +```jldoctest +julia> g = SimpleGraph([0 1 0; 1 0 1; 0 1 0]); + +julia> sum(g) +2 +``` """ sum(g::AbstractGraph) = ne(g)