Skip to content

Benchmark code evaluations for comparing Nock evaluation performance.

License

Notifications You must be signed in to change notification settings

urbit/benchmark

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

17 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Nock Benchmarks

Benchmark code evaluations for comparing Nock evaluation performance.

Benchmarks include:

  • .nock files containing cells of [subject formula]
  • .noun jamfiles of the Nock code.
  • .hoon source files for the Nock code (optional).

Generally speaking, benchmarks should be self-contained; they should not call out to additional libraries or include dependencies on even /sys/hoon. However, we do supply tiny.nock as a compiled version of /lib/tiny from Hoon 139K. This may be preferred for cases (like ackermann) which would otherwise require included more than six arms.

Benchmarks

Supplied

Desired

Reporting

Nock benchmarks supply the subject and the formula as a cell; no arguments are externally specified. In the Urbit Dojo, a benchmark may be run directly as:

=nok -build-file /=benchmark=/bar/ackermann/hoon
~>  %bout  .*(-.nok +.nok)

For cases for which a computation may run unreasonably long, the %jinx hint may be used to time-limit the computation: ~> %jinx.[~s100].

A benchmark report should include the following data:

  1. Hardware (CPU chipset): cat /proc/cpuinfo, then report model name and number of cores (siblings)
  2. Host OS: hostnamectl, then report Operating System and Kernel.
  3. Runtime version: urbit --version, then report major version. (With Vere and Ares developer builds, report the commit hash or release candidate number, etc.)
  4. Statistics: run a given calculation many times, and report $n$, $\max(t)$, $\min(t)$, and mean $\bar{t}$. Include any critical details about the computation (such as range of input arguments).

About

Benchmark code evaluations for comparing Nock evaluation performance.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 3

  •  
  •  
  •  

Languages