How to generate vector with non-linear spacing?
22 vues (au cours des 30 derniers jours)
Afficher commentaires plus anciens
Hello,
I am attempting to generate an array with non-linear spacing between the elements but struggling to figure out a way to impliment this. I need an array x of points spaced from a real, negative value a to a real, positive value b. Ideally the spacing should follow a Gaussian distribution such that many points are clustered about x=0 in the vicinity of some finite width d. Conversely the spacing should be large at the boundaries. More generally it doesn't have to be Gaussian but some guidance on a scheme where I can specify a length d<<|b-a| across which many points should be distributed would be really appreciated.
I tried to work out an algorithm of sorts from pen and paper but it didn't really work and resulted in something that did not appear to be immediately solveable.
Thanks
0 commentaires
Réponse acceptée
John D'Errico
le 14 Août 2024
Modifié(e) : John D'Errico
le 14 Août 2024
It sounds like you want a deterministic, non-random set of points. You can use the inverse gaiussian CDF to do what you want.
a = -2.5;
b = 3;
N = 40;
x = norminv(linspace(normcdf(a),normcdf(b),N));
xline(x,'r')
So most dense at zero, and a density that drops off away from there. I chose limits that are not centered around zero, but had they been centered, the set would be perfectly symmetric.
Of course, you can adjust the speed of fall off, by use of a different variance on the implicit Gaussian.
Plus de réponses (2)
Aquatris
le 14 Août 2024
A = 1;
B = 5;
std = .9; % need to play with this to get desired shape within desired range,
% if too high, it does not become a normal distribution
% if too low, it does not cover the whole A-B range
mean = 3;
step1Result = mean + std * randn(1e3,1); % create random data with mean and std
step2Result = min(max(step1Result,A),B); % make sure they end up in A-B range
hist(step2Result)
ylabel('# of occurence')
xlabel('Data Value')
0 commentaires
Voir également
Catégories
En savoir plus sur Descriptive Statistics dans Help Center et File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!