deriveDensity Subroutine

public recursive subroutine deriveDensity(fun, varSys, elempos, time, tree, nElems, nDofs, res)

Initiates the calculation of density This routine sets the function Pointer for density calcualtion and calls the generice get Element from PDF routine

The interface has to comply to the abstract interface tem_varSys_proc_element.

Arguments

Type IntentOptional Attributes Name
class(tem_varSys_op_type), intent(in) :: fun

Description of the method to obtain the variables, here some preset values might be stored, like the space time function to use or the required variables.

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

The variable system to obtain the variable from.

integer, intent(in) :: elempos(:)

Position of the TreeID of the element to get the variable for in the global treeID list.

type(tem_time_type), intent(in) :: time

Point in time at which to evaluate the variable.

type(treelmesh_type), intent(in) :: tree

global treelm mesh info

integer, intent(in) :: nElems

Number of values to obtain for this variable (vectorized access).

integer, intent(in) :: nDofs

Number of degrees of freedom within an element.

real(kind=rk), intent(out) :: res(:)

Resulting values for the requested variable.

Linearized array dimension: (n requested entries) x (nComponents of this variable) x (nDegrees of freedom) Access: (iElem-1)fun%nComponentsnDofs + (iDof-1)*fun%nComponents + iComp


Calls

proc~~derivedensity~~CallsGraph proc~derivedensity deriveDensity proc~mus_generic_frompdf_forelement mus_generic_fromPDF_forElement proc~derivedensity->proc~mus_generic_frompdf_forelement get_element get_element proc~mus_generic_frompdf_forelement->get_element tem_LevelOf tem_LevelOf proc~mus_generic_frompdf_forelement->tem_LevelOf