KernelMixtureDistributionCopy to clipboard.
✖
KernelMixtureDistribution
represents a kernel mixture distribution based on the data values xi.
represents a multivariate kernel mixture distribution based on data values {xi,yi,…}.
represents a kernel mixture distribution with bandwidth bw.
represents a kernel mixture distribution with bandwidth bw and smoothing kernel ker.
Details and Options



- KernelMixtureDistribution returns a DataDistribution object that can be used like any other probability distribution.
- The probability density function for KernelMixtureDistribution for a value
is given by
for a smoothing kernel
and bandwidth parameter
.
- The following bandwidth specifications bw can be given:
-
h bandwidth to use {"Standardized",h} bandwidth in units of standard deviation {"Adaptive",h,s} adaptive bandwidth with initial bandwidth h and sensitivity s Automatic automatically computed bandwidth "name" use a named bandwidth selection method {bwx,bwy,…} separate bandwidth specifications for x, y, etc. - For multivariate densities, h can be a positive definite symmetric matrix.
- For adaptive bandwidths, the sensitivity s must be a real number between 0 and 1 or Automatic. If Automatic is used, s is set to
, where
is the dimensionality of the data.
- Possible named bandwidth selection methods include:
-
"LeastSquaresCrossValidation" uses the method of least-squares cross-validation "Oversmooth" 1.08 times wider than the standard Gaussian "Scott" uses Scott's rule to determine bandwidth "SheatherJones" uses the Sheather–Jones plugin estimator "Silverman" uses Silverman's rule to determine bandwidth "StandardDeviation" uses the standard deviation as bandwidth "StandardGaussian" optimal bandwidth for standard normal data - By default, the "Silverman" method is used.
- For automatic bandwidth computation, constant arrays are assumed to have unit variance.
- The following kernel specifications ker can be given:
-
"Biweight" "Cosine" "Epanechnikov" "Gaussian" "Rectangular" "SemiCircle" "Triangular" "Triweight" func - In order for KernelMixtureDistribution to generate a true density estimate, the function fn should be a valid univariate probability density function.
- By default, the "Gaussian" kernel is used.
- For multivariate densities, the kernel function ker can be specified as product and radial types using {"Product",ker} and {"Radial",ker}, respectively. Product-type kernels are used if no type is specified.
- The precision used for density estimation is the minimum precision given in the bw and data.
- The following options can be given:
-
MaxMixtureKernels Automatic max number of kernels to use - KernelMixtureDistribution can be used with such functions as Mean, CDF, and RandomVariate.
Examples
open allclose allBasic Examples (3)Summary of the most common use cases
Create a kernel density estimate of univariate data:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-215ry

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-eappt7
Use the resulting distribution to perform analysis, including visualizing distribution functions:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-ee5bdw

Compute moments and quantiles:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-dhwfvv


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-o6eund

Create a kernel density estimate of some bivariate data:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-k2stc

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-f7pqnf
Visualize the estimated PDF and CDF:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-cjnijp

Compute covariance and general moments:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-byd32h


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-loyg6l

Create symbolic representations of kernel density estimates:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-mlfra

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-9wlp3
Investigate symbolic properties:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-plznr1


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-bz378y


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-f42lk

Scope (47)Survey of the scope of standard use cases
Basic Uses (8)
Create a kernel density estimate for some data:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-vefz5

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-dnlwni

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-c8hkq3

Compute probabilities from the distribution:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-fnnxjm

Create a kernel density estimate for data with quantities:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-grxfho


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-f6b1i5


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-y0nxue

Increase the bandwidth for smoother estimates:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-hulfhy

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-brcenj

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-hasy8b

Allow the bandwidth to vary adaptively with local density:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-df9h55

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-bi91m1

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-kckrb

Identify features in data to aid in parametric model fitting:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-1q1qe

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-dnonj3

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-qz2i0

The estimate suggests both the form and starting values for maximum likelihood estimation:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-bwaqbx

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-mpden0

Use kernel density estimation in higher dimensions:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-bo1p3a
A four-dimensional kernel density estimate:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-cogznz

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-e2ono


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-goo58l

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-mow3to

Explore properties of kernel density estimators using custom kernel functions:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-bhslqu

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-in5q9v

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-85ylc


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-cb1krc

Specify radial- or product-type kernels for multivariate estimates:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-dlmj1e

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-p4hca4

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-rb7gf

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-danoc6

Distribution Properties (10)
Estimate distribution functions:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-bam7ho

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-dxrnw9

The first few terms of the PDF and CDF:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-lrtz7v


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-ihkpk2

