|
"""Benchmark the qu2cu algorithm performance.""" |
|
|
|
from .qu2cu import * |
|
from fontTools.cu2qu import curve_to_quadratic |
|
import random |
|
import timeit |
|
|
|
MAX_ERR = 0.5 |
|
NUM_CURVES = 5 |
|
|
|
|
|
def generate_curves(n): |
|
points = [ |
|
tuple(float(random.randint(0, 2048)) for coord in range(2)) |
|
for point in range(1 + 3 * n) |
|
] |
|
curves = [] |
|
for i in range(n): |
|
curves.append(tuple(points[i * 3 : i * 3 + 4])) |
|
return curves |
|
|
|
|
|
def setup_quadratic_to_curves(): |
|
curves = generate_curves(NUM_CURVES) |
|
quadratics = [curve_to_quadratic(curve, MAX_ERR) for curve in curves] |
|
return quadratics, MAX_ERR |
|
|
|
|
|
def run_benchmark(module, function, setup_suffix="", repeat=25, number=1): |
|
setup_func = "setup_" + function |
|
if setup_suffix: |
|
print("%s with %s:" % (function, setup_suffix), end="") |
|
setup_func += "_" + setup_suffix |
|
else: |
|
print("%s:" % function, end="") |
|
|
|
def wrapper(function, setup_func): |
|
function = globals()[function] |
|
setup_func = globals()[setup_func] |
|
|
|
def wrapped(): |
|
return function(*setup_func()) |
|
|
|
return wrapped |
|
|
|
results = timeit.repeat(wrapper(function, setup_func), repeat=repeat, number=number) |
|
print("\t%5.1fus" % (min(results) * 1000000.0 / number)) |
|
|
|
|
|
def main(): |
|
"""Benchmark the qu2cu algorithm performance.""" |
|
run_benchmark("qu2cu", "quadratic_to_curves") |
|
|
|
|
|
if __name__ == "__main__": |
|
random.seed(1) |
|
main() |
|
|