Interested Article - Ядерная оценка плотности
- 2020-03-11
- 1
Ядерная оценка плотности ( ЯОП , англ. Kernel Density Estimation , KDE ) — это непараметрический способ плотности случайной величины . Ядерная оценка плотности является задачей сглаживания данных, когда делается заключение о совокупности , основываясь на конечных выборках данных. В некоторых областях, таких как обработка сигналов и математическая экономика , метод называется также методом окна Парзена-Розенблатта . Как считается, Эммануэль Парзен и Мюррей Розенблатт независимо создали метод в существующем виде .
Определение
Пусть является одномерной выборкой независимых одинаково распределённых величин, извлечённых из некоторого распределения с неизвестной плотностью ƒ . Наша задача заключается в оценке формы функции ƒ . Её ядерный оценщик плотности равен
где K является ядром , то есть неотрицательной функцией, а h > 0 является сглаживающим параметром, называемым шириной полосы . Ядро с индексом h называется взвешенным ядром и определяется как . Интуитивно стараются выбрать h как можно меньше, насколько данные это позволяют, однако всегда существует выбор между смещением оценщика и его дисперсией. Выбор полосы пропускания обсуждается более подробно ниже.
Существует ряд наиболее часто используемых ядерных функций : однородная, треугольная, бивзвешенная, тривзвешенная, Епанечникова, нормальная и другие. Ядро Епанечникова оптимально в смысле среднеквадратичной ошибки , хотя потеря эффективности для ядер, перечисленных до него, мала . Вследствие удобных математических свойств часто используется нормальное ядро, среднее которого , где является стандартной нормальной функцией плотности.
Построение ядерной оценки плотности находит интерпретацию в областях за пределами оценки плотности . Например, в термодинамике это эквивалентно количеству теплоты, получающейся, когда (фундаментальные решения уравнения теплопроводности ) помещаются в каждой точке данных x i . Похожие методы используются для построения дискретных операторов Лапласа в точках облака для .
Ядерные оценки плотности тесно связаны с гистограммами , но могут быть наделены свойствами, такими как гладкость или непрерывность, путём выбора подходящего ядра. Чтобы это увидеть, сравним построение гистограммы и ядерной оценки плотности на этих 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 (показаны красными пунктирными линиями) для каждой точки данных x i . Ядра суммируются, давая ядерную оценку плотности (сплошная синяя кривая). Гладкость ядерной оценки плотности очевидна при сравнении с дискретностью гистограммы, так как ядерные оценки плотности сходятся быстрее к истинной лежащей в основе плотности для непрерывных случайных величин .
Выбор полосы пропускания
Полоса пропускания ядра является свободным параметром , который оказывает сильное влияние на результат оценки. Чтобы показать этот эффект, мы возьмём псевдослучайную выборку из обычного нормального распределения (отражена синими чёрточками на на горизонтальной оси). Серая кривая представляет истинную плотность (нормальная плотность со средним 0 и дисперсией 1). Для сравнения, красная кривая недостаточно сглажена , поскольку она содержит слишком много случайных выбросов, возникающих при использовании полосы пропускания h =0,05, которая слишком мала. Зелёная кривая чрезмерно сглажена , поскольку используемая полоса пропускания h =2 существенно скрывает структуру. Чёрная кривая с полосой пропускания h =0,337 считается оптимально сглаженной, поскольку её оценка плотности близка к истинной плотности.
Наиболее употребительным критерием оптимальности для выбора этого параметра является ожидаемая функция потерь L 2 , также называемая ( англ. Mean Integrated Squared Error , MISE):
При слабых предположениях о функциях ƒ и K ( ƒ в общем случае является неизвестной вещественной функцией плотности) , MISE ( h )=AMISE( h ) + o(1/(nh) + h 4 ) , где o является «o» малым . AMISE обозначает «Asymptotic MISE» (асимптотическую MISE), которая состоит из двух ведущих членов
где для функции g , , а ƒ'' является второй производной от ƒ . Для нахождения значения h AMISE , где достигается минимум AMISE, необходимо продифференцировать предыдущее выражение для AMISE по h и получить решение из следующего алгебраического уравнения :
или
Формулы для вычисления AMISE и h AMISE не могут быть использованы прямо, поскольку они включают в себя неизвестную функцию плотности ƒ или её вторую производную ƒ'' , так что было разработано большое число автоматических, основанных на данных, методов для выбора полосы пропускания. Во многих обзорах сравнивается эффективность этих методов с общим мнением, что подключаемые выборочные функции и функции перекрёстной валидации наиболее полезны над широкой областью множеств данных.
Подстановка любой полосы пропускания h , которая имеет тот же асимптотический порядок n −1/5 как h AMISE в AMISE даёт , где O — «O» большое . Можно показать, что при слабых предположениях не может существовать непараметрического оценщика, который сходится быстрее, чем ядерный оценщик . Заметим, что скорость n −4/5 меньше, чем типичная скорость сходимости n −1 параметрических методов.
Если полоса пропускания не фиксирована и может меняться в зависимости от места либо величины оценки ( balloon оценщик) или величины выборки (поточечный оценщик), получается мощный метод, называемый методом .
Выбор полосы пропускания для ядерной оценки плотности с медленно убывающим «хвостом» является относительно трудной задачей .
Эмпирическое правило для выбора полосы пропускания
Если используются базовые функции Гаусса для аппроксимации одномерных данных и оцениваемая низлежащая плотность является гауссовой, оптимальный выбор для h (то есть полоса пропускания, минимизирующая ) равна
где является среднеквадратическим отклонением выборки. Аппроксимация называется аппроксимацией нормального распределения , гауссовым распределением или эмпирическим правилом Сильвермана (1986) . Хотя это эмпирическое правило вычислительно легко применять, его следует применять с осторожностью, так как оно даёт сильно неточные оценки, когда плотность не близка к нормальной. Например, рассмотрим оценку бимодальной гауссовой смеси:
из выборки с 200 точками. Рисунок справа внизу показывает истинную плотность и две ядерные оценки плотности — одна использует эмпирическое правило выбора полосы, а другая использует выбор полосы, основанный на решении уравнения . Оценка на основе эмпирического правила чрезмерно сглажена. Matlab скрипт для примера использует и дан ниже.
% Data
randn('seed',1) % Used for reproducibility
data=[randn(100,1)-10; randn(100,1)+10]; % Смесь двух нормальных распределений
% True
phi=@(x) exp(-.5*x.^2)/sqrt(2*pi); % Нормальная плотность
tpdf=@(x) phi(x+10)/2+phi(x-10)/2; % Истинная плотность
% Kernel
h=std(data)*(4/3/numel(data))^(1/5); % Полоса пропускания по эмпирическому правилу Сильвермана
kernel=@(x) mean(phi((x-data)/h)/h); % Ядерная плотность
kpdf=@(x) arrayfun(kernel,x); % Поэлементное применение
% Plot
figure(2), clf, hold on
x=linspace(-25,+25,1000); % Линейная плотность
plot(x,tpdf(x)) % График истинной плотности
plot(x,kpdf(x)) % График ядерной плотности с эмпирическим правилом
kde(data) % График ядерной плотности с решением уравнения для вычисления полосы
Связь с характеристической функцией оценщика плотности
Если дана выборка , естественно оценить характеристическую функцию как
Зная характеристическую функцию, можно найти соответствующую плотность вероятности через формулы преобразования Фурье . Имеется одна трудность применения этой формулы обращения, заключающаяся в том, что это приводит к расходящемуся интегралу, поскольку оценка недостоверна для больших t . Чтобы избежать этой проблемы, оценщик умножается на демпфирующую функцию , которая равна 1 в начале координат, а затем падает до 0 на бесконечности. «Параметр полосы пропускания» h контролирует, насколько мы пытаемся ограничить изменение функции . В частности, когда h мало, будет примерно равно единице для больших t , что означает, что остаётся практически неизменной в наиболее важной области t .
Наиболее употребимым способом выбора функции является либо однородной функцией , которая эффективно означает усечение интервала интегрирования в формуле инвертирования до [−1/ h , 1/ h ] , или гауссовой функцией . Когда функция выбрана, может быть применена формула инвертирования и оценщиком плотности будет
где K является преобразованием Фурье демпфирующей функции . Тогда ядерный оценщик плотности совпадает с характеристической функцией оценщика плотности.
Статистические реализации
Неполный список программного обеспечения, реализующих ядерные оценщики плотности:
-
В пакете
релиз 4.4 опция
Smoothing
для
функции плотности вероятности
использует KDE, и для выражений возможность доступна как встроенная
Pdf
функция. - На языках C / C++ является библиотекой, которая может быть использована для вычисления ядерной оценки плотности с помощью нормальных ядер. Доступен MATLAB-интерфейс.
- На языке C++ является библиотекой для .
- В программе ядерная оценка плотности реализована с пятью различными ядерными функциями — нормальная, однородная, четвёртого порядка, отрицательно экспоненциальная и треугольная. Доступны процедуры одно- и двуядерной оценки плотности. Ядерная оценка плотности используется также в интерполяционной процедуре Head Bang, в оценке двухмерной функции плотности Journey-to-crime, и оценке трёхмерной байесовой оценке Journey-to-crime.
-
Во фреймворке
ядерные функции плотности можно найти в пакете
de.lmu.ifi.dbs.elki.math.statistics.kernelfunctions
- В продуктах компании ESRI ядерное отображение плотности находится в пакете средств Spatial Analyst и использует ядро четвёртого порядка (бивзвешенное).
- Для программы Excel компания «the Royal Society of Chemistry» создала дополнение для выполнения ядерной оценки плотности, базирующееся на (Техническая сводка 4 Комитета Аналитических методов).
-
В
gnuplot
ядерная оценка плотности реализована опцией
smooth kdensity
, файл данных может содержать вес и полосу пропускания для каждой точки или полоса пропускания может быть установлена автоматически согласно «эмпирическому правилу Сильвермана» (см. выше). - В языке Haskell ядерная плотность реализована в пакете .
-
В системе
ядерная оценка плотности реализована в виде операции
StatsKDE
(добавлена в версии Igor Pro 7.00). Полоса пропускания может быть указана или оценена средними Сильвермана, Скотта или Боуманна и Аззалини. Типы ядер: Епанечникова, бивзвешенные, тривзвешенные, треугольные, гауссовы и прямоугольные. - На языке Java , пакет Weka предоставляет среди прочего другого.
- На языке JavaScript пакет визуализации содержит пакет KDE в пакете science.stats.
- В пакете может быть использовано средство «Distribution platform» для создания одномерной ядерной оценки плотности, а «Fit Y by X platform» может быть использовано для создания двумерной ядерной оценки плотности.
- На языке Julia ядерная оценка плотности реализована в .
-
В программе
MATLAB
ядерная оценка плотности реализована через функцию
ksdensity
(Statistics Toolbox). В релизе 2018 года MATLAB, , включая и другие опции, такие как указание пределов ядерной плотности. Альтернативно, бесплатный пакет для MATLAB, который реализует автоматический выбор полосы пропускания , доступен на странице «MATLAB Central File Exchange» для-
Бесплатный набор средств для MATLAB с реализацией ядерной регрессии, ядерной оценки плотности, ядерной оценки функции риска и многих других доступен на (этот набор является частью книги «Kernel Smoothing in MATLAB» ).
-
В системе
Mathematica
численная оценка ядерного распределения реализована в виде функции
SmoothKernelDistribution
, а символьная оценка реализована с помощью функцииKernelMixtureDistribution
и обе реализации осуществляют выбор полосы пропускания из представленных данных. - Для пакета Minitab компания «the Royal Society of Chemistry» создала макро для осуществления ядерной оценки плотности на основе их (Техническая сводка 4 Комитета Аналитических методов).
-
В
ядерная оценка плотности реализована процедурой
g10ba
(доступной на языке Fortran и языке C ). - В библиотеке методы ядерной плотности на языке C++ фокусируются на дынных из специальной евклидовой группы .
-
В системе
Octave
ядерная оценка плотности реализована возможностью
kernel_density
(пакет математической экономики). - В пакете Origin 2D ядерный график плотности может быть построен с помощью пользовательского интерфейса пакета, а коды двух функций Ksdensity для 1D и Ks2density для 2D могут быть взяты на языках , Python или C .
- На языке Perl реализацию можно найти в модуле
- На языке PHP реализацию можно найти в
-
На языке
Python
существует множество реализаций:
в
, SciPy (
scipy.stats.gaussian_kde
иscipy.signal.parzen
), Statsmodels (KDEUnivariate
иKDEMultivariate
) и Scikit-learn (KernelDensity
) (см. сравнение ). поддерживает взвешенные данные, и FFT-реализация на порядок быстрее других реализаций. -
В
языке R
это реализовано через
density
в базовой поставке, черезbkde
в , черезParetoDensityEstimation
в (для оценки плотности распределения Парето), черезkde
в , черезdkden
иdbckden
в ,npudens
в (численные и категоральные данные),sm.density
в . Для получения реализации функцииkde.R
, которая не требует установки какого-либо пакета или библиотеки, см. . , предназначенная для городского анализа, реализует ядерную оценку плотности черезkernel_smoothing
. -
В системе
может быть использована процедура
proc kde
для оценки одномерных и двумерных ядерных плотностей. -
В пакете
это реализовано в виде
kdensity
, напримерhistogram x, kdensity
. Альтернативно, доступен бесплатный модуль KDENS пакета Stata , который позволяет оценить 1D- или 2D-функции плотности. -
В
Apache Spark
вы можете использовать класс
KernelDensity()
(см. )
См. также
- Ядро (статистика)
- Ядерная регрессия
- (with presentation of other examples)
Примечания
- ↑ , с. 832.
- ↑ , с. 1065.
- , с. 153–158.
- .
- ↑ , с. 2916–2957.
- , с. 605–610.
- . www.mathnet.ru . Дата обращения: 31 января 2022.
- , с. 66–72.
- , с. 251–270.
- , с. 153–176.
- , с. 401–407.
- , с. 225–250, 271–281.
- , с. 575–597.
- , с. 28–37.
- ↑ , с. 683–690.
- , с. 65–78.
- , с. 353–360.
- , с. 1–20.
- , с. 15–29.
- , с. 503–518.
- , с. 48.
- , с. section 13.2.2.
- .
- The Numerical Algorithms Group . NAG Library Manual, Mark 23 . Дата обращения: 16 февраля 2012. 3 апреля 2015 года.
- The Numerical Algorithms Group . NAG Library Manual, Mark 9 . Дата обращения: 16 февраля 2012. Архивировано из 24 ноября 2011 года.
- Vanderplas, Jake (1 декабря 2013). Дата обращения: 12 марта 2014.
- . Дата обращения: 27 октября 2018. 29 августа 2017 года.
Литература
- Rosenblatt M. Remarks on Some Nonparametric Estimates of a Density Function // The Annals of Mathematical Statistics. — 1956. — Т. 27 , вып. 3 . — doi : .
- Parzen E. On Estimation of a Probability Density Function and Mode // . — 1962. — Т. 33 , вып. 3 . — doi : . — .
- Epanechnikov V.A. Non-parametric estimation of a multivariate probability density // Theory of Probability and its Applications. — 1969. — Т. 14 . — doi : .
- Wand M.P, Jones M.C. Kernel Smoothing. — London: Chapman & Hall/CRC, 1995. — ISBN 0-412-55270-1 .
- Botev Z.I., Grotowski J.F., Kroese D.P. Kernel density estimation via diffusion // . — 2010. — Т. 38 , вып. 5 . — doi : . — arXiv : .
- Scott D. On optimal and data-based histograms // Biometrika. — 1979. — Т. 66 , вып. 3 . — doi : .
- Park B. U., Marron J. S. Comparison of data-driven bandwidth selectors // Journal of the American Statistical Association . — 1990. — Т. 85 , вып. 409 . — doi : . — .
- Park B. U., Turlach B. A. // Computational Statistics. — 1992. — Т. 7 . — С. 251–270 .
- Cao R., Cuevas A., Manteiga W. G. A comparative study of several smoothing methods in density estimation // Computational Statistics and Data Analysis. — 1994. — Т. 17 , вып. 2 . — doi : .
- Jones M.C., Marron J.S., Sheather S. J. A brief survey of bandwidth selection for density estimation // Journal of the American Statistical Association. — 1996. — Т. 91 , вып. 433 . — doi : . — .
- Sheather S.J. The performance of six popular bandwidth selection methods on some real data sets (with discussion) // Computational Statistics. — 1992. — Т. 7 .
- Agarwal N., Aluru N.R. // International Journal for Numerical Methods in Engineering. — 2010. — Т. 83 , вып. 5 .
- Xu X., Yan Z., Xu S. // Electric Power Systems Research. — 2015. — Т. 121 . — С. 28–37 .
- Sheather S.J., Jones M.C. A reliable data-based bandwidth selection method for kernel density estimation // Journal of the Royal Statistical Society, Series B. — 1991. — Т. 53 , вып. 3 . — .
- Rudemo M. Empirical choice of histograms and kernel density estimators // Scandinavian Journal of Statistics. — 1982. — Т. 9 , вып. 2 . — .
- Bowman A.W. An alternative method of cross-validation for the smoothing of density estimates // Biometrika. — 1984. — Т. 71 , вып. 2 . — doi : .
- Hall P., Marron J.S., Park B.U. // Probability Theory and Related Fields. — 1992. — Т. 92 . — С. 1–20 . — doi : .
- Wahba G. // . — 1975. — Т. 3 , вып. 1 . — doi : .
- TINE Buch-Larsen. Kernel density estimation for heavy-tailed distributions using the Champernowne transformation // Statistics. — 2005. — Т. 39 , вып. 6 . — doi : .
- Silverman B.W. Density Estimation for Statistics and Data Analysis. — London: Chapman & Hall/CRC, 1986. — ISBN 0-412-24620-1 .
- Philipp K Janert. section 13.2.2 Kernel density estimates // Gnuplot in action : understanding data with graphs. — Connecticut, USA: Manning Publications, 2009. — ISBN 978-1-933988-39-9 .
- Horová I., Koláček J., Zelinka J. Kernel Smoothing in MATLAB: Theory and Practice of Kernel Smoothing. — Singapore: World Scientific Publishing, 2012. — ISBN 978-981-4405-48-5 .
Ссылки
- Короткое введение, где объясняется ядерная оценка плотности как усовершенствование гистограмм.
- Свободное онлайн средство, которое генерирует оптимизированную ядерную оценку плотности на ваших данных.
- вычисляет ядерную оценку плотности для любой выборки для ядер: гауссово, Епанечникова, прямоугольное, треугольное, бивзвешенное, косинусное и optcosine.
- Онлайновый интерактивный пример ядерной оценки плотности. Требует версию NET 3.0 или выше.
- 2020-03-11
- 1