Compute moments of the distribution:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-vxfgd

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-lzmypp


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-bza3ja


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-bsvzok


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-lh69xy


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-g90cqu

Moments can often be computed in closed form:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-c8bs33

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-gegoex

Compute a closed form expression for the variance with a symbolic adaptive bandwidth:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-cqlen

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-dnhhxe


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-eq02g9

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-mqlkdc


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-cd6357


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-i539uw


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-np6e1h


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-g1d58y


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-gzckhy

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-bougd6

Compare with KernelMixtureDistribution:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-741e9

Compute probabilities and expectations:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-gvn55

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-d0wsh2


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-c48x65


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-oyvs74

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-cnun9j


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-mvbzv

Estimate bivariate distribution functions:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-ccq0x0

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-13i7v8

Compute moments of a bivariate distribution:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-c1knu8

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-f529f2


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-ipu2ta


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-kgtfeq


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-ngxk


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-jdej52


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-j5owcf


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-d9q66t


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-ba05vx

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-dc9qit

Bandwidth Selection (19)
Automatically select the bandwidth to use:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-ia3qif

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-dqvq5g
More data yields better approximations to the underlying distribution:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-ii6o09

Explicitly specify the bandwidth to use:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-eqwtlm
Use bandwidths of 0.1 and 1.0:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-dy9ixw
Larger bandwidths yield smoother estimates:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-ws5pc

The bandwidth need not be numeric:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-btblxl

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-diuvtt
The PDF and CDF of the estimate:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-dizedb


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-grrjmm

Specify bandwidths in units of standard deviation:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-depnyr

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-d531rs

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-h06wg0

Allow the bandwidth to vary adaptively with local density:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-jv8p6b
Vary the local sensitivity from 0 (none) to 1 (full):

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-cr9w8c

Setting the sensitivity to Automatic uses where
is the dimension of the data:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-jgkwry

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-d5dhg

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-buo6ew

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-9axrl

Vary the initial bandwidth for an adaptive estimate:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-dlkl59
Specify an initial bandwidth of 1 and 0.1, respectively:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-mdyfo8

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-pohcol

Use any of several automatic bandwidth selection methods:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-dvb67j

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-fd66af

Silverman's method is used by default:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-e5a2a7

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-b6ja4g

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-cqkiix

In the multivariate case, the bandwidth is a symmetric positive definite ×
matrix:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-ffm2zn

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-hspypd
Giving a scalar h effectively uses h IdentityMatrix[p]:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-ii1io2


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-biijph

Specifying diagonal elements d effectively uses DiagonalMatrix[d]:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-bc2yf


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-fo1uow


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-e8hx6p

Any ×
matrix that could be symmetric positive definite can be given:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-flz71i

By default, Silverman's method is used to independently select bandwidths in each dimension:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-cy9kx2

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-cshoz5

Any automated method can be used to independently select diagonal bandwidth elements:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-dpzqqz

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-67jkq

Methods used to estimate the diagonal need not be the same:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-fgdddo
Use adaptive, oversmoothed, and constant bandwidths in the respective dimensions:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-du1qxm
Plot the univariate marginal PDFs:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-xf8rd

Give a scalar value to use the same bandwidth in all dimensions:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-g9z0ey

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-hym7yo

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-c6p729

To use nonzero off-diagonal elements, give a fully specified bandwidth matrix:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-dmyu6e

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-lotjsu

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-dzngw

The bandwidth matrix controls the variance and orientation of individual kernels:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-dvbpqd

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-n9x8i


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-bbkb8z

Fully specified bandwidth matrices:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-93c1y

Some named bandwidth methods follow a rule-of-thumb approach:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-br4ru

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-muv7za

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-e0capz
Formulas for some named bandwidth methods:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-cnklva

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-gjhxaw

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-joaf3n

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-c1yeek

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-c54i18

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-6zzit

The method of least-squares cross-validation:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-cgoqpt
The expectation of the PDF using a Gaussian kernel and bandwidth :

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-bv20rl
The expectation of the PDF of the leave-one-out density estimator:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-qld1jy

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-j1320l
The bandwidth is found by minimizing the least-squares cross-validation function over :

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-g924sl


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-f7yp9s

The method of Sheather and Jones uses a plugin estimator to solve for the bandwidth:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-d3liwb

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-c9a5yi
The Sheather and Jones estimator:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-omehce

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-ciakp3

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-fcq1k8


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-h8hypc

Kernel Functions (10)
Specify any one of several kernel functions:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-fx72d8

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-bf1q2g

