n_timeit: timeit for Nim.
see Lib/timeit for python compatiable APIs
Types
NullaryFunc = concept self self()
- Callable[[], Any] Source Edit
TimeitParam = string | NullaryFunc
- Source Edit
Vars
default_timer = default_timer_defval
- Source Edit
Consts
default_number = 1000000
- Source Edit
default_repeat = 5
- since python 3.7: default value of repeat parameter is changed from 3 to 5. Source Edit
Procs
proc newTimer(stmt: TimeitParam = NullStmt; setup: TimeitParam = NullStmt; timer = default_timer; number = default_number): Timer
- Source Edit
Templates
template repeat(self: Timer; repeat = default_repeat; number = default_number): seq[ float]
- Source Edit
template repeat(stmt: TimeitParam = NullStmt; setup: TimeitParam = NullStmt; timer = default_timer; repeat = default_repeat; number = default_number): seq[float]
- Source Edit
template timeit(repetitions: int; statements: untyped)
-
EXT. unstable.
returns nothing but send output to stdout.
output shows more information than Pythons.
Example:
var i = 0 timeit(10): i.inc assert i == 10
Source Edit template timeit(stmt: TimeitParam = NullStmt; setup: TimeitParam = NullStmt; timer = default_timer; number = default_number): float
-
timeit(stmt, setup, number=1000000) with globals is globals()|locals()
stmt, setup are Callable or str literal
Example:
discard timeit("i.inc", "var i = 0") assert i != 0 proc f() = discard discard timeit(f) proc retf(): int = 1 discard timeit(retf)
Source Edit