- boundaryThe list of boundary IDs from the mesh where the pressure will be appliedC++ Type:std::vector<BoundaryName> Controllable:No Description:The list of boundary IDs from the mesh where the pressure will be applied 
- displacementsThe nonlinear displacement variablesC++ Type:std::vector<VariableName> Unit:(no unit assumed) Controllable:No Description:The nonlinear displacement variables 
Cavity Pressure Action
Description
The CavityPressure Action system is used to calculate the pressure from an ideal gas trapped within an internal volume.
The pressure in the cavity is computed based on the ideal gas law, (1) where is the internal pressure, is the moles of gas, is the ideal gas constant, is the temperature, and is the volume of the cavity.
The moles of gas, the temperature, and the cavity volume in Eq. (1) are free to change with time. The moles of gas at any time is the original amount of gas (computed based on original pressure, temperature, and volume) plus the amount in the cavity due to any gas injected during the simulation.
Constructed MooseObjects
The Cavity Pressure Action system consists of three separate actions, listed in the Associated Actions block below, which are all created within the same block.
Table 1: Correspondence Among Action Functionality and MooseObjects for the CavityPressure Action
| Functionality | Replaced Classes | Associated Parameters | 
|---|---|---|
| Calculation of the initial moles quantity | CavityPressureUserObject | volume: the name of the internal volume postprocessor | 
| R: the universal gas constant | ||
| temperature: the name of the average temperature postprocessor | ||
| Store the value of the initial moles | CavityPressurePostprocessor | output_initial_moles: the postprocessor name to used to report the initial moles of gas | 
| Calculation of the current internal pressure | CavityPressureUserObject | output: the name of the cavity pressure postprocessor | 
| Store the internal pressure value | CavityPressurePostprocessor | output: the name of the cavity pressure postprocessor | 
| Apply the calculated internal pressure traction | Pressure | boundary: the list of boundary IDs to which the pressure should be applied | 
| displacements: a string of the displacement variables to which the Pressure BC should be applied | 
Example Input Syntax
[BCs<<<{"href": "../index.html"}>>>]
  [CavityPressure<<<{"href": "index.html"}>>>]
    [1]
      boundary<<<{"description": "The list of boundary IDs from the mesh where the pressure will be applied"}>>> = 100
      initial_pressure<<<{"description": "The initial pressure in the cavity.  If not given, a zero initial pressure will be used."}>>> = 100
      material_input<<<{"description": "The name of the postprocessor(s) that holds the amount of material injected into the cavity."}>>> = materialInput
      R<<<{"description": "The universal gas constant for the units used."}>>> = 8.314472
      temperature<<<{"description": "The name of the average temperature postprocessor value."}>>> = aveTempInterior
      volume<<<{"description": "The name of the postprocessor(s) that holds the value of the internal volume in the cavity"}>>> = internalVolume
      startup_time<<<{"description": "The amount of time during which the pressure will ramp from zero to its true value."}>>> = 0.5
      output<<<{"description": "The name to use for the cavity pressure value"}>>> = ppress
      save_in<<<{"description": "Auxiliary variables to save the displacement residuals"}>>> = 'pressure_residual_x pressure_residual_y pressure_residual_z'
    []
  []
[]Postprocessors for both the average temperature and the internal volume are also required for the Cavity Pressure Action system. Note that the name of the postprocessors correspond to the arguments for the parameters temperature and internal_volume in the CavityPressure block.
[Postprocessors<<<{"href": "../../Postprocessors/index.html"}>>>]
  [aveTempInterior]
    type = SideAverageValue<<<{"description": "Computes the average value of a variable on a sideset. Note that this cannot be used on the centerline of an axisymmetric model.", "href": "../../../source/postprocessors/SideAverageValue.html"}>>>
    boundary<<<{"description": "The list of boundary IDs from the mesh where this object applies"}>>> = 100
    variable<<<{"description": "The name of the variable which this postprocessor integrates"}>>> = temp
    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 linear'
  []
[][Postprocessors<<<{"href": "../../Postprocessors/index.html"}>>>]
  [internalVolume]
    type = InternalVolume<<<{"description": "Computes the volume of an enclosed area by performing an integral over a user-supplied boundary.", "href": "../../../source/postprocessors/InternalVolume.html"}>>>
    boundary<<<{"description": "The list of boundary IDs from the mesh where this object applies"}>>> = 100
    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 linear'
  []
[]Input Parameters
- absolute_value_vector_tagsThe tags for the vectors this residual object should fill with the absolute value of the residual contributionC++ Type:std::vector<TagName> Controllable:No Description:The tags for the vectors this residual object should fill with the absolute value of the residual contribution 
- active__all__ If specified only the blocks named will be visited and made activeDefault:__all__ C++ Type:std::vector<std::string> Controllable:No Description:If specified only the blocks named will be visited and made active 
- extra_vector_tagsThe extra tags for the vectors this Kernel should fillC++ Type:std::vector<TagName> Controllable:No Description:The extra tags for the vectors this Kernel should fill 
- inactiveIf specified blocks matching these identifiers will be skipped.C++ Type:std::vector<std::string> Controllable:No Description:If specified blocks matching these identifiers will be skipped. 
- outputThe name to use for the cavity pressure valueC++ Type:std::string Controllable:No Description:The name to use for the cavity pressure value 
- save_inAuxiliary variables to save the displacement residualsC++ Type:std::vector<AuxVariableName> Unit:(no unit assumed) Controllable:No Description:Auxiliary variables to save the displacement residuals 
- use_automatic_differentiationFalseFlag to use automatic differentiation (AD) objects when possibleDefault:False C++ Type:bool Controllable:No Description:Flag to use automatic differentiation (AD) objects when possible 
- use_displaced_meshTrueWhether to use displaced mesh in the boundary conditionDefault:True C++ Type:bool Controllable:No Description:Whether to use displaced mesh in the boundary condition 
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. 
Advanced Parameters
Associated Actions
Available Actions
- Solid Mechanics App
- CavityPressureActionAction to setup cavity pressure boundary condition
- CavityPressurePPActionThis Action creates a CavityPressurePostprocessor.
- CavityPressureUOActionAction to add user objects for cavity pressure