- functionThe initial condition function.C++ Type:FunctionName Unit:(no unit assumed) Controllable:No Description:The initial condition function. 
- integralPostprocessor providing the integral of the function, for normalizationC++ Type:PostprocessorName Unit:(no unit assumed) Controllable:No Description:Postprocessor providing the integral of the function, for normalization 
- magnitudeDesired magnitude of the initial condition upon integrationC++ Type:double Unit:(no unit assumed) Controllable:No Description:Desired magnitude of the initial condition upon integration 
- variableThe variable this initial condition is supposed to provide values for.C++ Type:VariableName Unit:(no unit assumed) Controllable:No Description:The variable this initial condition is supposed to provide values for. 
IntegralPreservingFunctionIC
Function initial condition that preserves an integral
Description
Sets an initial condition while preserving an integral. The "function" is used to specify the overall "form" of the initial condition, such that the applied initial condition is
(1)
where is the variable, is the function, and is a scaling factor used to preserve a total "magnitude" upon volume integration:
(2)
where is the total magnitude and is the domain of integration.
Example Input Syntax
As an example, below we set a sinusoidal heat source with generic form for a total magnitude of 550 (upon volume integration). This means that the actual initial condition is , where is determined in order to satisfy the specified total volume integral.
[ICs<<<{"href": "../../syntax/ICs/index.html"}>>>]
  [power]
    type = IntegralPreservingFunctionIC<<<{"description": "Function initial condition that preserves an integral", "href": "IntegralPreservingFunctionIC.html"}>>>
    variable<<<{"description": "The variable this initial condition is supposed to provide values for."}>>> = power
    magnitude<<<{"description": "Desired magnitude of the initial condition upon integration"}>>> = 550.0
    function<<<{"description": "The initial condition function."}>>> = 'sin(pi * z / 1.9)'
    integral<<<{"description": "Postprocessor providing the integral of the function, for normalization"}>>> = vol
  []
[]
[Postprocessors<<<{"href": "../../syntax/Postprocessors/index.html"}>>>]
  [vol]
    type = FunctionElementIntegral<<<{"description": "Integrates a function over elements", "href": "../postprocessors/FunctionElementIntegral.html"}>>>
    function<<<{"description": "Name of function to integrate"}>>> = 'sin(pi * z / 1.9)'
    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."}>>> = 'initial'
  []
  [integrated_power] # should equal 550
    type = ElementIntegralVariablePostprocessor<<<{"description": "Computes a volume integral of the specified variable", "href": "../postprocessors/ElementIntegralVariablePostprocessor.html"}>>>
    variable<<<{"description": "The name of the variable that this object operates on"}>>> = power
  []
[]Input Parameters
- blockThe list of blocks (ids or names) that this object will be appliedC++ Type:std::vector<SubdomainName> Controllable:No Description:The list of blocks (ids or names) that this object will be applied 
- boundaryThe list of boundaries (ids or names) from the mesh where this object appliesC++ Type:std::vector<BoundaryName> Controllable:No Description:The list of boundaries (ids or names) from the mesh where this object applies 
- scaling_factor1Scaling factor to apply on the functionDefault:1 C++ Type:double Unit:(no unit assumed) Controllable:No Description:Scaling factor to apply on the function 
- stateCURRENTThis parameter is used to set old state solutions at the start of simulation. If specifying multiple states at the start of simulation, use one IC object for each state being specified. The states are CURRENT=0 OLD=1 OLDER=2. States older than 2 are not currently supported. When the user only specifies current state, the solution is copied to the old and older states, as expected. This functionality is mainly used for dynamic simulations with explicit time integration schemes, where old solution states are used in the velocity and acceleration approximations.Default:CURRENT C++ Type:MooseEnum Controllable:No Description:This parameter is used to set old state solutions at the start of simulation. If specifying multiple states at the start of simulation, use one IC object for each state being specified. The states are CURRENT=0 OLD=1 OLDER=2. States older than 2 are not currently supported. When the user only specifies current state, the solution is copied to the old and older states, as expected. This functionality is mainly used for dynamic simulations with explicit time integration schemes, where old solution states are used in the velocity and acceleration approximations. 
Optional 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:No Description:Set the enabled status of the MooseObject. 
- ignore_uo_dependencyFalseWhen set to true, a UserObject retrieved by this IC will not be executed before the this ICDefault:False C++ Type:bool Controllable:No Description:When set to true, a UserObject retrieved by this IC will not be executed before the this IC 
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.