why my kernel density function never touches x axes?
1 visualización (últimos 30 días)
Mostrar comentarios más antiguos
Poulomi Ganguli
el 28 de En. de 2021
Respondida: the cyclist
el 28 de En. de 2021
Hello:
I want plot kernel density function with the attached test data. I have used foll. code:
Xgrid1 = linspace(min(X),max(X),1000);
pdfEst_1 = ksdensity(X,Xgrid1,'function','pdf');
plot(Xgrid1,pdfEst_1,'Color','B','linew',1.8);
However, the generated density function never touches the x-axes & always moves up, without any closed bounds. Any possible ways that the generated PDFs touches x - axes?
4 comentarios
the cyclist
el 28 de En. de 2021
Is that what is in the file Test1? Just those 15 data points?
It will depend on the kernel you choose, but the estimated density will be zero (or approach zero) as you move away from where the function has support. You haven't defined any grid points that are far away from where X has support.
Respuesta aceptada
the cyclist
el 28 de En. de 2021
Now that we've clarified some things, let me capture my reply in an actual answer.
The issue is that you have defined your X range to cover only places where the estimated PDF has support, because you actually have some data there. If, instead, you extend the range far enough away from the data, then the estimated PDF will go to zero (or at least approach zero).
For example:
extendRange = (max(X)-min(X))/2;
Xgrid1 = linspace(min(X) - extendRange,max(X) + extendRange,1000);
pdfEst_1 = ksdensity(X,Xgrid1,'function','pdf');
figure
plot(Xgrid1,pdfEst_1,'Color','B','linew',1.8);
Exactly how far out you need to go will depend on the kernel you choose for ksdensity.
0 comentarios
Más respuestas (0)
Ver también
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!