Probability Density Function using ksdensity is not normalized
Ältere Kommentare anzeigen
I have a vector "columnA" of N data points. I want to find the PDF. I use:
xi = min(columnA):1e-9:max(columnA);
f = ksdensity(columnA,xi);
plot(xi,f)
But when I use trapz to integrate f:
trapz(f)/length(xi)
the value is too far from 1. Even when increasing the range of xi, I still do not get reasonable value.
1 Kommentar
Ali
am 20 Aug. 2014
Antworten (3)
VladTheInstaller
am 15 Jan. 2017
Actually, the output from ksdensity is normalized, but you will have to use numerical integration along the appropriate space. In your case,
trapz(xi,f)
should be close to 1.
Image Analyst
am 21 Aug. 2014
0 Stimmen
Why not use hist() or histc() to get the histogram? The histogram is essentially the probability density function.
Youssef Khmou
am 21 Aug. 2014
The ksdensity produces a Probability density function, no need to divide by the length of the x vector :
x=randn(200,1);
y=[min(x):0.1:max(x)];
p=ksdensity(x,y);
sum(p)
% plot(y,p)
Kategorien
Mehr zu Exploration and Visualization finden Sie in Hilfe-Center und File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!