The Hough process accumulates counts for every white pixel for every possible orientation (for angles from 0 to 179 in 1 deg increments) and distance from the center of the image to the corner (in 1 px increments) and stores the counts in an accumulator matrix of angle vs distance. The size of the accumulator will be 180x(diagonal/2). It then searches this space for peaks in counts and converts the locations of the peaks to slope and intercept in the normal x,y input image space. The slope/intercepts are used to find the endpoints clipped to the bounds of the image. The lines are then drawn. The counts are a measure of the length of the lines
Given a binary edge image, the syntax is as follows
Code: Select all
convert binary_edge_image -background somecolor1 -fill somecolor2 -hough-lines WxH+threshold hough_lines_image
One may extract a text file of just the line endpoints and counts by using the .mvg suffix on the output file.
Code: Select all
convert binary_edge_image -hough-lines WxH+count hough_lines_image.mvg
Here are some examples.
Code: Select all
convert rectangle.png \
\( +clone -canny 0x1+10%+30% -write rectangle_canny.png \
-background none -fill red -stroke red -strokewidth 2 \
-hough-lines 9x9+40 -write rectangle_lines.png \) -composite rectangle_hough.png
data:image/s3,"s3://crabby-images/058df/058dfa2f8b5fa820b05f52ac4ec40bbe73b96d28" alt="Image"
data:image/s3,"s3://crabby-images/8cb2f/8cb2ff8efc55e60dfc55ffa90d9f604681e0be2b" alt="Image"
data:image/s3,"s3://crabby-images/10f01/10f01ffba88bfa3a6bfb21b5921b3b90861f2039" alt="Image"
data:image/s3,"s3://crabby-images/09120/091209947e834ffd4d5971705a2e375148c3989f" alt="Image"
Code: Select all
convert rectangle.png -canny 0x1+10%+30% -hough-lines 9x9+40 rectangle_lines.mvg
Code: Select all
cat rectangle_lines.mvg
# Hough line transform: 9x9+40
viewbox 0 0 276 276
line 158.785,0 -0.564065,276 # 48
line 0,29.4581 276,188.807 # 99
line 0,87.1932 276,246.542 # 97
line 274.255,0 114.906,276 # 48
Code: Select all
convert rectangle.png -canny 0x1+10%+30% -hough-lines 9x9+40 MVG:-
Code: Select all
convert rectangle.png -canny 0x1+10%+30% -fill white -stroke white \
-define hough-lines:accumulator=true -hough-lines 9x9+40 \
-delete 0 -contrast-stretch 0.1% rectangle_accumulator.png
data:image/s3,"s3://crabby-images/4ed4b/4ed4bc4ec7d8a95eef818d928d08e5ad2e3aadb3" alt="Image"
Code: Select all
convert blocks.gif -median 3 \
\( +clone -canny 0x1+10%+25% -write blocks_canny.png \
-background none -fill red -stroke red -strokewidth 2 \
-hough-lines 9x9+30 -write blocks_lines.png \) -composite blocks_hough.png
data:image/s3,"s3://crabby-images/2f3b7/2f3b7c2a850421eb965e22db033df44ef4f7441b" alt="Image"
data:image/s3,"s3://crabby-images/e9241/e9241dd52b91ef5bc3b6edd6031aea0f3ca67e6d" alt="Image"
data:image/s3,"s3://crabby-images/c5052/c5052be3443b9d8d25ed1ad60d8f4c569caac89d" alt="Image"
data:image/s3,"s3://crabby-images/5635f/5635f728e93da20e6d65e68bcbd4b6af00dcc489" alt="Image"
Code: Select all
convert fence.png \
\( +clone -canny 0x1+10%+40% -write fence_canny.png \
-background none -fill red -stroke red -strokewidth 2 \
-hough-lines 9x9+150 -write fence_lines.png \) -composite fence_hough.png
data:image/s3,"s3://crabby-images/3b1ff/3b1ff35145a67e4c08373697dff79764e73d5e56" alt="Image"
data:image/s3,"s3://crabby-images/19aa0/19aa06055b80d2f7784eeaa648927802e5227828" alt="Image"
data:image/s3,"s3://crabby-images/f0868/f0868d764c9eabef370d7da9fe6bf0a1ccb97ad4" alt="Image"
data:image/s3,"s3://crabby-images/1af16/1af16944728601fa486e4756d767a6ca8f7629ed" alt="Image"