Returns an array of reals given start, end, and increment values. If the
increment argument is not passed, default increment is 1. This procedure is
overloaded by the generic procedure range
.
Type | Intent | Optional | Attributes | Name | ||
---|---|---|---|---|---|---|
real(kind=rk), | intent(in) | :: | start | Start value of the array |
||
real(kind=rk), | intent(in) | :: | end | End value of the array |
||
real(kind=rk), | intent(in), | optional | :: | increment | Array increment |
Nodes of different colours represent the following:
Solid arrows point from a procedure to one which it calls. Dashed arrows point from an interface to procedures which implement that interface. This could include the module procedures in a generic interface or the implementation in a submodule of an interface in a parent module.
pure function range_real(start,end,increment) result(range)
!! Returns an array of reals given start, end, and increment values. If the
!! increment argument is not passed, default increment is 1. This procedure is
!! overloaded by the generic procedure `range`.
real(kind=rk),intent(in) :: start
!! Start value of the array
real(kind=rk),intent(in) :: end
!! End value of the array
real(kind=rk),intent(in),optional :: increment
!! Array increment
real(kind=rk),dimension(:),allocatable :: range
real(kind=rk) :: increment_
integer(kind=ik) :: i
integer(kind=ik) :: length
if(present(increment))then
increment_ = increment
else
increment_ = 1
endif
length = int((end-start)/increment_)+1
allocate(range(length))
do concurrent(i = 1:length)
range(i) = start+(i-1)*increment_
enddo
endfunction range_real