flux3D_LinearEuler3D_t Function

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)


Contents


Source Code

  pure function flux3D_LinearEuler3D_t(this,s,dsdx) result(flux)
    class(LinearEuler3D_t),intent(in) :: this
    real(prec),intent(in) :: s(1:this%nvar)
    real(prec),intent(in) :: dsdx(1:this%nvar,1:3)
    real(prec) :: flux(1:this%nvar,1:3)

    flux(1,1) = this%rho0*s(2) ! density, x flux ; rho0*u
    flux(1,2) = this%rho0*s(3) ! density, y flux ; rho0*v
    flux(1,3) = this%rho0*s(4) ! density, y flux ; rho0*w

    flux(2,1) = s(5)/this%rho0 ! x-velocity, x flux; p/rho0
    flux(2,2) = 0.0_prec ! x-velocity, y flux; 0
    flux(2,3) = 0.0_prec ! x-velocity, z flux; 0

    flux(3,1) = 0.0_prec ! y-velocity, x flux; 0
    flux(3,2) = s(5)/this%rho0 ! y-velocity, y flux; p/rho0
    flux(3,3) = 0.0_prec ! y-velocity, z flux; 0

    flux(4,1) = 0.0_prec ! z-velocity, x flux; 0
    flux(4,2) = 0.0_prec ! z-velocity, y flux; 0
    flux(4,3) = s(5)/this%rho0 ! z-velocity, z flux; p/rho0

    flux(5,1) = this%c*this%c*this%rho0*s(2) ! pressure, x flux : rho0*c^2*u
    flux(5,2) = this%c*this%c*this%rho0*s(3) ! pressure, y flux : rho0*c^2*v
    flux(5,3) = this%c*this%c*this%rho0*s(4) ! pressure, y flux : rho0*c^2*w

  endfunction flux3D_LinearEuler3D_t