You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
103 lines
3.2 KiB
103 lines
3.2 KiB
#!/usr/bin/env python3 |
|
|
|
# MIT License |
|
# |
|
# Copyright (c) 2023 Eugenio Parodi <ceccopierangiolieugenio AT googlemail DOT com> |
|
# |
|
# Permission is hereby granted, free of charge, to any person obtaining a copy |
|
# of this software and associated documentation files (the "Software"), to deal |
|
# in the Software without restriction, including without limitation the rights |
|
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell |
|
# copies of the Software, and to permit persons to whom the Software is |
|
# furnished to do so, subject to the following conditions: |
|
# |
|
# The above copyright notice and this permission notice shall be included in all |
|
# copies or substantial portions of the Software. |
|
# |
|
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR |
|
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, |
|
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE |
|
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER |
|
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, |
|
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE |
|
# SOFTWARE. |
|
|
|
import sys, os |
|
|
|
import timeit |
|
|
|
sys.path.append(os.path.join(sys.path[0],'../..')) |
|
|
|
testString1 = "1234567890ABCDEFGHI" |
|
|
|
class T1: |
|
def a(self): return 1 |
|
def b(self): return 2 |
|
def c(self): return 3 |
|
def d(self): return 4 |
|
|
|
def process1(txt): |
|
t = T1() |
|
return t.a() + t.b() + t.c() + t.d() |
|
|
|
class T2a: |
|
def a(self): return 1 |
|
class T2b(T2a): |
|
def b(self): return 2 |
|
class T2c(T2b): |
|
def c(self): return 3 |
|
class T2d(T2c): |
|
def d(self): return 4 |
|
class T2(T2d): pass |
|
|
|
def process2(txt): |
|
t = T2() |
|
return t.a() + t.b() + t.c() + t.d() |
|
|
|
class T3a: |
|
def a(self): return 1 |
|
class T3b: |
|
def b(self): return 2 |
|
class T3c: |
|
def c(self): return 3 |
|
class T3d: |
|
def d(self): return 4 |
|
class T3(T3a, T3b, T3c, T3d): pass |
|
|
|
def process3(txt): |
|
t = T3() |
|
return t.a() + t.b() + t.c() + t.d() |
|
|
|
t1 = T1() |
|
t2 = T2() |
|
t3 = T3() |
|
def process4(t): return ( t.a() + t.b() + t.c() + t.d() + |
|
t.a() + t.b() + t.c() + t.d() + |
|
t.a() + t.b() + t.c() + t.d() + |
|
t.a() + t.b() + t.c() + t.d() + |
|
t.a() + t.b() + t.c() + t.d() + |
|
t.a() + t.b() + t.c() + t.d() + |
|
t.a() + t.b() + t.c() + t.d() + |
|
t.a() + t.b() + t.c() + t.d() + |
|
t.a() + t.b() + t.c() + t.d() + |
|
t.a() + t.b() + t.c() + t.d() ) |
|
|
|
|
|
def test1(): return process1(None) |
|
def test2(): return process2(None) |
|
def test3(): return process3(None) |
|
def test4(): return process4(t1) |
|
def test5(): return process4(t2) |
|
def test6(): return process4(t3) |
|
|
|
loop = 100000 |
|
|
|
a={} |
|
|
|
iii = 1 |
|
while (testName := f'test{iii}') and (testName in globals()): |
|
result = timeit.timeit(f'{testName}(*a)', globals=globals(), number=loop) |
|
# print(f"test{iii}) fps {loop / result :.3f} - s {result / loop:.10f} - {result / loop} {globals()[testName](*a)}") |
|
print(f"test{iii:02}) | {result / loop:.10f} sec. | {loop / result : 15.3f} Fps ╞╡-> {globals()[testName](*a)}") |
|
iii+=1 |
|
|
|
|