mrt_advRel_d3q19f3_MSLiquid_WTDF Subroutine

public subroutine mrt_advRel_d3q19f3_MSLiquid_WTDF(fieldProp, inState, outState, auxField, neigh, nElems, nSolve, level, layout, params, varSys, derVarPos)

Optimized Advection relaxation routine for the multispecies mrt model for d3q19 with 3 species with thermodynamic factor

This routine contains the implementation based on the paper "A Lattice Boltzmann Scheme for liquid mixtures - Part II: Discretization and Numerics, Jens Zudrop, Sabine Roller, Pietro Asinari. "\n MRT paper "Lattice Boltzmann liquid mixture modeling for electrodialytic engineering applications - J. Zudrop, K. Masilamani, S. Roller and P. Asinari"\n

This subroutine interface must match the abstract interface definition kernel in scheme/mus_scheme_type_module.f90 in order to be callable via compute function pointer.

Arguments

Type IntentOptional Attributes Name
type(mus_field_prop_type), intent(in) :: fieldProp(:)

Array of field properties (fluid or species)

real(kind=rk), intent(in) :: inState(nElems*varSys%nScalars)

input pdf vector

real(kind=rk), intent(out) :: outState(nElems*varSys%nScalars)

output pdf vector

real(kind=rk), intent(inout) :: auxField(nElems*varSys%nAuxScalars)

Auxiliary field computed from pre-collision state Is updated with correct velocity field for multicomponent models

integer, intent(in) :: neigh(nElems*layout%fStencil%QQ)

connectivity vector

integer, intent(in) :: nElems

number of elements in state Array

integer, intent(in) :: nSolve

number of elements solved in kernel

integer, intent(in) :: level

current level

type(mus_scheme_layout_type), intent(in) :: layout

current layout

type(mus_param_type), intent(in) :: params

global parameters

type(tem_varSys_type), intent(in) :: varSys

variable system definition

type(mus_derVarPos_type), intent(in) :: derVarPos(:)

position of derived quantities in varsys for all fields


Calls

proc~~mrt_advrel_d3q19f3_msliquid_wtdf~~CallsGraph proc~mrt_advrel_d3q19f3_msliquid_wtdf mrt_advRel_d3q19f3_MSLiquid_WTDF auxfield_varpos auxfield_varpos proc~mrt_advrel_d3q19f3_msliquid_wtdf->auxfield_varpos interface~mus_calc_ms_diffmatrix mus_calc_MS_DiffMatrix proc~mrt_advrel_d3q19f3_msliquid_wtdf->interface~mus_calc_ms_diffmatrix interface~mus_calc_thermfactor mus_calc_thermFactor proc~mrt_advrel_d3q19f3_msliquid_wtdf->interface~mus_calc_thermfactor invert_matrix invert_matrix proc~mrt_advrel_d3q19f3_msliquid_wtdf->invert_matrix val val proc~mrt_advrel_d3q19f3_msliquid_wtdf->val proc~mus_calc_ms_diffmatrix_single mus_calc_MS_DiffMatrix_single interface~mus_calc_ms_diffmatrix->proc~mus_calc_ms_diffmatrix_single proc~mus_calc_thermfactor_single mus_calc_thermFactor_single interface~mus_calc_thermfactor->proc~mus_calc_thermfactor_single