ref: 0e76b69fed84458da0a1d414588a3c4b06622c85
converter/vendor/rybakit/msgpack/tests/Perf/Benchmark/DurationBenchmark.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 63 64 65 66 67 68 69 |
<?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 DurationBenchmark implements Benchmark { private $duration; public function __construct($duration) { $this->duration = $duration; } /** * {@inheritdoc} */ public function benchmark(Target $target, Test $test) { $target->sanitize($test); $iterations = $this->measurePerform($target, $test); $overheadTime = $this->measureOverhead($target, $test, $iterations); $extraIterations = round($overheadTime * $iterations / $this->duration); return $iterations + $extraIterations; } public function getInfo() : array { return ['Duration' => $this->duration]; } private function measurePerform(Target $target, Test $test) : int { $iterations = 0; $time = microtime(true) + $this->duration; while (microtime(true) <= $time) { $target->perform($test); ++$iterations; } return $iterations; } private function measureOverhead(Target $target, Test $test, $iterations) : float { $time = microtime(true); for ($i = $iterations; $i; --$i) { $target->calibrate($test); } return microtime(true) - $time; } } |