-def projection(point, line, vector):
- return V(*intersection(g_line(point, point + vector.normal), g_line(*line)))
-
-def job_br1(args):
- X, Y, im_l, a, b, c, d, s, v1, v2, k, hough, size = args
- return [(distance(im_l,
- get_grid(a + X[y] * s * v1,
- b + Y[y] * s * v1,
- c, d, hough, size),
- size), a + X[y] * s * v1, b + Y[y] * s * v1) for y in range(2 *k)]
-
-def job_br2(args):
- X, Y, im_l, a, b, c, d, s, v1, v2, k, hough, size = args
- return [(distance(im_l,
- get_grid(a, b, c + X[y] * s * v2,
- d + Y[y] * s * v2,
- hough, size),
- size), c + X[y] * s * v2, d + Y[y] * s * v2) for y in range(2 *k)]
+def job_4(x, y, w, z, im_l, v1, v2, h1, h2, dv, dh, size):
+ v1 = (v1[0] + x * dv, v1[1] + x)
+ v2 = (v2[0] + y * dv, v2[1] + y)
+ h1 = (h1[0] + w * dh, h1[1] + w)
+ h2 = (h2[0] + z * dh, h2[1] + z)
+ return (distance(im_l, get_grid([v1, v2], [h1, h2], size), size))