- input_filesThe input file for each App. If this parameter only contains one input file it will be used for all of the Apps. When using 'positions_from_file' it is also admissable to provide one input_file per file.C++ Type:std::vector<FileName> Controllable:No Description:The input file for each App. If this parameter only contains one input file it will be used for all of the Apps. When using 'positions_from_file' it is also admissable to provide one input_file per file. 
- samplerThe Sampler object to utilize for creating MultiApps.C++ Type:SamplerName Controllable:No Description:The Sampler object to utilize for creating MultiApps. 
SamplerTransientMultiApp
The SamplerTransientMultiApp simply creates a transient-type sub application (see MultiApps) for each row of each matrix returned from the Sampler object.
This object is capable of running in batch mode by setting the 'mode' parameter. For more information refer to Stochastic Tools Batch Mode.
Defining Minimum Processors Per App
It is often useful to define the minimum processors to use when running sub-applications. Typically this is done for large models in batch mode to avoid excessive memory usage. The "min_procs_per_app" will utilize this capability, however it is required that the "min_procs_per_row" parameter in the Samplers block be set to the same value. This is to ensure that the sampler partitioning is equivalent to the multiapp partitioning. 
Example Syntax
[MultiApps<<<{"href": "../../syntax/MultiApps/index.html"}>>>]
  [runner]
    type = SamplerTransientMultiApp<<<{"description": "Creates a sub-application for each row of each Sampler matrix.", "href": "SamplerTransientMultiApp.html"}>>>
    sampler<<<{"description": "The Sampler object to utilize for creating MultiApps."}>>> = mc
    input_files<<<{"description": "The input file for each App.  If this parameter only contains one input file it will be used for all of the Apps.  When using 'positions_from_file' it is also admissable to provide one input_file per file."}>>> = 'sub.i'
  []
