Stochastic Tools Failure Analysis Report
Introduction
The Failure Analysis Report (FAR) for the Stochastic Tools module describes the system functional and non-functional requirements that describe the expected interactions that the software shall provide.
Dependencies
The Stochastic Tools module is developed using MOOSE and can itself be based on various MOOSE modules, as such the FAR for the Stochastic Tools module is dependent upon the following documents.
Failure Analysis Requirements
The following is a complete list for all the requirements related to failure analysis for the Stochastic Tools module.
- stochastic_tools: Actions
- 10.1.2The system shall throw an error if the following sampler parameters are missing or unused when doing a simple parameter study
- 'num_samples' parameter for Monte Carlo sampling;
- 'distributions' parameter for Monte Carlo sampling;
- 'linear_space_items' parameter with Monte Carlo sampling;
- 'num_samples' parameter for latin hypercube sampling;
- 'distributions' parameter for latin hypercube sampling;
- 'linear_space_items' parameter for cartesian product sampling;
- 'samples_file' parameter for CSV sampling;
- both 'csv_column_indices' and 'csv_column_names' parameters are specified for CSV sampling;
- 'matrix' parameter for input matrix sampling;
Specification(s): sampling_errors/monte_carlo_num_samples, sampling_errors/monte_carlo_distributions, sampling_errors/monte_carlo_unused, sampling_errors/lhs_num_samples, sampling_errors/lhs_distributions, sampling_errors/cartesian_product, sampling_errors/csv, sampling_errors/csv_both, sampling_errors/input_matrix
Design: ParameterStudy
Issue(s): #22512
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): RunException
- 10.1.4The system shall throw an error when doing a simple parameter study if distribution parameters are
- missing;
- inconsitent size;
- unused;
Specification(s): distribution_errors/missing, distribution_errors/inconsistent, distribution_errors/unused
Design: ParameterStudy
Issue(s): #22512
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): RunException
- 10.1.5The system shall be able to setup a simple parameter study with ability to
- compute statistics;
- not compute statistics;
- error if there are unused statistics parameters;
Specification(s): stats/true, stats/false, stats/unused
Design: ParameterStudy
Issue(s): #22512
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): JSONDiffRunAppRunException
- stochastic_tools: Auxkernels
- 10.2.3The system shall throw an error when evaluating a surrogate for auxiliary variable assignment if
- a parameter is undefined,
- a scalar parameter is not found, or
- a coupled array variable does not match the number of components.
Specification(s): errors/parameter_unspecified, errors/scalar_missing, errors/wrong_array_size
Design: SurrogateModelAuxKernel
Issue(s): #23018
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): RunException
Prerequisite(s): 10.2.1
- stochastic_tools: Distributions
- 10.4.3The system shall produce an error if a distribution is retrieved with the differing type than supplied.
Specification(s): normal_direct_type_error
Design: Normal
Issue(s): #12720
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): RunException
- stochastic_tools: Ics
- 10.6.2The system shall generate an error the random initial condition is used with both a distribution and min or max value defined.
Specification(s): test_err_distribution_and_min_max
Design: RandomIC
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): RunException
Prerequisite(s): 10.6.1
- stochastic_tools: Likelihoods
- 10.7.2The system shall throw an error when
- the specified lower bound is greater than the upper bound;
Specification(s): likelihoods_errors/truncatedgaussian_bounds
Design: GaussianTruncatedGaussianExtremeValue
Issue(s): #23837
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): RunException
- stochastic_tools: Multiapps
- 10.8.2The system shall report an error when the supplied sampler object operates in a mode that does not allow for command line arguments to be modified.
Specification(s): wrong_batch_mode
Design: SamplerFullSolveMultiAppMultiAppSamplerControl
Issue(s): #13320
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): RunException
Prerequisite(s): 10.8.1
- 10.8.3The system shall report an error when the supplied sampler does not use the correct execution flags.
Specification(s): wrong_execute_on
Design: SamplerFullSolveMultiAppMultiAppSamplerControl
Issue(s): #13320
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): RunException
Prerequisite(s): 10.8.1
- 10.8.4The system shall report an error when '[]' syntax is not used for all parameters.
Specification(s): vector_no_bracket
Design: SamplerFullSolveMultiAppMultiAppSamplerControl
Issue(s): #13320
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): RunException
- 10.8.5The system shall report an error when provided global column index is out of bound.
Specification(s): vector_out_of_bound
Design: SamplerFullSolveMultiAppMultiAppSamplerControl
Issue(s): #13320
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): RunException
- 10.8.10The SamplerTransientMultiApp object shall error if the 'batch-reset' mode is supplied.
Specification(s): mode_error
Design: SamplerTransientMultiApp
Issue(s): #13320
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): RunException
- 10.8.13The system shall report an error when sub-apps are constructed too early thus unable to be changed by samplers.
Specification(s): wrong_multiapp_type
Design: MultiAppSamplerControl
Issue(s): #12576
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): RunException
- 10.8.14The system shall report an error when the number of samples differs from the number of command line parameters.
Specification(s): wrong_num_params
Design: MultiAppSamplerControl
Issue(s): #12576
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): RunException
- 10.8.15The system shall be able to control whether a sub-app is run for a certain sample
- with a parsed function dependent on time and sampler values;
- error if running in normal mode.
Specification(s): conditional/function, conditional/error
Design: SamplerFullSolveMultiAppConditionalSampleReporter
Issue(s): #19350
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): JSONDiffRunException
- 10.8.17The system shall report an error when the size of a sampler is altered an sub-applications are progressing with time with the main application.
Specification(s): error
Design: Samplers SystemSamplerFullSolveMultiApp
Issue(s): #16842
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): RunException
- 10.8.21The system shall have consistent partitioning between multiapps and sampler for full solves
- with less processors than rows in normal mode;
- with more processors than rows in normal mode;
- with specified minimum processors per app in normal mode;
- with less processors than rows in batch-reset mode;
- with more processors than rows in batch-reset mode;
- with specified minimum processors per app in batch-reset mode;
- with less processors than rows in batch-restore mode;
- with more processors than rows in batch-restore mode;
- with specified minimum processors per app in batch-restore mode;
- error when partitionings do not match;
Specification(s): full_solve/normal_less_procs, full_solve/normal_more_procs, full_solve/normal_min_procs, full_solve/reset_less_procs, full_solve/reset_more_procs, full_solve/reset_min_procs, full_solve/restore_less_procs, full_solve/restore_more_procs, full_solve/restore_min_procs, full_solve/error_min_procs
Design: SamplerFullSolveMultiApp
Issue(s): #15787
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): RunExceptionCSVDiff
- 10.8.22The system shall have consistent partitioning between multiapps and sampler for transient solves
- with less processors than rows in normal mode;
- with more processors than rows in normal mode;
- with specified minimum processors per app in normal mode;
- with less processors than rows in batch-restore mode;
- with more processors than rows in batch-restore mode;
- with specified minimum processors per app in batch-restore mode;
- error when partitionings do not match;
Specification(s): transient/normal_less_procs, transient/normal_more_procs, transient/normal_min_procs, transient/restore_less_procs, transient/restore_more_procs, transient/restore_min_procs, transient/error_min_procs
Design: SamplerTransientMultiApp
Issue(s): #15787
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): RunExceptionCSVDiff
- stochastic_tools: Reporters
- 10.9.5The system shall support the calculation of statistics using
- vector of data from the reporting system; including
- confidence level intervals for statistics calculations
- and error if the supplied type is not supported.
Specification(s): reporters/statistics, reporters/ci, reporters/error
Design: StatisticsReporter
Issue(s): #16584
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): JSONDiffRunException
- 10.9.7The system shall report an error when computing confidence level intervals when
- the confidence level intervals are omitted;
- the confidence level intervals are less than or equal to zero;
- the confidence level intervals are greater than or equal to one;
- input is not provided.
Specification(s): errors/no_ci_levels, errors/ci_levels_zero, errors/ci_levels_one, errors/no_input
Design: StatisticsReporter
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): RunException
- 10.9.23The system shall throw an error when attempting to output samples from a sampler when
- inputting the wrong number of column names;
- using a different sampler than the transfer's;
Specification(s): errors/wrong_num_names, errors/wrong_sampler
Design: StochasticMatrix
Issue(s): #22827
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): RunException
- stochastic_tools: Samplers
- 10.10.2The system shall throw an error when
- the selected sampler type is not of an adaptive type when performing adaptive decision;
Specification(s): ais_errors/ais_error1
Design: Adaptive Importance Sampling (AIS)
Issue(s): #17664
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): RunException
- 10.10.4The system shall throw an error when
- the selected sampler type is not of an adaptive type.
Specification(s): pss_errors/pss_error1
Design: Parallel Subset Simulation (PSS)
Issue(s): #19398
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): RunException
- 10.10.6The system shall throw an error when performing 1D Cartesian sampling if
- the specified grid does not form a triplet,
- the number of nominal values specified does not match the number of sample columns,
- the number of grid points is not an integer, or
- the number of grid points is negative.
Specification(s): errors/no_triplet, errors/wrong_num_values, errors/non_int, errors/negative
Design: Cartesian1D
Issue(s): #24566
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): RunException
- 10.10.20The system shall throw an error when
- only the lower bounds specified;
- the specified bounds are not of the same size;
- the priors, bounds, and initial values are not of the same size;
- the proposal stds, initial values, and priors are not of the same size;
- the number of scales provided do not match the number of tunable params;
Specification(s): mcmc_sampling_errors/pmcmc_base_bounds1, mcmc_sampling_errors/pmcmc_base_bounds2, mcmc_sampling_errors/pmcmc_base_sizes, mcmc_sampling_errors/imh_std_sizes, mcmc_sampling_errors/des_scale_sizes
Design: PMCMCBase (PMCMCBase)
Issue(s): #23837
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): RunException
- 10.10.24The system shall report an error when the number of nested Monte Carlo loops does not match the number of sets of distributions.
Specification(s): error
Design: NestedMonteCarlo
Issue(s): #20130
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): RunException
- 10.10.26The system shall report an error if the SOBOL sampling method is setup with input sampling matrices
- with differing number of rows;
- with differing number of columns; and
- if the matrices are the same.
Specification(s): errors/row_mismatch, errors/col_mismatch, errors/same_matrix
Design: Sobol
Issue(s): #8065
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): RunException
- stochastic_tools: Surrogates
- 10.11.1The system shall demonstrate cross validation
- for a 1-dimensional polynomial regression surrogate with Real
- and std::vector<Real> response types.
- and throw an error if a SurrogateModel is not provided.
Specification(s): cross_validate/cv_real, cross_validate/cv_vector_real, cross_validate/surr-error
Design: Surrogates System
Issue(s): #21399
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): JSONDiffRunException
- 10.11.5The system shall throw an error when
- the batch size is greater than the training data set size for Adam optimization.
Specification(s): errors/optimization_adam_batch_size
Design: GaussianProcessTrainerGaussianProcess
Issue(s): #15482
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): RunException
- 10.11.18PODFullSolveMultiapp shall throw an error when
- the trainer object cannot be found.
- the trainer is run with more than one processors per subapp.
- the number of samples is lower than the number of processors.
Specification(s): multiapp/trainer_name, multiapp/max_procs_per_app, multiapp/more_procs_than_samples
Design: PODFullSolveMultiApp
Issue(s): #15538
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): RunException
- 10.11.19PODSamplerSolutionTransfer shall throw an error when
- the trainer object cannot be found.
Specification(s): solution_transfer/trainer_name
Design: PODSamplerSolutionTransfer
Issue(s): #15538
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): RunException
- 10.11.20PODReducedBasisTrainer shall throw an error when
- the variable names cannot be found on sub-applications,
- the number of energy limits and variable names do not match,
- the number of tag names and tag types do not match,
- the Dirichlet tag types do not exist,
- and the residual generation is called before having the basis vectors.
Specification(s): trainer/var_names, trainer/en_limits, trainer/tag_types, trainer/dir_tag_names, trainer/wrong_res_transfer
Design: PODReducedBasisTrainerPODResidualTransferPODSamplerSolutionTransfer
Issue(s): #15538
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): RunException
- 10.11.21PODReducedBasisSurrogate shall throw an error when
- the number of inputs in 'change_rank' and 'new_ranks' is not the same.
Specification(s): surrogate/var_name
Design: PODReducedBasisSurrogate
Issue(s): #15538
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): RunException
- 10.11.26The system shall throw an error when
- the number of samples does not match the number of results.
Specification(s): errors/wrong_sampler
Design: PolynomialRegressionTrainer
Issue(s): #15361
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): RunException
- stochastic_tools: Transfers
- 10.12.4The 'StochasticToolsTransfer object shall error if the 'execute_on' parameter is defined when the corresponding MultiApp object is running in batch mode.
Specification(s): StochasticToolsTransfer_execute_on_error
Design: SamplerParameterTransfer
Issue(s): #8863
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): RunException
- 10.12.5The 'StochasticToolsTransfer' object shall error if the 'execute_on' parameter does not match the corresponding MultiApp object is running in normal mode.
Specification(s): StochasticToolsTransfer_execute_on_check
Design: SamplerParameterTransfer
Issue(s): #8863
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): RunException
- 10.12.6The system shall report a reasonable error if parameters for a trasnfer between multiapps are provided to stochastics transfer, which do not support this currently
Specification(s): direction_error
Design: SamplerParameterTransfer
Issue(s): #8863
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): RunException
- 10.12.9The system shall produce an error if neither a 'SamplerTransientMultiApp' nor
SamplerFullSolveMultiApp
is provided in SamplerPostprocessorTransfer.Specification(s): wrong_multi_app
Design: StochasticResults
Issue(s): #9419
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): RunException
- 10.12.10The system shall produce an error if the 'result' object in 'SamplerPostprocessorTransfer' is not a 'StochasticResults object'.
Specification(s): require_stochastic_results
Design: StochasticResults
Issue(s): #9419
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): RunException
- 10.12.12The system shall report an error if the supplied name is invalid when attempting to transfer a single value from a sub-application.
Specification(s): invalid_sub_pp_name
Design: SamplerPostprocessorTransfer
Issue(s): #8065
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): RunException
- 10.12.13When sub-application solve does not converge, the system shall either
- abort run,
- transfer last computed postprocessor value,
- or transfer NaN.
Specification(s): solve_not_converge/abort, solve_not_converge/last_computed, solve_not_converge/nan
Design: SamplerPostprocessorTransfer
Issue(s): #8065
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): RunExceptionCheckFilesCSVDiff
- 10.12.14The system shall support the ability to transfer reporter data from each sub-application for a set of stochastic data
- in normal mode,
- in batch mode,
- with distributed output,
- with more processors than samples,
- and error if transferring unsupported type.
Specification(s): transfer/normal, transfer/batch, transfer/distributed, transfer/more_cpus, transfer/invalid_type
Design: SamplerReporterTransfer
Issue(s): #16166
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): JSONDiffRunException
- 10.12.15The system shall produce an error if neither a 'SamplerTransientMultiApp' nor
SamplerFullSolveMultiApp
is provided in SamplerParameterTransfer.Specification(s): multiapp_type
Design: SamplerParameterTransfer
Issue(s): #11363
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): RunException
- 10.12.16The system shall produce an error if the sampler sub-application does not contain a Control object with the name 'stochastic'.
Specification(s): control_missing
Design: SamplerTransientMultiApp
Issue(s): #11363
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): RunException
- 10.12.17The system shall produce an error if supplied vector of real values is not sized correctly within the SamplerParameterTransfer object.
Specification(s): num_parameters_wrong
Design: SamplerParameterTransfer
Issue(s): #11363
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): RunException
- 10.12.18The system shall produce an error if a vector of values is supplied to a scalar parameter.
Specification(s): not_vector
Design: SamplerParameterTransfer
Issue(s): #11363
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): RunException
- 10.12.19The system shall produce an error if sampling method differs between the sub-application and the associated sub-application data transfer.
Specification(s): sampler_mismatch
Design: SamplerParameterTransfer
Issue(s): #11363
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): RunException
- 10.12.22The system shall report an error if the transferred vector to a sub-application
- if the vector parameter does not exist;
- if the sub-application does not consume all of the supplied data;
Specification(s): errors/invalid_name, errors/extra_data
Design: SamplerParameterTransfer
Issue(s): #8065
Collection(s): FUNCTIONALFAILURE_ANALYSIS
Type(s): RunException