Isis 3 Programmer Reference
|
This class helps to call other Isis Applications in a Pipeline. More...
#include <Pipeline.h>
Public Member Functions | |
Pipeline (const QString &procAppName="") | |
This is the one and only Pipeline constructor. | |
~Pipeline () | |
This destroys the pipeline. | |
void | Prepare () |
This method is the core of the pipeline class. | |
void | Run () |
This method executes the pipeline. | |
void | SetInputFile (const char *inputParam) |
This method is used to set the original input file. | |
void | SetInputFile (const QString &inputParam) |
This method is used to set the original input file. | |
void | SetInputFile (const char *inputParam, const char *virtualBandsParam) |
This method is used to set the original input file. | |
void | SetInputFile (const QString &inputParam, const QString &virtualBandsParam) |
This method is used to set the original input file. | |
void | SetInputListFile (const char *inputParam) |
This method is used to set the original input files. | |
void | SetInputListFile (const QString &inputParam) |
This method is used to set the original input files. | |
void | SetInputFile (const FileName &inputFileName) |
This method is used to set the original input file. | |
void | SetInputListFile (const FileName &inputFileName) |
This method is used to set the original input files. | |
void | SetOutputFile (const char *outputParam) |
This method is used to set the final output file. | |
void | SetOutputFile (const QString &outputParam) |
This method is used to set the final output file. | |
void | SetOutputFile (const FileName &outputFile) |
This method is used to set the final output file. | |
void | SetOutputListFile (const char *outputFileNameParam) |
This method is used to set an output list file. | |
void | SetOutputListFile (const QString &outputFileNameParam) |
This method is used to set an output list file. | |
void | SetOutputListFile (const FileName &outputFileNameList) |
This method is used to set an output list file. | |
void | KeepTemporaryFiles (bool keep) |
Set whether or not to keep temporary files (files generated in the middle of the pipeline that are neither the original input nor the final output). | |
bool | KeepTemporaryFiles () |
Returns true if temporary files will not be deleted, false if they will. | |
void | AddPause () |
Add a pause to the pipeline. | |
void | AddToPipeline (const QString &appname) |
Add a new program to the pipeline. | |
void | AddToPipeline (const QString &appname, const QString &identifier) |
Add a new program to the pipeline. | |
PipelineApplication & | Application (const QString &identifier) |
This is an accessor to get a specific PipelineApplication. | |
PipelineApplication & | Application (const int &index) |
This is an accessor to get a specific PipelineApplication. | |
void | SetFirstApplication (const QString &appname) |
This method disables all applications up to this one. | |
void | SetLastApplication (const QString &appname) |
This method disables all applications after to this one. | |
QString | Name () const |
Returns the name of the pipeline. | |
int | Size () const |
Returns the number of applications in the pipeline. | |
QString | OriginalInput (unsigned int branch) |
Returns the initial input file for the pipeline. | |
int | OriginalInputSize () |
Returns the number of input files. | |
int | OriginalBranchesSize () |
Returns the total number of input branches Original branches = Number of input files * Number of branches. | |
std::vector< QString > | OriginalBranches () |
Returns the names of the original branches of the pipeline (input files * branches if any) | |
QString | FinalOutput (int branch=0, bool addModifiers=true) |
This gets the final output for the specified branch; this is necessary for the PipelineApplications to calculate the correct outputs to use. | |
QString | TemporaryFolder () |
This method returns the user's temporary folder for temporary files. | |
void | EnableAllApplications () |
This method re-enables all applications. | |
void | AddOriginalBranch (QString branch) |
Start off the branches directly from the pipeline. | |
void | SetContinue (bool pbFlag) |
Set the continue flag. | |
Private Attributes | |
int | p_pausePosition |
QString | p_procAppName |
The name of the pipeline. | |
std::vector< QString > | p_originalInput |
The original input file. | |
std::vector< QString > | p_inputBranches |
Branches for input list. | |
std::vector< QString > | p_originalBranches |
The input file(s) + original branches from pipeline. | |
std::vector< QString > | p_finalOutput |
The final output file (empty if needs calculated) | |
std::vector< QString > | p_virtualBands |
The virtual bands string. | |
bool | p_keepTemporary |
True if keeping temporary files. | |
bool | p_addedCubeatt |
True if the "cubeatt" program was added. | |
std::vector< PipelineApplication * > | p_apps |
The pipeline applications. | |
std::vector< QString > | p_appIdentifiers |
The strings to identify the pipeline applications. | |
bool | p_outputListNeedsModifiers |
bool | p_continue |
continue the execution even if exception is encountered. | |
Friends | |
std::ostream & | operator<< (std::ostream &os, Pipeline &pipeline) |
This class helps to call other Isis Applications in a Pipeline.
This object works by creating a Pipeline and setting the initial input, final output of the Pipeline which are got from the user interface. Applications are added to the Pipeline and parameters relevant to the application are set using relevant APIs'.
The Pipeline will control the flow of calls to the different applications in the Pipeline in First In First Out fashion. Also the first and last application in the Pipeline can be explicitly set. Pipeline automatically calculates the input to an application from the output of the previous application.
The Pipeline branches automatically for a list file with multiple input files or user can explicitly create branches from the Pipeline directly or from any application in the Pipeline. The branches are required when an application generates multiple outputs. Branches may be disabled / enabled and the Pipeline will figure out the input for an application whose previous app in the same branch was disabled.
Parameters for an application in a branch can be set commonly for all branches or explicitly for a branch by specifiying the branch name.
Option continue allows the pipeline to proceed with the execution inspite of any exceptions encountered while running an application in the pipeline. If continue is not enabled, then on encountering an exception the pipeline exits.
Temporary files are created and will be deleted when explicitly set by the user.
The Pipeline calls cubeatt app inherently if virtual bands are true.
It is suggested that you "cout" this object in order to debug you're usage of the class.
Refer to Applications thmproc, mocproc, hidestripe, hiproc, hinoise2 for Pipeline usage.
Here's an example usage of this class:
2008-09-25 Unknown - Added features: Application identifiers other than the application names, branched original input, branching from branches, partial branch merging (discontinuing branches*)
2008-10-28 Unknown - The input no longer has to have virtual bands if the SetInputFile(QString,QString) has an empty parameter name for the virtual bands parameter. SetInputListFile(...) method added.
2008-12-19 Unknown - List files are now fully supported, along with output list files.
2010-12-20 Sharmila Prasad - Added ability to add branches right off of the Pipeline
2010-12-21 Sharmila Prasad - Added documentation and ignore temp files from disabled branches
2011-02-09 Sharmila Prasad - Added option continue to proceed with execution even if an application in the pipeline encounters an exception.
2011-08-15 Debbie A. Cook - Added member p_pausePosition and method AddPause and modified method Run to allow the pipeline to be stopped temporarily and resumed. When AddPause is used, Run will need to be called an additional time for each AddPause included in the pipeline to resume the execution of the pipeline.
2012-11-21 Jeannie Backer - Added Progress output to indicate which application is running. Added padding to control statements. References # 795.
2016-08-28 Kelvin Rodriguez - Removed useless if statement comparing a reference variable to Null. Part of porting to OS X 10.11.
2021-17-03 Adam Paquette - Update SetInputListFile to use the FileList object rather than the TextFile object. Also updated SetInputListFile isisparameter function to chain into the SetInputListFile FileName function.
Definition at line 151 of file Pipeline.h.
Isis::Pipeline::Pipeline | ( | const QString & | procAppName = "" | ) |
This is the one and only Pipeline constructor.
This will initialize a pipeline object.
procAppName | This is an option parameter that gives the pipeline a name |
Definition at line 36 of file Pipeline.cpp.
References p_addedCubeatt, p_continue, and p_procAppName.
Isis::Pipeline::~Pipeline | ( | ) |
|
inline |
Start off the branches directly from the pipeline.
branch | - Branch name to be added |
Definition at line 252 of file Pipeline.h.
References p_inputBranches, and p_originalBranches.
void Isis::Pipeline::AddPause | ( | ) |
Add a pause to the pipeline.
Definition at line 558 of file Pipeline.cpp.
References p_appIdentifiers, and p_apps.
void Isis::Pipeline::AddToPipeline | ( | const QString & | appname | ) |
Add a new program to the pipeline.
This method must be called before calling Pipeline::Application(...) to access it. The string used to access this program will be the program's name.
appname | The name of the new application |
Definition at line 643 of file Pipeline.cpp.
References p_addedCubeatt, p_appIdentifiers, p_apps, Isis::IException::Programmer, and Isis::PipelineApplication::SetNext().
Referenced by Prepare().
void Isis::Pipeline::AddToPipeline | ( | const QString & | appname, |
const QString & | identifier ) |
Add a new program to the pipeline.
This method must be called before calling Pipeline::Application(...) to access it. The string identifier will access this program.
appname | The name of the new application |
identifier | The program's identifier for when calling Pipeline::Application |
Definition at line 581 of file Pipeline.cpp.
References p_addedCubeatt, p_appIdentifiers, p_apps, Isis::IException::Programmer, and Isis::PipelineApplication::SetNext().
PipelineApplication & Isis::Pipeline::Application | ( | const int & | index | ) |
This is an accessor to get a specific PipelineApplication.
This accessor is mainly in place for the output operator; it is not recommended.
index | The index of the pipeline application |
Definition at line 726 of file Pipeline.cpp.
References p_apps, Isis::IException::Programmer, and Size().
PipelineApplication & Isis::Pipeline::Application | ( | const QString & | identifier | ) |
This is an accessor to get a specific PipelineApplication.
This is the recommended accessor.
identifier | The identifier (usually name) of the application to access, such as "spiceinit" |
Definition at line 696 of file Pipeline.cpp.
References p_appIdentifiers, p_apps, Isis::IException::Programmer, and Size().
void Isis::Pipeline::EnableAllApplications | ( | ) |
This method re-enables all applications.
This resets the effects of PipelineApplication::Disable, SetFirstApplication and SetLastApplication.
Definition at line 896 of file Pipeline.cpp.
QString Isis::Pipeline::FinalOutput | ( | int | branch = 0, |
bool | addModifiers = true ) |
This gets the final output for the specified branch; this is necessary for the PipelineApplications to calculate the correct outputs to use.
branch | Branch index to get the final output for |
addModifiers | Whether or not to add the last name modifier |
Definition at line 805 of file Pipeline.cpp.
References Isis::FileName::baseName(), p_apps, p_finalOutput, p_originalInput, Isis::FileName::path(), Isis::PipelineApplication::Previous(), and Isis::IException::Programmer.
Referenced by Isis::PipelineApplication::CalculateOutputFile().
|
inline |
Returns true if temporary files will not be deleted, false if they will.
Definition at line 176 of file Pipeline.h.
References p_keepTemporary.
Referenced by Run().
void Isis::Pipeline::KeepTemporaryFiles | ( | bool | keep | ) |
Set whether or not to keep temporary files (files generated in the middle of the pipeline that are neither the original input nor the final output).
keep | True means don't delete, false means delete. |
Definition at line 546 of file Pipeline.cpp.
References p_keepTemporary.
|
inline |
Returns the name of the pipeline.
Definition at line 192 of file Pipeline.h.
References p_procAppName.
Referenced by Run().
|
inline |
Returns the names of the original branches of the pipeline (input files * branches if any)
Definition at line 233 of file Pipeline.h.
References p_inputBranches, and p_originalBranches.
Referenced by Isis::PipelineApplication::PipelineApplication(), and Prepare().
|
inline |
Returns the total number of input branches Original branches = Number of input files * Number of branches.
Definition at line 224 of file Pipeline.h.
References p_inputBranches, and p_originalBranches.
Referenced by Isis::PipelineApplication::CalculateInputFile().
|
inline |
Returns the initial input file for the pipeline.
branch | Branch of the original input to get the filename from |
Definition at line 207 of file Pipeline.h.
References p_originalInput.
Referenced by Isis::PipelineApplication::CalculateInputFile().
|
inline |
Returns the number of input files.
Definition at line 212 of file Pipeline.h.
References p_originalInput.
Referenced by Isis::PipelineApplication::CalculateInputFile().
void Isis::Pipeline::Prepare | ( | ) |
This method is the core of the pipeline class.
This method tells each PipelineApplication to learn about itself and calculate necessary filenames, execution calls, etc... Pipeline error checking happens in here, so if a Pipeline is invalid this method will throw the IException.
Definition at line 69 of file Pipeline.cpp.
References AddToPipeline(), Application(), OriginalBranches(), p_addedCubeatt, p_appIdentifiers, p_apps, p_virtualBands, Isis::IException::Programmer, Isis::PipelineApplication::SetInputParameter(), and Isis::PipelineApplication::SetOutputParameter().
Referenced by Run().
void Isis::Pipeline::Run | ( | ) |
This method executes the pipeline.
When you're ready to start your proc program, call this method.
Definition at line 199 of file Pipeline.cpp.
References Application(), Isis::PipelineApplication::Enabled(), KeepTemporaryFiles(), Name(), Isis::PipelineApplication::Name(), p_apps, p_continue, p_procAppName, Isis::PipelineApplication::ParamString(), Prepare(), Isis::ProgramLauncher::RunIsisProgram(), Isis::Progress::SetText(), Size(), Isis::PipelineApplication::TemporaryFiles(), and Isis::FileList::write().
|
inline |
Set the continue flag.
pbFlag | - true/false |
Definition at line 271 of file Pipeline.h.
References p_continue.
void Isis::Pipeline::SetFirstApplication | ( | const QString & | appname | ) |
This method disables all applications up to this one.
Effectively, the application specified becomes the first application. This is not a guarantee that the application specified is enabled, it only guarantees no applications before it will be run.
appname | The program to start with |
Definition at line 748 of file Pipeline.cpp.
References p_apps, and Isis::IException::Programmer.
void Isis::Pipeline::SetInputFile | ( | const char * | inputParam | ) |
This method is used to set the original input file.
This file is the first program's input, and the virtual bands will be taken directly from this parameter.
inputParam | The parameter to get from the user interface that contains the input file |
Definition at line 292 of file Pipeline.cpp.
References SetInputFile().
Referenced by SetInputFile(), and SetInputFile().
void Isis::Pipeline::SetInputFile | ( | const char * | inputParam, |
const char * | virtualBandsParam ) |
This method is used to set the original input file.
This file is the first program's input.
inputParam | The parameter to get from the user interface that contains the input file |
virtualBandsParam | The parameter to get from the user interface that contains the virtual bands list; internal default is supported. Empty string if no virtual bands parameter exists. |
Definition at line 400 of file Pipeline.cpp.
References SetInputFile().
void Isis::Pipeline::SetInputFile | ( | const FileName & | inputFile | ) |
This method is used to set the original input file.
No virtual bands will be read, and the inputFile parameter will be read as a path to a file instead of as a parameter.
inputParam | A filename object containing the location of the input file |
Definition at line 324 of file Pipeline.cpp.
References p_inputBranches, p_originalInput, and p_virtualBands.
void Isis::Pipeline::SetInputFile | ( | const QString & | inputParam | ) |
This method is used to set the original input file.
This file is the first program's input, and the virtual bands will be taken directly from this parameter.
inputParam | The parameter to get from the user interface that contains the input file |
Definition at line 307 of file Pipeline.cpp.
References Isis::Application::GetUserInterface(), p_inputBranches, p_originalInput, and p_virtualBands.
void Isis::Pipeline::SetInputFile | ( | const QString & | inputParam, |
const QString & | virtualBandsParam ) |
This method is used to set the original input file.
This file is the first program's input.
inputParam | The parameter to get from the user interface that contains the input file |
virtualBandsParam | The parameter to get from the user interface that contains the virtual bands list; internal default is supported. Empty string if no virtual bands parameter exists. |
Definition at line 418 of file Pipeline.cpp.
References Isis::Application::GetUserInterface(), p_inputBranches, p_originalInput, and p_virtualBands.
void Isis::Pipeline::SetInputListFile | ( | const char * | inputParam | ) |
This method is used to set the original input files.
These files are the first program's input, a branch will be added for every line in the file, and the virtual bands will be taken directly from this parameter.
inputParam | The parameter to get from the user interface that contains the input file |
Definition at line 339 of file Pipeline.cpp.
References SetInputListFile().
Referenced by SetInputListFile(), and SetInputListFile().
void Isis::Pipeline::SetInputListFile | ( | const FileName & | inputFileName | ) |
This method is used to set the original input files.
These files are the first program's input, a branch will be added for every line in the file.
inputParam | The filename of the list file contains the input files |
Definition at line 370 of file Pipeline.cpp.
References Isis::FileName::expanded(), Isis::FileName::name(), p_finalOutput, p_inputBranches, p_originalInput, p_virtualBands, and Isis::toString().
void Isis::Pipeline::SetInputListFile | ( | const QString & | inputParam | ) |
This method is used to set the original input files.
These files are the first program's input, a branch will be added for every line in the file, and the virtual bands will be taken directly from this parameter.
inputParam | The parameter to get from the user interface that contains the input file |
Definition at line 354 of file Pipeline.cpp.
References Isis::Application::GetUserInterface(), and SetInputListFile().
void Isis::Pipeline::SetLastApplication | ( | const QString & | appname | ) |
This method disables all applications after to this one.
Effectively, the application specified becomes the last application. This is not a guarantee that the application specified is enabled, it only guarantees no applications after it will be run.
appname | The program to end with |
Definition at line 778 of file Pipeline.cpp.
References p_apps, and Isis::IException::Programmer.
void Isis::Pipeline::SetOutputFile | ( | const char * | outputParam | ) |
This method is used to set the final output file.
If no programs generate output, the final output file will not be used. If the output file was not entered, one will be generated automatically and placed into the current working folder.
outputParam | The parameter to get from the user interface that contains the output file; internal default is supported. |
Definition at line 441 of file Pipeline.cpp.
References SetOutputFile().
Referenced by SetOutputFile().
void Isis::Pipeline::SetOutputFile | ( | const FileName & | outputFile | ) |
This method is used to set the final output file.
If no programs generate output, the final output file will not be used. If the output file was not entered, one will be generated automatically and placed into the current working folder.
outputFile | The filename of the output file; NOT the parameter name. |
Definition at line 473 of file Pipeline.cpp.
References p_finalOutput.
void Isis::Pipeline::SetOutputFile | ( | const QString & | outputParam | ) |
This method is used to set the final output file.
If no programs generate output, the final output file will not be used. If the output file was not entered, one will be generated automatically and placed into the current working folder.
outputParam | The parameter to get from the user interface that contains the output file; internal default is supported. |
Definition at line 455 of file Pipeline.cpp.
References Isis::Application::GetUserInterface(), and p_finalOutput.
void Isis::Pipeline::SetOutputListFile | ( | const char * | outputFileNameParam | ) |
This method is used to set an output list file.
Basically, this means the output filenames are specified in the list file. Internal defaults/automatic name calculations are supported.
outputFileNameList | Parameter name containing the path to the output list file |
Definition at line 487 of file Pipeline.cpp.
References SetOutputListFile().
Referenced by SetOutputListFile(), and SetOutputListFile().
void Isis::Pipeline::SetOutputListFile | ( | const FileName & | outputFileNameList | ) |
This method is used to set an output list file.
Basically, this means the output filenames are specified in the list file.
outputFileNameList | List file with output cube names |
Definition at line 525 of file Pipeline.cpp.
References p_finalOutput.
void Isis::Pipeline::SetOutputListFile | ( | const QString & | outputFileNameParam | ) |
This method is used to set an output list file.
Basically, this means the output filenames are specified in the list file. Internal defaults/automatic name calculations are supported.
outputFileNameList | Parameter name containing the path to the output list file |
Definition at line 500 of file Pipeline.cpp.
References Isis::Application::GetUserInterface(), p_finalOutput, p_originalInput, and SetOutputListFile().
|
inline |
Returns the number of applications in the pipeline.
Definition at line 196 of file Pipeline.h.
References p_apps.
Referenced by Application(), Application(), EnableAllApplications(), and Run().
QString Isis::Pipeline::TemporaryFolder | ( | ) |
This method returns the user's temporary folder for temporary files.
It's simply a conveinient accessor to the user's preferences.
Definition at line 882 of file Pipeline.cpp.
Referenced by Isis::PipelineApplication::BuildParamString(), and Isis::PipelineApplication::CalculateOutputFile().
|
private |
True if the "cubeatt" program was added.
Definition at line 284 of file Pipeline.h.
Referenced by AddToPipeline(), AddToPipeline(), Pipeline(), and Prepare().
|
private |
The strings to identify the pipeline applications.
Definition at line 286 of file Pipeline.h.
Referenced by AddPause(), AddToPipeline(), AddToPipeline(), Application(), and Prepare().
|
private |
The pipeline applications.
Definition at line 285 of file Pipeline.h.
Referenced by AddPause(), AddToPipeline(), AddToPipeline(), Application(), Application(), EnableAllApplications(), FinalOutput(), Prepare(), Run(), SetFirstApplication(), SetLastApplication(), Size(), and ~Pipeline().
|
private |
continue the execution even if exception is encountered.
Definition at line 288 of file Pipeline.h.
Referenced by Pipeline(), Run(), and SetContinue().
|
private |
The final output file (empty if needs calculated)
Definition at line 281 of file Pipeline.h.
Referenced by FinalOutput(), SetInputListFile(), SetOutputFile(), SetOutputFile(), SetOutputListFile(), and SetOutputListFile().
|
private |
Branches for input list.
Definition at line 279 of file Pipeline.h.
Referenced by AddOriginalBranch(), OriginalBranches(), OriginalBranchesSize(), SetInputFile(), SetInputFile(), SetInputFile(), and SetInputListFile().
|
private |
True if keeping temporary files.
Definition at line 283 of file Pipeline.h.
Referenced by KeepTemporaryFiles(), and KeepTemporaryFiles().
|
private |
The input file(s) + original branches from pipeline.
Definition at line 280 of file Pipeline.h.
Referenced by AddOriginalBranch(), OriginalBranches(), and OriginalBranchesSize().
|
private |
The original input file.
Definition at line 278 of file Pipeline.h.
Referenced by FinalOutput(), OriginalInput(), OriginalInputSize(), SetInputFile(), SetInputFile(), SetInputFile(), SetInputListFile(), and SetOutputListFile().
|
private |
Definition at line 287 of file Pipeline.h.
|
private |
Definition at line 276 of file Pipeline.h.
|
private |
The name of the pipeline.
Definition at line 277 of file Pipeline.h.
Referenced by Name(), Pipeline(), and Run().
|
private |
The virtual bands string.
Definition at line 282 of file Pipeline.h.
Referenced by Prepare(), SetInputFile(), SetInputFile(), SetInputFile(), and SetInputListFile().