how to generate random point inside a sphere

24 visualizzazioni (ultimi 30 giorni)
I am trying to generate random points inside a sphere given the radius and the center. If anyone has a sample code or can help me with this, thanks for the help.

Risposta accettata

Torsten
Torsten il 24 Lug 2019
Modificato: Torsten il 24 Lug 2019
R = 3; % radius of the sphere
Xc = 4;
Yc = -4;
Zc = pi; % (Xc,Yc,Zc) center of the sphere
rval = 2*rand(1)-1;
elevation = asin(rval);
azimuth = 2*pi*rand(1);
radius = R*(rand(1))^(1/3);
[x,y,z] = sph2cart(azimuth,elevation,radius);
x=x+Xc
y=y+Yc
z=z+Zc

Più risposte (2)

Najwa Yaminah
Najwa Yaminah il 17 Gen 2020
Modificato: Ashish il 13 Mag 2020
I have an assignment so I try the following code :
function getPoint() {
var d, x, y, z;
do {
x = Math.random() * 2.0 - 1.0;
y = Math.random() * 2.0 - 1.0;
z = Math.random() * 2.0 - 1.0;
d = x*x + y*y + z*z;
} while(d > 1.0);
return {x: x, y: y, z: z};
}
This works well as you can see
  1 Commento
John D'Errico
John D'Errico il 28 Gen 2020
Sigh. Of course, you posted this answer as Python code, when MATLAB code was needed.

Accedi per commentare.


Patricia Sperry
Patricia Sperry il 21 Set 2019
Modificato: Ashish il 13 Mag 2020
Floow this method for generating the random points on sphere. I have also used this method for doing my work for the project.
Do try this code:
TH = 2*pi*rand(1,1e4);
PH = asin(-1+2*rand(1,1e4));
[X,Y,Z] = sph2cart(TH,PH,1);
plot3(X,Y,Z,'.','markersize',1)
axis equal vis3d
  2 Commenti
darova
darova il 21 Set 2019
I like how it looks like but all points are on sphere surface (not inside)
I think random radius should be added
DGM
DGM il 23 Feb 2024
Considering that I just deleted 8 other junk answers used for spam links, something tells me that these answers were also spam but have since had their links removed. That might explain why they're not relevant to the question.

Accedi per commentare.

Tag

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by