Многомерная дискретная свертка - Multidimensional discrete convolution
При обработке сигналов многомерная дискретная свертка относится к математической операции между двумя функциями ж и грамм на п-мерная решетка, которая порождает третью функцию, также п-размеры. Многомерная дискретная свертка является дискретным аналогом многомерная свертка функций на евклидовом пространстве. Это также частный случай свертка по группам когда группа это группа п-наборы целых чисел.
Определение
Постановка проблемы и основные сведения
Как и в одномерном случае, звездочка используется для обозначения операции свертки. Количество измерений в данной операции отображается в количестве звездочек. Например, M-мерная свертка будет записана с M звездочки. Следующее представляет собой M-мерная свертка дискретных сигналов:
Для сигналов с дискретными значениями эта свертка может быть напрямую вычислена с помощью следующего:
Результирующая выходная область поддержки дискретной многомерной свертки будет определяться на основе размера и областей поддержки двух входных сигналов.
Перечислены несколько свойств оператора двумерной свертки. Обратите внимание, что они также могут быть расширены для сигналов -размеры.
Коммутативная собственность:
Сопутствующее имущество:
Распределительное свойство:
Эти свойства показаны на рисунке ниже. Учитывая некоторый вклад который входит в фильтр с импульсной характеристикой а потом еще один фильтр с импульсной характеристикой , выход определяется как . Предположим, что выход первого фильтра определяется выражением , это означает, что:
Кроме того, эта промежуточная функция затем сворачивается с импульсной характеристикой второго фильтра, и, таким образом, выходной сигнал может быть представлен следующим образом:
Используя свойство ассоциативности, это можно переписать следующим образом:
Это означает, что эквивалентный импульсный отклик для каскадной системы определяется следующим образом:
Аналогичный анализ можно провести на наборе параллельных систем, показанных ниже.
В этом случае ясно, что:
Используя закон распределения, показано, что:
Это означает, что в случае параллельной системы эквивалентный импульсный отклик обеспечивается:
Эквивалентные импульсные характеристики как в каскадных, так и в параллельных системах можно обобщить на системы с -количество фильтров.[1]
Мотивация и приложения
Свертка в одном измерении была мощным открытием, которое позволило вводить и выводить линейную инвариантную относительно сдвига (LSI) систему (см. Теория систем LTI ), чтобы их можно было легко сравнить, если была известна импульсная характеристика системы фильтров. Это понятие переносится и на многомерную свертку, поскольку простое знание импульсной характеристики многомерного фильтра также позволяет проводить прямое сравнение между входом и выходом системы. Это очень важно, поскольку некоторые из сигналов, которые передаются в современном цифровом мире, имеют множество измерений, включая изображения и видео. Подобно одномерной свертке, многомерная свертка позволяет вычислять выходные данные системы LSI для заданного входного сигнала.
Например, рассмотрим изображение, которое передается по беспроводной сети, подверженной оптико-электронным помехам. Возможные источники шума включают ошибки в канальной передаче, аналого-цифровой преобразователь и датчик изображения. Обычно шум, вызванный каналом или датчиком, создает пространственно-независимые высокочастотные компоненты сигнала, которые превращаются в произвольные светлые и темные пятна на фактическом изображении. Чтобы избавить данные изображения от высокочастотного спектрального содержания, его можно умножить на частотную характеристику фильтра нижних частот, который, основываясь на теореме свертки, эквивалентен свертке сигнала во временной / пространственной области на импульсная характеристика фильтра нижних частот. Некоторые импульсные характеристики, которые это делают, показаны ниже.[2]
В дополнение к фильтрации спектрального содержимого многомерная свертка может реализовывать обнаружение границ и сглаживание. Это опять же полностью зависит от значений импульсной характеристики, которая используется для свертки с входным изображением. Типичные импульсные характеристики для обнаружения края показаны ниже.
В дополнение к обработке изображений, многомерная свертка может быть реализована для поддержки множества других приложений. Поскольку фильтры широко распространены в системах цифровой связи, любой системе, которая должна передавать многомерные данные, помогают методы фильтрации. Они используются при обработке видео в реальном времени, анализе нейронных сетей, анализе цифровых геофизических данных и многом другом.[3]
Одним из типичных искажений, которые возникают во время приложений захвата или передачи изображений и видео, является размытие, вызванное процессом фильтрации нижних частот. Введенное размытие можно смоделировать с помощью гауссовой фильтрации нижних частот.
Декомпозиция строки-столбца с разделяемыми сигналами
Разделимые сигналы
Сигнал называется отделяемый если его можно записать как произведение нескольких одномерных сигналов.[1] Математически это выражается следующим образом:
Некоторые легко распознаваемые разделяемые сигналы включают функцию единичного шага и импульсную функцию дельта-дирака.
(функция единичного шага)
(импульсная функция дельта-дирака)
Свертка - это линейная операция. Из этого следует, что многомерная свертка разделяемых сигналов может быть выражена как произведение многих одномерных сверток. Например, рассмотрим случай, когда Икс и час обе разделимые функции.
Применяя свойства отделимости, это можно переписать следующим образом:
Легко видеть, что это сводится к произведению одномерных сверток:
Затем этот вывод можно распространить на свертку двух разделимых M-размерные сигналы следующим образом:
Итак, когда два сигнала разделимы, многомерная свертка может быть вычислена путем вычисления одномерные свертки.
Декомпозиция строки-столбца
Метод строка-столбец может применяться, когда один из сигналов в свертке разделяется. Этот метод использует свойства разделимости для достижения метода вычисления свертки двух многомерных сигналов, который является более эффективным в вычислительном отношении, чем прямое вычисление каждой выборки (при условии, что один из сигналов является разделимым).[4] Ниже показано математическое обоснование подхода декомпозиции строки-столбца (обычно - разделимый сигнал):
Значение теперь можно повторно использовать при оценке других ценности с общим значением :
Таким образом, результирующую свертку можно эффективно вычислить, сначала выполнив операцию свертки для всех строк , а затем во всех его столбцах. Этот подход может быть дополнительно оптимизирован, если учесть, как осуществляется доступ к памяти в процессоре компьютера.
Процессор загрузит данные сигнала, необходимые для данной операции. Для современных процессоров данные будут загружаться из памяти в кэш процессора, который имеет более быстрое время доступа, чем память. Сам кеш разбит на строки. Когда строка кэша загружается из памяти, одновременно загружается несколько операндов данных. Рассмотрим оптимизированный случай, когда строка данных сигнала может полностью уместиться в кэш-памяти процессора. Этот конкретный процессор сможет эффективно получать доступ к данным по строкам, но не по столбцам, поскольку разные операнды данных в одном столбце будут лежать в разных строках кэша.[5] Чтобы воспользоваться преимуществами способа доступа к памяти, более эффективно транспонировать набор данных, а затем ось его по строкам, а не пытаться обращаться к нему по столбцам. Затем алгоритм становится:
- Разделить разделяемый двумерный сигнал в два одномерных сигнала и
- Выполните построчную свертку горизонтальных компонентов сигнала. с помощью чтобы получить
- Транспонируйте вертикальные компоненты сигнала в результате шага 2.
- Выполните построчную свертку транспонированных вертикальных компонентов чтобы получить желаемый результат
Ускорение вычислений за счет декомпозиции строки-столбца
Рассмотрим случай, когда изображение размера проходит через отделяемый фильтр размером . Само изображение не отделимо. Если результат вычисляется с использованием подхода прямой свертки без использования разделимости фильтра, это потребует приблизительно умножения и сложения. Если учесть разделимость фильтра, фильтрацию можно проводить в два этапа. Первый шаг будет иметь умножения и сложения, а второй шаг будет иметь , в результате чего всего или же умножения и сложения.[6] Сравнение вычислительной сложности прямой и разделяемой свертки дается на следующем изображении:
Круговая свертка многомерных дискретных сигналов.
Предпосылка, лежащая в основе подхода круговой свертки к многомерным сигналам, состоит в том, чтобы установить связь между Теорема свертки и Дискретное преобразование Фурье (ДПФ), который можно использовать для вычисления свертки между двумя дискретными сигналами конечной протяженности.[7]
Теорема о свертке в многомерности
Для одномерных сигналов Теорема свертки заявляет, что преобразование Фурье свертки между двумя сигналами равно произведению преобразований Фурье этих двух сигналов. Таким образом, свертка во временной области равна умножению в частотной области. Математически этот принцип выражается следующим образом:
При работе с многомерными сигналами:
Подход круговой свертки
Мотивация использования подхода круговой свертки заключается в том, что он основан на ДПФ. Предпосылка круговой свертки состоит в том, чтобы взять ДПФ входных сигналов, умножить их вместе, а затем взять обратное ДПФ. Необходимо соблюдать осторожность, чтобы использовать достаточно большое ДПФ, чтобы не возникало наложения спектров. ДПФ вычислимо численно при работе с сигналами конечной протяженности. Одним из преимуществ этого подхода является то, что, поскольку он требует использования ДПФ и обратного ДПФ, можно использовать эффективные алгоритмы, такие как Быстрое преобразование Фурье (БПФ). Круговая свертка также может быть вычислена во временной / пространственной области, а не только в частотной области.
Выбор размера ДПФ, чтобы избежать сглаживания
Рассмотрим следующий случай, когда два сигнала конечной протяженности Икс и час принимаются. Для обоих сигналов существует соответствующее ДПФ:
и
Регион поддержки является и и регион поддержки является и .
Линейная свертка этих двух сигналов будет дана как:
за
Результатом будет то, что будет версией результата линейной свертки с пространственным алиасом . Это можно выразить следующим образом:
Затем, чтобы избежать наложения спектров между репликами с пространственным псевдонимом, и должен быть выбран так, чтобы удовлетворять следующим условиям:
Если эти условия выполнены, то результаты круговой свертки будут равны результатам линейной свертки (принимая основной период круговой свертки в качестве области опоры). То есть:
за
Краткое описание процедуры с использованием ДПФ
Таким образом, теорему о свертке и круговую свертку можно использовать следующим образом для достижения результата, равного выполнению линейной свертки:[8]
- выбирать и удовлетворить и
- Обнулить сигналы и так что они оба по размеру
- Вычислить ДПФ обоих и
- Умножьте результаты ДПФ, чтобы получить
- Результат IDFT тогда будет равно результату выполнения линейной свертки двух сигналов
Перекрытие и добавление
Другой метод выполнения многомерной свертки - это перекрыть и добавить подход.Этот метод помогает снизить вычислительную сложность, часто связанную с многомерными свертками из-за огромных объемов данных, присущих современным цифровым системам.[9] Для краткости в качестве примера используется двумерный случай, но те же концепции можно распространить на несколько измерений.
Рассмотрим двумерную свертку с помощью прямого вычисления:
Предполагая, что выходной сигнал имеет N ненулевых коэффициентов, а импульсный отклик имеет M ненулевых отсчетов, это прямое вычисление потребует MN умножений и MN - 1 сложения для вычисления. Вместо этого при использовании БПФ частотная характеристика фильтра и преобразование Фурье входа должны быть сохранены в памяти.[10] Огромные объемы вычислений и чрезмерное использование памяти для хранения создают проблемную проблему по мере добавления дополнительных измерений. Именно здесь на помощь приходит метод перекрытия и добавления свертки.
Разложение на более мелкие блоки свертки
Вместо того, чтобы выполнять свертку блоков информации в целом, информация может быть разбита на более мелкие блоки измерений. Икс что приводит к меньшему количеству БПФ, меньшей вычислительной сложности и меньшему объему памяти. Математически это можно выразить следующим образом:
куда представляет Икс входной сигнал, который представляет собой сумму блочные сегменты, с и .
Для получения выходного сигнала выполняется двумерная свертка:
Замена на приводит к следующему:
Эта свертка добавляет больше сложности, чем прямая свертка; однако, поскольку он интегрирован с быстрой сверткой БПФ, сложение с перекрытием выполняется быстрее и является более эффективным с точки зрения памяти методом, что делает его практичным для больших наборов многомерных данных.
Нарушение процедуры
Позволять иметь размер :
- Разрыв ввода в неперекрывающиеся блоки размеров .
- Нулевая площадка такой, что он имеет размеры () ().
- Используйте DFT, чтобы получить .
- Для каждого входного блока:
- Нулевая площадка иметь размеры () ().
- Возьмите дискретное преобразование Фурье каждого блока, чтобы получить .
- Умножьте, чтобы получить .
- Возьмем обратное дискретное преобразование Фурье получить .
- Находить путем перекрытия и добавления последнего образцы с первым образцы чтобы получить результат.[11]
Графический метод работы
Чтобы нагляднее представить метод сложения с перекрытием, на следующих иллюстрациях этот метод рассматривается графически. Предположим, что вход имеет квадратную опору длиной N как в вертикальном, так и в горизонтальном направлениях, как показано на рисунке ниже. Затем он разбивается на четыре меньших сегмента таким образом, что теперь он состоит из четырех меньших квадратов. Каждый блок совокупного сигнала имеет размеры .
Затем каждый компонент свертывается с импульсной характеристикой фильтра. Обратите внимание, что здесь можно визуализировать преимущество такой реализации, поскольку каждая из этих сверток может быть распараллелена на компьютере, если компьютер имеет достаточно памяти и ресурсов для одновременного хранения и вычислений.
На рисунке ниже первый график слева представляет свертку, соответствующую компоненту входных данных. с соответствующей импульсной характеристикой . Справа от него вход затем сворачивается с импульсной характеристикой .
Тот же процесс выполняется для двух других входных данных соответственно, и они накапливаются вместе, чтобы сформировать свертку. Это изображено слева.
Предположим, что импульсная характеристика фильтра имеет регион поддержки в обоих измерениях. Это означает, что каждая свертка сворачивает сигналы с размерами в обоих и направлений, что приводит к перекрытию (выделено синим), поскольку длина каждой отдельной свертки эквивалентна:
=
в обоих направлениях. Светло-синяя часть коррелирует с перекрытием между двумя соседними свертками, тогда как более темная синяя часть коррелирует с перекрытием между всеми четырьмя свертками. Все эти перекрывающиеся части складываются вместе в дополнение к сверткам, чтобы сформировать комбинированную свертку. .[12]
Перекрытие и сохранение
Метод перекрытия и сохранения, как и метод перекрытия и добавления, также используется для уменьшения вычислительной сложности, связанной с дискретными свертками. Этот метод в сочетании с БПФ позволяет фильтровать огромные объемы данных через цифровую систему, при этом минимизируя необходимое пространство памяти, используемое для вычислений над массивными массивами данных.
Сравнение с перекрытием и сложением
Метод перекрытия и сохранения очень похож на методы перекрытия и добавления с некоторыми заметными исключениями. Метод сложения с перекрытием включает в себя линейную свертку сигналов с дискретным временем, тогда как метод с сохранением перекрытия использует принцип круговой свертки. Кроме того, метод перекрытия и сохранения использует только одноразовое заполнение нулями импульсной характеристики, тогда как метод добавления перекрытия включает заполнение нулями для каждой свертки на каждом входном компоненте. Вместо использования нулевого заполнения для предотвращения сглаживания во временной области, как его аналог с перекрытием-добавлением, overlap-save просто отбрасывает все точки сглаживания и сохраняет предыдущие данные в одном блоке для копирования в свертку для следующего блока.
В одном измерении различия в показателях производительности и хранилища между двумя методами минимальны. Однако в случае многомерной свертки метод сохранения с перекрытием предпочтительнее метода сложения с перекрытием с точки зрения скорости и возможностей хранения.[13] Как и в случае наложения и добавления, процедура вызывает двумерный случай, но может быть легко расширена на все многомерные процедуры.
Нарушение процедуры
Позволять иметь размер :
- Вставлять колонны и строки нулей в начале входного сигнала в обоих измерениях.
- Разделите соответствующий сигнал на перекрывающиеся сегменты размеров ()(), в котором каждый двумерный блок будет перекрываться на .
- Нулевая площадка такой, что он имеет размеры ()().
- Используйте DFT, чтобы получить .
- Для каждого входного блока:
- Возьмите дискретное преобразование Фурье каждого блока, чтобы получить .
- Умножьте, чтобы получить .
- Возьмем обратное дискретное преобразование Фурье получить .
- Избавьтесь от первого для каждого выходного блока .
- Находить прикрепив последний образцы для каждого выходного блока .[11]
Преобразование спирали
Подобно разложению строки-столбца, преобразование спирали вычисляет многомерную свертку путем включения одномерных сверточных свойств и операторов. Однако вместо использования разделимости сигналов он отображает декартово координатное пространство в спиральное координатное пространство, позволяя отображать многомерное пространство в одномерное пространство.
Многомерная свертка с методами одномерной свертки
Чтобы понять преобразование спирали, полезно сначала понять, как многомерная свертка может быть разбита на одномерную свертку. Предположим, что два сигнала для свертки и , что приводит к выходу . Это выражается следующим образом:
Затем создаются две матрицы, которые заполняют каждый вход нулями в обоих измерениях, так что каждый вход имеет эквивалентные размеры, т.е.
и
где каждая из входных матриц теперь имеет размеры . Затем можно реализовать лексикографическое упорядочение по столбцам, чтобы преобразовать модифицированные матрицы в векторы, и . Чтобы минимизировать количество неважных выборок в каждом векторе, каждый вектор усекается после последней выборки в исходных матрицах. и соответственно. Учитывая это, длина вектора и даны:
+
+
Длина свертки этих двух векторов, , может быть получено и показано как:
Длина этого вектора эквивалентна размерам исходной выходной матрицы. , что делает преобразование обратно в матрицу прямым преобразованием. Таким образом, вектор, , преобразуется обратно в матричную форму, которая дает результат двумерной дискретной свертки.[14]
Фильтрация по спирали
При работе с двумерной декартовой сеткой преобразование Фурье по любой из осей приведет к тому, что двумерная плоскость станет цилиндром, поскольку конец каждого столбца или строки присоединяется к соответствующей вершине, образуя цилиндр. Фильтрация по спирали ведет себя аналогичным образом, за исключением того, что в этом случае нижняя часть каждого столбца присоединяется к верху следующего столбца, в результате чего получается спиральная сетка. Это проиллюстрировано ниже. Затемненные плитки представляют коэффициенты фильтра.
Если эту спиральную структуру затем разрезать и развернуть в одномерную полосу, те же коэффициенты фильтра на 2-мерной декартовой плоскости будут совпадать с теми же входными данными, что приведет к эквивалентной схеме фильтрации. Это гарантирует, что двумерная свертка сможет быть выполнена оператором одномерной свертки, поскольку двумерный фильтр был развернут в одномерный фильтр с пропусками нулей, разделяющими коэффициенты фильтра.
Предполагая, что использовался какой-то двухмерный фильтр нижних частот, например:
0 | -1 | 0 |
-1 | 4 | -1 |
0 | -1 | 0 |
Затем, как только двумерное пространство было преобразовано в спираль, одномерный фильтр будет выглядеть следующим образом:
Обратите внимание на то, что в одномерном фильтре нет ведущих нулей, как показано на одномерной полосе фильтрации после разматывания. Всю одномерную полосу можно было бы свернуть; однако игнорировать начальные нули проще с точки зрения вычислений. Кроме того, ни одно из этих обратных нулевых значений не нужно хранить в памяти, что позволяет экономить драгоценные ресурсы памяти.[15]
Приложения
Преобразования спирали для реализации рекурсивных фильтров посредством свертки используются в различных областях обработки сигналов. Хотя анализ Фурье в частотной области эффективен, когда системы являются стационарными, с постоянными коэффициентами и периодически дискретизируемыми данными, в нестабильных системах он становится более трудным. Преобразование спирали позволяет выполнять трехмерные процессы миграции после суммирования, которые могут обрабатывать данные для трехмерных изменений скорости.[15] Кроме того, его можно применять для решения проблемы неявной экстраполяции трехмерного волнового поля.[16] Другие приложения включают полезные алгоритмы регуляризации сейсмических данных, фильтры ошибок прогнозирования и ослабление шума в геофизических цифровых системах.[14]
Гауссова свертка
Одно из применений многомерной свертки, которое используется при обработке сигналов и изображений, - это свертка по Гауссу. Это относится к свертке входного сигнала с функцией распределения Гаусса.
Распределение Гаусса, полученное с дискретными значениями в одном измерении, дается следующим образом (при условии, что ):
Аппроксимация КИХ-фильтром
Гауссова свертка может быть эффективно аппроксимирована с помощью реализации Конечный импульсный отклик (FIR) фильтр. Фильтр будет разработан с усеченными версиями Гаусса. Для двумерного фильтра передаточная функция такого фильтра будет определяться следующим образом:[17]
куда
Выбор более низких значений для и приведет к выполнению меньшего количества вычислений, но даст менее точное приближение, в то время как выбор более высоких значений даст более точное приближение, но потребует большего количества вычислений.
Аппроксимация коробчатым фильтром
Другой метод аппроксимации гауссовой свертки - это рекурсивные проходы через блочный фильтр. Для аппроксимации одномерной свертки этот фильтр определяется следующим образом:[17]
Обычно рекурсивные проходы выполняются 3, 4 или 5 раз, чтобы получить точное приближение.[17] Предлагаемый метод расчета р тогда дается как следующее:[18]
куда K - количество рекурсивных проходов через фильтр.
Затем, поскольку распределение Гаусса разделяется по разным измерениям, из этого следует, что рекурсивные проходы через одномерные фильтры (изолирующие каждое измерение отдельно), таким образом, приведут к приближению многомерной свертки Гаусса. То есть, М-мерная гауссова свертка может быть аппроксимирована рекурсивными проходами через следующие одномерные фильтры:
Приложения
Гауссовы свертки широко используются при обработке сигналов и изображений. Например, размытие изображения может быть выполнено с помощью гауссовой свертки, где Параметр будет контролировать силу размытия. Таким образом, более высокие значения будут соответствовать более размытому конечному результату.[19] Он также обычно используется в Компьютерное зрение такие приложения, как Масштабно-инвариантное преобразование признаков (SIFT) обнаружение функции.[20]
Смотрите также
Рекомендации
- ^ а б Даджен, Дэн; Мерсеро, Рассел (1983), Многомерная цифровая обработка сигналов, Prentice-Hall, стр. 21–22.
- ^ "МРАМОР: Интерактивное видение". homepages.inf.ed.ac.uk. Получено 2015-11-12.
- ^ «Редизайн цифрового геофизического анализа». www-rohan.sdsu.edu. Получено 2015-11-12.
- ^ Сихво, Теро; Нийттылахти, Джаркко (5 июня 2005 г.). «Оптимизация двухмерного преобразования на основе декомпозиции строк и столбцов на подсловных параллельных процессорах». Международный симпозиум по сигналам, схемам и системам, 2005 г. ISSCS 2005. 1. С. 99–102. Дои:10.1109 / ISSCS.2005.1509860. ISBN 978-0-7803-9029-4.
- ^ «Введение в кеши». Университет компьютерных наук Мэриленда. Получено 10 ноября 2015.
- ^ Эддинс, Стив. «Разделимая свертка». Математические слова. Получено 10 ноября 2015.
- ^ Даджен, Дэн; Мерсеро, Рассел (1983), Многомерная цифровая обработка сигналов, Прентис-Холл, стр. 70
- ^ Даджен, Дэн; Мерсеро, Рассел (1983), Многомерная цифровая обработка сигналов, Прентис-Холл, стр. 72
- ^ Фернандес, Джозеф; Кумар, Виджая (2013). Многомерное сложение перекрытия и сохранение перекрытия для корреляции и свертки. С. 509–513. Дои:10.1109 / ICIP.2013.6738105. ISBN 978-1-4799-2341-0.
- ^ «Обработка 2D-сигналов» (PDF). EE502: Цифровая обработка сигналов. Дублинский городской университет. п. 24. Получено 11 ноября, 2015.
- ^ а б Кундур, Дипа. "Сохранение внахлест и добавление внахлест" (PDF). Университет Торонто. Получено 12 ноября, 2015.
- ^ «Обработка 2D-сигналов» (PDF). EE502: Цифровая обработка сигналов. Дублинский городской университет. п. 26. Получено 11 ноября, 2015.
- ^ Ким, Чанг; Стринцис, Майкл (май 1980). «Скоростная многомерная свертка». IEEE Transactions по анализу шаблонов и машинному анализу. ПАМИ-2 (3): 269–273. Дои:10.1109 / тпами.1980.4767017.
- ^ а б Нагизаде, Мостафа; Сакки, Маурисио (ноябрь 2009 г.). «Многомерная свертка с помощью алгоритма одномерной свертки». Передний край.
- ^ а б Клаербут, Джон (сентябрь 1998 г.). «Многомерные рекурсивные фильтры по спирали». Геофизика. 63 (5): 9. Bibcode:1998 Геоп ... 63.1532C. CiteSeerX 10.1.1.76.1193. Дои:10.1190/1.1444449.
- ^ Фомель, Сергей; Клаербут, Джон (1997). «Изучение трехмерной неявной экстраполяции волнового поля с помощью спирального преобразования» (PDF). Отчет SEP: 43–60.
- ^ а б c Гетройер, Паскаль (2013). "Обзор алгоритмов гауссовой свертки". Обработка изображений в режиме онлайн. 3: 286–310. Дои:10.5201 / ipol.2013.87.
- ^ Уэллс, W.M. (1986). «Эффективный синтез гауссовых фильтров с помощью каскадных однородных фильтров». IEEE Transactions по анализу шаблонов и машинному анализу. ПАМИ-8 (2): 234–239. Дои:10.1109 / TPAMI.1986.4767776.
- ^ "Размытие по Гауссу - обработка изображений для ученых и инженеров, часть 4". patrick-fuller.com. Получено 2015-11-12.
- ^ Лоу, Д. (1999). «Распознавание объектов по локальным масштабно-инвариантным признакам» (PDF). Материалы Международной конференции по компьютерному зрению. 2: 1150–1157.