forked from johnzero7/XNALaraMesh
-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathtiming.py
34 lines (27 loc) · 784 Bytes
/
timing.py
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
import time
import io
import cProfile
import pstats
def profile(fnc):
"""Create decorator function that uses cProfile to profile a function."""
def inner(*args, **kwargs):
pr = cProfile.Profile()
pr.enable()
retval = fnc(*args, **kwargs)
pr.disable()
s = io.StringIO()
sortby = 'cumulative'
ps = pstats.Stats(pr, stream=s).sort_stats(sortby)
ps.print_stats()
print(s.getvalue())
return retval
return inner
def timing(f):
def wrap(*args):
time1 = time.time()
ret = f(*args)
time2 = time.time()
print('%s function took %0.3f ms' % (f.__name__,
(time2 - time1) * 1000.0))
return ret
return wrap