images.geotrans.Warper

Примените то же геометрическое преобразование ко многим изображениям эффективно

Описание

Warper объект применяет affine2d или projective2d геометрическое преобразование к изображениям с определенным размером.

Создание

Описание

пример

w = images.geotrans.Warper(tform,inputSize) создает сновальную машину изображений из объекта tform геометрического преобразования и устанавливает свойство InputSize.

w = images.geotrans.Warper(tform,inputRef) задает систему координат входных изображений, inputRef.

w = images.geotrans.Warper(tform,inputRef,outputRef) задает систему координат выходного изображения, outputRef. Этот синтаксис может использоваться, чтобы улучшать производительность путем ограничения приложения геометрического преобразования к определенной выходной необходимой области.

w = images.geotrans.Warper(sourceX,sourceY) задает входные координаты изображений, sourceX и sourceY, требуемый выполнить геометрическое преобразование.

w = images.geotrans.Warper(___,Name,Value) устанавливает свойства Interpolation и FillValue с помощью одного или нескольких аргументов пары "имя-значение". Заключите каждое имя свойства в одинарные кавычки.

Например, warper = images.geotrans.Warper(tform,size(im),'FillValue',1) задает значение заливки 1 для пикселей вне оригинального изображения.

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

развернуть все

Геометрическое преобразование, заданное как affine2d или projective2d объект геометрического преобразования.

Объект привязки сопоставлен с входным изображением, заданным как imref2d пространственный объект привязки.

Объект привязки сопоставлен с выходным изображением, заданным как imref2d пространственный объект привязки.

Введите координаты изображений, заданные как 2D матрица тот же размер как необходимое выходное изображение. Каждый (x, y) индексирует в sourceX и sourceY задает местоположение во входном изображении для соответствующего выходного пикселя.

Типы данных: single

Свойства

развернуть все

Размер входных изображений, заданных как 2-или вектор с 3 элементами положительных целых чисел.

Размер первых двух размерностей выходного изображения, заданного как вектор с 2 элементами положительных целых чисел.

Метод интерполяции, заданный как 'linear'самый близкий, или 'cubic'.

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

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

Функции объекта

warpПримените геометрическое преобразование

Примеры

свернуть все

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

imds = imageDatastore(fullfile(matlabroot,'toolbox','images','imdata','AT*'));

Создайте геометрическое преобразование, чтобы вращать каждое изображение 45 градусами и уменьшить каждое изображение.

tform = affine2d([ 0.5*cos(pi/4) sin(pi/4)     0;
                  -sin(pi/4)     0.5*cos(pi/4) 0;
                   0             0             1]);

Создайте Warper объект, задавая объект геометрического преобразования, tform, и размер входных изображений.

im = readimage(imds,1);
warper = images.geotrans.Warper(tform,size(im));

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

numFiles = numel(imds.Files);
imr = zeros([warper.OutputSize 1 numFiles],'like',im);

Примените геометрическое преобразование к каждому из входных изображений путем вызова warp функция Warper объект.

for ind = 1:numFiles
    im = read(imds);
    imr(:,:,1,ind) = warp(warper,im);
end

Визуализируйте выходные изображения. (Выключите предупреждающее сообщение об изображениях, масштабируемых для отображения.)

warning('off','images:initSize:adjustingMag')
montage(imr);

Советы

  • Если входные изображения являются изображениями RGB или 3-D полутоновыми изображениями размера m-by-n-by-p, то warp применяет преобразование к каждому цветовому каналу или плоскому p независимо.

Алгоритмы

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

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

Функции

Объекты

Введенный в R2017b