chromadapt

Настройте цветовой баланс изображения RGB с цветной адаптацией

Описание

пример

B = chromadapt(A,illuminant) настраивает цветовой баланс sRGB отображают A согласно источнику света сцены. Источник света должен быть в том же цветовом пространстве как входное изображение.

пример

B = chromadapt(A,illuminant,Name,Value) настраивает цветовой баланс A использование пар "имя-значение", чтобы управлять дополнительными опциями.

Примеры

свернуть все

Считайте и отобразите изображение с сильным желтым цветовым оттенком.

A = imread('hallway.jpg');
imshow(A)
title('Original Image')

Figure contains an axes object. The axes object with title Original Image contains an object of type image.

Выберите пиксель в изображении, которое должно выглядеть белым или серым, такие как точка на столбе. Не выбирайте влажный пиксель, такой как точка на потолочном светильнике. Отобразите выбранную точку зеленого цвета.

x = 2800;
y = 1000;
gray_val = impixel(A,x,y);
drawpoint('Position',[x y],'Color','g');

Figure contains an axes object. The axes object with title Original Image contains 2 objects of type image, images.roi.point.

Используйте выбранный цвет в качестве ссылки для освещения сцены и откорректируйте баланс белого изображения.

B = chromadapt(A,gray_val);

Отобразите откорректированное изображение. Столбы теперь кажутся белыми как ожидалось, и остальная часть изображения не имеет никакого желтого оттенка.

imshow(B)
title('White-Balanced Image')

Figure contains an axes object. The axes object with title White-Balanced Image contains an object of type image.

Откройтесь файл изображения, содержащий минимально, обработал линейную интенсивность RGB.

A = imread('foosballraw.tiff');

Данные изображения являются необработанными данными о датчике после исправления уровня черного и масштабирования к 16 битам на пиксель. Интерполируйте интенсивность, чтобы восстановить цвет. Диаграмма направленности антенной решетки цветового фильтра является RGGB.

A = demosaic(A,'rggb');

Отобразите изображение. Поскольку изображение находится в линейном цветовом пространстве RGB, примените гамма-коррекцию, таким образом, изображение появляется правильно на экране.

A_sRGB = lin2rgb(A);
imshow(A_sRGB)
title('Original Image')

Figure contains an axes object. The axes object with title Original Image contains an object of type image.

Изображение имеет график X-Rite® ColorChecker® в сцене. Чтобы получить цвет рассеянного света, отобразите значения RGB пикселя в одной из нейтральных закрашенных фигур графика. Интенсивность красного канала ниже, чем интенсивность других двух каналов, которая указывает, что свет синевато-зеленый.

x = 1510;
y = 1250;
light_color = [A(y,x,1) A(y,x,2) A(y,x,3)]
light_color = 1x3 uint16 row vector

    7361   14968   10258

Сбалансируйте цветовые каналы изображения. Используйте 'ColorSpace' опция, чтобы указать, что изображение и источник света описываются в линейном RGB.

B = chromadapt(A,light_color,'ColorSpace','linear-rgb');

Отобразите сбалансированное с цвета изображение с гамма-коррекцией.

B_sRGB = lin2rgb(B);
imshow(B_sRGB)
title('Color-Balanced Image')

Figure contains an axes object. The axes object with title Color-Balanced Image contains an object of type image.

Подтвердите, что серая закрашенная фигура была сбалансированным цветом. Эти три цветовых канала в сбалансированной с цвета серой закрашенной фигуре имеют подобную интенсивность, как ожидалось.

patch_color = [B(y,x,1) B(y,x,2) B(y,x,3)]
patch_color = 1x3 uint16 row vector

   13010   13010   13010

Входные параметры

свернуть все

Изображение RGB в виде m-by-n-by-3 числовой массив.

Типы данных: single | double | uint8 | uint16

Источник света сцены в виде числового вектора с 3 элементами. Источник света должен быть в том же цветовом пространстве как входное изображение, A.

Типы данных: single | double | uint8 | uint16

Аргументы name-value

Задайте дополнительные разделенные запятой пары Name,Value аргументы. Name имя аргумента и Value соответствующее значение. Name должен появиться в кавычках. Вы можете задать несколько аргументов в виде пар имен и значений в любом порядке, например: Name1, Value1, ..., NameN, ValueN.

Пример: I2 = chromadapt(I,uint8([22 97 118]),'ColorSpace','linear-rgb') настраивает цветовой баланс изображения, I, в линейном цветовом пространстве RGB.

Цветовое пространство входного изображения и источника света в виде разделенной запятой пары, состоящей из 'ColorSpace' и 'srgb', 'adobe-rgb-1998', или 'linear-rgb'. Используйте 'linear-rgb' опция, чтобы настроить цветовой баланс RGB отображает, чья интенсивность линейна.

Типы данных: char | string

Цветной метод адаптации раньше масштабировал значения RGB в AВ виде разделенной запятой пары, состоящей из 'Method' и один из:

  • 'bradford'— Шкала с помощью Брэдфордской конической модели ответа

  • 'vonkries'— Шкала с помощью модели ответа конуса фон Криса

  • 'simple'— Шкала с помощью источника света

Типы данных: char | string

Выходные аргументы

свернуть все

Сбалансированное с цвета изображение RGB, возвращенное как m-by-n-by-3 числовой массив совпадающего типа данных как A.

Ссылки

[1] Lindbloom, Брюс. Цветная Адаптация. http://www.brucelindbloom.com/index.html? Eqn_ChromAdapt.html.

Смотрите также

| | | |

Введенный в R2017b