Define the kernel function as a pure function:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-egxjti

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-hk6z5g

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-edl7w7

By default, the Gaussian kernel is used:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-c7vz41

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-hl9jua

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-mdsir2

This is equivalent to using the PDF of a NormalDistribution[0,1]:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-em0v4t

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-fkbcoz

Shapes of some univariate kernel functions:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-lwtela

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-f11x9

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-qd3ap

Specify any one of several kernel functions for multivariate data:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-jh4fp6

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-oba6ab

Shapes of some bivariate product kernels:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-es3kr6

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-kunyhu

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-enbbvk

Choose between product- and radial-type kernel functions for multivariate data:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-ja6lzt

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-f0hrhw

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-erjh65

Computation of a single biweight kernel in two dimensions:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-fchpvn

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-eb7d9e

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-pdin4x


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-oezdhr

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-b086a2

Bandwidths have similar effects for both radial- and product-type kernels:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-wt2tc

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-23tje

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-e52vlg
Scalar bandwidths stretch the kernel equally in each dimension:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-x3a0o

Diagonal elements stretch the kernel independently along each axis:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-eq25jx

Nonzero off-diagonal elements change the orientation:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-fvap

The PDFs of the various kernel functions:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-dwnfva
The efficiency of kernels under the assumption of normally distributed data:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-ieaff
The built-in kernel functions all have relatively high statistical efficiency:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-9i88

Options (7)Common values & functionality for each option
MaxMixtureKernels (7)
By default, a kernel is placed at each data point for sample sizes less than 300:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-j3za8i

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-pivp1t

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-f299af

For larger sample sizes, a maximum of 300 uniformly spaced kernels is used by default:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-bf1lc9

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-ek4v2n

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-ycbyk

Specify the maximum number of kernels to use in the estimate:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-oz3ure

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-bf70r1

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-gc5epz

A larger number of kernels gives a better estimate of the underlying distribution:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-doacsb

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-oa46xa

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-oolnbg

Place a kernel at each data point:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-gaaibx

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-nmsuch

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-k79u3l

Vary the bandwidth used for the same number of kernels:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-zz8al7

Specify the number of kernels to use in each dimension for bivariate data:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-dcyfaf
Place at most 10 and 100 kernels, respectively:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-cw9hh4

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-g09ds7

Set a different maximum number of kernels in each dimension:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-fepb7d
Specify a maximum of 5 and 50 kernels, or 50 and 5:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-ciff5t

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-ft80s

Applications (6)Sample problems that can be solved with this function
Compare an estimated density to a theoretical model:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-dk5ufe

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-txkuh
Use an adaptive bandwidth and many mixture kernels when high resolution is desired:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-cnuxr

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-8zdf08

The moments for the model and the estimate are similar:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-djme1n


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-coxp2s

Estimate the distribution of daily point changes for Apple stocks on the NASDAQ:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-bk460m

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-rq8c2
Increase the MaxMixtureKernels option with heavy-tailed data for a smoother estimate:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-b0x82w

Compute the probability of a 10% point change or more on a given day:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-60qum

Estimate the distribution of snowfall in Buffalo, New York:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-u1s9vl


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-gxe106

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-qv12v1

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-5wh2ks

Different bandwidths yield different descriptions of the snowfall distribution:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-nvc6mx

Identify which of six measures might be most useful for identifying counterfeit bank notes:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-xot39u

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-uwbq2d


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-8n44pw

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-9jyixr
Measure 6 appears to best separate the two classes of notes:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-2q2vza

Using measure 6 as a classifier with a cutoff of 140.5 mm, find the probability of misclassification:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-oxx1yr

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-j3ve1a

Find the bandwidth that minimizes the mean squared error (MSE) of the PDF:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-iemh8k

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-leqoz

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-bjepwo


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-g75n0

Use the bandwidth to estimate the PDF:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-cwol1q

KernelMixtureDistribution can be used to create an elliptical distribution. Elliptical distributions are a generalization of multivariate normal distributions:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-hjn1xb

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-degnu
Using NormalDistribution[0,1] for the marginal gives MultinormalDistribution[μ,Σ]:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-c41yr9


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-dvgrns


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-bf4mfc

Some other elliptical distributions:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-ohbsif

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-qfl16j


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-k9aeh

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-cv6lnb

Properties & Relations (9)Properties of the function, and connections to other functions
The resulting density estimate integrates to unity:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-f7d3up

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-dbqbbi

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-gvbxjl

The density is a weighted sum of kernel functions:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-deajr4

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-hsrdj

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-bxq4mh

