+ im_edges = filters.edge_detection(im_l)
+ if show_all:
+ do_something(im_edges, "edge detection")
+
+ im_h = filters.high_pass(im_edges, 100)
+ if show_all:
+ do_something(im_h, "high pass filters")
+
+ if verbose:
+ print >> sys.stderr, "hough transform"
+
+ hough1 = Hough(im_h.size)
+ im_hough = hough1.transform(im_h)
+ if show_all:
+ do_something(im_hough, "hough transform")
+
+ im_hough = filters.peaks(im_hough)
+ if show_all:
+ do_something(im_hough, "peak extraction")
+
+ im_h2 = filters.high_pass(im_hough, 120)
+ if show_all:
+ do_something(im_h2, "second high pass filters")
+
+ im_h2 = filters.components(im_h2)
+ if show_all:
+ do_something(im_h2, "components centers")
+
+ if verbose:
+ print >> sys.stderr, "second hough transform"
+
+ hough2 = Hough(im_h2.size)
+ im_hough2 = hough2.transform(im_h2)
+ if show_all:
+ do_something(im_hough2, "second hough transform")
+
+ im_h3 = filters.high_pass(im_hough2, 120)
+ if show_all:
+ do_something(im_h3, "third high pass filter")
+
+ im_h3 = filters.half_centers(im_h3)
+ if show_all:
+ do_something(im_h3, "half centers")
+
+ if verbose:
+ print >> sys.stderr, "finding the grid"
+
+ lines_m = hough2.all_lines(im_h3)
+ lines = []
+
+ for line in lines_m:
+ im_line = Image.new('L', im_h2.size)
+ draw = ImageDraw.Draw(im_line)
+ draw.line(line_from_angl_dist(line, im_h2.size), fill=255, width=5)
+ if show_all:
+ do_something(im_line, "line")
+ im_c = combine(im_h2, im_line)
+ if show_all:
+ do_something(im_c, "hough x lines")
+ lines.append(hough1.all_lines(im_c))
+
+ intersections = intersections_from_angl_dist(lines, image.size)
+ image_g = image.copy()
+ draw = ImageDraw.Draw(image_g)
+ for line in intersections:
+ for (x, y) in line:
+ draw.point((x , y), fill=(120, 255, 120))