Размытие по Гауссу - Википедия - Gaussian blur
В обработка изображений, а Размытие по Гауссу (также известный как Гауссово сглаживание) является результатом размытия изображения на Функция Гаусса (назван в честь математика и ученого Карл Фридрих Гаусс ).
Это широко используемый эффект в графическом программном обеспечении, обычно для уменьшения шум изображения и уменьшить детализацию. Визуальный эффект этой техники размытия - плавное размытие, напоминающее вид изображение через полупрозрачный экран, резко отличающийся от боке эффект, производимый расфокусированным объективом или тенью объекта при обычном освещении.
Гауссово сглаживание также используется как этап предварительной обработки в компьютерное зрение алгоритмы для улучшения структур изображения в различных масштабах - см. представление масштабного пространства и реализация масштабного пространства.
Математика
Математически применение размытия по Гауссу к изображению аналогично свертывание изображение с Функция Гаусса. Это также известно как двумерное Преобразование Вейерштрасса. Напротив, свертывание по кругу (т. Е. размытие коробки ) более точно воспроизводит боке эффект.
Поскольку преобразование Фурье если гауссиан является другим гауссовым, применение размытия по Гауссу приводит к уменьшению высокочастотных компонентов изображения; гауссово размытие, таким образом, фильтр нижних частот.
Размытие по Гауссу - это тип фильтров размытия изображения, в котором используется функция Гаусса (которая также выражает нормальное распределение в статистике) для расчета трансформация применить к каждому пиксель на изображении. Формула функции Гаусса в одном измерении:
В двух измерениях это произведение двух таких функций Гаусса, по одной в каждом измерении:
куда Икс расстояние от начала координат по горизонтальной оси, у - расстояние от начала координат по вертикальной оси, а σ это стандартное отклонение распределения Гаусса. При применении в двух измерениях эта формула дает поверхность, контуры находятся концентрические круги с гауссовым распределением от центральной точки.
Значения из этого распределения используются для построения свертка матрица, которая применяется к исходному изображению. Этот процесс свертки визуально проиллюстрирован на рисунке справа. Новое значение каждого пикселя устанавливается на средневзвешенное окрестности этого пикселя. Значение исходного пикселя получает наибольший вес (имеющий наивысшее значение Гаусса), а соседние пиксели получают меньшие веса по мере увеличения их расстояния до исходного пикселя. Это приводит к размытию, которое сохраняет границы и края лучше, чем другие, более однородные фильтры размытия; смотрите также реализация масштабного пространства.
Теоретически функция Гаусса в каждой точке изображения будет отличной от нуля, а это означает, что все изображение должно быть включено в вычисления для каждого пикселя. На практике при вычислении дискретной аппроксимации функции Гаусса пиксели на расстоянии более 3σ имеют достаточно малое влияние, чтобы считаться фактически нулевым. Таким образом, вклад пикселей за пределами этого диапазона можно игнорировать. Как правило, программе обработки изображений требуется только вычислить матрицу с размерами × (куда это функция потолка ), чтобы гарантировать результат, достаточно близкий к результату, полученному по всему распределению Гаусса.
Помимо круговой симметрии, размытие по Гауссу может быть применено к двухмерному изображению как два независимых одномерных вычисления, и поэтому называется отделяемый фильтр. То есть эффект применения двумерной матрицы также может быть достигнут путем применения серии одномерных гауссовых матриц в горизонтальном направлении с последующим повторением процесса в вертикальном направлении. С вычислительной точки зрения это полезное свойство, так как расчет может быть выполнен в время (где час высота и ш ширина; видеть Обозначение Big O ), в отличие от для неразделимого ядра.
Применение последовательных размытий по Гауссу к изображению имеет тот же эффект, что и применение одного большего размытия по Гауссу, радиус которого является квадратным корнем из суммы квадратов фактически примененных радиусов размытия. Например, применение последовательных размытий по Гауссу с радиусами 6 и 8 дает те же результаты, что и применение одного размытия по Гауссу с радиусом 10, поскольку . Из-за этой взаимосвязи время обработки не может быть сэкономлено путем имитации размытия по Гауссу с последовательными, более мелкими размытиями - необходимое время будет по крайней мере таким же большим, как выполнение одного большого размытия.
Размытие по Гауссу обычно используется при уменьшении размера изображения. Когда понижающая дискретизация изображения, обычно перед передискретизацией к изображению применяется фильтр нижних частот. Это необходимо для предотвращения появления ложной высокочастотной информации в субдискретизированном изображении (сглаживание ). Размытие по Гауссу обладает хорошими свойствами, например, не имеет острых краев и, следовательно, не вносит звона в отфильтрованное изображение.
Фильтр нижних частот
Эта секция нуждается в расширении. Вы можете помочь добавляя к этому. (Март 2009 г.) |
Размытие по Гауссу - это фильтр нижних частот, ослабляя высокочастотные сигналы.[3]
Его амплитуда Сюжет Боде (в шкала журнала в частотная область ) это парабола.
Снижение дисперсии
Сколько стоит фильтр Гаусса со стандартным отклонением? сгладить картинку? Другими словами, насколько это снижает стандартное отклонение значений пикселей на картинке? Предположим, что значения пикселей в градациях серого имеют стандартное отклонение. , то после применения фильтра приведенное стандартное отклонение можно аппроксимировать как
- .[нужна цитата ]
Пример гауссовой матрицы
Эта матрица выборки создается путем выборки ядра фильтра Гаусса (с σ = 0,84089642) в средних точках каждого пикселя с последующей нормализацией. Центральный элемент (в [4, 4]) имеет наибольшее значение, симметрично уменьшаясь по мере увеличения расстояния от центра.
Элемент 0,22508352 (центральный) в 1177 раз больше, чем 0,00019117, который находится сразу за пределами 3σ.
Выполнение
Эффект размытия по Гауссу обычно создается путем свертки изображения с FIR ядро гауссовых значений.
На практике лучше всего использовать свойство разделяемости размытия по Гауссу, разделив процесс на два прохода. На первом проходе используется одномерное ядро для размытия изображения только в горизонтальном или вертикальном направлении. Во втором проходе то же одномерное ядро используется для размытия в оставшемся направлении. Результирующий эффект такой же, как при свертке с двумерным ядром за один проход, но требует меньше вычислений.
Дискретность обычно достигается путем дискретизации ядра гауссова фильтра в дискретных точках, обычно в положениях, соответствующих средним точкам каждого пикселя. Это снижает вычислительные затраты, но для очень маленьких ядер фильтров точечная дискретизация функции Гаусса с очень небольшим количеством отсчетов приводит к большой ошибке.
В этих случаях точность поддерживается (с небольшими вычислительными затратами) путем интегрирования функции Гаусса по площади каждого пикселя.[4]
При преобразовании непрерывных значений Гаусса в дискретные значения, необходимые для ядра, сумма значений будет отличаться от 1. Это приведет к затемнению или осветлению изображения. Чтобы исправить это, значения можно нормализовать, разделив каждый член в ядре на сумму всех членов в ядре.
Эффективность FIR снижается для высоких сигм. Существуют альтернативы КИХ-фильтру. К ним относятся очень быстрое множественное коробка размывается, быстрый и точный IIR Детектор края Deriche, "стековое размытие" на основе размытия прямоугольника и многое другое.[5]
Общее использование
Обнаружение края
Гауссово сглаживание обычно используется с обнаружение края. Большинство алгоритмов обнаружения края чувствительны к шуму; 2-мерный лапласовский фильтр, построенный на дискретизации Оператор Лапласа, очень чувствителен к шумной среде.
Использование фильтра размытия по Гауссу перед обнаружением краев направлено на снижение уровня шума в изображении, что улучшает результат следующего алгоритма обнаружения краев. Этот подход обычно называют Лапласиан Гаусса, или фильтрация LoG.[6]
Фотография
Нижний конец цифровые фотоаппараты, в том числе многие мобильный телефон камеры, обычно используют размытие по Гауссу, чтобы скрыть шум изображения вызвано более высоким ISO светочувствительность.
Размытие по Гауссу автоматически применяется как часть изображения Постобработка фотографии с помощью программного обеспечения камеры, что приводит к необратимой потере деталей.[7]
Смотрите также
- Разница гауссианов
- Шум изображения
- Гауссов фильтр
- Пирамида Гаусса
- Бесконечный импульсный отклик (IIR)
- Реализация масштабного пространства
- Медианный фильтр
- Преобразование Вейерштрасса
Примечания и ссылки
- ^ Шапиро, Л.Г. & Stockman, G.C: "Computer Vision", стр. 137, 150. Prentice Hall, 2001
- ^ Марк С. Никсон и Альберто С. Агуадо. Извлечение функций и обработка изображений. Academic Press, 2008, стр. 88.
- ^ а б Р.А. Хаддад и А. Акансу, "Класс быстрых гауссовских биномиальных фильтров для обработки речи и изображений, "IEEE Transactions on Acoustics, Speech, and Signal Processing, vol. 39, pp 723-727, March 1991.
- ^ Эрик Рейнхард. Визуализация с высоким динамическим диапазоном: получение, отображение и освещение на основе изображений. Морган Кауфманн, 2006, стр. 233–234.
- ^ Гетройер, Паскаль (17 декабря 2013 г.). «Обзор алгоритмов гауссовой свертки». Обработка изображений в режиме онлайн. 3: 286–310. Дои:10.5201 / ipol.2013.87. (код документ )
- ^ Фишер, Перкинс, Уокер и Вольфарт (2003). «Пространственные фильтры - лапласиан гауссиана». Получено 2010-09-13.CS1 maint: несколько имен: список авторов (связь)
- ^ Риттер, Франк (24 октября 2013 г.). "Смартфоны-камеры: фото, которые вы хотите увидеть, если хотите, чтобы они были в порядке [Комментарии]". GIGA (на немецком). GIGA Television. Получено 20 сентября 2020.
Bei Fotos, die in der Nacht entstanden sind, Dominiert Pixelmatsch.
внешняя ссылка
- GLSL реализация разделяемого фильтра размытия по Гауссу.
- Пример для Размытие по Гауссу (фильтрация нижних частот), примененное к гравюре и гравюре чтобы удалить детали для сравнения изображений.
- Mathematica GaussianFilter функция
- OpenCV (C ++) GaussianBlur функция