Line data Source code
1 : //* This file is part of the MOOSE framework 2 : //* https://mooseframework.inl.gov 3 : //* 4 : //* All rights reserved, see COPYRIGHT for full restrictions 5 : //* https://github.com/idaholab/moose/blob/master/COPYRIGHT 6 : //* 7 : //* Licensed under LGPL 2.1, please see LICENSE for details 8 : //* https://www.gnu.org/licenses/lgpl-2.1.html 9 : 10 : #include "MomentumFluxIntegral.h" 11 : 12 : registerMooseObject("ThermalHydraulicsApp", MomentumFluxIntegral); 13 : 14 : InputParameters 15 150 : MomentumFluxIntegral::validParams() 16 : { 17 150 : InputParameters params = SideIntegralPostprocessor::validParams(); 18 150 : params.addClassDescription("Computes the integral of the momentum flux over a boundary"); 19 300 : params.addRequiredCoupledVar("arhouA", "Momentum equation variable"); 20 300 : params.addRequiredCoupledVar("vel", "Velocity"); 21 300 : params.addRequiredCoupledVar("p", "Pressure"); 22 300 : params.addRequiredCoupledVar("A", "Area"); 23 300 : params.addCoupledVar("alpha", 1.0, "Volume fraction (two-phase only)"); 24 150 : return params; 25 0 : } 26 : 27 54 : MomentumFluxIntegral::MomentumFluxIntegral(const InputParameters & parameters) 28 : : SideIntegralPostprocessor(parameters), 29 54 : _arhouA(coupledValue("arhouA")), 30 54 : _velocity(coupledValue("vel")), 31 54 : _pressure(coupledValue("p")), 32 54 : _area(coupledValue("A")), 33 108 : _alpha(coupledValue("alpha")) 34 : { 35 54 : } 36 : 37 : void 38 6 : MomentumFluxIntegral::threadJoin(const UserObject & y) 39 : { 40 : const auto & pps = static_cast<const MomentumFluxIntegral &>(y); 41 6 : _integral_value += pps._integral_value; 42 6 : } 43 : 44 : Real 45 30 : MomentumFluxIntegral::computeQpIntegral() 46 : { 47 30 : return _arhouA[_qp] * _velocity[_qp] + _alpha[_qp] * _pressure[_qp] * _area[_qp]; 48 : }