self_LinearEuler3D_t Module

This module defines a class that can be used to solve the Linear Euler equations in 3-D. The Linear Euler Equations, here, are the Euler equations linearized about a motionless background state.

The conserved variables are

The conservative flux is

and the source terms are null.


Uses

  • module~~self_lineareuler3d_t~~UsesGraph module~self_lineareuler3d_t self_LinearEuler3D_t module~self_dgmodel3d~2 SELF_DGModel3D module~self_lineareuler3d_t->module~self_dgmodel3d~2 module~self_mesh SELF_Mesh module~self_lineareuler3d_t->module~self_mesh module~self_model SELF_Model module~self_lineareuler3d_t->module~self_model module~self_gpuinterfaces SELF_GPUInterfaces module~self_dgmodel3d~2->module~self_gpuinterfaces module~self_gpu SELF_GPU module~self_dgmodel3d~2->module~self_gpu module~self_dgmodel3d_t SELF_DGModel3D_t module~self_dgmodel3d~2->module~self_dgmodel3d_t module~self_constants SELF_Constants module~self_mesh->module~self_constants module~self_domaindecomposition~2 SELF_DomainDecomposition module~self_mesh->module~self_domaindecomposition~2 iso_c_binding iso_c_binding module~self_mesh->iso_c_binding FEQParse FEQParse module~self_model->FEQParse HDF5 HDF5 module~self_model->HDF5 module~self_hdf5 SELF_HDF5 module~self_model->module~self_hdf5 module~self_metadata SELF_Metadata module~self_model->module~self_metadata module~self_supportroutines SELF_SupportRoutines module~self_model->module~self_supportroutines module~self_constants->iso_c_binding iso_fortran_env iso_fortran_env module~self_constants->iso_fortran_env module~self_gpuinterfaces->module~self_gpu module~self_gpuinterfaces->iso_c_binding module~self_gpu->iso_c_binding module~self_gpu_enums SELF_GPU_enums module~self_gpu->module~self_gpu_enums module~self_dgmodel3d_t->module~self_model module~self_dgmodel3d_t->FEQParse module~self_dgmodel3d_t->HDF5 module~self_dgmodel3d_t->module~self_hdf5 module~self_dgmodel3d_t->module~self_metadata module~self_dgmodel3d_t->module~self_supportroutines module~self_geometry_3d SELF_Geometry_3D module~self_dgmodel3d_t->module~self_geometry_3d module~self_mappedscalar_3d~2 SELF_MappedScalar_3D module~self_dgmodel3d_t->module~self_mappedscalar_3d~2 module~self_mesh_3d~2 SELF_Mesh_3D module~self_dgmodel3d_t->module~self_mesh_3d~2 module~self_mappedvector_3d SELF_MappedVector_3D module~self_dgmodel3d_t->module~self_mappedvector_3d module~self_domaindecomposition~2->iso_c_binding mpi mpi module~self_domaindecomposition~2->mpi module~self_domaindecomposition_t SELF_DomainDecomposition_t module~self_domaindecomposition~2->module~self_domaindecomposition_t module~self_hdf5->module~self_constants module~self_hdf5->HDF5 module~self_hdf5->iso_fortran_env module~self_hdf5->mpi module~self_metadata->HDF5 module~self_metadata->module~self_hdf5 module~self_supportroutines->module~self_constants module~self_supportroutines->iso_fortran_env module~self_geometry_3d->module~self_constants module~self_geometry_3d->module~self_supportroutines module~self_geometry_3d->module~self_mesh_3d~2 module~self_vector_3d SELF_Vector_3D module~self_geometry_3d->module~self_vector_3d module~self_tensor_3d~2 SELF_Tensor_3D module~self_geometry_3d->module~self_tensor_3d~2 module~self_lagrange~2 SELF_Lagrange module~self_geometry_3d->module~self_lagrange~2 module~self_data SELF_Data module~self_geometry_3d->module~self_data module~self_scalar_3d SELF_Scalar_3D module~self_geometry_3d->module~self_scalar_3d module~self_mappedscalar_3d~2->module~self_gpuinterfaces module~self_mappedscalar_3d~2->module~self_gpu module~self_mappedscalar_3d~2->iso_c_binding module~self_mappedscalar_3d_t SELF_MappedScalar_3D_t module~self_mappedscalar_3d~2->module~self_mappedscalar_3d_t module~self_mesh_3d~2->module~self_gpu module~self_mesh_3d~2->iso_c_binding module~self_mesh_3d_t SELF_Mesh_3D_t module~self_mesh_3d~2->module~self_mesh_3d_t module~self_gpu_enums->iso_c_binding module~self_mappedvector_3d->module~self_gpuinterfaces module~self_mappedvector_3d->module~self_gpu module~self_mappedvector_3d->iso_c_binding module~self_gpublas SELF_GPUBLAS module~self_mappedvector_3d->module~self_gpublas module~self_mappedvector_3d_t SELF_MappedVector_3D_t module~self_mappedvector_3d->module~self_mappedvector_3d_t module~self_domaindecomposition_t->module~self_constants module~self_domaindecomposition_t->iso_c_binding module~self_domaindecomposition_t->module~self_supportroutines module~self_domaindecomposition_t->mpi module~self_domaindecomposition_t->module~self_lagrange~2 module~self_vector_3d->module~self_constants module~self_vector_3d->module~self_gpuinterfaces module~self_vector_3d->module~self_gpu module~self_vector_3d->iso_c_binding module~self_vector_3d->module~self_gpublas module~self_vector_3d_t SELF_Vector_3D_t module~self_vector_3d->module~self_vector_3d_t module~self_tensor_3d~2->module~self_constants module~self_tensor_3d~2->module~self_gpu module~self_tensor_3d~2->iso_c_binding module~self_tensor_3d~2->iso_fortran_env module~self_tensor_3d~2->module~self_gpublas module~self_tensor_3d_t SELF_Tensor_3D_t module~self_tensor_3d~2->module~self_tensor_3d_t module~self_lagrange~2->module~self_constants module~self_lagrange~2->module~self_gpu module~self_lagrange~2->iso_c_binding module~self_lagrange~2->iso_fortran_env module~self_lagrange_t SELF_Lagrange_t module~self_lagrange~2->module~self_lagrange_t module~self_mappedscalar_3d_t->module~self_constants module~self_mappedscalar_3d_t->FEQParse module~self_mappedscalar_3d_t->module~self_domaindecomposition~2 module~self_mappedscalar_3d_t->iso_c_binding module~self_mappedscalar_3d_t->module~self_geometry_3d module~self_mappedscalar_3d_t->module~self_mesh_3d~2 module~self_mappedscalar_3d_t->module~self_tensor_3d~2 module~self_mappedscalar_3d_t->module~self_lagrange~2 module~self_mappedscalar_3d_t->module~self_scalar_3d module~self_mesh_3d_t->module~self_mesh module~self_mesh_3d_t->module~self_constants module~self_mesh_3d_t->HDF5 module~self_mesh_3d_t->module~self_domaindecomposition~2 module~self_mesh_3d_t->iso_c_binding module~self_mesh_3d_t->module~self_hdf5 module~self_mesh_3d_t->module~self_supportroutines module~self_mesh_3d_t->module~self_lagrange~2 module~self_gpublas->module~self_constants module~self_gpublas->iso_c_binding module~self_gpublas->module~self_gpu_enums module~self_gpublas->iso_fortran_env module~self_mappedvector_3d_t->module~self_constants module~self_mappedvector_3d_t->FEQParse module~self_mappedvector_3d_t->module~self_domaindecomposition~2 module~self_mappedvector_3d_t->iso_c_binding module~self_mappedvector_3d_t->module~self_geometry_3d module~self_mappedvector_3d_t->module~self_mesh_3d~2 module~self_mappedvector_3d_t->module~self_lagrange~2 module~self_data->module~self_constants module~self_data->FEQParse module~self_data->HDF5 module~self_data->iso_c_binding module~self_data->module~self_hdf5 module~self_data->module~self_metadata module~self_data->module~self_lagrange~2 module~self_scalar_3d->module~self_constants module~self_scalar_3d->module~self_gpuinterfaces module~self_scalar_3d->module~self_gpu module~self_scalar_3d->iso_c_binding module~self_scalar_3d->module~self_gpublas module~self_scalar_3d_t SELF_Scalar_3D_t module~self_scalar_3d->module~self_scalar_3d_t module~self_vector_3d_t->module~self_constants module~self_vector_3d_t->FEQParse module~self_vector_3d_t->HDF5 module~self_vector_3d_t->iso_c_binding module~self_vector_3d_t->module~self_hdf5 module~self_vector_3d_t->module~self_metadata module~self_vector_3d_t->module~self_lagrange~2 module~self_vector_3d_t->module~self_data module~self_lagrange_t->module~self_constants module~self_lagrange_t->HDF5 module~self_lagrange_t->iso_c_binding module~self_lagrange_t->module~self_hdf5 module~self_lagrange_t->module~self_supportroutines module~self_lagrange_t->iso_fortran_env module~self_quadrature SELF_Quadrature module~self_lagrange_t->module~self_quadrature module~self_tensor_3d_t->module~self_constants module~self_tensor_3d_t->FEQParse module~self_tensor_3d_t->HDF5 module~self_tensor_3d_t->iso_c_binding module~self_tensor_3d_t->module~self_hdf5 module~self_tensor_3d_t->module~self_metadata module~self_tensor_3d_t->module~self_lagrange~2 module~self_tensor_3d_t->module~self_data module~self_scalar_3d_t->module~self_constants module~self_scalar_3d_t->FEQParse module~self_scalar_3d_t->HDF5 module~self_scalar_3d_t->iso_c_binding module~self_scalar_3d_t->module~self_hdf5 module~self_scalar_3d_t->module~self_metadata module~self_scalar_3d_t->module~self_lagrange~2 module~self_scalar_3d_t->module~self_data module~self_quadrature->module~self_constants module~self_quadrature->iso_fortran_env

