Package adams.flow.transformer
Class AbstractProcessMOAInstanceWithModel<T>
- java.lang.Object
-
- adams.core.logging.LoggingObject
-
- adams.core.logging.CustomLoggingLevelObject
-
- adams.core.option.AbstractOptionHandler
-
- adams.flow.core.AbstractActor
-
- adams.flow.transformer.AbstractTransformer
-
- adams.flow.transformer.AbstractProcessMOAInstanceWithModel<T>
-
- Type Parameters:
T- the type of model to use
- All Implemented Interfaces:
adams.core.AdditionalInformationHandler,adams.core.CleanUpHandler,adams.core.Destroyable,adams.core.GlobalInfoSupporter,adams.core.io.ModelFileHandler,adams.core.logging.LoggingLevelHandler,adams.core.logging.LoggingSupporter,adams.core.option.OptionHandler,adams.core.QuickInfoSupporter,adams.core.ShallowCopySupporter<adams.flow.core.Actor>,adams.core.SizeOfHandler,adams.core.Stoppable,adams.core.StoppableWithFeedback,adams.core.VariablesInspectionHandler,adams.event.VariableChangeListener,adams.flow.core.Actor,adams.flow.core.DynamicInitializer,adams.flow.core.DynamicModelLoaderSupporter,adams.flow.core.ErrorHandler,adams.flow.core.InputConsumer,adams.flow.core.ModelLoaderSupporter,adams.flow.core.OptionalModelResetWithVariable,adams.flow.core.OutputProducer,Serializable,Comparable
- Direct Known Subclasses:
MOAClassifying,MOAClustering,MOARegressing
public abstract class AbstractProcessMOAInstanceWithModel<T> extends adams.flow.transformer.AbstractTransformer implements adams.flow.core.DynamicModelLoaderSupporter, adams.flow.core.OptionalModelResetWithVariableAncestor for transformers that user models for processing Instance objects, e.g., classifiers making predictions.- Author:
- fracpete (fracpete at waikato dot ac dot nz), Corey Sterling (coreytsterling at gmail dot com)
- See Also:
- Serialized Form
-
-
Field Summary
Fields Modifier and Type Field Description static StringBACKUP_MODELthe key for storing the current model in the backup.protected Tm_Modelthe model that was loaded from the model file.protected adams.flow.core.AbstractModelLoaderm_ModelLoaderthe model loader.protected adams.core.VariableNamem_ModelResetVariablethe variable to monitor for changes, triggering resets of the model.protected booleanm_OnTheFlywhether the model gets built on the fly and might not be present at the start.protected booleanm_ResetModelwhether we need to reset the model.protected booleanm_UseModelResetVariablewhether to use a variable to monitor for changes, triggering resets of the model.-
Fields inherited from class adams.flow.transformer.AbstractTransformer
BACKUP_INPUT, BACKUP_OUTPUT, m_InputToken, m_OutputToken
-
Fields inherited from class adams.flow.core.AbstractActor
m_Annotations, m_BackupState, m_DetectedObjectVariables, m_DetectedVariables, m_ErrorHandler, m_Executed, m_Executing, m_ExecutionListeningSupporter, m_FullName, m_LoggingPrefix, m_Name, m_Parent, m_ScopeHandler, m_Self, m_Silent, m_Skip, m_StopFlowOnError, m_StopMessage, m_Stopped, m_StorageHandler, m_VariablesUpdated
-
-
Constructor Summary
Constructors Constructor Description AbstractProcessMOAInstanceWithModel()
-
Method Summary
All Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description Class[]accepts()Returns the class that the consumer accepts.protected Hashtable<String,Object>backupState()Backs up the current state of the actor before update the variables.voiddefineOptions()Adds options to the internal list of options.protected StringdoExecute()Executes the flow item.abstract Class[]generates()Returns the class of objects that it generates.adams.flow.core.CallableActorReferencegetModelActor()Returns the filter source actor.adams.core.io.PlaceholderFilegetModelFile()Returns the file to load the model from.adams.flow.core.AbstractModelLoader.ModelLoadingTypegetModelLoadingType()Returns the loading type.adams.core.VariableNamegetModelResetVariable()Returns the variable to monitor for changes in order to reset the model.adams.flow.control.StorageNamegetModelStorage()Returns the filter storage item.booleangetOnTheFly()Returns whether the model file gets built on the fly and might not be present at start up time.StringgetQuickInfo()Returns a quick info about the actor, which will be displayed in the GUI.booleangetUseModelResetVariable()Returns whether to use a variable to monitor for changes in order to reset the model.protected voidinitialize()StringmodelActorTipText()Returns the tip text for this property.StringmodelFileTipText()Returns the tip text for this property.StringmodelLoadingTypeTipText()Returns the tip text for this property.StringmodelResetVariableTipText()Returns the tip text for this property.StringmodelStorageTipText()Returns the tip text for this property.protected abstract adams.flow.core.AbstractModelLoadernewModelLoader()Instantiates the model loader to use.StringonTheFlyTipText()Returns the tip text for this property.protected abstract adams.flow.core.TokenprocessInstance(com.yahoo.labs.samoa.instances.Instance inst)Processes the instance and generates the output token.protected voidpruneBackup()Removes entries from the backup.protected voidreset()Resets the scheme.protected voidrestoreState(Hashtable<String,Object> state)Restores the state of the actor before the variables got updated.voidsetLoggingLevel(adams.core.logging.LoggingLevel value)Sets the logging level.voidsetModelActor(adams.flow.core.CallableActorReference value)Sets the filter source actor.voidsetModelFile(adams.core.io.PlaceholderFile value)Sets the file to load the model from.voidsetModelLoadingType(adams.flow.core.AbstractModelLoader.ModelLoadingType value)Sets the loading type.voidsetModelResetVariable(adams.core.VariableName value)Sets the variable to monitor for changes in order to reset the model.voidsetModelStorage(adams.flow.control.StorageName value)Sets the filter storage item.voidsetOnTheFly(boolean value)Sets whether the model file gets built on the fly and might not be present at start up time.StringsetUp()Initializes the item for flow execution.protected StringsetUpModel()Loads the model from the model file.voidsetUseModelResetVariable(boolean value)Sets whether to use a variable to monitor for changes in order to reset the model.StringuseModelResetVariableTipText()Returns the tip text for this property.voidvariableChanged(adams.event.VariableChangeEvent e)Gets triggered when a variable changed (added, modified, removed).voidwrapUp()Cleans up after the execution has finished.-
Methods inherited from class adams.flow.transformer.AbstractTransformer
currentInput, execute, hasInput, hasPendingOutput, input, output, postExecute
-
Methods inherited from class adams.flow.core.AbstractActor
annotationsTipText, canInspectOptions, canPerformSetUpCheck, cleanUp, compareTo, configureLogger, destroy, equals, finalUpdateVariables, findVariables, findVariables, forceVariables, forCommandLine, forName, forName, getAdditionalInformation, getAnnotations, getDefaultName, getDetectedVariables, getErrorHandler, getFlowActors, getFlowExecutionListeningSupporter, getFullName, getName, getNextSibling, getParent, getParentComponent, getPreviousSibling, getRoot, getScopeHandler, getSilent, getSkip, getStopFlowOnError, getStopMessage, getStorageHandler, getVariables, handleError, handleException, hasErrorHandler, hasStopMessage, index, isBackedUp, isExecuted, isExecuting, isFinished, isHeadless, isStopped, nameTipText, performSetUpChecks, performVariableChecks, preExecute, pruneBackup, setAnnotations, setErrorHandler, setName, setParent, setSilent, setSkip, setStopFlowOnError, setVariables, shallowCopy, shallowCopy, silentTipText, sizeOf, skipTipText, stopExecution, stopExecution, stopFlowOnErrorTipText, updateDetectedVariables, updatePrefix, updateVariables
-
Methods inherited from class adams.core.option.AbstractOptionHandler
cleanUpOptions, finishInit, getDefaultLoggingLevel, getOptionManager, globalInfo, loggingLevelTipText, newOptionManager, toCommandLine, toString
-
Methods inherited from class adams.core.logging.LoggingObject
getLogger, getLoggingLevel, initializeLogging, isLoggingEnabled
-
Methods inherited from class java.lang.Object
clone, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface adams.flow.core.Actor
cleanUp, compareTo, destroy, equals, execute, findVariables, getAnnotations, getDefaultName, getDetectedVariables, getErrorHandler, getFlowExecutionListeningSupporter, getFullName, getName, getNextSibling, getParent, getParentComponent, getPreviousSibling, getRoot, getScopeHandler, getSilent, getSkip, getStopFlowOnError, getStopMessage, getStorageHandler, getVariables, handleError, hasErrorHandler, hasStopMessage, index, isExecuted, isFinished, isHeadless, isStopped, setAnnotations, setErrorHandler, setName, setParent, setSilent, setSkip, setStopFlowOnError, setVariables, shallowCopy, shallowCopy, sizeOf, stopExecution, stopExecution, toCommandLine
-
-
-
-
Field Detail
-
BACKUP_MODEL
public static final String BACKUP_MODEL
the key for storing the current model in the backup.- See Also:
- Constant Field Values
-
m_Model
protected T m_Model
the model that was loaded from the model file.
-
m_OnTheFly
protected boolean m_OnTheFly
whether the model gets built on the fly and might not be present at the start.
-
m_UseModelResetVariable
protected boolean m_UseModelResetVariable
whether to use a variable to monitor for changes, triggering resets of the model.
-
m_ModelResetVariable
protected adams.core.VariableName m_ModelResetVariable
the variable to monitor for changes, triggering resets of the model.
-
m_ResetModel
protected boolean m_ResetModel
whether we need to reset the model.
-
m_ModelLoader
protected adams.flow.core.AbstractModelLoader m_ModelLoader
the model loader.
-
-
Method Detail
-
defineOptions
public void defineOptions()
Adds options to the internal list of options.- Specified by:
defineOptionsin interfaceadams.core.option.OptionHandler- Overrides:
defineOptionsin classadams.flow.core.AbstractActor
-
initialize
protected void initialize()
- Overrides:
initializein classadams.flow.core.AbstractActor
-
reset
protected void reset()
Resets the scheme.- Overrides:
resetin classadams.flow.core.AbstractActor
-
setLoggingLevel
public void setLoggingLevel(adams.core.logging.LoggingLevel value)
Sets the logging level.- Specified by:
setLoggingLevelin interfaceadams.core.logging.LoggingLevelHandler- Overrides:
setLoggingLevelin classadams.core.option.AbstractOptionHandler- Parameters:
value- the level
-
newModelLoader
protected abstract adams.flow.core.AbstractModelLoader newModelLoader()
Instantiates the model loader to use.- Returns:
- the model loader to use
-
setModelLoadingType
public void setModelLoadingType(adams.flow.core.AbstractModelLoader.ModelLoadingType value)
Sets the loading type. In case ofAbstractModelLoader.ModelLoadingType.AUTO, first file, then callable actor, then storage.- Specified by:
setModelLoadingTypein interfaceadams.flow.core.ModelLoaderSupporter- Parameters:
value- the type
-
getModelLoadingType
public adams.flow.core.AbstractModelLoader.ModelLoadingType getModelLoadingType()
Returns the loading type. In case ofAbstractModelLoader.ModelLoadingType.AUTO, first file, then callable actor, then storage.- Specified by:
getModelLoadingTypein interfaceadams.flow.core.ModelLoaderSupporter- Returns:
- the type
-
modelLoadingTypeTipText
public String modelLoadingTypeTipText()
Returns the tip text for this property.- Specified by:
modelLoadingTypeTipTextin interfaceadams.flow.core.ModelLoaderSupporter- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
setModelFile
public void setModelFile(adams.core.io.PlaceholderFile value)
Sets the file to load the model from.- Specified by:
setModelFilein interfaceadams.core.io.ModelFileHandler- Specified by:
setModelFilein interfaceadams.flow.core.ModelLoaderSupporter- Parameters:
value- the model file
-
getModelFile
public adams.core.io.PlaceholderFile getModelFile()
Returns the file to load the model from.- Specified by:
getModelFilein interfaceadams.core.io.ModelFileHandler- Specified by:
getModelFilein interfaceadams.flow.core.ModelLoaderSupporter- Returns:
- the model file
-
modelFileTipText
public String modelFileTipText()
Returns the tip text for this property.- Specified by:
modelFileTipTextin interfaceadams.core.io.ModelFileHandler- Specified by:
modelFileTipTextin interfaceadams.flow.core.ModelLoaderSupporter- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
setModelActor
public void setModelActor(adams.flow.core.CallableActorReference value)
Sets the filter source actor.- Specified by:
setModelActorin interfaceadams.flow.core.ModelLoaderSupporter- Parameters:
value- the source
-
getModelActor
public adams.flow.core.CallableActorReference getModelActor()
Returns the filter source actor.- Specified by:
getModelActorin interfaceadams.flow.core.ModelLoaderSupporter- Returns:
- the source
-
modelActorTipText
public String modelActorTipText()
Returns the tip text for this property.- Specified by:
modelActorTipTextin interfaceadams.flow.core.ModelLoaderSupporter- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
setModelStorage
public void setModelStorage(adams.flow.control.StorageName value)
Sets the filter storage item.- Specified by:
setModelStoragein interfaceadams.flow.core.ModelLoaderSupporter- Parameters:
value- the storage item
-
getModelStorage
public adams.flow.control.StorageName getModelStorage()
Returns the filter storage item.- Specified by:
getModelStoragein interfaceadams.flow.core.ModelLoaderSupporter- Returns:
- the storage item
-
modelStorageTipText
public String modelStorageTipText()
Returns the tip text for this property.- Specified by:
modelStorageTipTextin interfaceadams.flow.core.ModelLoaderSupporter- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
setOnTheFly
public void setOnTheFly(boolean value)
Sets whether the model file gets built on the fly and might not be present at start up time.- Specified by:
setOnTheFlyin interfaceadams.flow.core.DynamicInitializer- Parameters:
value- if true then the model does not have to be present at start up time
-
getOnTheFly
public boolean getOnTheFly()
Returns whether the model file gets built on the fly and might not be present at start up time.- Specified by:
getOnTheFlyin interfaceadams.flow.core.DynamicInitializer- Returns:
- true if the model is not necessarily present at start up time
-
onTheFlyTipText
public String onTheFlyTipText()
Returns the tip text for this property.- Specified by:
onTheFlyTipTextin interfaceadams.flow.core.DynamicInitializer- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
setUseModelResetVariable
public void setUseModelResetVariable(boolean value)
Sets whether to use a variable to monitor for changes in order to reset the model.- Specified by:
setUseModelResetVariablein interfaceadams.flow.core.OptionalModelResetWithVariable- Parameters:
value- true if to use monitor variable
-
getUseModelResetVariable
public boolean getUseModelResetVariable()
Returns whether to use a variable to monitor for changes in order to reset the model.- Specified by:
getUseModelResetVariablein interfaceadams.flow.core.OptionalModelResetWithVariable- Returns:
- true if to use monitor variable
-
useModelResetVariableTipText
public String useModelResetVariableTipText()
Returns the tip text for this property.- Specified by:
useModelResetVariableTipTextin interfaceadams.flow.core.OptionalModelResetWithVariable- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
setModelResetVariable
public void setModelResetVariable(adams.core.VariableName value)
Sets the variable to monitor for changes in order to reset the model.- Specified by:
setModelResetVariablein interfaceadams.flow.core.OptionalModelResetWithVariable- Parameters:
value- the variable
-
getModelResetVariable
public adams.core.VariableName getModelResetVariable()
Returns the variable to monitor for changes in order to reset the model.- Specified by:
getModelResetVariablein interfaceadams.flow.core.OptionalModelResetWithVariable- Returns:
- the variable
-
modelResetVariableTipText
public String modelResetVariableTipText()
Returns the tip text for this property.- Specified by:
modelResetVariableTipTextin interfaceadams.flow.core.OptionalModelResetWithVariable- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
getQuickInfo
public String getQuickInfo()
Returns a quick info about the actor, which will be displayed in the GUI.- Specified by:
getQuickInfoin interfaceadams.flow.core.Actor- Specified by:
getQuickInfoin interfaceadams.core.QuickInfoSupporter- Overrides:
getQuickInfoin classadams.flow.core.AbstractActor- Returns:
- null if no info available, otherwise short string
-
accepts
public Class[] accepts()
Returns the class that the consumer accepts.- Specified by:
acceptsin interfaceadams.flow.core.InputConsumer- Returns:
- the accepted classes
-
generates
public abstract Class[] generates()
Returns the class of objects that it generates.- Specified by:
generatesin interfaceadams.flow.core.OutputProducer- Returns:
- the classes
-
pruneBackup
protected void pruneBackup()
Removes entries from the backup.- Overrides:
pruneBackupin classadams.flow.core.AbstractActor
-
backupState
protected Hashtable<String,Object> backupState()
Backs up the current state of the actor before update the variables.- Overrides:
backupStatein classadams.flow.transformer.AbstractTransformer- Returns:
- the backup
-
restoreState
protected void restoreState(Hashtable<String,Object> state)
Restores the state of the actor before the variables got updated.- Overrides:
restoreStatein classadams.flow.transformer.AbstractTransformer- Parameters:
state- the backup of the state to restore from
-
variableChanged
public void variableChanged(adams.event.VariableChangeEvent e)
Gets triggered when a variable changed (added, modified, removed).- Specified by:
variableChangedin interfaceadams.flow.core.Actor- Specified by:
variableChangedin interfaceadams.event.VariableChangeListener- Overrides:
variableChangedin classadams.flow.core.AbstractActor- Parameters:
e- the event
-
setUpModel
protected String setUpModel()
Loads the model from the model file.- Returns:
- null if everything worked, otherwise an error message
-
setUp
public String setUp()
Initializes the item for flow execution.- Specified by:
setUpin interfaceadams.flow.core.Actor- Overrides:
setUpin classadams.flow.core.AbstractActor- Returns:
- null if everything is fine, otherwise error message
-
processInstance
protected abstract adams.flow.core.Token processInstance(com.yahoo.labs.samoa.instances.Instance inst) throws ExceptionProcesses the instance and generates the output token.- Parameters:
inst- the instance to process- Returns:
- the generated output token (e.g., container)
- Throws:
Exception- if processing fails
-
doExecute
protected String doExecute()
Executes the flow item.- Specified by:
doExecutein classadams.flow.core.AbstractActor- Returns:
- null if everything is fine, otherwise error message
-
wrapUp
public void wrapUp()
Cleans up after the execution has finished.- Specified by:
wrapUpin interfaceadams.flow.core.Actor- Overrides:
wrapUpin classadams.flow.transformer.AbstractTransformer
-
-