Quero encontrar a linha entre a cor azul e a cinza na figura a seguir:
Mais exatamente, os pontos finais dessa linha.
A transformação Hough é uma escolha? Se sim, como devo configurar a imagem antes de usar o Hough?
Qualquer maneira de resolver isso seria útil.
Respostas:
Em geral, você deseja um detector de borda, como o detector de borda Canny, para esse tipo de problema. A transformação Hough é útil para extrair linhas em vez de arestas.
No entanto, nesse caso específico, é melhor fazer algo como:
já que é uma imagem tão simples.
fonte
Para uma imagem tão simples, um kernel de convolução como o seguinte encontrará as bordas muito bem:
[-1 2 - 1]
Isso gera um único pixel de borda em cada ponto de borda. Sem confusão, sem confusão. Canny está muito envolvido para esse problema. Se você deseja encontrar pontos de aresta para linhas em qualquer ângulo, use um Laplaciano simples, um Laplaciano de Gaussiano (LoG) ou Diferença de Gaussiano (DoG). Sobel e Prewitt também são simples, mas inadequados, pois produzem uma linha de "espessura dupla".
Há uma implementação rápida e maliciosa de Hough descrita aqui: http://www.ic.uff.br/~laffernandes/projects/kht/index.html
Existem também algoritmos "Hough sem parâmetros" que são muito rápidos, mas um pouco complicados de implementar e depurar.
fonte