[qu2cu.benchmark] Convert multiple quadratics splines instead of 1

More realistic benchmark.
This commit is contained in:
Behdad Esfahbod 2023-02-20 17:06:06 -07:00
parent 26f590ddaa
commit c77ddcad45

View File

@ -5,23 +5,28 @@ from fontTools.cu2qu import curve_to_quadratic
import random
import timeit
MAX_ERR = 0.05
MAX_ERR = 0.5
NUM_CURVES = 5
def generate_curve():
return [
def generate_curves(n):
points = [
tuple(float(random.randint(0, 2048)) for coord in range(2))
for point in range(4)
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():
curve = generate_curve()
quadratics = curve_to_quadratic(curve, MAX_ERR)
return [quadratics], MAX_ERR
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=10, number=20):
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="")