Used by

  • module~~self_lineareuler3d_t~~UsedByGraph module~self_lineareuler3d_t self_LinearEuler3D_t module~self_lineareuler3d~2 self_LinearEuler3D module~self_lineareuler3d~2->module~self_lineareuler3d_t module~self_lineareuler3d self_LinearEuler3D module~self_lineareuler3d->module~self_lineareuler3d_t

Contents


Derived Types

type, public, extends(DGModel3D) :: LinearEuler3D_t

Components

TypeVisibilityAttributesNameInitial
real(kind=prec), public :: c =1.0_prec
type(MappedScalar3D), public :: dSdt
real(kind=prec), public :: dt
real(kind=prec), public :: entropy
type(MappedVector3D), public :: flux
type(MappedScalar3D), public :: fluxDivergence
real(kind=prec), public :: g =0.0_prec
type(SEMHex), public, pointer:: geometry
logical, public :: gradient_enabled =.false.
integer, public :: ioIterate =0
type(Mesh3D), public, pointer:: mesh
integer, public :: nvar
logical, public :: prescribed_bcs_enabled =.true.
real(kind=prec), public :: rho0 =1.0_prec
type(MappedScalar3D), public :: solution
type(MappedVector3D), public :: solutionGradient
type(MappedScalar3D), public :: source
real(kind=prec), public :: t
logical, public :: tecplot_enabled =.true.
procedure(SELF_timeIntegrator), public, pointer:: timeIntegrator=> Euler_timeIntegrator
type(MappedScalar3D), public :: workSol

