Filtros Laplaciana - Computer Vision Group

Transcripción

Filtros Laplaciana - Computer Vision Group
Índice
¿Qué es la laplaciana?
ƒ Laplaciana: mide cambios en
ƒ Introducción (15 min.)
• ¿Qué es un borde?
• Pasos en la detección
ƒ Detectores de bordes basados en gradiente (1 h.)
• ¿Qué es gradiente?
• Detectores
9 Detectores de bordes basados en laplaciana (1 h.)
9 ¿Qué es laplaciana?
• Detectores
ƒ Detección de esquinas (45 min.)
• ¿Qué es una esquina?
• Detectores
T5. Detección de bordes
el gradiente
• ≅ Diferencia de gradiente
∇f
Paso por 0
∇2f
Paso por 0
Paso por 0
T5. Detección de bordes
2
¿Qué es la laplaciana?
2ª derivada de f
Filtros Laplaciana
ƒ Convolución: [1 − 2 1]
∂2 f ∂2 f
∇ f ( x, y ) =
+
∂x 2 ∂y 2
2
Laplace
T5. Detección de bordes
2 − 1]
Laplace
inversa
Operadores de Laplace (inverso)
 0 −1 0 
− 1 4 − 1


 0 − 1 0 
fxx(x) = f(x) – f(x-1) – f(x-1) + f(x-2)
fxx(x) = f(x) – 2 f(x-1) + f(x-2)
[− 1
[− 1
Laplace
ƒ Un ejemplo simplificado:
• Gradiente de f
fx(x) = f(x) – f(x-1)
• Laplaciana de f
fxx(x) = fx(x) – fx(x-1)
ƒ Convolución: [1 − 2 1]
∂2 f
∂x 2
f
1
ƒ Laplaciana =
∇ 2 f ( x) =
− 1 − 1 − 1
− 1 8 − 1


− 1 − 1 − 1
Más peso en los pixeles centrales:
 1 −4 1 
− 4 20 − 4


 1 − 4 1 
2 − 1]
Laplace
inversa
3
T5. Detección de bordes
Sensibles
al ruido
4
Laplaciana + imagen original
Laplaciana+imagen original
f
-∇2f
α
(-∇2f
+α·
=
+α·
=
)
f + α (-∇2f )
Realzado de imágenes
(sharpening)
T5. Detección de bordes
5
Filtro LoG: Laplaciana de la Gaussiana
G ( x, y ) = e
6
Filtro LoG: Laplaciana de la Gaussiana
ƒ 2ª derivada de la Gaussiana (Marr-Hildreth, 1980)
= Laplaciana de una gaussiana (LoG)
= Operador de Marr-Hildreth
= Sombrero Mejicano
−
T5. Detección de bordes
ƒ 2ª derivada de la Gaussiana (Marr-Hildreth, 1980)
= Laplaciana de una gaussiana (LoG)
= Operador de Marr-Hildreth
= Sombrero Mejicano
x2 + y2
2σ 2
 x 2 + y 2 − 2σ 2  − x + y2
 e 2σ
∇ G = 
4
σ


2
2
2
T5. Detección de bordes
Gaussiana 1D
7
T5. Detección de bordes
LoG 1D
8
Filtro LoG: Laplaciana de la Gaussiana
Filtro DoG: Diferencia de Gaussianas
ƒ 2ª derivada de la Gaussiana (Marr-Hildreth, 1980)
= Laplaciana de una gaussiana (LoG)
= Operador de Marr-Hildreth
= Sombrero Mejicano
σ1 = 2
Gσ1
σ2 = 10
Gσ2
Gσ2 - Gσ1
Gaussiana 2D
LoG 2D
T5. Detección de bordes
9
T5. Detección de bordes
Filtro DoG: Diferencia de Gaussianas
Índice
ƒ Introducción (15 min.)
• ¿Qué es un borde?
• Pasos en la detección
ƒ Detectores de bordes basados en gradiente (1 h.)
• ¿Qué es gradiente?
• Detectores
ƒ Detectores de bordes basados en laplaciana (1 h.)
• ¿Qué es laplaciana?
9 Detectores
ƒ Detección de esquinas (45 min.)
• ¿Qué es una esquina?
• Detectores
ƒ Diferencia de Gaussianas (DoG)
= Aproximación al filtro LoG
= Restar dos gaussianas de distinta σ
Gσ2
ƒ Empleado en fotografía y la industria
gráfica antes
de la aparición de los ordenadores:
Gσ2 - Gσ1
T5. Detección de bordes
10
11
T5. Detección de bordes
12
Detectores basados en la Laplaciana
Detectores basados en la Laplaciana
ƒ Laplaciana ≅ diferencia de gradiente
• Detectar pasos por cero (zero-crossings)
Pendiente
del paso
por cero
È
cantidad
de cambio
f
∇f
σ2 = 2,
Paso por 0
∇2f
distintos
umbrales
Paso por 0
Paso por 0
Pendientes
significativas
T5. Detección de bordes
13
T5. Detección de bordes
Detectores basados en la Laplaciana
Espacio Escala
ƒ Pendiente del paso por cero relacionada con
1. Suavizado
2. Realzado: Laplaciana
3. Detección:
• Pasos por cero significativos (pico significativo
en la 1a derivada)
4. Estimación con precisión subpixel (opcional)
• Interpolación
∇2f
Demasiado ruidoso Æ no práctico
T5. Detección de bordes
14
15
cantidad de cambio
• Más suavizado Æ menos pendiente
ƒ σ regula la cantidad de suavizado
• σ menor Æ
X
Más sensibilidad al ruido / Más bordes
falsos
X
Más precisión en la localización
• σ mayor Æ
X
Más bordes perdidos / Bordes encontrados
son robustos
X
Menor precisión (deslocalización) / Bordes
cercanos pueden llegar a mezclarse
T5. Detección de bordes
16
Espacio Escala
Espacio Escala
ƒ Solución:
• Filtrar con máscaras de distintos σ
• Analizar el comportamiento de los bordes a
f
diferentes escalas de filtrado
X
σ mayor Æ
bordes robustos,
pero desplazados
X
σ menor Æ
mejor localización
Ruido
∇f
Pasos por 0
significativos
∇2f
Menor precisión
T5. Detección de bordes
17
T5. Detección de bordes
18
Detector de bordes LoG
1. Suavizado: Filtro LoG
2. Realzado:
3. Detección:
• Pasos por cero significativos (pico significativo
σ = 0.6
σ =1
en la 1a derivada)
4. Estimación con precisión subpixel (opcional)
• Demasiado ruidoso Æ no práctico
• Interpolación
σ =2
∇2f
σ =4
T5. Detección de bordes
σ =6
19
T5. Detección de bordes
20
Índice
¿Qué es una esquina?
ƒ Esquina = Intersección de 2 bordes rectos
• Nivel semántico ↑
ƒ Particularmente importantes para:
• Orientar objetos
• Dar medidas de sus dimensiones
ƒ Introducción (15 min.)
• ¿Qué es un borde?
• Pasos en la detección
ƒ Detectores de bordes basados en gradiente (1 h.)
• ¿Qué es gradiente?
• Detectores
ƒ Detectores de bordes basados en laplaciana (1 h.)
• ¿Qué es laplaciana?
• Detectores
9 Detección de esquinas
9 ¿Qué es una esquina?
• Detectores
T5. Detección de bordes
ƒ Detección de esquinas
• Basada en bordes: Bordes Æ contornos Æ
Segmentos rectos Æ intersección de rectas
Segmentos curvos Æ curvatura
• Basada en filtros:
Sin necesidad de
X Filtros específicos
detectar bordes
X Derivadas de 2º orden
X
X
21
T5. Detección de bordes
Índice
Filtros específicos
ƒ Introducción (15 min.)
• ¿Qué es un borde?
• Pasos en la detección
ƒ Detectores de bordes basados en gradiente (1 h.)
• ¿Qué es gradiente?
• Detectores
ƒ Detectores de bordes basados en laplaciana (1 h.)
• ¿Qué es laplaciana?
• Detectores
ƒ Detección de esquinas
• ¿Qué es una esquina?
9 Detectores
T5. Detección de bordes
22
ƒ Máscaras 3x3, con forma de esquina.
5
− 4 5
− 4 5
5 

− 4 − 4 − 4
5
5
5
 − 4 5 − 4

 ...
− 4 − 4 − 4
Hasta 8,
rotaciones de 90º
ƒ Mediante convolución:
• Hallar el máximo de los resultados.
ƒ En el caso ideal, encontraría:
• Todas las esquinas
• Y su orientación (error 22,5º)
23
T5. Detección de bordes
24
Filtros específicos
Basados en derivadas de 2º orden
ƒ En la práctica,
• Las esquinas varían mucho en:
ƒ Consideran variaciones locales en la intensidad,
hasta, al menos, el 2º orden.
ƒ En una esquina:
• Cambia significativamente la dirección del
gradiente, y
• La magnitud del gradiente también es significativa.
Ángulo interno, gradiente de intensidad en los
límites, ...
• En vecindarios mayores (5x5, 7x7,...) no sólo
aumenta el tamaño, sino también el número de
máscaras.
ƒ Conclusión:
• Usar máscaras-esquina es insuficiente.
X
T5. Detección de bordes
25
T5. Detección de bordes
26
Detectores de esquinas
Detectores de esquinas
ƒ Kitchen & Rosenfeld (1982):
• Es esquina si:
X
X
ƒ Kitchen & Rosenfeld (1982):
• Núcleos para las derivadas:
Razón de cambio de la dirección de ∇ > u1
& Magnitud del ∇ > u2
E=
f xx f y2 + f yy f x2 − 2 f xy f x f y
(f
2
x
+ f y2
)
3
2
− 1 0 1
∂ 
= − 1 0 1
∂x 
− 1 0 1
≥ U1
− 1 − 1 − 1
∂ 
=  0 0 0 
∂y
 1 1 1 
fx, fy ÆDerivadas de 1er. Orden
fx ≡
donde:
fx, fy ÆDerivadas de 1er. orden
fxx , fyy , fxy Æ Derivadas de 2o. orden
∂f
∂x
fy ≡
∂f
∂y
fxx , fyy , fxy Æ Derivadas de 2o. orden
f xx ≡
• + Supresión de no-máximos a lo largo de la dirección
∂  ∂f 
 
∂x  ∂x 
f yy ≡
∂  ∂f 
 
∂y  ∂y 
f xy ≡
∂  ∂f 
 
∂x  ∂y 
normal al borde
T5. Detección de bordes
27
T5. Detección de bordes
28
Detectores de esquinas
Detectores de esquinas
ƒ Lipschutz (1969)
• Es esquina si:
X
La curvatura gaussiana de la superficie > u1
K=
donde:
f xx f yy − f xy2
(1 + f
2
x
+ f y2
)
2
≥ U2
fx, fy ÆDerivadas de 1er. orden
fxx , fyy , fxy Æ Derivadas de 2o. orden
• El numerador es el determinante de la matriz
Hessiana
• El denominador es casi la magnitud del gradiente4
(en la práctica, se puede quitar el 1)
T5. Detección de bordes
29
T5. Detección de bordes
Detectores de esquinas
30
Artículos para el trabajo
ƒ Canny, J.; “A computational approach to edge
detection”, IEEE Trans. on PAMI, 8(6): 344-371,
1986.
ƒ Marr, D. and Hildreth, E.; “Theory of edge detection”,
Proc. of the Royal Society of London, Series B, vol.
207: 187-217, 1980.
ƒ Kitchen, P.W. and Rosenfeld, A.; “Grey-level corner
detection”. Pattern Recognition Letters, 1, 95-102,
1982.
T5. Detección de bordes
31
T5. Detección de bordes
32
Bibliografía
ƒ Gonzalo Pajares & Jesús M. De la Cruz, Visión por
Computador: Imágenes digitales y aplicaciones,
Ra-Ma, 2001.
X detección de bordes y esquinas
ƒ Jain, R., Kasturi R. & Schunck, B.G.; Machine Vision,
McGraw-Hill, 1995.
X detección de bordes
T5. Detección de bordes
Fundamentos de Visión por
Computador
Sistemas Informáticos Avanzados
T5. Detección de bordes
33

Documentos relacionados