This is machine translation

Translated by Microsoft
Mouse over text to see original. Click the button below to return to the English verison of the page.

Fit Kernel Distribution Object to Data

This example shows how to fit a kernel probability distribution object to sample data.

Step 1. Load sample data.

Load the sample data.

load carsmall;

This data contains miles per gallon (MPG) measurements for different makes and models of cars, grouped by country of origin (Origin), model year (Year), and other vehicle characteristics.

Step 2. Fit a kernel distribution object.

Use fitdist to fit a kernel probability distribution object to the miles per gallon (MPG) data for all makes of cars.

pd = fitdist(MPG,'Kernel')
pd = 


    Kernel = normal
    Bandwidth = 4.11428
    Support = unbounded

This creates a prob.KernelDistribution object. By default, fitdist uses a normal kernel smoothing function and chooses an optimal bandwidth for estimating normal densities, unless you specify otherwise. You can access information about the fit and perform further calculations using the related object functions.

Step 3. Compute descriptive statistics.

Compute the mean, median, and standard deviation of the fitted kernel distribution.

m = mean(pd)
med = median(pd)
s = std(pd)
m =


med =


s =


Step 4. Compute and plot the pdf.

Compute and plot the pdf of the fitted kernel distribution.

x = 0:1:60;
y = pdf(pd,x);
title('Miles per Gallon');

The plot shows the pdf of the kernel distribution fit to the MPG data across all makes of cars. The distribution is smooth and fairly symmetrical, although it is slightly skewed with a heavier right tail.

Step 5. Generate random numbers.

Generate a vector of random numbers from the fitted kernel distribution.

rng('default')  % For reproducibility
r = random(pd,1000,1);
set(get(gca,'Children'),'FaceColor',[.8 .8 1]);
hold on;
y = y*5000;  % Scale pdf to overlay on histogram
title('Random Numbers Generated From Distribution');
hold off;

The histogram has a similar shape to the pdf plot because the random numbers generate from the nonparametric kernel distribution fit to the sample data.

See Also

Related Examples

More About

Was this topic helpful?