Skip to content

Commit

Permalink
Fix ambiguity on steiner_tree
Browse files Browse the repository at this point in the history
  • Loading branch information
JoeyT1994 committed Nov 7, 2024
1 parent 0feb539 commit 47598e3
Show file tree
Hide file tree
Showing 2 changed files with 23 additions and 1 deletion.
14 changes: 13 additions & 1 deletion src/steiner_tree.jl
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
using Graphs: Graphs, IsDirected, nv, steiner_tree
using SimpleTraits: SimpleTraits, Not, @traitfn

@traitfn function Graphs.steiner_tree(
@traitfn function namedgraph_steiner_tree(
g::AbstractNamedGraph::(!IsDirected), term_vert, distmx=weights(g)
)
position_tree = steiner_tree(
Expand All @@ -11,3 +11,15 @@ using SimpleTraits: SimpleTraits, Not, @traitfn
)
return typeof(g)(position_tree, map(v -> ordered_vertices(g)[v], vertices(position_tree)))
end

@traitfn function Graphs.steiner_tree(
g::AbstractNamedGraph::(!IsDirected), term_vert, args...
)
return namedgraph_steiner_tree(g, term_vert, args...)
end

@traitfn function Graphs.steiner_tree(
g::AbstractNamedGraph::(!IsDirected), term_vert::Vector{<:Integer}, args...
)
return namedgraph_steiner_tree(g, term_vert, args...)
end
10 changes: 10 additions & 0 deletions test/test_namedgraph.jl
Original file line number Diff line number Diff line change
Expand Up @@ -679,6 +679,16 @@ end
for e in es
@test has_edge(st, e)
end

g = named_path_graph(4)
terminal_vertices = [1, 3]
st = steiner_tree(g, terminal_vertices)
es = [1 => 2, 2 => 3]
@test ne(st) == 2
@test nv(st) == 3
for e in es
@test has_edge(st, e)
end
end
@testset "topological_sort_by_dfs" begin
g = NamedDiGraph(["A", "B", "C", "D", "E", "F", "G"])
Expand Down

0 comments on commit 47598e3

Please sign in to comment.