Type-Bound Procedures

procedure, public :: AdditionalFree => AdditionalFree_Model
procedure, public :: AdditionalInit => AdditionalInit_Model
procedure, public :: AdditionalOutput => AdditionalOutput_Model
procedure, public :: BoundaryFlux => BoundaryFlux_DGModel3D
procedure, public :: CalculateEntropy => CalculateEntropy_DGModel3D
procedure, public :: CalculateSolutionGradient => CalculateSolutionGradient_DGModel3D
procedure, public :: CalculateTendency => CalculateTendency_DGModel3D
procedure, public :: Euler_timeIntegrator
procedure, public :: FluxMethod => fluxmethod_DGModel3D
procedure, public :: ForwardStep => ForwardStep_Model
procedure, public :: Free => Free_DGModel3D_t
procedure, public :: GetSimulationTime
procedure, public :: IncrementIOCounter
procedure, public :: Init => Init_DGModel3D_t
procedure, public :: LowStorageRK2_timeIntegrator
procedure, public :: LowStorageRK3_timeIntegrator
procedure, public :: LowStorageRK4_timeIntegrator
procedure, public :: PreTendency => PreTendency_Model
procedure, public :: PrintType => PrintType_Model
procedure, public :: ReadModel => Read_DGModel3D_t
procedure, public :: ReportEntropy => ReportEntropy_Model
procedure, public :: ReportMetrics => ReportMetrics_DGModel3D_t
procedure, public :: ReportUserMetrics => ReportUserMetrics_Model
procedure, public :: SetBoundaryCondition => setboundarycondition_DGModel3D
procedure, public :: SetGradientBoundaryCondition => setgradientboundarycondition_DGModel3D
procedure, public :: SetMetadata => SetMetadata_LinearEuler3D_t
procedure, public :: SetNumberOfVariables => SetNumberOfVariables_LinearEuler3D_t
procedure, public :: SetSimulationTime
generic, public :: SetSolution => SetSolutionFromChar_DGModel3D_t, SetSolutionFromEqn_DGModel3D_t
generic, public :: SetTimeIntegrator => SetTimeIntegrator_withChar
procedure, public :: SourceMethod => sourcemethod_LinearEuler3D_t
procedure, public :: SphericalSoundWave => SphericalSoundWave_LinearEuler3D_t
procedure, public :: UpdateGRK2 => UpdateGRK2_DGModel3D
procedure, public :: UpdateGRK3 => UpdateGRK3_DGModel3D
procedure, public :: UpdateGRK4 => UpdateGRK4_DGModel3D
procedure, public :: UpdateSolution => UpdateSolution_DGModel3D
procedure, public :: WriteModel => Write_DGModel3D_t
procedure, public :: WriteTecplot => WriteTecplot_DGModel3D_t
procedure, public :: entropy_func => entropy_func_LinearEuler3D_t
procedure, public :: flux1D => flux1d_Model
procedure, public :: flux2D => flux2d_Model
procedure, public :: flux3D => flux3D_LinearEuler3D_t
procedure, public :: hbc1d_NoNormalFlow => hbc1d_Generic_Model
procedure, public :: hbc1d_Prescribed => hbc1d_Prescribed_Model
procedure, public :: hbc1d_Radiation => hbc1d_Generic_Model
procedure, public :: hbc2d_NoNormalFlow => hbc2d_Generic_Model
procedure, public :: hbc2d_Prescribed => hbc2d_Prescribed_Model
procedure, public :: hbc2d_Radiation => hbc2d_Generic_Model
procedure, public :: hbc3d_NoNormalFlow => hbc3d_Generic_Model
procedure, public :: hbc3d_Prescribed => hbc3d_Prescribed_Model
procedure, public :: hbc3d_Radiation => hbc3d_Generic_Model
procedure, public :: pbc1d_NoNormalFlow => pbc1d_Generic_Model
procedure, public :: pbc1d_Prescribed => pbc1d_Prescribed_Model
procedure, public :: pbc1d_Radiation => pbc1d_Generic_Model
procedure, public :: pbc2d_NoNormalFlow => pbc2d_Generic_Model
procedure, public :: pbc2d_Prescribed => pbc2d_Prescribed_Model
procedure, public :: pbc2d_Radiation => pbc2d_Generic_Model
procedure, public :: pbc3d_NoNormalFlow => pbc3d_Generic_Model
procedure, public :: pbc3d_Prescribed => pbc3d_Prescribed_Model
procedure, public :: pbc3d_Radiation => pbc3d_Generic_Model
procedure, public :: riemannflux1d => riemannflux1d_Model
procedure, public :: riemannflux2d => riemannflux2d_Model
procedure, public :: riemannflux3D => riemannflux3D_LinearEuler3D_t
procedure, public :: source1d => source1d_Model
procedure, public :: source2d => source2d_Model
procedure, public :: source3d => source3d_Model

