種類
- インスタンスメソッド (24)
- モジュール関数 (5)
- 定数 (4)
- 特異メソッド (1)
- クラス (1)
クラス
-
Benchmark
:: Report (3) -
Benchmark
:: Tms (20) -
Process
:: Tms (4)
キーワード
- * (1)
- + (1)
- - (1)
-
/ (1) - CAPTION (2)
- FORMAT (2)
- add (1)
- add! (1)
- benchmark (1)
- bm (1)
- bmbm (1)
-
clock
_ gettime (1) - cstime (1)
- cstime= (1)
- cutime (1)
- cutime= (1)
- format (1)
- item (1)
- label (1)
- list (1)
- measure (1)
- memberwise (1)
- new (1)
- real (1)
- report (1)
- stime (1)
- stime= (1)
-
to
_ a (1) -
to
_ s (1) - total (1)
- utime (1)
- utime= (1)
検索結果
先頭5件
- Benchmark
:: Tms - Benchmark
. # benchmark(caption = "" , label _ width = nil , fmtstr = nil , *labels) {|rep| . . . } -> [Benchmark :: Tms] - Benchmark
:: Tms . new(utime = 0 . 0 , stime = 0 . 0 , cutime = 0 . 0 , cstime = 0 . 0 , real = 0 . 0 , label = nil) -> Benchmark :: Tms - Benchmark
:: Tms :: CAPTION -> String - Benchmark
:: Tms # memberwise(op , x) -> Benchmark :: Tms
-
Benchmark
:: Tms (63001.0) -
ベンチマークの計測に関連する各種時間を表現するクラスです。
ベンチマークの計測に関連する各種時間を表現するクラスです。 -
Benchmark
. # benchmark(caption = "" , label _ width = nil , fmtstr = nil , *labels) {|rep| . . . } -> [Benchmark :: Tms] (28192.0) -
Benchmark::Report オブジェクトを生成し、それを引数として与えられたブロックを実行します。
Benchmark::Report オブジェクトを生成し、それを引数として与えられたブロックを実行します。
基本的には以下のように使います。
ブロックが Benchmark::Tms オブジェクトの配列を返した場合は、
それらの数値も追加の行に表示されます。
@param caption レポートの一行目に表示する文字列を指定します。
@param label_width ラベルの幅を指定します。
@param fmtstr フォーマット文字列を指定します。
この引数を省略すると Benchmark::FORMAT が使用されます。... -
Benchmark
:: Tms . new(utime = 0 . 0 , stime = 0 . 0 , cutime = 0 . 0 , cstime = 0 . 0 , real = 0 . 0 , label = nil) -> Benchmark :: Tms (27652.0) -
新しい Benchmark::Tms オブジェクトを生成して返します。
新しい Benchmark::Tms オブジェクトを生成して返します。
@param utime User CPU time
@param stime System CPU time
@param cutime 子プロセスの User CPU time
@param cstime 子プロセスの System CPU time
@param real 実経過時間
@param label ラベル -
Benchmark
:: Tms :: CAPTION -> String (27301.0) -
Benchmark.#bm の内部などで使用されます。
Benchmark.#bm の内部などで使用されます。
@see Benchmark::CAPTION -
Benchmark
:: Tms # memberwise(op , x) -> Benchmark :: Tms (18688.0) -
Benchmark::Tms の四則演算を実行するために内部で使用されるメソッドです。
Benchmark::Tms の四則演算を実行するために内部で使用されるメソッドです。
@param op 演算子をシンボルで与えます。
@param x Benchmark::Tms のオブジェクトか Float に暗黙の変換ができるオブジェクトです。
@return 計算結果は新しい Benchmark::Tms オブジェクトです。 -
Benchmark
:: Tms # *(x) -> Benchmark :: Tms (18658.0) -
self と x の乗算を計算します。
self と x の乗算を計算します。
@param x Benchmark::Tms のオブジェクトか Float に暗黙の変換ができるオブジェクトです。
@return 計算結果は新しい Benchmark::Tms オブジェクトです。
@see Benchmark::Tms#memberwise -
Benchmark
:: Tms # +(x) -> Benchmark :: Tms (18658.0) -
self と x の加算を計算します。
self と x の加算を計算します。
@param x Benchmark::Tms のオブジェクトか Float に暗黙の変換ができるオブジェクトです。
@return 計算結果は新しい Benchmark::Tms オブジェクトです。
@see Benchmark::Tms#memberwise -
Benchmark
:: Tms # -(x) -> Benchmark :: Tms (18658.0) -
self と x の減算を計算します。
self と x の減算を計算します。
@param x Benchmark::Tms のオブジェクトか Float に暗黙の変換ができるオブジェクトです。
@return 計算結果は新しい Benchmark::Tms オブジェクトです。
@see Benchmark::Tms#memberwise -
Benchmark
:: Tms # / (x) -> Benchmark :: Tms (18658.0) -
self と x の除算を計算します。
self と x の除算を計算します。
@param x Benchmark::Tms のオブジェクトか Float に暗黙の変換ができるオブジェクトです。
@return 計算結果は新しい Benchmark::Tms オブジェクトです。
@see Benchmark::Tms#memberwise -
Benchmark
:: Tms # add { . . . } -> Benchmark :: Tms (18652.0) -
与えられたブロックの実行時間を self に加算して 新しい Benchmark::Tms オブジェクトを生成して返します。
与えられたブロックの実行時間を self に加算して
新しい Benchmark::Tms オブジェクトを生成して返します。
@see Benchmark.#measure -
Benchmark
:: Tms # format(fmtstr = nil , *args) -> String (18499.0) -
self を指定されたフォーマットで整形して返します。
self を指定されたフォーマットで整形して返します。
このメソッドは Kernel.#format のようにオブジェクトを整形しますが、
以下の拡張を使用することができます。
: %u
user CPU time で置き換えられます。Benchmark::Tms#utime
: %y
system CPU time で置き換えられます(Mnemonic: y of "s*y*stem")。Benchmark::Tms#stime
: %U
子プロセスの user CPU time で置き換えられます。Benchmark::Tms#cutime
: %Y
子プロセスの s... -
Benchmark
:: Tms :: FORMAT -> String (18499.0) -
Benchmark.#benchmark の第三引数のデフォルト値。
Benchmark.#benchmark の第三引数のデフォルト値。
: %u
user CPU time で置き換えられます。Benchmark::Tms#utime
: %y
system CPU time で置き換えられます(Mnemonic: y of "s*y*stem")。Benchmark::Tms#stime
: %U
子プロセスの user CPU time で置き換えられます。Benchmark::Tms#cutime
: %Y
子プロセスの system CPU time で置き換えられます。Benchmark::Tms#cstime
: %t
t... -
Benchmark
:: Tms # to _ s -> String (18349.0) -
引数を省略して Benchmark::Tms#format を呼び出すのと同じです。
引数を省略して Benchmark::Tms#format を呼び出すのと同じです。 -
Benchmark
:: CAPTION -> String (18337.0) -
Benchmark.#bm の内部などで使用されます。
Benchmark.#bm の内部などで使用されます。
実際の定義は Benchmark::Tms::CAPTION でされています。
@see Benchmark::Tms::CAPTION -
Benchmark
:: Tms # label -> String (18301.0) -
ラベル。
ラベル。 -
Benchmark
:: Tms # add! { . . . } -> self (18001.0) -
与えられたブロックの実行時間を self に加算して返します。
与えられたブロックの実行時間を self に加算して返します。
このメソッドは self を破壊的に変更します。
@see Benchmark.#measure -
Benchmark
:: Tms # cstime -> Float (18001.0) -
子プロセスの System CPU time
子プロセスの System CPU time -
Benchmark
:: Tms # cutime -> Float (18001.0) -
子プロセスの User CPU time
子プロセスの User CPU time -
Benchmark
:: Tms # real -> Float (18001.0) -
実経過時間。
実経過時間。 -
Benchmark
:: Tms # stime -> Float (18001.0) -
System CPU time
System CPU time -
Benchmark
:: Tms # to _ a -> Array (18001.0) -
6 要素の配列を返します。
6 要素の配列を返します。
要素は以下の順番で配列に格納されています。
* ラベル
* user CPU time
* system CPU time,
* 子プロセスの user CPU time
* 子プロセスの system CPU time,
* 実経過時間 -
Benchmark
:: Tms # total -> Float (18001.0) -
合計時間。(utime + stime + cutime + cstime)
合計時間。(utime + stime + cutime + cstime) -
Benchmark
:: Tms # utime -> Float (18001.0) -
User CPU time
User CPU time -
Benchmark
. # bm(label _ width = 0 , *labels) {|rep| . . . } -> [Benchmark :: Tms] (9838.0) -
Benchmark.#benchmark メソッドの引数を簡略化したものです。
Benchmark.#benchmark メソッドの引数を簡略化したものです。
Benchmark.#benchmark メソッドと同様に働きます。
@param label_width ラベルの幅を指定します。
@param labels ブロックが Benchmark::Tms オブジェクトの配列を返す場合に指定します。
//emlist[][ruby]{
require 'benchmark'
n = 50000
Benchmark.bm do |x|
x.report { for i in 1..n; a = "1"; end }
x.report { n.t... -
Benchmark
. # measure(label = "") { . . . } -> Benchmark :: Tms (9670.0) -
与えられたブロックを実行して、経過した時間を Process.#times で計り、 Benchmark::Tms オブジェクトを生成して返します。
与えられたブロックを実行して、経過した時間を Process.#times で計り、
Benchmark::Tms オブジェクトを生成して返します。
Benchmark::Tms オブジェクトには to_s が定義されているので、
基本的には以下のように使います。
//emlist[][ruby]{
require 'benchmark'
puts Benchmark::CAPTION
puts Benchmark.measure { "a"*1_000_000 }
#=>
#
# user system total real
# 1.1666... -
Benchmark
:: Report # list -> [Benchmark :: Tms] (9652.0) -
Benchmark::Report#item 実行時に作成された Benchmark::Tms オ ブジェクトの一覧を返します。
Benchmark::Report#item 実行時に作成された Benchmark::Tms オ
ブジェクトの一覧を返します。
@see Benchmark::Report#item -
Benchmark
:: Report # item(label = "" , *fmt) { . . . } -> Benchmark :: Tms (9643.0) -
ラベルと与えられたブロックの実行時間を標準出力に出力します。
ラベルと与えられたブロックの実行時間を標準出力に出力します。
出力のフォーマットは Benchmark::Tms#format が行います。
@param label ラベル
@param fmt 結果に出力したいオブジェクト
@see Benchmark::Tms#format -
Benchmark
:: Report # report(label = "" , *fmt) { . . . } -> Benchmark :: Tms (9643.0) -
ラベルと与えられたブロックの実行時間を標準出力に出力します。
ラベルと与えられたブロックの実行時間を標準出力に出力します。
出力のフォーマットは Benchmark::Tms#format が行います。
@param label ラベル
@param fmt 結果に出力したいオブジェクト
@see Benchmark::Tms#format -
Benchmark
. # bmbm(width = 0) {|job| . . . } -> [Benchmark :: Tms] (9604.0) -
Benchmark::Job オブジェクトを生成して、それを引数として与えられたブロックを 実行します。
Benchmark::Job オブジェクトを生成して、それを引数として与えられたブロックを
実行します。
ベンチマークの結果は GC の影響によって歪められてしまうことがあります。
このメソッドは与えられたブロックを二度実行する事によってこの影響を最小化します。
一回目は実行環境を安定化するためにリハーサルとして実行します。二回目は本番として
実行します。
二回目のブロック実行の前に GC.start を実行しますが、この実行時間は計測には
含まれません。しかし、実際にはこのメソッドを使用しても、GC などの影響を分離する
ことは保証されません。
@param width ラベルの幅を... -
Benchmark
:: FORMAT -> String (9517.0) -
Benchmark.#benchmark の第三引数のデフォルト値。
Benchmark.#benchmark の第三引数のデフォルト値。
: %u
user CPU time で置き換えられます。Benchmark::Tms#utime
: %y
system CPU time で置き換えられます(Mnemonic: y of "s*y*stem")。Benchmark::Tms#stime
: %U
子プロセスの user CPU time で置き換えられます。Benchmark::Tms#cutime
: %Y
子プロセスの system CPU time で置き換えられます。Benchmark::Tms#cstime
: %t
t... -
Process
:: Tms # cstime=(n) (9304.0) -
終了した子プロセスのシステム CPU 時間の合計(秒)をセットします。
終了した子プロセスのシステム CPU 時間の合計(秒)をセットします。 -
Process
:: Tms # cutime=(n) (9304.0) -
終了した子プロセスのユーザー CPU 時間の合計(秒)をセットします。
終了した子プロセスのユーザー CPU 時間の合計(秒)をセットします。 -
Process
:: Tms # stime=(n) (9304.0) -
システム CPU 時間をセットします。
システム CPU 時間をセットします。 -
Process
:: Tms # utime=(n) (9304.0) -
ユーザー CPU 時間をセットします。
ユーザー CPU 時間をセットします。 -
Process
. # clock _ gettime(clock _ id , unit=:float _ second) -> Float | Integer (373.0) -
POSIX の clock_gettime() 関数の時間を返します。
POSIX の clock_gettime() 関数の時間を返します。
例:
p Process.clock_gettime(Process::CLOCK_MONOTONIC) #=> 896053.968060096
@param clock_id クロックの種類を以下の定数のいずれかで指定します。
サポートされている定数は OS やバージョンに依存します。
: Process::CLOCK_REALTIME
SUSv2 to 4, Linux 2.5.63, FreeBSD 3.0, NetBSD 2.0, OpenBSD 2.1, macOS...