Class TaskManager
- java.lang.Object
-
- pulse.util.UpwardsNavigable
-
- pulse.tasks.TaskManager
-
- All Implemented Interfaces:
Serializable
,Descriptive
public final class TaskManager extends UpwardsNavigable
The
TaskManager
is a high-level class for dealing with operations of creation, removal, storage, and execution ofSearchTask
s, as well as with the associatedResult
s andInterpolationDataset
s. Note thatTaskManager
adopts aPathSolver
.- See Also:
- Serialized Form
-
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description void
addExternalDatasetListener(ExternalDatasetListener edl)
void
addSelectionListener(TaskSelectionListener listener)
static void
addSessionListener(SessionListener sl)
SearchTask
addTask(SearchTask t)
If a taskequal
tot
has already been previously loaded, does nothing.void
addTaskRepositoryListener(TaskRepositoryListener listener)
Set<Group>
allGrouppedContents()
static void
assumeNewState(TaskManager loaded)
void
cancelAllTasks()
This will terminate all tasks in thisTaskManager
and trigger aSHUTDOWN
TaskRepositoryEvent
.void
clear()
Purges all tasks from thisTaskManager
.List<NumericPropertyKeyword>
derivableProperties()
Creates a list of property keywords that can be derived with help of the loaded data.String
describe()
ThisTaskManager
will be described by the sample name for the experiment.void
evaluate()
void
execute(SearchTask t)
Executes t
asynchronously using aCompletableFuture
.void
executeAll()
Creates a queue ofSearchTask
s based on their readiness and feeds that queue to aForkJoinPool
using a parallel stream.void
fireTaskSelected(Object source)
void
generateTask(File file)
Generates aSearchTask
assuming that theExperimentalData
is stored in thefile
.void
generateTasks(List<File> files)
Generates multiple tasks from multiplefiles
.InterpolationDataset
getDensityDataset()
static TaskManager
getManagerInstance()
This class uses a singleton pattern, meaning there is only instance of this class.SampleName
getSampleName()
Uses the first non-null
SearchTask
to retrieve the sample name from theMetadata
associated with itsExperimentalData
.SearchTask
getSelectedTask()
List<TaskSelectionListener>
getSelectionListeners()
InterpolationDataset
getSpecificHeatDataset()
SearchTask
getTask(int externalId)
Finds aSearchTask
using the external identifier specified in its metadata.SearchTask
getTask(Identifier id)
Finds aSearchTask
whoseIdentifier
matchesid
.List<SearchTask>
getTaskList()
List<TaskRepositoryListener>
getTaskRepositoryListeners()
int
indexOfTask(SearchTask t)
void
initListeners()
boolean
isSingleStatement()
Checks whether changes in thisPropertyHolder
should automatically be accounted for by other instances of this class.boolean
isTaskQueueEmpty()
Checks if any of the tasks that thisTaskManager
manages is eitherQUEUED
orIN_PROGRESS
.void
notifyListeners(TaskRepositoryEvent e)
Notifies theTaskRepositoryListener
s of thee
int
numberOfTasks()
Gets the current number of tasks in the repository.void
removeSelectionListeners()
static void
removeSessionListeners()
boolean
removeTask(SearchTask t)
Ift
is found in the local repository, removes it and triggers aTASK_REMOVED
event.void
removeTaskRepositoryListener(TaskRepositoryListener trl)
void
reset()
Clears any progress for all the tasks and resets everything.void
selectFirstTask()
void
selectTask(Identifier id, Object src)
Selects aSearchTask
within this repository with the specifiedid
(if present).void
setDensityDataset(InterpolationDataset dataset)
void
setSingleStatement(boolean singleStatement)
Sets the flag to isolate or inter-connects changes in all instances ofPropertyHolder
void
setSpecificHeatDataset(InterpolationDataset dataset)
-
Methods inherited from class pulse.util.UpwardsNavigable
addHierarchyListener, getHierarchyListeners, getParent, identify, removeHierarchyListener, removeHierarchyListeners, setParent, specificAncestor, tellParent
-
-
-
-
Method Detail
-
derivableProperties
public List<NumericPropertyKeyword> derivableProperties()
Creates a list of property keywords that can be derived with help of the loaded data. For example, if heat capacity and density data is available, the returned list will containCONDUCTIVITY
.- Returns:
-
initListeners
public void initListeners()
- Overrides:
initListeners
in classUpwardsNavigable
-
getManagerInstance
public static TaskManager getManagerInstance()
This class uses a singleton pattern, meaning there is only instance of this class.- Returns:
- the single (static) instance of this class
-
execute
public void execute(SearchTask t)
Executes t
asynchronously using aCompletableFuture
. When done, creates aResult
and puts it into theMap(SearchTask,Result)
in thisTaskManager
.- Parameters:
t
- aSearchTask
that will be executed
-
notifyListeners
public void notifyListeners(TaskRepositoryEvent e)
Notifies theTaskRepositoryListener
s of thee
- Parameters:
e
- an event
-
executeAll
public void executeAll()
Creates a queue of
SearchTask
s based on their readiness and feeds that queue to aForkJoinPool
using a parallel stream. The size of the pool is usually limited by hardware, e.g. for a 4 core system with 2 independent threads on each core, the limitation will be , etc.
-
isTaskQueueEmpty
public boolean isTaskQueueEmpty()
Checks if any of the tasks that thisTaskManager
manages is eitherQUEUED
orIN_PROGRESS
.- Returns:
false
if the status of theSearchTask
is any of the above;false
otherwise.
-
cancelAllTasks
public void cancelAllTasks()
This will terminate all tasks in thisTaskManager
and trigger aSHUTDOWN
TaskRepositoryEvent
.
-
fireTaskSelected
public void fireTaskSelected(Object source)
-
clear
public void clear()
Purges all tasks from this
TaskManager
. Generates aTASK_REMOVED
TaskRepositoryEvent
for each of the removed tasks. Clears task selection.
-
getSampleName
public SampleName getSampleName()
Uses the first non-null
SearchTask
to retrieve the sample name from theMetadata
associated with itsExperimentalData
.- Returns:
- a
String
with the sample name, ornull
if no suitable task can be found.
-
reset
public void reset()
Clears any progress for all the tasks and resets everything. Triggers a
TASK_RESET
event.
-
getTask
public SearchTask getTask(Identifier id)
Finds aSearchTask
whoseIdentifier
matchesid
.- Parameters:
id
- theIdentifier
of the task.- Returns:
- the
SearchTask
associated with thisIdentifier
.
-
getTask
public SearchTask getTask(int externalId)
Finds aSearchTask
using the external identifier specified in its metadata.- Parameters:
externalId
- the external ID of the data.- Returns:
- the
SearchTask
associated with thisIdentifier
.
-
generateTask
public void generateTask(File file)
Generates a
SearchTask
assuming that theExperimentalData
is stored in thefile
. This will make theReaderManager
attempt to read thatfile
. If successful, invokesaddTask(...)
on the createdSearchTask
. After the task is generated, checks whether the acquisition time recorded by the experimental setup has been chosen appropriately.- Parameters:
file
- the file to load the experimental data from- See Also:
addTask(pulse.tasks.SearchTask)
-
generateTasks
public void generateTasks(List<File> files)
Generates multiple tasks from multiplefiles
.- Parameters:
files
- a list ofFile
s that can be parsed down toExperimentalData
.
-
addTask
public SearchTask addTask(SearchTask t)
If a task
equal
tot
has already been previously loaded, does nothing. Otherwise, adds thist
to the task repository and triggers aTASK_ADDED
event.- Parameters:
t
- theSearchTask
that needs to be added to the internal repository- Returns:
null
if a task liket
has already been added previously,t
otherwise.
-
removeTask
public boolean removeTask(SearchTask t)
Ift
is found in the local repository, removes it and triggers aTASK_REMOVED
event.- Parameters:
t
- aSearchTask
that has been previously loaded to this repository.- Returns:
true
if the operation is successful,false
otherwise.
-
numberOfTasks
public int numberOfTasks()
Gets the current number of tasks in the repository.- Returns:
- the number of available tasks.
-
selectTask
public void selectTask(Identifier id, Object src)
Selects a
SearchTask
within this repository with the specifiedid
(if present). Informs the listeners this selection has been triggered bysrc
.- Parameters:
id
- theIdentifier
of a task within this repository.src
- the source of the selection.
-
selectFirstTask
public void selectFirstTask()
-
addSelectionListener
public final void addSelectionListener(TaskSelectionListener listener)
-
addTaskRepositoryListener
public final void addTaskRepositoryListener(TaskRepositoryListener listener)
-
getSelectionListeners
public List<TaskSelectionListener> getSelectionListeners()
-
removeSelectionListeners
public void removeSelectionListeners()
-
removeTaskRepositoryListener
public void removeTaskRepositoryListener(TaskRepositoryListener trl)
-
indexOfTask
public int indexOfTask(SearchTask t)
-
getTaskList
public List<SearchTask> getTaskList()
-
getSelectedTask
public SearchTask getSelectedTask()
-
getTaskRepositoryListeners
public List<TaskRepositoryListener> getTaskRepositoryListeners()
-
describe
public String describe()
ThisTaskManager
will be described by the sample name for the experiment.- Specified by:
describe
in interfaceDescriptive
- Overrides:
describe
in classUpwardsNavigable
- Returns:
- the string descriptor
-
evaluate
public void evaluate()
-
isSingleStatement
public boolean isSingleStatement()
Checks whether changes in thisPropertyHolder
should automatically be accounted for by other instances of this class.- Returns:
true
if the user has specified so (set by default),false
otherwise
-
assumeNewState
public static void assumeNewState(TaskManager loaded)
-
addExternalDatasetListener
public void addExternalDatasetListener(ExternalDatasetListener edl)
-
addSessionListener
public static void addSessionListener(SessionListener sl)
-
removeSessionListeners
public static void removeSessionListeners()
-
setSingleStatement
public void setSingleStatement(boolean singleStatement)
Sets the flag to isolate or inter-connects changes in all instances ofPropertyHolder
- Parameters:
singleStatement
-false
if otherPropertyHoder
s should disregard changes, which happened to this instances.true
otherwise.
-
getDensityDataset
public InterpolationDataset getDensityDataset()
-
getSpecificHeatDataset
public InterpolationDataset getSpecificHeatDataset()
-
setDensityDataset
public void setDensityDataset(InterpolationDataset dataset)
-
setSpecificHeatDataset
public void setSpecificHeatDataset(InterpolationDataset dataset)
-
-