subroutine Init_Vector3D_t(this,interp,nVar,nElem)
implicit none
class(Vector3D_t),intent(out) :: this
type(Lagrange),target,intent(in) :: interp
integer,intent(in) :: nVar
integer,intent(in) :: nElem
! local
integer :: i
this%interp => interp
this%nVar = nVar
this%nElem = nElem
this%N = interp%N
this%M = interp%M
allocate(this%interior(1:interp%N+1,1:interp%N+1,1:interp%N+1,1:nelem,1:nvar,1:3), &
this%boundary(1:interp%N+1,1:interp%N+1,1:6,1:nelem,1:nvar,1:3), &
this%extBoundary(1:interp%N+1,1:interp%N+1,1:6,1:nelem,1:nvar,1:3), &
this%avgBoundary(1:interp%N+1,1:interp%N+1,1:6,1:nelem,1:nvar,1:3), &
this%boundaryNormal(1:interp%N+1,1:interp%N+1,1:6,1:nelem,1:nvar))
allocate(this%meta(1:nVar))
allocate(this%eqn(1:3*nVar))
! Initialize equation parser
! This is done to prevent segmentation faults that arise
! when building with amdflang that are traced back to
! feqparse_functions.f90 : finalize routine
! When the equation parser is not initialized, the
! functions are not allocated, which I think are the
! source of the segfault - joe@fluidnumerics.com
do i = 1,3*nvar
this%eqn(i) = EquationParser('f=0',(/'x','y','z','t'/))
enddo
this%interior = 0.0_prec
this%boundary = 0.0_prec
this%boundarynormal = 0.0_prec
this%extBoundary = 0.0_prec
this%avgBoundary = 0.0_prec
endsubroutine Init_Vector3D_t