メモリ割り当てを確認するために、単精度配列に単位値を設定し、 コマンドSUMとDOT_PRODUCTコマンドで問い合わせます。これらの組み込み関数は、16777216 (= 2^24) でカウントを停止します。これらのコマンドで数十億の要素をカウントするにはどうすればよいでしょうか? DOループを避けることを好みます。これは、精度の高い配列では問題になりません。
program allocator
use iso_fortran_env
implicit NONE
integer, parameter :: sp = selected_real_kind ( REAL32 )
integer, parameter :: xlint = selected_int_kind ( INT64 )
integer ( xlint ) :: n = 100000000
real ( sp ), allocatable, dimension ( : ) :: array
integer ( xlint ) :: alloc_status = 0
character ( len = 255 ) :: alloc_msg = ""
! ALLOCATE
allocate ( array ( 1 : n ), stat = alloc_status, errmsg = alloc_msg )
if ( alloc_status /= 0 ) print *, 'allocation error on ', n, ' elements: stat = ', alloc_status, ', errmsg = ', alloc_msg
! POPULATE
array = 1.0_sp
write ( *, '( "number of elements allocated = ", g0 )' ) n
write ( *, '( "sum of elements = ", g0 )' ) sum ( array )
write ( *, '( "dot product = ", g0, / )' ) dot_product ( array, array )
! DEALLOCATE
deallocate ( array, stat = alloc_status, errmsg = alloc_msg )
if ( alloc_status /= 0 ) print *, 'deallocation error on ', n, ' elements: stat = ', alloc_status, ', errmsg = ', alloc_msg
write ( *, '( "compiler version = ", A )' ) compiler_version()
write ( *, '( "compiler options = ", A )' ) trim ( compiler_options() )
end program allocator
出力:
number of elements allocated = 100000000
sum of elements = 16777216.
dot product = 16777216.
compiler version = GCC version 4.6.2 20111019 (prerelease)
compiler options = -fPIC -mmacosx-version-min=10.6.8 -mtune=core2