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 : #pragma once 11 : 12 : #include "Kernel.h" 13 : 14 : // Forward Declarations 15 : 16 : /** 17 : * This class computes the pressure Poisson solve which is part of 18 : * the "split" scheme used for solving the incompressible Navier-Stokes 19 : * equations. 20 : */ 21 : class INSChorinPressurePoisson : public Kernel 22 : { 23 : public: 24 : static InputParameters validParams(); 25 : 26 : INSChorinPressurePoisson(const InputParameters & parameters); 27 : 28 44 : virtual ~INSChorinPressurePoisson() {} 29 : 30 : protected: 31 : virtual Real computeQpResidual(); 32 : virtual Real computeQpJacobian(); 33 : virtual Real computeQpOffDiagJacobian(unsigned jvar); 34 : 35 : // Gradients of the "star" velocity 36 : const VariableGradient & _grad_u_star; 37 : const VariableGradient & _grad_v_star; 38 : const VariableGradient & _grad_w_star; 39 : 40 : // Variable numberings 41 : unsigned _u_vel_star_var_number; 42 : unsigned _v_vel_star_var_number; 43 : unsigned _w_vel_star_var_number; 44 : 45 : // Material properties 46 : const MaterialProperty<Real> & _rho; 47 : };