Class WeightedShortestPathSelectionAlgorithm
java.lang.Object
org.graffiti.plugin.algorithm.AbstractAlgorithm
de.ipk_gatersleben.ag_nw.graffiti.plugins.algorithms.shortest_paths.WeightedShortestPathSelectionAlgorithm
- All Implemented Interfaces:
UndoableEdit
,Algorithm
public class WeightedShortestPathSelectionAlgorithm extends AbstractAlgorithm
- Author:
- klukas
-
Constructor Summary
Constructors Constructor Description WeightedShortestPathSelectionAlgorithm()
Constructs a new instance. -
Method Summary
Modifier and Type Method Description void
check()
Checks whether all preconditions of the current graph are satisfied.void
execute()
Executes the whole algorithm.KeyStroke
getAcceleratorKeyStroke()
Default: no accelerator for the menu item, created for this algorithm.String
getCategory()
Returns the category an algorithm should assigned to.String
getDescription()
The algorithm description.String
getMenuCategory()
For backwards compatibility the standard implementation will return the CategoryString
getName()
Returns the name (ID) of the algorithm.Parameter[]
getParameters()
Returns a list ofParameter
that are set for this algorithm.Set<Category>
getSetCategory()
Returns a set of categories to classify this algorithm .static Collection<GraphElement>
getShortestPathElements(Collection<GraphElement> validGraphElements, GraphElement startGraphElement, org.apache.commons.collections.set.ListOrderedSet targetGraphElements, boolean directed, boolean considerNodeWeight, boolean considerEdgeWeight, double maxDistance, AttributePathNameSearchType weightattribute, boolean putWeightOnEdges, boolean setAttribute, boolean setLabel)
boolean
mayWorkOnMultipleGraphs()
void
reset()
Resets the internal state of the algorithm.void
setParameters(Parameter[] params)
Sets the parameters for this algorithm.void
setSelection(Selection selection)
Methods inherited from class org.graffiti.plugin.algorithm.AbstractAlgorithm
addEdit, attach, canRedo, canUndo, die, doesUndo, getActionEvent, getPresentationName, getRedoPresentationName, getUndoPresentationName, isAlwaysExecutable, isLayoutAlgorithm, isSignificant, markExecutionDone, markRedoDone, markUndoDone, redo, replaceEdit, setActionEvent, showMenuIcon, undo
-
Constructor Details
-
WeightedShortestPathSelectionAlgorithm
public WeightedShortestPathSelectionAlgorithm()Constructs a new instance.
-
-
Method Details
-
check
Description copied from interface:Algorithm
Checks whether all preconditions of the current graph are satisfied.- Specified by:
check
in interfaceAlgorithm
- Overrides:
check
in classAbstractAlgorithm
- Throws:
PreconditionException
- if the preconditions of the current graph are not satisfied.
-
getParameters
Description copied from interface:Algorithm
Returns a list ofParameter
that are set for this algorithm.- Specified by:
getParameters
in interfaceAlgorithm
- Overrides:
getParameters
in classAbstractAlgorithm
- Returns:
- a collection of
Parameter
that are needed by theAlgorithm
. - See Also:
Algorithm.getParameters()
-
setParameters
Description copied from interface:Algorithm
Sets the parameters for this algorithm. Must have the same types and order as the array returned bygetParameter
.- Specified by:
setParameters
in interfaceAlgorithm
- Overrides:
setParameters
in classAbstractAlgorithm
- Parameters:
params
- Parameter array
-
execute
public void execute()Description copied from interface:Algorithm
Executes the whole algorithm.- See Also:
Algorithm.execute()
-
getShortestPathElements
public static Collection<GraphElement> getShortestPathElements(Collection<GraphElement> validGraphElements, GraphElement startGraphElement, org.apache.commons.collections.set.ListOrderedSet targetGraphElements, boolean directed, boolean considerNodeWeight, boolean considerEdgeWeight, double maxDistance, AttributePathNameSearchType weightattribute, boolean putWeightOnEdges, boolean setAttribute, boolean setLabel) -
reset
public void reset()Description copied from interface:Algorithm
Resets the internal state of the algorithm.- Specified by:
reset
in interfaceAlgorithm
- Overrides:
reset
in classAbstractAlgorithm
- See Also:
Algorithm.reset()
-
getDescription
Description copied from class:AbstractAlgorithm
The algorithm description.- Specified by:
getDescription
in interfaceAlgorithm
- Overrides:
getDescription
in classAbstractAlgorithm
- Returns:
- String, could be HTML-styled.
-
getName
Description copied from interface:Algorithm
Returns the name (ID) of the algorithm.- Returns:
- DOCUMENT ME!
- See Also:
Algorithm.getName()
-
getAcceleratorKeyStroke
Description copied from class:AbstractAlgorithm
Default: no accelerator for the menu item, created for this algorithm.- Specified by:
getAcceleratorKeyStroke
in interfaceAlgorithm
- Overrides:
getAcceleratorKeyStroke
in classAbstractAlgorithm
- Returns:
- NULL (default) if no accelerator should be assigned for this algorithm.
-
getCategory
Description copied from interface:Algorithm
Returns the category an algorithm should assigned to. Return NULL if the algorithm should be sorted directly in the plugin menu.- Specified by:
getCategory
in interfaceAlgorithm
- Overrides:
getCategory
in classAbstractAlgorithm
- Returns:
- The category an algorithm should assigned to.
-
getSetCategory
Description copied from interface:Algorithm
Returns a set of categories to classify this algorithm . e.g. return new HashSet(Arrays.asList( Category.GRAPH, Category.NODE )); is an algorithm, working on graphs and more specific on nodes - Specified by:
getSetCategory
in interfaceAlgorithm
- Overrides:
getSetCategory
in classAbstractAlgorithm
- Returns:
- Set of Category Enums that classify this algorithm.
-
getMenuCategory
Description copied from class:AbstractAlgorithm
For backwards compatibility the standard implementation will return the Category- Specified by:
getMenuCategory
in interfaceAlgorithm
- Overrides:
getMenuCategory
in classAbstractAlgorithm
- Returns:
-
setSelection
-
mayWorkOnMultipleGraphs
public boolean mayWorkOnMultipleGraphs()- Specified by:
mayWorkOnMultipleGraphs
in interfaceAlgorithm
- Overrides:
mayWorkOnMultipleGraphs
in classAbstractAlgorithm
-