From 6ee197ab43676d666e7c9a2faaba5bde51009bcd 2013-09-23 19:30:20 From: Thomas Kluyver Date: 2013-09-23 19:30:20 Subject: [PATCH] Merge pull request #4153 from Carreau/timeitobj make timeit return an object that contains values --- diff --git a/IPython/core/magics/execution.py b/IPython/core/magics/execution.py index 92a7cfa..795bbd2 100644 --- a/IPython/core/magics/execution.py +++ b/IPython/core/magics/execution.py @@ -56,6 +56,37 @@ from IPython.utils.warn import warn, error # Magic implementation classes #----------------------------------------------------------------------------- + +class TimeitResult(object): + """ + Object returned by the timeit magic with info about the run. + + Contain the following attributes : + + loops: (int) number of loop done per measurement + repeat: (int) number of time the mesurement has been repeated + best: (float) best execusion time / number + all_runs: (list of float) execusion time of each run (in s) + compile_time: (float) time of statement compilation (s) + + """ + + def __init__(self, loops, repeat, best, all_runs, compile_time, precision): + self.loops = loops + self.repeat = repeat + self.best = best + self.all_runs = all_runs + self.compile_time = compile_time + self._precision = precision + + def _repr_pretty_(self, p , cycle): + unic = u"%d loops, best of %d: %s per loop" % (self.loops, self.repeat, + _format_time(self.best, self._precision)) + p.text(u'') + + + + @magics_class class ExecutionMagics(Magics): """Magics related to code execution, debugging, profiling, etc. @@ -803,9 +834,9 @@ python-profiler package from non-free.""") """Time execution of a Python statement or expression Usage, in line mode: - %timeit [-n -r [-t|-c]] statement + %timeit [-n -r [-t|-c] -q -p

-o] statement or in cell mode: - %%timeit [-n -r [-t|-c]] setup_code + %%timeit [-n -r [-t|-c] -q -p

-o] setup_code code code... @@ -836,6 +867,11 @@ python-profiler package from non-free.""") -p

: use a precision of

digits to display the timing result. Default: 3 + -q: Quiet, do not print result. + + -o: return a TimeitResult that can be stored in a variable to inspect + the result in more details. + Examples -------- @@ -868,7 +904,7 @@ python-profiler package from non-free.""") import timeit - opts, stmt = self.parse_options(line,'n:r:tcp:', + opts, stmt = self.parse_options(line,'n:r:tcp:qo', posix=False, strict=False) if stmt == "" and cell is None: return @@ -877,6 +913,8 @@ python-profiler package from non-free.""") number = int(getattr(opts, "n", 0)) repeat = int(getattr(opts, "r", timeit.default_repeat)) precision = int(getattr(opts, "p", 3)) + quiet = 'q' in opts + return_result = 'o' in opts if hasattr(opts, "t"): timefunc = time.time if hasattr(opts, "c"): @@ -948,13 +986,15 @@ python-profiler package from non-free.""") if timer.timeit(number) >= 0.2: break number *= 10 - - best = min(timer.repeat(repeat, number)) / number - - print u"%d loops, best of %d: %s per loop" % (number, repeat, - _format_time(best, precision)) - if tc > tc_min: - print "Compiler time: %.2f s" % tc + all_runs = timer.repeat(repeat, number) + best = min(all_runs) / number + if not quiet : + print u"%d loops, best of %d: %s per loop" % (number, repeat, + _format_time(best, precision)) + if tc > tc_min: + print "Compiler time: %.2f s" % tc + if return_result: + return TimeitResult(number, repeat, best, all_runs, tc, precision) @skip_doctest @needs_local_scope diff --git a/IPython/core/tests/test_magic.py b/IPython/core/tests/test_magic.py index 7740524..fcf6c8c 100644 --- a/IPython/core/tests/test_magic.py +++ b/IPython/core/tests/test_magic.py @@ -487,7 +487,21 @@ def test_timeit_special_syntax(): # cell mode test _ip.run_cell_magic('timeit', '-n1 -r1', '%lmagic my line2') nt.assert_equal(_ip.user_ns['lmagic_out'], 'my line2') - + +def test_timeit_return(): + """ + test wether timeit -o return object + """ + + res = _ip.run_line_magic('timeit','-n10 -r10 -o 1') + assert(res is not None) + +def test_timeit_quiet(): + """ + test quiet option of timeit magic + """ + with tt.AssertNotPrints("loops"): + _ip.run_cell("%timeit -n1 -r1 -q 1") @dec.skipif(execution.profile is None) def test_prun_special_syntax():