All Downloads are FREE. Search and download functionalities are using the official Maven repository.

nl.uu.cs.ape.solver.solutionStructure.ModuleNode Maven / Gradle / Ivy

Go to download

APE is a command line tool and an API for the automated exploration of possible computational pipelines (workflows) from large collections of computational tools.

There is a newer version: 2.3.0
Show newest version
package nl.uu.cs.ape.solver.solutionStructure;

import guru.nidi.graphviz.attribute.Color;
import guru.nidi.graphviz.attribute.Label;
import guru.nidi.graphviz.attribute.Shape;
import guru.nidi.graphviz.attribute.Style;
import guru.nidi.graphviz.model.Graph;
import lombok.extern.slf4j.Slf4j;
import nl.uu.cs.ape.automaton.ModuleAutomaton;
import nl.uu.cs.ape.automaton.State;
import nl.uu.cs.ape.utils.APEUtils;
import nl.uu.cs.ape.models.AbstractModule;
import nl.uu.cs.ape.models.Module;
import nl.uu.cs.ape.models.enums.AtomType;

import java.util.ArrayList;
import java.util.HashSet;
import java.util.List;
import java.util.Set;
import java.util.stream.Collectors;

import static guru.nidi.graphviz.model.Factory.node;

/**
 * The {@code ModuleNode} class is used to represent module step in the actual
 * solution workflow.
 * Each {@code ModuleNode} represents an action/tool in the solution workflow.
 * 

* When compared to the {@link ModuleAutomaton} representation of the problem, a * Workflow {@code TypeNode} * correspond to a {@link State} of a {@link AtomType#MODULE} element. * * @author Vedran Kasalica */ @Slf4j public class ModuleNode extends SolutionWorkflowNode { /** * Tool that is used in the workflow step. */ private Module usedModule; /** * Abstract Modules that describe the workflow step. */ private Set abstractModules; /** * Next module step in the workflow. */ private ModuleNode nextModuleNode; /** * Previous module step in the workflow. */ private ModuleNode prevModuleNode; /** * List of the data instances that are used as input for the tool. */ private List inputTypes; /** * List of the data instances that are generated as output of the tool. */ private List outputTypes; /** * Creating Workflow Node that corresponds to a tool usage. * * @param automatonState state in the {@link ModuleAutomaton} that corresponds * to the workflow node. * @throws ExceptionInInitializerError Exception when the Tool Workflow Node is * instantiated using * a State in ModuleAutomaton that does not * correspond to a {@code AtomType#MODULE}.. */ public ModuleNode(State automatonState) throws ExceptionInInitializerError { super(automatonState); this.usedModule = null; this.abstractModules = new HashSet(); this.prevModuleNode = null; this.nextModuleNode = null; if (automatonState.getWorkflowStateType() != AtomType.MODULE) { throw new ExceptionInInitializerError( "Class ModuleNode can only be instantiated using State that is of type AtomType. MODULE, as a parameter."); } inputTypes = new ArrayList(); outputTypes = new ArrayList(); } /** * Set module/tool that defines this step in the workflow. * * @param module - tool provided by the tool/module annotations. */ public void setUsedModule(Module module) { this.usedModule = module; } /** * Add the abstract module to the list of modules that describes the tool * instance. * * @param abstractModule - abstract type that describes the instance. */ public void addAbstractDescriptionOfUsedType(AbstractModule abstractModule) { if (!abstractModule.isSimplePredicate()) { this.abstractModules.add(abstractModule); } else { log.warn("A concrete tool cannot be used to describe an abstract module."); } } /** * Add input type. * * @param inputTypeNode the input type node */ public void addInputType(TypeNode inputTypeNode) { inputTypes.add(inputTypeNode); } /** * Sets input type. * * @param inputIndex A specific input slot. * @param memoryTypeNode Input type to be set. */ public void setInputType(int inputIndex, TypeNode memoryTypeNode) { APEUtils.safeSet(this.inputTypes, inputIndex, memoryTypeNode); } /** * Add output type. * * @param outputTypeNode the output type node */ public void addOutputType(TypeNode outputTypeNode) { outputTypes.add(outputTypeNode); } /** * Sets next module node. * * @param nextModuleNode the next module node */ public void setNextModuleNode(ModuleNode nextModuleNode) { this.nextModuleNode = nextModuleNode; } /** * Sets prev module node. * * @param prevModuleNode the prev module node */ public void setPrevModuleNode(ModuleNode prevModuleNode) { this.prevModuleNode = prevModuleNode; } /** * Gets used module. * * @return the used module */ public Module getUsedModule() { return usedModule; } /** * Gets abstract modules. * * @return the abstract modules */ public Set getAbstractModules() { return abstractModules; } /** * Gets next module node. * * @return The next operation that should be per in the workflow structure. */ public ModuleNode getNextModuleNode() { return nextModuleNode; } /** * Has next module boolean. * * @return True if the current operation is not the last one in the workflow, * false otherwise. */ public boolean hasNextModule() { return nextModuleNode != null; } /** * Has prev module boolean. * * @return True if the current operation is not the first one in the workflow, * false otherwise. */ public boolean hasPrevModule() { return prevModuleNode != null; } /** * Gets prev module node. * * @return the prev module node */ public ModuleNode getPrevModuleNode() { return prevModuleNode; } /** * Gets input types. * * @return the input types */ public List getInputTypes() { return inputTypes; } /** * Check if the module has any non empty input types. * * @return {@code true} is the module has input types, {@code false} otherwise. */ public boolean hasInputTypes() { return !inputTypes.stream().filter(typeNode -> !typeNode.isEmpty()).collect(Collectors.toList()).isEmpty(); } /** * Gets output types. * * @return the output types */ public List getOutputTypes() { return outputTypes; } /** * Check if the module has any non empty output types. * * @return {@code true} is the module has output types, {@code false} otherwise. */ public boolean hasOutputTypes() { return !outputTypes.stream().filter(typeNode -> !typeNode.isEmpty()).collect(Collectors.toList()).isEmpty(); } /** * Is empty boolean. * * @return the boolean */ public boolean isEmpty() { return usedModule == null; } /** * Get string representation of the ModuleNode. * * @return Printable string that can be used for the presentation of this * workflow node. */ public String toString() { if (usedModule == null) { return "[]"; } StringBuilder printString = new StringBuilder(); printString.append("[").append(this.usedModule.getPredicateID()).append("]"); return printString.toString(); } /** * Gets dot definition. * * @return the dot definition */ public String getDotDefinition() { return getNodeID() + " [label=\"" + getNodeLabel() + "\", shape=box];\n"; } /** * Add the current tool node to the workflow graph, and return the graph. * * @param workflowGraph Graph that is to be extended. * @return The {@link Graph} extended with the current {@link ModuleNode}. */ public Graph addModuleToGraph(Graph workflowGraph) { return workflowGraph .with(node(getNodeID()).with(Label.of(getNodeLabel() + " "), Shape.RECTANGLE, Color.BLUE, Style.BOLD)); } public Graph addTavernaStyleModuleToGraph(Graph workflowGraph) { return workflowGraph .with(node(getNodeID()).with(Style.FILLED, Color.rgb("F8FFB0").fill(), Label.html(getNodeGraphLabel()), Shape.RECTANGLE)); } /** * Get id of the current workflow node. */ public String getNodeID() { StringBuilder printString = new StringBuilder(); printString.append("\"").append(this.usedModule.getPredicateID()); printString.append("_").append(super.getAutomatonState().getPredicateID()).append("\""); return printString.toString(); } /** * Get label of the current workflow node. */ public String getNodeLabel() { return this.usedModule.getPredicateLabel(); } /** * Get label of the current workflow node as an HTML element. */ public String getNodeGraphLabel() { return "" + this.usedModule.getPredicateLabel() + ""; } /** * Gets node descriptive label, containing module IDs. */ public String getNodeLongLabel() { return this.usedModule.getPredicateLongLabel(); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy