- al_gpActive learning GP trainer.C++ Type:UserObjectName Controllable:No Description:Active learning GP trainer. 
- gp_evaluatorEvaluate the trained GP.C++ Type:UserObjectName Controllable:No Description:Evaluate the trained GP. 
- learning_functionThe learning function for active learning.C++ Type:MooseEnum Controllable:No Description:The learning function for active learning. 
- learning_function_thresholdThe learning function threshold.C++ Type:double Unit:(no unit assumed) Controllable:No Description:The learning function threshold. 
- n_trainNumber of training steps.C++ Type:int Controllable:No Description:Number of training steps. 
- outputs_lfValue of the LF model output from the SubApp.C++ Type:ReporterName Controllable:No Description:Value of the LF model output from the SubApp. 
- samplerThe sampler object.C++ Type:SamplerName Controllable:No Description:The sampler object. 
BiFidelityActiveLearningGPDecision
Perform active learning decision making in bi-fidelity modeling.
Description
The BiFidelityActiveLearningGPDecision class has a very similar behavior as the ActiveLearningGPDecision class. The figure below demonstrates the behavior of active learning with bi-fidelity modeling using Monte Carlo sampling with ActiveLearningMonteCarloSampler. Instead of relying on a Gaussian Process (GP) prediction by default, a low-fidelity (LF) model prediction that is cheap to evaluate is used. Then, a GP correction is added to the LF model prediction to improve its quality and also quantify the LF prediction uncertainty. The GP itself is trained on the differences between the high-fidelity (HF) and LF model predictions. If the GP-corrected LF model prediction is not acceptable based on the uncertainty information, only then, the expensive HF model is called. Otherwise, the GP-corrected LF model predictions are used in a Monte Carlo sampler. Moreover, the calls to both the LF and HF model can be parallelized with the num_batch option in ActiveLearningMonteCarloSampler. When set to 1, it represents a serial Monte Carlo sampling.

Figure 1: Schematic of the bi-fidelity active learning process in MOOSE.
Input file syntax
The input file syntax is largely similar to GP-based active learning described in ActiveLearningGPDecision. There are three fundamental differences for leveraging bi-fidelity modeling.
First, the MultiApps block needs to have two subApps, one for the LF model and one for the HF model. This is shown in the listing below.
[MultiApps<<<{"href": "../../syntax/MultiApps/index.html"}>>>]
  [sub_lf]
    type = SamplerFullSolveMultiApp<<<{"description": "Creates a full-solve type sub-application for each row of each Sampler matrix.", "href": "../multiapps/SamplerFullSolveMultiApp.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_lf.i'
  []
  [sub]
    type = SamplerFullSolveMultiApp<<<{"description": "Creates a full-solve type sub-application for each row of each Sampler matrix.", "href": "../multiapps/SamplerFullSolveMultiApp.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'
    mode<<<{"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."}>>> = batch-reset
    should_run_reporter<<<{"description": "Vector reporter value determining whether a certain multiapp should be run with this multiapp. This only works in batch-reset or batch-restore mode."}>>> = conditional/need_sample
    execute_on<<<{"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."}>>> = TIMESTEP_END
  []
[]Second, the Transfers block needs to transfer the stochastic parameters to both the LF and HF models. Also, the outputs need to be transferred back to the mainApp from both the LF and HF models. This is shown in the listing below.
[Transfers<<<{"href": "../../syntax/Transfers/index.html"}>>>]
  [sub]
    type = SamplerParameterTransfer<<<{"description": "Copies Sampler data to a SamplerReceiver object.", "href": "../transfers/SamplerParameterTransfer.html"}>>>
    to_multi_app<<<{"description": "The name of the MultiApp to transfer the data to"}>>> = sub
    sampler<<<{"description": "A the Sampler object that Transfer is associated.."}>>> = mc
    parameters<<<{"description": "A list of parameters (on the sub application) to control with the Sampler data. The order of the parameters listed here should match the order of the items in the Sampler."}>>> = 'Materials/conductivity/prop_values Kernels/source/value BCs/right/value'
    check_multiapp_execute_on<<<{"description": "When false the check between the multiapp and transfer execute on flags is not performed."}>>> = false
  []
  [sub_lf]
    type = SamplerParameterTransfer<<<{"description": "Copies Sampler data to a SamplerReceiver object.", "href": "../transfers/SamplerParameterTransfer.html"}>>>
    to_multi_app<<<{"description": "The name of the MultiApp to transfer the data to"}>>> = sub_lf
    sampler<<<{"description": "A the Sampler object that Transfer is associated.."}>>> = mc
    parameters<<<{"description": "A list of parameters (on the sub application) to control with the Sampler data. The order of the parameters listed here should match the order of the items in the Sampler."}>>> = 'Materials/conductivity/prop_values Kernels/source/value BCs/right/value'
    check_multiapp_execute_on<<<{"description": "When false the check between the multiapp and transfer execute on flags is not performed."}>>> = false
  []
  [reporter_transfer_lf]
    type = SamplerReporterTransfer<<<{"description": "Transfers data from Reporters on the sub-application to a StochasticReporter on the main application.", "href": "../transfers/SamplerReporterTransfer.html"}>>>
    from_reporter<<<{"description": "The name(s) of the Reporter(s) on the sub-app to transfer from."}>>> = 'avg/value'
    stochastic_reporter<<<{"description": "The name of the StochasticReporter object to transfer values to."}>>> = 'constant'
    from_multi_app<<<{"description": "The name of the MultiApp to receive data from"}>>> = sub_lf
    sampler<<<{"description": "A the Sampler object that Transfer is associated.."}>>> = mc
  []
  [reporter_transfer]
    type = SamplerReporterTransfer<<<{"description": "Transfers data from Reporters on the sub-application to a StochasticReporter on the main application.", "href": "../transfers/SamplerReporterTransfer.html"}>>>
    from_reporter<<<{"description": "The name(s) of the Reporter(s) on the sub-app to transfer from."}>>> = 'avg/value'
    stochastic_reporter<<<{"description": "The name of the StochasticReporter object to transfer values to."}>>> = 'conditional'
    from_multi_app<<<{"description": "The name of the MultiApp to receive data from"}>>> = sub
    sampler<<<{"description": "A the Sampler object that Transfer is associated.."}>>> = mc
  []
[]Third, instead of relying on ActiveLearningGPDecision for evaluating the quality of the GP-corrected LF model prediction, we rely on BiFidelityActiveLearningGPDecision. This takes into account the LF model predictions, as shown in the listing below.
[Reporters<<<{"href": "../../syntax/Reporters/index.html"}>>>]
  [constant]
    type = StochasticReporter<<<{"description": "Storage container for stochastic simulation results coming from Reporters.", "href": "StochasticReporter.html"}>>>
  []
  [conditional]
    type = BiFidelityActiveLearningGPDecision<<<{"description": "Perform active learning decision making in bi-fidelity modeling.", "href": "BiFidelityActiveLearningGPDecision.html"}>>>
    sampler<<<{"description": "The sampler object."}>>> = mc
    parallel_type<<<{"description": "This parameter will determine how the stochastic data is gathered. It is common for outputting purposes that this parameter be set to ROOT, otherwise, many files will be produced showing the values on each processor. However, if there are lot of samples, gathering on root may be memory restrictive."}>>> = ROOT
    execute_on<<<{"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."}>>> = 'timestep_begin'
    flag_sample<<<{"description": "Flag samples."}>>> = 'flag_sample'
    inputs<<<{"description": "The inputs."}>>> = 'inputs'
    gp_mean<<<{"description": "The GP mean prediction."}>>> = 'gp_mean'
    gp_std<<<{"description": "The GP standard deviation."}>>> = 'gp_std'
    n_train<<<{"description": "Number of training steps."}>>> = 8
    al_gp<<<{"description": "Active learning GP trainer."}>>> = GP_al_trainer
    gp_evaluator<<<{"description": "Evaluate the trained GP."}>>> = GP_eval
    learning_function<<<{"description": "The learning function for active learning."}>>> = 'Ufunction'
    learning_function_parameter<<<{"description": "The learning function parameter."}>>> = 349.345
    learning_function_threshold<<<{"description": "The learning function threshold."}>>> = 2.0
    outputs_lf<<<{"description": "Value of the LF model output from the SubApp."}>>> = constant/reporter_transfer_lf:avg:value
  []
[]Input Parameters
- flag_sampleflag_sampleFlag samples.Default:flag_sample C++ Type:ReporterValueName Controllable:No Description:Flag samples. 
- gp_meangp_meanThe GP mean prediction.Default:gp_mean C++ Type:ReporterValueName Controllable:No Description:The GP mean prediction. 
- gp_stdgp_stdThe GP standard deviation.Default:gp_std C++ Type:ReporterValueName Controllable:No Description:The GP standard deviation. 
- inputsinputsThe inputs.Default:inputs C++ Type:ReporterValueName Controllable:No Description:The inputs. 
- learning_function_parameter1.79769e+308The learning function parameter.Default:1.79769e+308 C++ Type:double Unit:(no unit assumed) Controllable:No Description:The learning function parameter. 
- lf_correctedlf_correctedGP-corrected LF prediciton.Default:lf_corrected C++ Type:ReporterValueName Controllable:No Description:GP-corrected LF prediciton. 
- parallel_typeDISTRIBUTEDThis parameter will determine how the stochastic data is gathered. It is common for outputting purposes that this parameter be set to ROOT, otherwise, many files will be produced showing the values on each processor. However, if there are lot of samples, gathering on root may be memory restrictive.Default:DISTRIBUTED C++ Type:MooseEnum Controllable:No Description:This parameter will determine how the stochastic data is gathered. It is common for outputting purposes that this parameter be set to ROOT, otherwise, many files will be produced showing the values on each processor. However, if there are lot of samples, gathering on root may be memory restrictive. 
Optional Parameters
- allow_duplicate_execution_on_initialFalseIn the case where this UserObject is depended upon by an initial condition, allow it to be executed twice during the initial setup (once before the IC and again after mesh adaptivity (if applicable).Default:False C++ Type:bool Controllable:No Description:In the case where this UserObject is depended upon by an initial condition, allow it to be executed twice during the initial setup (once before the IC and again after mesh adaptivity (if applicable). 
- execute_onTIMESTEP_ENDThe 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_END 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. 
- execution_order_group0Execution order groups are executed in increasing order (e.g., the lowest number is executed first). Note that negative group numbers may be used to execute groups before the default (0) group. Please refer to the user object documentation for ordering of user object execution within a group.Default:0 C++ Type:int Controllable:No Description:Execution order groups are executed in increasing order (e.g., the lowest number is executed first). Note that negative group numbers may be used to execute groups before the default (0) group. Please refer to the user object documentation for ordering of user object execution within a group. 
- force_postauxFalseForces the UserObject to be executed in POSTAUXDefault:False C++ Type:bool Controllable:No Description:Forces the UserObject to be executed in POSTAUX 
- force_preauxFalseForces the UserObject to be executed in PREAUXDefault:False C++ Type:bool Controllable:No Description:Forces the UserObject to be executed in PREAUX 
- force_preicFalseForces the UserObject to be executed in PREIC during initial setupDefault:False C++ Type:bool Controllable:No Description:Forces the UserObject to be executed in PREIC during initial setup 
Execution Scheduling 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. 
- outputsVector of output names where you would like to restrict the output of variables(s) associated with this objectC++ Type:std::vector<OutputName> Controllable:No Description:Vector of output names where you would like to restrict the output of variables(s) associated with this object 
- 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. 
Advanced Parameters
- prop_getter_suffixAn optional suffix parameter that can be appended to any attempt to retrieve/get material properties. The suffix will be prepended with a '_' character.C++ Type:MaterialPropertyName Unit:(no unit assumed) Controllable:No Description:An optional suffix parameter that can be appended to any attempt to retrieve/get material properties. The suffix will be prepended with a '_' character. 
- use_interpolated_stateFalseFor the old and older state use projected material properties interpolated at the quadrature points. To set up projection use the ProjectedStatefulMaterialStorageAction.Default:False C++ Type:bool Controllable:No Description:For the old and older state use projected material properties interpolated at the quadrature points. To set up projection use the ProjectedStatefulMaterialStorageAction.