KernelMixtureDistribution is a consistent estimator of the underlying distribution:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-dmap0e

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-jg554

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-htg8i

The number of kernels actually used will be no larger than the sample size:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-inxt8t
Placing at most 10000 kernels:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-co6yo
The number of terms corresponds to the number of kernels used:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-drsjwd

As the bandwidth approaches infinity, the estimate approaches the shape of the kernel:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-gihbws

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-c26ukj

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-cc6gox

A linear interpolation of KernelMixtureDistribution is SmoothKernelDistribution:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-dux1w3

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-fzn252

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-o0rlly

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-oa0nj9

KernelMixtureDistribution results in a MixtureDistribution of kernels:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-djvebi

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-g7wnne

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-cklsq


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-p1pvy


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-bwr00p

KernelMixtureDistribution works with the values only when the input is a TimeSeries or an EventSeries:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-5cnypl

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-to38xt


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-d86q20


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-gibkjm

KernelMixtureDistribution works with all the values together when the input is a TemporalData:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-ldkb7z

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-h4n01u


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-o8g3s9


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-xderss

Possible Issues (5)Common pitfalls and unexpected behavior
The kernel function needs to be a PDF:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-ntynw1

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-hhe756
The resulting density estimate is not a PDF:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-gfa99x

Automatic adaptive bandwidths may be too small with large samples:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-b8tng6

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-b0cwwi

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-banqjh

Try increasing the initial bandwidth, MaxMixtureKernels, or decreasing the sensitivity:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-b48b8n

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-bh2ths

A kernel must be placed at each data point with symbolic data:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-ekol3y

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-elv074


Set MaxMixtureKernels to All or Automatic:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-bh41p2


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-mu3xf8

Symbolic data cannot be used with the "SheatherJones" and "LeastSquaresCrossValidation" methods:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-vsbmb


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-egbgnm


Specify bandwidths that do not require estimation:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-jg0ysh

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-b8ib2f

Some of the kernel functions are bounded and trigger exclusions in plots:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-c6cnfm

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-bly6jc
Set the Exclusions option to None to avoid spurious gaps and to decrease plot timings:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-ccqse5

Neat Examples (2)Surprising or curious use cases
Use KernelMixtureDistribution to apply a Gaussian blur to a binarized image:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-e4aukj


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-ieqv81

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-5mol4

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-nycxp

Compute a completely symbolic trivariate density estimate:

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-d5c73x


https://wolfram.com/xid/0fom4s94p5k7x7p0lui-en32i3

https://wolfram.com/xid/0fom4s94p5k7x7p0lui-hla6b4

Wolfram Research (2010), KernelMixtureDistribution, Wolfram Language function, https://reference.wolfram.com/language/ref/KernelMixtureDistribution.html (updated 2016).
Text
Wolfram Research (2010), KernelMixtureDistribution, Wolfram Language function, https://reference.wolfram.com/language/ref/KernelMixtureDistribution.html (updated 2016).
Wolfram Research (2010), KernelMixtureDistribution, Wolfram Language function, https://reference.wolfram.com/language/ref/KernelMixtureDistribution.html (updated 2016).
CMS
Wolfram Language. 2010. "KernelMixtureDistribution." Wolfram Language & System Documentation Center. Wolfram Research. Last Modified 2016. https://reference.wolfram.com/language/ref/KernelMixtureDistribution.html.
Wolfram Language. 2010. "KernelMixtureDistribution." Wolfram Language & System Documentation Center. Wolfram Research. Last Modified 2016. https://reference.wolfram.com/language/ref/KernelMixtureDistribution.html.
APA
Wolfram Language. (2010). KernelMixtureDistribution. Wolfram Language & System Documentation Center. Retrieved from https://reference.wolfram.com/language/ref/KernelMixtureDistribution.html
Wolfram Language. (2010). KernelMixtureDistribution. Wolfram Language & System Documentation Center. Retrieved from https://reference.wolfram.com/language/ref/KernelMixtureDistribution.html
BibTeX
@misc{reference.wolfram_2025_kernelmixturedistribution, author="Wolfram Research", title="{KernelMixtureDistribution}", year="2016", howpublished="\url{https://reference.wolfram.com/language/ref/KernelMixtureDistribution.html}", note=[Accessed: 04-April-2025
]}
BibLaTeX
@online{reference.wolfram_2025_kernelmixturedistribution, organization={Wolfram Research}, title={KernelMixtureDistribution}, year={2016}, url={https://reference.wolfram.com/language/ref/KernelMixtureDistribution.html}, note=[Accessed: 04-April-2025
]}