PorousFlowPointEnthalpySourceFromPostprocessor

PorousFlowPointEnthalpySourceFromPostprocessor implements a point source that adds heat energy corresponding to adding fluid at a mass flux rate (computed by a postprocessor) at a specified temperature (computed by a postprocessor).

This object should be used in conjunction with (PorousFlowPointSourceFromPostprocessor)PorousFlowPointSourceFromPostprocessor that uses the same mass_flux Postprocessor, so that the correct amount of fluid is injected into the system.

Note that the fluid property object used by this Dirac kernel should be the same one that used in the computational domain where this object is located.

Parameter "pressure" (along with "T_in") is used to calculate the injected fluid enthalpy. Most frequently, it is the PorousFlow pressure variable (the porepressure in the porous medium). This models the situation where fluid is injected at a specified rate and temperature (using this DiracKernel and a PorousFlowPointSourceFromPostprocessor) which potentially leads to changes in the porepressure. Alternately, it may be the pressure of the injected fluid, as fixed by an external agent (such as a pump) which is stored in an AuxVariable.

For instance:

[DiracKernels]
  [source]
    type = PorousFlowPointSourceFromPostprocessor
    variable = pressure
    mass_flux = mass_flux_in
    point = '0.5 0.5 0'
  []
  [source_h]
    type = PorousFlowPointEnthalpySourceFromPostprocessor
    variable = temperature
    mass_flux = mass_flux_in
    point = '0.5 0.5 0'
    T_in = T_in
    pressure = pressure
    fp = simple_fluid
  []
[]
(modules/porous_flow/test/tests/dirackernels/hfrompps.i)

Note that the execute_on parameter is set to timestep_begin so that the correct value is being used within the timestep.

[Postprocessors]
  [total_mass]
    type = PorousFlowFluidMass
    execute_on = 'initial timestep_end'
  []

  [total_heat]
    type = PorousFlowHeatEnergy
  []

  [mass_flux_in]
    type = FunctionValuePostprocessor
    function = mass_flux_in_fn
    execute_on = 'initial timestep_end'
  []

  [avg_temp]
    type = ElementAverageValue
    variable = temperature
    execute_on = 'initial timestep_end'
  []

  [T_in]
    type = FunctionValuePostprocessor
    function = T_in_fn
    execute_on = 'initial timestep_end'
  []
[]
(modules/porous_flow/test/tests/dirackernels/hfrompps.i)
[DiracKernels]
  [source]
    type = PorousFlowPointSourceFromPostprocessor
    variable = pressure
    mass_flux = mass_flux_in
    point = '0.5 0.5 0'
  []
  [source_h]
    type = PorousFlowPointEnthalpySourceFromPostprocessor
    variable = temperature
    mass_flux = mass_flux_in
    point = '0.5 0.5 0'
    T_in = T_in
    pressure = pressure
    fp = simple_fluid
  []
[]
(modules/porous_flow/test/tests/dirackernels/hfrompps.i)

Input Parameters

  • T_inThe postprocessor name holding the temperature of injected fluid (measured in K)

    C++ Type:PostprocessorName

    Controllable:No

    Description:The postprocessor name holding the temperature of injected fluid (measured in K)

  • fpThe name of the user object used to calculate the fluid properties of the injected fluid

    C++ Type:UserObjectName

    Controllable:No

    Description:The name of the user object used to calculate the fluid properties of the injected fluid

  • mass_fluxThe postprocessor name holding the mass flux of injected fluid at this point in kg/s (please ensure this is positive so that this object acts like a source)

    C++ Type:PostprocessorName

    Controllable:No

    Description:The postprocessor name holding the mass flux of injected fluid at this point in kg/s (please ensure this is positive so that this object acts like a source)

  • pointThe x,y,z coordinates of the point source

    C++ Type:libMesh::Point

    Controllable:No

    Description:The x,y,z coordinates of the point source

  • pressurePressure used to calculate the injected fluid enthalpy (measured in Pa)

    C++ Type:std::vector<VariableName>

    Controllable:No

    Description:Pressure used to calculate the injected fluid enthalpy (measured in Pa)

  • variableThe name of the variable that this residual object operates on

    C++ Type:NonlinearVariableName

    Controllable:No

    Description:The name of the variable that this residual object operates on

Required Parameters

  • blockThe list of blocks (ids or names) that this object will be applied

    C++ Type:std::vector<SubdomainName>

    Controllable:No

    Description:The list of blocks (ids or names) that this object will be applied

  • point_not_found_behaviorIGNOREBy default (IGNORE), it is ignored if an added point cannot be located in the specified subdomains. If this option is set to ERROR, this situation will result in an error. If this option is set to WARNING, then a warning will be issued.

    Default:IGNORE

    C++ Type:MooseEnum

    Options:ERROR, WARNING, IGNORE

    Controllable:No

    Description:By default (IGNORE), it is ignored if an added point cannot be located in the specified subdomains. If this option is set to ERROR, this situation will result in an error. If this option is set to WARNING, then a warning will be issued.

  • 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

    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.

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.

  • drop_duplicate_pointsTrueBy default points added to a DiracKernel are dropped if a point at the same locationhas been added before. If this option is set to false duplicate points are retainedand contribute to residual and Jacobian.

    Default:True

    C++ Type:bool

    Controllable:No

    Description:By default points added to a DiracKernel are dropped if a point at the same locationhas been added before. If this option is set to false duplicate points are retainedand contribute to residual and Jacobian.

  • 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 form

    Default:True

    C++ Type:bool

    Controllable:No

    Description:Determines whether this object is calculated using an implicit or explicit form

  • seed0The seed for the master random number generator

    Default:0

    C++ Type:unsigned int

    Controllable:No

    Description:The seed for the master random number generator

  • 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

  • extra_matrix_tagsThe extra tags for the matrices this Kernel should fill

    C++ Type:std::vector<TagName>

    Controllable:No

    Description:The extra tags for the matrices this Kernel should fill

  • extra_vector_tagsThe extra tags for the vectors this Kernel should fill

    C++ Type:std::vector<TagName>

    Controllable:No

    Description:The extra tags for the vectors this Kernel should fill

  • matrix_tagssystemThe tag for the matrices this Kernel should fill

    Default:system

    C++ Type:MultiMooseEnum

    Options:nontime, system

    Controllable:No

    Description:The tag for the matrices this Kernel should fill

  • vector_tagsnontimeThe tag for the vectors this Kernel should fill

    Default:nontime

    C++ Type:MultiMooseEnum

    Options:nontime, time

    Controllable:No

    Description:The tag for the vectors this Kernel should fill

Tagging Parameters

Input Files