- grids = list(gen_corners(diag1, diag2))
-
- try:
- sc, grid = min(map(lambda g: (score(sum(g, []), data), g), grids))
+ data = sum(points, [])
+ # TODO what if lines are missing?
+ sc = float("inf")
+ grid = None
+ for (line1, line2, c) in cen_lin:
+ diag1 = Line(line1)
+ diag1.points = ransac.filter_near(data, diag1, 2)
+ diag2 = Line(line2)
+ diag2.points = ransac.filter_near(data, diag2, 2)
+
+
+ grids = list(gen_corners(diag1, diag2, min(size) / 3))
+
+ try:
+ new_sc, new_grid = min(map(lambda g: (score(sum(g, []), data), g), grids))
+ if new_sc < sc:
+ sc, grid = new_sc, new_grid
+ except ValueError:
+ pass
+ if grid: