understanding hough transform accumulator

863 Views Asked by At

I don't know if I am understanding things wrong or if it's something else. This is how the hough transformation appears to me:

You just go over every pixel and calculate rho and theta with this formula:
r = x.cos(θ) + y.sin(θ)
Most people put this formula in a loop from 0->180 or 0-360.
why?
afterwards you put all the values in the accumulator.

But for some dark and mysterious reason, all the points from a same line will give the same theta and r value. How is this possible? I really don't get it.

I tried it, these were my results: I Just put a straight black horizontal line on an image. The line was 10px long 1px high. So I applied the formula, but Instead of getting 1 place in my accumulator with value 10. I got 5 places with value 10, why?

this is my code if necessary:

int outputImage[400][400];
int accumulator[5000][5000]; //random size
int i,j; 
int r,t;
int x1,y1,x2,y2;

/* PUT ALL VALUES IN ACCU */
         for(i=0;i<imageSize[0];i++)  
            {  
                 for( j=0;j<imageSize[1];j++)  
                 {  
                    if (inputImage[i][j] == 0x00) //just to test everything, formula only applied on the black line
                          { 

                           for( t=0;t<180;t++)  
                           { 
                              r = i  * cos(t) + j*sin(t);
                               accumulator[r][t] ++;                      
                           }   
                     }
                 }  
           }  


/*READ ACCU, and draw lines */
       for (i=0; i<5000;i++)
      {
        for (j=0;j<5000;j++)
        {
           if(accumulator[i][j] >= 10) // If accu value >= tresholdvalue, I believe we have a line
            {
              x1 = accumulator[i][j]  * i / (cos(accumulator[i][j] * j));
              y1 = 0;
              x2 = 0;
              y2 =  accumulator[i][j]  * i / (sin(accumulator[i][j] * j));
           // now i just need to draw all the lines between x1y1 and x2y2
            }
        }
       }

Thanks!

0

There are 0 best solutions below