Interface DominatingSetAlgo
-
public interface DominatingSetAlgo
An algorithm for computing a minimum dominating set.Given a graph G=(V,E), a dominating set is a subset D⊆V such that for every v∈V, either v∈D or there is an edge (u,v)∈E such that u∈D. The minimum dominating set problem is to find a dominating set of minimum size or weight. The problem is NP-hard. Algorithms implementing this interfaces are heuristics or fixed ration approximation algorithms.
In a directed graph, the 'dominance' should be defined with respect to either the in-edges, out-edges or in-edges + out-edges of the vertices. This is specified as a
EdgeDirection
parameter tocomputeMinimumDominationSet(Graph, WeightFunction, EdgeDirection)
, which yields different types of dominating sets.Use
newInstance()
to get a default implementation of this interface. A builder obtained vianewBuilder()
may support different options to obtain different implementations.- Author:
- Barak Ugav
-
-
Nested Class Summary
Nested Classes Modifier and Type Interface Description static interface
DominatingSetAlgo.Builder
A builder forDominatingSetAlgo
algorithms.
-
Method Summary
All Methods Static Methods Instance Methods Abstract Methods Default Methods Modifier and Type Method Description default <V,E>
Set<V>computeMinimumDominationSet(Graph<V,E> g, WeightFunction<V> w)
Compute a minimum dominating set of the graph with respect to the in-degree + out-degree of the vertices.<V,E>
Set<V>computeMinimumDominationSet(Graph<V,E> g, WeightFunction<V> w, EdgeDirection dominanceDirection)
Compute a minimum dominating set of the graph with respect to the given edges direction.static <V,E>
booleanisDominatingSet(Graph<V,E> g, Collection<V> dominatingSet, EdgeDirection dominanceDirection)
Check whether a given set of vertices is a dominating set of a graph.static DominatingSetAlgo.Builder
newBuilder()
Create a new dominating set algorithm builder.static DominatingSetAlgo
newInstance()
Create a new dominating set algorithm object.
-
-
-
Method Detail
-
computeMinimumDominationSet
default <V,E> Set<V> computeMinimumDominationSet(Graph<V,E> g, WeightFunction<V> w)
Compute a minimum dominating set of the graph with respect to the in-degree + out-degree of the vertices.- Type Parameters:
V
- the vertices typeE
- the edges type- Parameters:
g
- a graphw
- a vertex weight function- Returns:
- a minimum dominating set of the graph
-
computeMinimumDominationSet
<V,E> Set<V> computeMinimumDominationSet(Graph<V,E> g, WeightFunction<V> w, EdgeDirection dominanceDirection)
Compute a minimum dominating set of the graph with respect to the given edges direction.- Type Parameters:
V
- the vertices typeE
- the edges type- Parameters:
g
- a graphw
- a vertex weight functiondominanceDirection
- the direction of the edges to consider- Returns:
- a minimum dominating set of the graph
-
isDominatingSet
static <V,E> boolean isDominatingSet(Graph<V,E> g, Collection<V> dominatingSet, EdgeDirection dominanceDirection)
Check whether a given set of vertices is a dominating set of a graph.- Type Parameters:
V
- the vertices typeE
- the edges type- Parameters:
g
- a graphdominatingSet
- a set of verticesdominanceDirection
- the direction of the edges to consider, ifnull
thenEdgeDirection.All
is used- Returns:
- true if the given set is a dominating set of the graph
-
newInstance
static DominatingSetAlgo newInstance()
Create a new dominating set algorithm object.This is the recommended way to instantiate a new
DominatingSetAlgo
object. TheDominatingSetAlgo.Builder
might support different options to obtain different implementations.- Returns:
- a default implementation of
DominatingSetAlgo
-
newBuilder
static DominatingSetAlgo.Builder newBuilder()
Create a new dominating set algorithm builder.Use
newInstance()
for a default implementation.- Returns:
- a new builder that can build
DominatingSetAlgo
objects
-
-