Functions

public pure function entropy_func_LinearEuler3D_t(this, s) result(e)

The entropy function is the sum of kinetic and internal energy For the linear model, this is

Read more…

Arguments

TypeIntentOptionalAttributesName
class(LinearEuler3D_t), intent(in) :: this
real(kind=prec), intent(in) :: s(1:this%nvar)

Return Value real(kind=prec)

public pure function flux3D_LinearEuler3D_t(this, s, dsdx) result(flux)

Arguments

TypeIntentOptionalAttributesName
class(LinearEuler3D_t), intent(in) :: this
real(kind=prec), intent(in) :: s(1:this%nvar)
real(kind=prec), intent(in) :: dsdx(1:this%nvar,1:3)

Return Value real(kind=prec)(1:this%nvar,1:3)

public pure function riemannflux3D_LinearEuler3D_t(this, sL, sR, dsdx, nhat) result(flux)

Uses a local lax-friedrich's upwind flux The max eigenvalue is taken as the sound speed

Arguments

TypeIntentOptionalAttributesName
class(LinearEuler3D_t), intent(in) :: this
real(kind=prec), intent(in) :: sL(1:this%nvar)
real(kind=prec), intent(in) :: sR(1:this%nvar)
real(kind=prec), intent(in) :: dsdx(1:this%nvar,1:3)
real(kind=prec), intent(in) :: nhat(1:3)

Return Value real(kind=prec)(1:this%nvar)


Subroutines

public subroutine SetMetadata_LinearEuler3D_t(this)

Arguments

TypeIntentOptionalAttributesName
class(LinearEuler3D_t), intent(inout) :: this

public subroutine SetNumberOfVariables_LinearEuler3D_t(this)

Arguments

TypeIntentOptionalAttributesName
class(LinearEuler3D_t), intent(inout) :: this

public subroutine SphericalSoundWave_LinearEuler3D_t(this, rhoprime, Lr, x0, y0, z0)

This subroutine sets the initial condition for a weak blast wave problem. The initial condition is given by

Read more…

Arguments

TypeIntentOptionalAttributesName
class(LinearEuler3D_t), intent(inout) :: this
real(kind=prec), intent(in) :: rhoprime
real(kind=prec), intent(in) :: Lr
real(kind=prec), intent(in) :: x0
real(kind=prec), intent(in) :: y0
real(kind=prec), intent(in) :: z0

public subroutine sourcemethod_LinearEuler3D_t(this)

Arguments

TypeIntentOptionalAttributesName
class(LinearEuler3D_t), intent(inout) :: this