[]Input Parameters
- app_typeThe type of application to build (applications not registered can be loaded with dynamic libraries. Parent application type will be used if not provided.C++ Type:MooseEnum Controllable:No Description:The type of application to build (applications not registered can be loaded with dynamic libraries. Parent application type will be used if not provided. 
- bounding_box_inflation0.01Relative amount to 'inflate' the bounding box of this MultiApp.Default:0.01 C++ Type:double Unit:(no unit assumed) Controllable:No Description:Relative amount to 'inflate' the bounding box of this MultiApp. 
- bounding_box_padding0 0 0Additional padding added to the dimensions of the bounding box. The values are added to the x, y and z dimension respectively.Default:0 0 0 C++ Type:libMesh::Point Controllable:No Description:Additional padding added to the dimensions of the bounding box. The values are added to the x, y and z dimension respectively. 
- clone_parent_meshFalseTrue to clone parent app mesh and use it for this MultiApp.Default:False C++ Type:bool Controllable:No Description:True to clone parent app mesh and use it for this MultiApp. 
- execute_onTIMESTEP_BEGINThe list of flag(s) indicating when this object should be executed. For a description of each flag, see https://mooseframework.inl.gov/source/interfaces/SetupInterface.html.Default:TIMESTEP_BEGIN C++ Type:ExecFlagEnum Controllable:No Description:The list of flag(s) indicating when this object should be executed. For a description of each flag, see https://mooseframework.inl.gov/source/interfaces/SetupInterface.html. 
- global_time_offset0The time offset relative to the parent application for the purpose of starting a subapp at a different time from the parent application. The global time will be ahead by the offset specified here.Default:0 C++ Type:double Unit:(no unit assumed) Controllable:No Description:The time offset relative to the parent application for the purpose of starting a subapp at a different time from the parent application. The global time will be ahead by the offset specified here. 
- modenormalThe operation mode, 'normal' creates one sub-application for each row in the Sampler and 'batch-reset' and 'batch-restore' creates N sub-applications, where N is the minimum of 'num_rows' in the Sampler and floor(number of processes / min_procs_per_app). To run the rows in the Sampler, 'batch-reset' will destroy and re-create sub-apps as needed, whereas the 'batch-restore' will backup and restore sub-apps to the initial state prior to execution, without destruction.Default:normal C++ Type:MooseEnum Controllable:No Description:The operation mode, 'normal' creates one sub-application for each row in the Sampler and 'batch-reset' and 'batch-restore' creates N sub-applications, where N is the minimum of 'num_rows' in the Sampler and floor(number of processes / min_procs_per_app). To run the rows in the Sampler, 'batch-reset' will destroy and re-create sub-apps as needed, whereas the 'batch-restore' will backup and restore sub-apps to the initial state prior to execution, without destruction. 
Optional Parameters
- catch_upFalseIf true this will allow failed solves to attempt to 'catch up' using smaller timesteps.Default:False C++ Type:bool Controllable:No Description:If true this will allow failed solves to attempt to 'catch up' using smaller timesteps. 
- max_catch_up_steps2Maximum number of steps to allow an app to take when trying to catch back up after a failed solve.Default:2 C++ Type:double Unit:(no unit assumed) Controllable:No Description:Maximum number of steps to allow an app to take when trying to catch back up after a failed solve. 
Recovering Failed Solutions Parameters
- cli_argsAdditional command line arguments to pass to the sub apps. If one set is provided the arguments are applied to all, otherwise there must be a set for each sub app.C++ Type:std::vector<CLIArgString> Controllable:Yes Description:Additional command line arguments to pass to the sub apps. If one set is provided the arguments are applied to all, otherwise there must be a set for each sub app. 
- cli_args_filesFile names that should be looked in for additional command line arguments to pass to the sub apps. Each line of a file is set to each sub app. If only one line is provided, it will be applied to all sub apps.C++ Type:std::vector<FileName> Controllable:No Description:File names that should be looked in for additional command line arguments to pass to the sub apps. Each line of a file is set to each sub app. If only one line is provided, it will be applied to all sub apps. 
Passing Command Line Argument Parameters
- control_tagsAdds user-defined labels for accessing object parameters via control logic.C++ Type:std::vector<std::string> Controllable:No Description:Adds user-defined labels for accessing object parameters via control logic. 
- enableTrueSet the enabled status of the MooseObject.Default:True C++ Type:bool Controllable:Yes Description:Set the enabled status of the MooseObject. 
- implicitTrueDetermines whether this object is calculated using an implicit or explicit formDefault:True C++ Type:bool Controllable:No Description:Determines whether this object is calculated using an implicit or explicit form 
- max_multiapp_level10Integer set by user that will stop the simulation if the multiapp level exceeds it. Useful for preventing infinite loops with multiapp simulationsDefault:10 C++ Type:unsigned int Controllable:No Description:Integer set by user that will stop the simulation if the multiapp level exceeds it. Useful for preventing infinite loops with multiapp simulations 
- use_displaced_meshFalseWhether or not this object should use the displaced mesh for computation. Note that in the case this is true but no displacements are provided in the Mesh block the undisplaced mesh will still be used.Default:False C++ Type:bool Controllable:No Description:Whether or not this object should use the displaced mesh for computation. Note that in the case this is true but no displacements are provided in the Mesh block the undisplaced mesh will still be used. 
- wait_for_first_app_initFalseCreate the first sub-application on rank 0, then MPI_Barrier before creating the next N-1 apps (on all ranks). This is only needed if your sub-application needs to perform some setup actions in quiet, without other sub-applications working at the same time.Default:False C++ Type:bool Controllable:No Description:Create the first sub-application on rank 0, then MPI_Barrier before creating the next N-1 apps (on all ranks). This is only needed if your sub-application needs to perform some setup actions in quiet, without other sub-applications working at the same time. 
Advanced Parameters
- detect_steady_stateFalseIf true, then if/while sub-cycling ('sub_cycling = true'), a steady-state check will be performed for each child app, allowing them to skip to the end of the parent time step if steady conditions are detected.Default:False C++ Type:bool Controllable:No Description:If true, then if/while sub-cycling ('sub_cycling = true'), a steady-state check will be performed for each child app, allowing them to skip to the end of the parent time step if steady conditions are detected. 
- interpolate_transfersFalseOnly valid when sub_cycling. This allows transferred values to be interpolated over the time frame the MultiApp is executing over when sub_cyclingDefault:False C++ Type:bool Controllable:No Description:Only valid when sub_cycling. This allows transferred values to be interpolated over the time frame the MultiApp is executing over when sub_cycling 
- max_failures0Maximum number of solve failures tolerated while sub_cycling.Default:0 C++ Type:unsigned int Controllable:No Description:Maximum number of solve failures tolerated while sub_cycling. 
- output_sub_cyclesFalseIf true then every sub-cycle will be output.Default:False C++ Type:bool Controllable:No Description:If true then every sub-cycle will be output. 
- print_sub_cyclesTrueToggle the display of sub-cycles on the screen.Default:True C++ Type:bool Controllable:No Description:Toggle the display of sub-cycles on the screen. 
- sub_cyclingFalseSet to true to allow this MultiApp to take smaller timesteps than the rest of the simulation. More than one timestep will be performed for each parent application timestepDefault:False C++ Type:bool Controllable:No Description:Set to true to allow this MultiApp to take smaller timesteps than the rest of the simulation. More than one timestep will be performed for each parent application timestep 
Sub Cycling Parameters
- keep_aux_solution_during_restoreFalseThis is useful when doing MultiApp coupling iterations. It takes the final auxiliary solution from the previous coupling iterationand re-uses it as the initial guess for the next coupling iterationDefault:False C++ Type:bool Controllable:No Description:This is useful when doing MultiApp coupling iterations. It takes the final auxiliary solution from the previous coupling iterationand re-uses it as the initial guess for the next coupling iteration 
- keep_solution_during_restoreFalseThis is useful when doing MultiApp coupling iterations. It takes the final solution from the previous coupling iterationand re-uses it as the initial guess for the next coupling iterationDefault:False C++ Type:bool Controllable:No Description:This is useful when doing MultiApp coupling iterations. It takes the final solution from the previous coupling iterationand re-uses it as the initial guess for the next coupling iteration 
- no_restoreFalseTrue to turn off restore for this multiapp. This is useful when doing steady-state Picard iterations where we want to use the solution of previous Picard iteration as the initial guess of the current Picard iteration.Default:False C++ Type:bool Controllable:No Description:True to turn off restore for this multiapp. This is useful when doing steady-state Picard iterations where we want to use the solution of previous Picard iteration as the initial guess of the current Picard iteration. 
- relaxation_factor1Fraction of newly computed value to keep.Set between 0 and 2.Default:1 C++ Type:double Unit:(no unit assumed) Controllable:No Description:Fraction of newly computed value to keep.Set between 0 and 2. 
- transformed_postprocessorsList of subapp postprocessors to use coupling algorithm on during Multiapp coupling iterationsC++ Type:std::vector<PostprocessorName> Unit:(no unit assumed) Controllable:No Description:List of subapp postprocessors to use coupling algorithm on during Multiapp coupling iterations 
- transformed_variablesList of subapp variables to use coupling algorithm on during Multiapp coupling iterationsC++ Type:std::vector<std::string> Controllable:No Description:List of subapp variables to use coupling algorithm on during Multiapp coupling iterations 
Fixed Point Iteration Parameters
- library_load_dependenciesFalseTells MOOSE to manually load library dependencies. This should not be necessary and is here for debugging/troubleshooting.Default:False C++ Type:bool Controllable:No Description:Tells MOOSE to manually load library dependencies. This should not be necessary and is here for debugging/troubleshooting. 
- library_nameThe file name of the library (*.la file) that will be dynamically loaded.C++ Type:std::string Controllable:No Description:The file name of the library (*.la file) that will be dynamically loaded. 
- library_pathPath to search for dynamic libraries (please avoid committing absolute paths in addition to MOOSE_LIBRARY_PATH)C++ Type:std::string Controllable:No Description:Path to search for dynamic libraries (please avoid committing absolute paths in addition to MOOSE_LIBRARY_PATH) 
Dynamic Loading Parameters
- max_procs_per_app4294967295Maximum number of processors to give to each App in this MultiApp. Useful for restricting small solves to just a few procs so they don't get spread outDefault:4294967295 C++ Type:unsigned int Controllable:No Description:Maximum number of processors to give to each App in this MultiApp. Useful for restricting small solves to just a few procs so they don't get spread out 
- min_procs_per_app1Minimum number of processors to give to each App in this MultiApp. Useful for larger, distributed mesh solves.Default:1 C++ Type:unsigned int Controllable:No Description:Minimum number of processors to give to each App in this MultiApp. Useful for larger, distributed mesh solves. 
Parallelism Parameters
- positions_objectsThe name of a Positions object that will contain the locations of the sub-apps created. This and 'positions(_file)' cannot be both suppliedC++ Type:std::vector<PositionsName> Controllable:No Description:The name of a Positions object that will contain the locations of the sub-apps created. This and 'positions(_file)' cannot be both supplied 
- run_in_positionFalseIf true this will cause the mesh from the MultiApp to be 'moved' by its position vectorDefault:False C++ Type:bool Controllable:No Description:If true this will cause the mesh from the MultiApp to be 'moved' by its position vector 
Positions / Transformations Of The Multiapp Frame Of Reference Parameters
- reset_appsThe Apps that will be reset when 'reset_time' is hit. These are the App 'numbers' starting with 0 corresponding to the order of the App positions. Resetting an App means that it is destroyed and recreated, possibly modeling the insertion of 'new' material for that app.C++ Type:std::vector<unsigned int> Controllable:No Description:The Apps that will be reset when 'reset_time' is hit. These are the App 'numbers' starting with 0 corresponding to the order of the App positions. Resetting an App means that it is destroyed and recreated, possibly modeling the insertion of 'new' material for that app. 
- reset_timeThe time(s) at which to reset Apps given by the 'reset_apps' parameter. Resetting an App means that it is destroyed and recreated, possibly modeling the insertion of 'new' material for that app.C++ Type:std::vector<double> Unit:(no unit assumed) Controllable:No Description:The time(s) at which to reset Apps given by the 'reset_apps' parameter. Resetting an App means that it is destroyed and recreated, possibly modeling the insertion of 'new' material for that app. 
Reset Multiapp Parameters
- tolerate_failureFalseIf true this MultiApp won't participate in dt decisions and will always be fast-forwarded to the current time.Default:False C++ Type:bool Controllable:No Description:If true this MultiApp won't participate in dt decisions and will always be fast-forwarded to the current time. 
Accepting Failed Solutions Parameters
Input Files
- (modules/stochastic_tools/test/tests/transfers/sobol/sobol.i)
- (modules/stochastic_tools/test/tests/transfers/monte_carlo/monte_carlo.i)
- (modules/stochastic_tools/test/tests/vectorpostprocessors/multiple_stochastic_results/parent.i)
- (modules/stochastic_tools/test/tests/vectorpostprocessors/stochastic_results/parent.i)
- (modules/stochastic_tools/test/tests/transfers/sampler_transfer/errors/parent_missing_control.i)
- (modules/stochastic_tools/test/tests/multiapps/dynamic_sub_app_number_error_with_transient/main.i)
- (modules/stochastic_tools/test/tests/vectorpostprocessors/stochastic_results_complete_history/parent.i)
- (modules/stochastic_tools/test/tests/multiapps/user_cli_args/main_transient.i)
- (modules/stochastic_tools/test/tests/multiapps/sampler_transient_multiapp/parent_transient_cmd_control.i)
- (modules/stochastic_tools/test/tests/transfers/sampler_transfer_vector/parent.i)
- (modules/stochastic_tools/test/tests/transfers/sampler_transfer/errors/parent_num_parameters_wrong.i)
- (modules/stochastic_tools/test/tests/transfers/sampler_postprocessor/errors/require_stochastic_results.i)
- (modules/stochastic_tools/test/tests/transfers/sampler_transfer/errors/parent_transfer_wrong_sampler.i)
- (modules/stochastic_tools/test/tests/transfers/sampler_transfer/sobol.i)
- (modules/stochastic_tools/test/tests/multiapps/partitioning/main_transient.i)
- (modules/stochastic_tools/test/tests/multiapps/sampler_transient_multiapp/parent_transient.i)
- (modules/stochastic_tools/test/tests/transfers/sampler_transfer/errors/parent_not_vector.i)
- (modules/stochastic_tools/test/tests/multiapps/batch_sampler_transient_multiapp/parent_transient.i)
- (modules/stochastic_tools/examples/parameter_study/main_time.i)
- (modules/stochastic_tools/test/tests/transfers/sampler_postprocessor/parent.i)