Esta página aún no se ha traducido para esta versión. Puede ver la versión más reciente de esta página en inglés.

illumwhite

La iluminante estimación con el algoritmo White patch Retinex

Descripción

illuminant = illumwhite(A) estima la iluminación de la escena en la imagen RGB asumiendo que los valores más brillantes del 1% de rojo, verde y azul representan el color blanco.A

ejemplo

illuminant = illumwhite(A,topPercentile) estima la iluminación mediante el porcentaje de valores más brillantes de rojo, verde y azul.topPercentile

illuminant = illumwhite(___,Name,Value) estima la iluminación mediante pares nombre-valor para controlar opciones adicionales.

Ejemplos

contraer todo

Abra una imagen y mostrarla. Especifique una ampliación opcional para reducir el tamaño de la imagen mostrada.

A = imread('foosball.jpg'); figure imshow(A,'InitialMagnification',25) title('Original Image')

El formato de archivo JPEG guarda las imágenes en el espacio de color sRGB con corrección gamma. Deshacer la corrección de gamma utilizando la función.rgb2lin

A_lin = rgb2lin(A);

Calcule la iluminación de la escena desde los píxeles superiores al 5% más brillantes. Dado que la imagen de entrada se ha linealizado, la función devuelve la iluminante en el espacio de color RGB lineal.illumwhite

topPercentile = 5; illuminant = illumwhite(A,topPercentile)
illuminant = 1×3

    0.7333    0.8314    1.0000

El tercer coeficiente de es el más grande, que es consistente con el tinte azul de la imagen.illuminant

Corrija los colores proporcionando la iluminante estimada a la función.chromadapt

B_lin = chromadapt(A_lin,illuminant,'ColorSpace','linear-rgb');

Para mostrar la imagen de equilibrio blanco correctamente en la pantalla, aplique la corrección de gamma utilizando la función.lin2rgb

B = lin2rgb(B_lin);

Visualice la imagen corregida, estableciendo la ampliación opcional.

figure imshow(B,'InitialMagnification',25) title(['White-Balanced Image using White Patch with topPercentile=' ...     num2str(topPercentile)])

Argumentos de entrada

contraer todo

Entrada de imagen RGB, especificada como una matriz real, no dispersa,-por--por-3.mn

Tipos de datos: single | double | uint8 | uint16

Percentil de colores más brillantes a utilizar para la estimación de iluminantes, especificado como un escalar numérico en el intervalo [0, 100). Para devolver los valores máximos de rojo, verde y azul, establezca el valor en 0.topPercentile

La imagen indica el valor rojo, verde y azul que se selecciona para estimar la iluminante. La selección es independiente para cada canal de color.

Tipos de datos: single | double | int8 | int16 | int32 | int64 | uint8 | uint16 | uint32 | uint64

Argumentos de par nombre-valor

Especifique pares de argumentos separados por comas opcionales. es el nombre del argumento y es el valor correspondiente. deben aparecer dentro de las cotizaciones.Name,ValueNameValueName Puede especificar varios argumentos de par de nombre y valor en cualquier orden como.Name1,Value1,...,NameN,ValueN

Ejemplo: estima la iluminante de escena utilizando un subconjunto de píxeles en la imagen, seleccionado de acuerdo con una máscara binaria,.illuminant = illumwhite(I,'Mask',m)Im

Máscara de imagen, especificada como el par separado por comas que consta de y una matriz numérica o lógica.'Mask'mn La máscara indica qué píxeles de la imagen de entrada se utilizarán al estimar la iluminante.A El cálculo excluye los píxeles que corresponden a un valor de máscara de 0.A De forma predeterminada, la máscara tiene todos los 1s, y todos los píxeles en se incluyen en la estimación.A

Tipos de datos: single | double | int8 | int16 | int32 | int64 | uint8 | uint16 | uint32 | uint64 | logical

Argumentos de salida

contraer todo

Estimación de la iluminación de la escena, devuelta como un vector de fila numérico de 3 elementos. Los tres elementos corresponden a los valores rojo, verde y azul del iluminante.

Tipos de datos: double

Referencias

[1] Ebner, Marc. "White Patch Retinex." Color Constancy. Chichester, West Sussex: John Wiley & Sons, 2007.

Introducido en R2017b