-
Notifications
You must be signed in to change notification settings - Fork 280
/
YR1_hough_transform.py
88 lines (65 loc) · 3.19 KB
/
YR1_hough_transform.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
# https://youtu.be/FxqZ92gVh58
"""
@author: Sreenivas Bhattiprolu
Hough Transform to detect straight lines and measure angles between them.
https://en.wikipedia.org/wiki/Hough_transform
The origin is the top left corner of the original image. X and Y axis are
horizontal and vertical edges respectively. The distance is the minimal
algebraic distance from the origin to the detected line. The angle accuracy
can be improved by decreasing the step size in the theta array.
https://scikit-image.org/docs/dev/auto_examples/edges/plot_line_hough_transform.html#sphx-glr-auto-examples-edges-plot-line-hough-transform-py
Image downloaded from: https://geometryhelp.net/wp-content/uploads/2019/04/intersecting-lines.jpg
Then inverted to dark background.
"""
from skimage.transform import (hough_line, hough_line_peaks)
import numpy as np
import cv2
from matplotlib import pyplot as plt
image = cv2.imread('images/lines1.jpg', 0) #Fails if uses as-is due to bright background.
#Also try lines2 to see how it only picks up straight lines
#Invert images to show black background
image = ~image #Invert the image (only if it had bright background that can confuse hough)
plt.imshow(image, cmap='gray')
# Set a precision of 1 degree. (Divide into 180 data points)
# You can increase the number of points if needed.
tested_angles = np.linspace(-np.pi / 2, np.pi / 2, 180)
# Perform Hough Transformation to change x, y, to h, theta, dist space.
hspace, theta, dist = hough_line(image, tested_angles)
plt.figure(figsize=(10,10))
plt.imshow(hspace)
#Now, to find the location of peaks in the hough space we can use hough_line_peaks
h, q, d = hough_line_peaks(hspace, theta, dist)
#################################################################
#Example ode from skimage documentation to plot the detected lines
angle_list=[] #Create an empty list to capture all angles
# Generating figure 1
fig, axes = plt.subplots(1, 3, figsize=(15, 6))
ax = axes.ravel()
ax[0].imshow(image, cmap='gray')
ax[0].set_title('Input image')
ax[0].set_axis_off()
ax[1].imshow(np.log(1 + hspace),
extent=[np.rad2deg(theta[-1]), np.rad2deg(theta[0]), dist[-1], dist[0]],
cmap='gray', aspect=1/1.5)
ax[1].set_title('Hough transform')
ax[1].set_xlabel('Angles (degrees)')
ax[1].set_ylabel('Distance (pixels)')
ax[1].axis('image')
ax[2].imshow(image, cmap='gray')
origin = np.array((0, image.shape[1]))
for _, angle, dist in zip(*hough_line_peaks(hspace, theta, dist)):
angle_list.append(angle) #Not for plotting but later calculation of angles
y0, y1 = (dist - origin * np.cos(angle)) / np.sin(angle)
ax[2].plot(origin, (y0, y1), '-r')
ax[2].set_xlim(origin)
ax[2].set_ylim((image.shape[0], 0))
ax[2].set_axis_off()
ax[2].set_title('Detected lines')
plt.tight_layout()
plt.show()
###############################################################
# Convert angles from radians to degrees (1 rad = 180/pi degrees)
angles = [a*180/np.pi for a in angle_list]
# Compute difference between the two lines
angle_difference = np.max(angles) - np.min(angles)
print(180 - angle_difference) #Subtracting from 180 to show it as the small angle between two lines