truncate_ga_ellipsoid Subroutine

private subroutine truncate_ga_ellipsoid(me)

Arguments

Type IntentOptional Attributes Name
type(grw_ellipsoidarray_type) :: me

Called by

proc~~truncate_ga_ellipsoid~2~~CalledByGraph proc~truncate_ga_ellipsoid~2 truncate_ga_ellipsoid interface~truncate~30 truncate interface~truncate~30->proc~truncate_ga_ellipsoid~2

Contents

Source Code


Source Code

  subroutine truncate_ga_ellipsoid(me)
    !------------------------------------------------------------------------
    type(grw_ellipsoidarray_type) :: me !< array to truncate
    !------------------------------------------------------------------------
    type(tem_ellipsoid_type), allocatable :: tarray(:)
    !------------------------------------------------------------------------
    integer :: ii
    !------------------------------------------------------------------------

    ! nothing to do if container size is not larger than the number of values
    ! in the array.
    if (me%containersize > me%nvals) then
      allocate(tarray(me%nvals))
      do ii = 1, me%nvals
        tarray(ii) = me%val(ii)
      end do
      call move_alloc(tarray, me%val)
      me%containersize = me%nvals
    end if

  end subroutine truncate_ga_ellipsoid