4 #include <deal.II/base/conditional_ostream.h> 5 #include <deal.II/base/types.h> 6 #include <deal.II/base/tensor.h> 7 #include <deal.II/lac/la_parallel_vector.templates.h> 8 #include <deal.II/numerics/data_component_interpretation.h> 10 #include "parameters/parameters_manufactured_solution.h" 11 #include "physics/manufactured_solution.h" 17 template <
int dim,
int nstate,
typename real>
33 dealii::ConditionalOStream
pcout;
37 virtual std::array<dealii::Tensor<1,dim,real>,nstate>
39 const std::array<real,nstate> &conservative_soln)
const = 0;
42 virtual std::array<dealii::Tensor<1,dim,real>,nstate>
44 const std::array<real,nstate> &conservative_soln,
45 const std::array<dealii::Tensor<1,dim,real>,nstate> &solution_gradient,
46 const dealii::types::global_dof_index cell_index)
const = 0;
52 const std::array<real,nstate> &,
53 const dealii::Tensor<1,dim,real> &)
const = 0;
62 const std::array<real,nstate> &soln,
63 const dealii::Tensor<1,dim,real> &normal)
const = 0;
67 const dealii::Point<dim,real> &pos,
68 const std::array<real,nstate> &solution,
69 const std::array<dealii::Tensor<1,dim,real>,nstate> &solution_gradient,
70 const dealii::types::global_dof_index cell_index)
const;
74 const dealii::Point<dim,real> &pos,
75 const std::array<real,nstate> &solution,
76 const real current_time,
77 const dealii::types::global_dof_index cell_index)
const = 0;
81 const int boundary_type,
82 const dealii::Point<dim, real> &pos,
83 const dealii::Tensor<1,dim,real> &normal,
84 const std::array<real,nstate> &soln_int,
85 const std::array<dealii::Tensor<1,dim,real>,nstate> &soln_grad_int,
86 std::array<real,nstate> &soln_bc,
87 std::array<dealii::Tensor<1,dim,real>,nstate> &soln_grad_bc)
const;
92 const dealii::Vector<double> &uh,
93 const std::vector<dealii::Tensor<1,dim> > &,
94 const std::vector<dealii::Tensor<2,dim> > &,
95 const dealii::Tensor<1,dim> &,
96 const dealii::Point<dim> &)
const;
108 dealii::LinearAlgebra::distributed::Vector<double> cellwise_volume;
113 const dealii::Point<dim, real> &pos,
114 const dealii::Tensor<1,dim,real> &normal_int,
115 const std::array<real,nstate> &soln_int,
116 const std::array<dealii::Tensor<1,dim,real>,nstate> &soln_grad_int,
117 std::array<real,nstate> &soln_bc,
118 std::array<dealii::Tensor<1,dim,real>,nstate> &soln_grad_bc)
const;
122 std::array<real,nstate> &soln_bc,
123 std::array<dealii::Tensor<1,dim,real>,nstate> &soln_grad_bc)
const;
127 const std::array<real,nstate> &soln_int,
128 const std::array<dealii::Tensor<1,dim,real>,nstate> &soln_grad_int,
129 std::array<real,nstate> &soln_bc,
130 std::array<dealii::Tensor<1,dim,real>,nstate> &soln_grad_bc)
const;
134 const std::array<real,nstate> &soln_int,
135 const std::array<dealii::Tensor<1,dim,real>,nstate> &soln_grad_int,
136 std::array<real,nstate> &soln_bc,
137 std::array<dealii::Tensor<1,dim,real>,nstate> &soln_grad_bc)
const;
141 std::array<real,nstate> &soln_bc)
const;
143 virtual void boundary_riemann (
144 const dealii::Tensor<1,dim,real> &normal_int,
145 const std::array<real,nstate> &soln_int,
146 std::array<real,nstate> &soln_bc)
const;
148 virtual void boundary_slip_wall (
149 const dealii::Tensor<1,dim,real> &normal_int,
150 const std::array<real,nstate> &soln_int,
151 const std::array<dealii::Tensor<1,dim,real>,nstate> &soln_grad_int,
152 std::array<real,nstate> &soln_bc,
153 std::array<dealii::Tensor<1,dim,real>,nstate> &soln_grad_bc)
const;
virtual ~ModelBase()=default
Virtual destructor required for abstract classes.
virtual std::vector< dealii::DataComponentInterpretation::DataComponentInterpretation > post_get_data_component_interpretation() const
Returns DataComponentInterpretation of the solution to be used by PhysicsPostprocessor to output curr...
std::shared_ptr< ManufacturedSolutionFunction< dim, real > > manufactured_solution_function
Manufactured solution function.
virtual void boundary_wall(std::array< real, nstate > &soln_bc, std::array< dealii::Tensor< 1, dim, real >, nstate > &soln_grad_bc) const
Wall boundary condition.
const MPI_Comm mpi_communicator
MPI communicator.
dealii::ConditionalOStream pcout
Parallel std::cout that only outputs on mpi_rank==0.
Manufactured solution used for grid studies to check convergence orders.
virtual void boundary_inflow(const std::array< real, nstate > &soln_int, const std::array< dealii::Tensor< 1, dim, real >, nstate > &soln_grad_int, std::array< real, nstate > &soln_bc, std::array< dealii::Tensor< 1, dim, real >, nstate > &soln_grad_bc) const
Inflow boundary conditions.
Files for the baseline physics.
virtual real max_convective_normal_eigenvalue(const std::array< real, nstate > &soln, const dealii::Tensor< 1, dim, real > &normal) const =0
Maximum convective normal eigenvalue (used in Lax-Friedrichs) of the additional models' PDEs...
ModelBase(std::shared_ptr< ManufacturedSolutionFunction< dim, real > > manufactured_solution_function_input=nullptr)
Constructor.
Physics model additional terms and equations to the baseline physics.
virtual void boundary_farfield(std::array< real, nstate > &soln_bc) const
Farfield boundary conditions based on freestream values.
virtual std::array< real, nstate > physical_source_term(const dealii::Point< dim, real > &pos, const std::array< real, nstate > &solution, const std::array< dealii::Tensor< 1, dim, real >, nstate > &solution_gradient, const dealii::types::global_dof_index cell_index) const
Physical source terms additional to the baseline physics (including physical source terms in addition...
virtual real max_convective_eigenvalue(const std::array< real, nstate > &soln) const =0
Maximum convective eigenvalue of the additional models' PDEs.
dealii::LinearAlgebra::distributed::Vector< int > cellwise_poly_degree
Cellwise polynomial degree.
void boundary_face_values(const int boundary_type, const dealii::Point< dim, real > &pos, const dealii::Tensor< 1, dim, real > &normal, const std::array< real, nstate > &soln_int, const std::array< dealii::Tensor< 1, dim, real >, nstate > &soln_grad_int, std::array< real, nstate > &soln_bc, std::array< dealii::Tensor< 1, dim, real >, nstate > &soln_grad_bc) const
Boundary condition handler.
virtual void boundary_outflow(const std::array< real, nstate > &soln_int, const std::array< dealii::Tensor< 1, dim, real >, nstate > &soln_grad_int, std::array< real, nstate > &soln_bc, std::array< dealii::Tensor< 1, dim, real >, nstate > &soln_grad_bc) const
Outflow Boundary Condition.
virtual std::array< dealii::Tensor< 1, dim, real >, nstate > convective_flux(const std::array< real, nstate > &conservative_soln) const =0
Convective flux terms additional to the baseline physics (including convective flux terms in addition...
virtual std::array< dealii::Tensor< 1, dim, real >, nstate > dissipative_flux(const std::array< real, nstate > &conservative_soln, const std::array< dealii::Tensor< 1, dim, real >, nstate > &solution_gradient, const dealii::types::global_dof_index cell_index) const =0
Dissipative flux terms additional to the baseline physics (including dissipative flux terms in additi...
virtual void boundary_manufactured_solution(const dealii::Point< dim, real > &pos, const dealii::Tensor< 1, dim, real > &normal_int, const std::array< real, nstate > &soln_int, const std::array< dealii::Tensor< 1, dim, real >, nstate > &soln_grad_int, std::array< real, nstate > &soln_bc, std::array< dealii::Tensor< 1, dim, real >, nstate > &soln_grad_bc) const
Evaluate the manufactured solution boundary conditions.
virtual dealii::Vector< double > post_compute_derived_quantities_vector(const dealii::Vector< double > &uh, const std::vector< dealii::Tensor< 1, dim > > &, const std::vector< dealii::Tensor< 2, dim > > &, const dealii::Tensor< 1, dim > &, const dealii::Point< dim > &) const
Returns current vector solution to be used by PhysicsPostprocessor to output current solution...
virtual std::array< real, nstate > convective_eigenvalues(const std::array< real, nstate > &, const dealii::Tensor< 1, dim, real > &) const =0
Convective eigenvalues of the additional models' PDEs.
virtual std::array< real, nstate > source_term(const dealii::Point< dim, real > &pos, const std::array< real, nstate > &solution, const real current_time, const dealii::types::global_dof_index cell_index) const =0
Manufactured source terms additional to the baseline physics (including manufactured source terms in ...
virtual std::vector< std::string > post_get_names() const
Returns names of the solution to be used by PhysicsPostprocessor to output current solution...