addOption( 'count', "How many time to run a benchmark", false, true ); } public function bench( array $benchs ) { $bench_number = 0; $count = $this->getOption( 'count', 100 ); foreach ( $benchs as $bench ) { // handle empty args if ( !array_key_exists( 'args', $bench ) ) { $bench['args'] = array(); } $bench_number++; $start = microtime( true ); for ( $i = 0; $i < $count; $i++ ) { call_user_func_array( $bench['function'], $bench['args'] ); } $delta = microtime( true ) - $start; // function passed as a callback if ( is_array( $bench['function'] ) ) { $ret = get_class( $bench['function'][0] ) . '->' . $bench['function'][1]; $bench['function'] = $ret; } $this->results[$bench_number] = array( 'function' => $bench['function'], 'arguments' => $bench['args'], 'count' => $count, 'delta' => $delta, 'average' => $delta / $count, ); } } public function getFormattedResults() { $ret = ''; foreach ( $this->results as $res ) { // show function with args $ret .= sprintf( "%s times: function %s(%s) :\n", $res['count'], $res['function'], join( ', ', $res['arguments'] ) ); $ret .= sprintf( " %6.2fms (%6.2fms each)\n", $res['delta'] * 1000, $res['average'] * 1000 ); } return $ret; } }