Probability Density Function using ksdensity is not normalized
Mostrar comentarios más antiguos
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 comentario
Ali
el 20 de Ag. de 2014
Respuestas (3)
VladTheInstaller
el 15 de En. de 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
el 21 de Ag. de 2014
0 votos
Why not use hist() or histc() to get the histogram? The histogram is essentially the probability density function.
Youssef Khmou
el 21 de Ag. de 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)
Categorías
Más información sobre Exploration and Visualization en Centro de ayuda y File Exchange.
Productos
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!