ref: bbe9c621a38627a8ce44ee46045f586b8e44704c
converter/vendor/rybakit/msgpack/tests/Perf/Benchmark/IterationBenchmark.php
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 |
<?php /* * This file is part of the rybakit/msgpack.php package. * * (c) Eugene Leonovich <gen.work@gmail.com> * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace MessagePack\Tests\Perf\Benchmark; use MessagePack\Tests\Perf\Target\Target; use MessagePack\Tests\Perf\Test; class IterationBenchmark implements Benchmark { private $iterations; public function __construct($iterations) { $this->iterations = $iterations; } public function benchmark(Target $target, Test $test) { $target->sanitize($test); $overheadTime = $this->measureOverhead($target, $test); $performTime = $this->measurePerform($target, $test); return $performTime - $overheadTime; } public function getInfo() : array { return ['Iterations' => $this->iterations]; } private function measurePerform(Target $target, Test $test) : float { $time = microtime(true); for ($i = $this->iterations; $i; --$i) { $target->perform($test); } return microtime(true) - $time; } private function measureOverhead(Target $target, Test $test) : float { $time = microtime(true); for ($i = $this->iterations; $i; --$i) { $target->calibrate($test); } return microtime(true) - $time; } } |