XL Fortran for AIX V8.1.1

ランゲージ・リファレンス

+---------------------------------Fortran 95---------------------------------+

CPU_TIME(TIME)

すべてのスレッドの現行プロセス、および、場合によっては子プロセスにかかる CPU 時間を秒単位で戻します。 CPU_TIME を呼び出すと、プログラムの始まりからの処理にかかるプロセッサー時間を戻します。計測される時間は、プログラムが実際に実行された時間であり、プログラムが中断している時間または待っている時間は含まれません。

引き数タイプおよび属性

TIME
実数タイプのスカラーです。これは、INTENT(OUT) 引き数で、プロセッサー時間の近似値を割り当てられます。この時間は秒単位で計測されます。 CPU_TIME によって戻される時間は、XLFRTEOPTS 環境変数実行時オプション cpu_time_type の設定によって異なります。 cpu_time_type の有効な設定値は次のとおりです。

usertime
現行プロセスのユーザー時間です。ユーザー時間の定義については、「AIX Performance and Tuning Guide」を参照してください。

systime
現行プロセスのシステム時間です。システム時間の定義については、「AIX Performance and Tuning Guide」を参照してください。

alltime
現行プロセスのシステム時間とユーザー時間の合計です。

total_usertime
現行プロセスのユーザー時間の合計です。ユーザー時間の合計とは、現行プロセスのユーザー時間の合計と、その子プロセス (ある場合) のユーザー時間の合計です。

total_systime
現行プロセスのシステム時間の合計です。システム時間の合計とは、現行プロセスのシステム時間の合計と、その子プロセス (ある場合) のシステム時間の合計です。

total_alltime
現行プロセスのユーザー時間とシステム時間の合計です。ユーザー時間とシステム時間の合計とは、現行プロセスのユーザー時間とシステム時間の合計と、その子プロセス (存在する場合) のユーザー時間とシステム時間の合計です。

これが、cpu_time_type 実行時オプションを設定していない場合の、CPU_TIME の時間のデフォルト測定です。

cpu_time_type 実行時オプションの設定は、setrteopts プロシージャーを使用して行います。 cpu_time_type 設定へのそれぞれの変更は、後続の CPU_TIME の呼び出しすべてに影響します。

クラス

サブルーチン

例 1:

! The default value for cpu_time_type is used
REAL T1, T2
...         ! First chunk of code to be timed
CALL CPU_TIME(T1)
...         ! Second chunk of code to be timed
CALL CPU_TIME(T2)
print *, 'Time taken for first chunk of code: ', T1, 'seconds.'
print *, 'Time taken for both chunks of code: ', T2, 'seconds.'
print *, 'Time for second chunk of code was ', T2-T1, 'seconds.'

cpu_time_type 実行時オプションを usertime に設定したい場合、ksh または bsh コマンド行から次のコマンドを入力します。

export XLFRTEOPTS=cpu_time_type=usertime

例 2:

! Use setrteopts to set the cpu_time_type run-time option as many times
! as you need to
CALL setrteopts ('cpu_time_type=alltime')
CALL stallingloop
CALL CPU_TIME(T1)
print *, 'The sum of the user and system time is', T1, 'seconds'.
CALL setrteopts ('cpu_time_type=usertime')
CALL stallingloop
CALL CPU_TIME(T2)
print *, 'The total user time from the start of the program is', T2, 'seconds'.

関連情報

+------------------------------Fortran 95 の終り------------------------------+


[ ページのトップ | 前ページ | 次ページ | 目次 | 索引 ]