Ядерная оценка плотности (ЯОП, англ. Kernel Density Estimation, KDE) — это непараметрический способ оценки[en] плотности случайной величины. Ядерная оценка плотности является задачей сглаживания данных, когда делается заключение о совокупности, основываясь на конечных выборках данных. В некоторых областях, таких как обработка сигналов и математическая экономика, метод называется также методом окна Парзена-Розенблатта. Как считается, Эммануэль Парзен и Мюррей Розенблатт независимо создали метод в существующем виде[1][2].
Пусть является одномерной выборкой независимых одинаково распределённых величин, извлечённых из некоторого распределения с неизвестной плотностью ƒ. Наша задача заключается в оценке формы функции ƒ. Её ядерный оценщик плотности равен
где K является ядром, т.е. неотрицательной функцией, а h > 0 является сглаживающим параметром, называемым шириной полосы. Ядро с индексом h называется взвешенным ядром и определяется как . Интуитивно стараются выбрать h как можно меньше, насколько данные это позволяют, однако всегда существует выбор между смещением оценщика и его дисперсией. Выбор полосы пропускания обсуждается более подробно ниже.
Существует ряд наиболее часто используемых ядерных функций: однородная, треугольная, бивзвешенная, тривзвешенная, Епанечникова, нормальная и другие. Ядро Епанечникова оптимально в смысле среднеквадратичной ошибки[3], хотя потеря эффективности для ядер, перечисленных до него, мала[4]. Вследствие удобных математических свойств часто используется нормальное ядро, среднее которого , где является стандартной нормальной функцией плотности.
Построение ядерной оценки плотности находит интерпретацию в областях за пределами оценки плотности[5]. Например, в термодинамике это эквивалентно количеству теплоты, получающеейся, когда ядра оператора теплопроводнсти[en] (фундаментальные решения уравнения теплопроводности) помещаются в каждой точке данных xi. Похожие методы используются для построения дискретных операторов Лапласа в точках облака для обучения на основе многообразий[en].
Ядерные оценки плотности тесно связаны с гистограммами, но могут быть наделены свойствами, такими как гладкость или непрерывность, путём выбора подходящего ядра. Чтобы это увидеть, сравним построение гистограммы и ядерной оценки плотности на этих 6 точках:
1 | 2 | 3 | 4 | 5 | 6 |
---|---|---|---|---|---|
-2,1 | -1,3 | -0,4 | 1,9 | 5,1 | 6,2 |
Для гистограммы горизонтальная ось разделена на подинтервалы, которые покрывают область данных. В этом случае мы имеем 6 отрезков, каждая длины 2. Когда точка данных попадает внутрь отрезка, мы помещаем прямоугольник высоты 1/12. Если в отрезок попадает более одной точки, мы размещаем прямоугольники друг над другом.
Для ядерной оценки плотности мы помещаем нормальное ядро с дисперсией 2,25 (показаны красными пунктирными линиями) для каждой точки данных xi. Ядра суммируются, давая ядерную оценку плотности (сплошная синяя кривая). Гладкость ядерной оценки плотности очевидна при сравнении с дискретностью гистограммы, так как ядерные оценки плотности сходятся быстрее к истинной лежащей в основе плотности для непрерывных случайных величин[6].
Полоса пропускания ядра является свободным параметром, который оказывает сильное влияние на результат оценки. Чтобы показать этот эффект, мы возьмём псевдослучайную выборку из обычного нормального распределения (отражена синими чёрточками на ленточной диаграмме[en] на горизонтальной оси). Серая кривая представляет истинную плотность (нормальная плотность со средним 0 и дисперсией 1). Для сравнения, красная кривая недостаточно сглажена, поскольку она содержит слишком много случайных выбросов, возникающих при использовании полосы пропускания h=0,05, которая слишком мала. Зелёная кривая чрезмерно сглажена, поскольку используемая полоса пропускания h=2 существенно скрывает структуру. Чёрная кривая с полосой пропускания h=0,337 считается оптимально сглаженной, поскольку её оценка плотности близка к истинной плотности.
Наиболее употребительным критерием оптимальности для выбора этого параметра является ожидаемая функция потерь L2, также называемая средним накопленным квадратом ошибки[en] (англ. Mean Integrated Squared Error, MISE):
При слабых допущениях для функции ƒ and K, (ƒ в общем случае является неизвестной вещественной функцией плотности)[1][2], MISE (h)=AMISE(h) + o(1/(nh) + h4), где o является «o» малым. AMISE обозначает «Asymptotic MISE» (асимптотическую MISE), которая состоит из двух ведущих членов
где для функции g, , а ƒ'' является второй производной от ƒ. Минимум этой AMISE является решением дифференциального уравнения
или
Ни AMISE, ни hAMISE формулы не могут быть использованы прямо, поскольку они вовлекают неизвестную функцию плотности ƒ или её вторую производную ƒ'', так что было разработано большое число автоматических, основанных на данных, методов для выбора полосы пропускания. Много обзоров сравнивают эффективность этих методов[7][8][9][10][11][12][13] с общим мнением, что подключаемые выборочные функции[5][14] и функции перекрёстной валидации[15][16][17] наиболее полезны над широкой областью множеств данных.
Подстановка любой полосы пропускания h, которая имеет тот же асимптотический порядок n−1/5 как hAMISE в AMISE даёт , где O — «O» большое. Можно показать, что при слабых предположениях не может существовать непараметрического оценщика, который сходится быстрее, чем ядерный оценщик[18]. Заметим, что скорость n−4/5 меньше, чем типичная скорость сходимости n−1 параметрических методов.
Если полоса пропускания не фиксирована и может меняться в зависимости от места либо величины оценки (balloon оценщик) или величины выборки (поточечный оценщик), получается мощный метод, называемый методом адаптивной ядерной оценки плотности[en].
Выбор полосы пропускания для ядерной оценки плотности с медленно убывающим «хвостом» является относительно трудной задачей[19].
Если используются базовые функции Гаусса для аппроксимации одномерных данных и оцениваемая низлежащая плотность является гауссовой, отимальный выбор для h (то есть полоса пропускания, минимизирующая средний накопленный квадрат ошибки[en]) равна[20]
где является среднеквадратическим отклонением выборки. Аппроксимация называется аппроксимацией нормального распределения, гауссовым распределением или эмпирическим правилом Сильвермана (1986). Хотя это эмпирическое правило вычислительно легко применять, его следует применять с осторожностью, так как оно даёт сильно неточные оценки, когда плотность не близка к нормальной. Например, рассмотрим оценку бимодальной гауссовой смеси:
из выборки с 200 точками. Рисунок справа внизу показывает истинную плотность и две ядерные оценки плотности — одна использует эмпирическое правило выбора полосы, а другая использует выбор полосы, основанный на решении уравнения[5][14]. Оценка на основе эмпирического правила чрезмерно сглажена. Matlab скрипт для примера использует kde.m и дан ниже.
1 % Data
2 randn('seed',1) % Used for reproducibility
3 data=[randn(100,1)-10; randn(100,1)+10]; % Смесь двух нормальных распределений
4 % True
5 phi=@(x) exp(-.5*x.^2)/sqrt(2*pi); % Нормальная плотность
6 tpdf=@(x) phi(x+10)/2+phi(x-10)/2; % Истинная плотность
7 % Kernel
8 h=std(data)*(4/3/numel(data))^(1/5); % Полоса пропускания по эмпирическому правилу Сильвермана
9 kernel=@(x) mean(phi((x-data)/h)/h); % Ядерная плотность
10 kpdf=@(x) arrayfun(kernel,x); % Поэлементное применение
11 % Plot
12 figure(2), clf, hold on
13 x=linspace(-25,+25,1000); % Линейная плотность
14 plot(x,tpdf(x)) % График истинной плотности
15 plot(x,kpdf(x)) % График ядерной плотности с эмпирическим правилом
16 kde(data) % График ядерной плотности с решением уравнения для вычисления полосы
Если дана выборка , естественно оценить характеристическую функцию как
Зная характеристическую функцию, можно найти соответствующую плотность вероятности через формулы преобразования Фурье. Имеется одна трудность применения этой формулы обращения, заключающаяся в том, что это приводит к расходящемуся интегралу, поскольку оценка недостоверна для больших t. Чтобы избежать этой проблемы, оценщик умножается на демпфирующую функцию , которая равна 1 в начале координат, а затем падает до 0 на бесконечности. «Параметр полосы пропускания» h контролирует, насколько мы пытаемся ограничить изменение функции . В частности, когда h мало, будет примерно равно единице для больших t, что означает, что остаётся практически неизменной в наиболее важной области t.
Наиболее употребимым способом выбора функции является либо однородной функцией , которая эффективно означает усечение интервала интегрирования в формуле инвертирования до [−1/h, 1/h], или гауссовой функцией . Когда функция выбрана, может быть применена формула инвертирования и оценщиком плотности будет
где K является преобразованием Фурье демпфирующей функции . Тогда ядерный оценщик плотности совпадает с характеристичекой функцией оценщика плотности.
Неполный список программного обеспечения, реализующих ядерные оценщики плотности:
Pdf
функция.de.lmu.ifi.dbs.elki.math.statistics.kernelfunctions
smooth kdensity
, файл данных может содержать вес и полосу пропускания для каждой точки или полоса пропускания может быть установлена автоматически[21] согласно "эмпирическому правилу Сильвермана" (см. выше).StatsKDE
(добавлена в версии Igor Pro 7.00). Полоса пропускания может быть указана или оценена средними Сильвермана, Скотта или Боуманна и Аззалини. Типы ядер: Епанечникова, бивзвешенные, тривзвешенные, треугошьные, гауссовы и прямоугольные.ksdensity
(Statistics Toolbox). В релизе 2018 года MATLAB, могут быть заданы как полоса пропускания, так и ядерный сглаживатель, включая и другие опции, такие как указание пределов ядерной плотности. Альтернативно, бесплатный пакет для MATLAB, который реализует автоматический выбор полосы пропускания[5], доступен на странице «MATLAB Central File Exchange» для
SmoothKernelDistribution
здесь, а символьная оценка реализована с помощью функции KernelMixtureDistribution
here и обе реализации осуществляют выбор полосы пропускания из представленных данных.g10ba
(доступной на языке Fortran[23] и языке C[24]).kernel_density
(пакет математической экономики).scipy.stats.gaussian_kde
и scipy.signal.parzen
), Statsmodels (KDEUnivariate
и KDEMultivariate
) и Scikit-learn (KernelDensity
) (см. сравнение[25]). KDEpy поддерживает взвешенные данные, и FFT-реализация на порядок быстрее других реализаций.density
в базовой поставке, через bkde
в библиотеке KernSmooth, через ParetoDensityEstimation
в библиотеке AdaptGauss (для оценки плотности распределения Парето), через kde
в библиотеке ks, через dkden
и dbckden
в библиотеке evmix, npudens
в библиотеке np (численные и категоральные данные), sm.density
в библиотеке sm. Для получения реализации функции kde.R
, которая не требует установки какого-либо пакета или библиотеки, см. kde.R. Библиотека btb, предназначенная для городского анализа, реализует ядерную оценку плотности через kernel_smoothing
. proc kde
для оценки одномерных и двумерных ядерных плотностей.kdensity
[26], например histogram x, kdensity
. Альтернативно, доступен бесплатный модуль KDENS пакета Stata здесь, который позволяет оценить 1D- или 2D-функции плотности.KernelDensity()
(см. официальную документацию)
Для улучшения этой статьи желательно: |
Данная страница на сайте WikiSort.ru содержит текст со страницы сайта "Википедия".
Если Вы хотите её отредактировать, то можете сделать это на странице редактирования в Википедии.
Если сделанные Вами правки не будут кем-нибудь удалены, то через несколько дней они появятся на сайте WikiSort.ru .