Look at particle on the x-y plane instead of 3-D

2 views (last 30 days)
Hi anyone,
I have a cubic box with 512 spherical particles in three-dimensional space. The particles are random distributed in the box as knowing the x,y,z positions as well as the radius of particle (radius is the same for every spherical particle). Now, I want to look at particles on x-y plane only (z=0) instead in 3-D. is there any function to do that in matlab such as slice. I have read slice function but I still do not understand how it works. If anybody is similar with the problem, then please help me.
Thanks

Accepted Answer

Walter Roberson
Walter Roberson on 25 Nov 2015
It sounds as if you have a list of (x,y,z) triples instead of an 8 x 8 x 8 cube of points. You will therefore need to identify the points of interest. I will assume for this purpose that you consider points to be on the z plane if their sphere crosses the z plane.
zmask = (z >= -R & z <= R);
x0 = x(zmask);
y0 = y(zmask);
z0 = z(zmask);
Now you need to draw a bunch of circles, but the radius of each will depend upon how close the z coordinate is to 0.
r0 = sqrt(R^2 - z0.^2);
and now you can viscircles() with x0, y0, r0
  2 Comments
Phong Pham
Phong Pham on 18 Dec 2015
Edited: Walter Roberson on 18 Dec 2015
Thanks for your answer, Walter.
What if I now look at Z=R instead of 0.
zmask = (z >= R & z <= 2R);
x0 = x(mask);
y0 = y(mask);
z0 = z(mask);
r0 = sqrt(R^2 - z0.^2);
is the r0 equation still right? I don't think it is because r0 is now imaginary number because it is far down. Is r0 = sqrt(R^2 - (z0-R).^2)? Thanks.
Walter Roberson
Walter Roberson on 18 Dec 2015
For points crossing z = L then
zmask = (z >= (L-R) & z <= (L+R));
x0 = x(mask);
y0 = y(mask);
z0 = z(mask);
r0 = sqrt(R^2 - (z0-L).^2);

Sign in to comment.

More Answers (0)

Categories

Find more on Seismology in Help Center and File Exchange

Tags

Community Treasure Hunt

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

Start Hunting!