Hello. I have a shape that I would like to cut out a slice of. I also have coordinates from an XY plane at a particular Z value that I'd like to use. So because I'm expecting 2 circles, I calculate their radii and see if my XY plane coordinates match up. However, I'm not getting any good results...is there a better way to do this
This is my shape
This is the way the slice is supposed to look (but upside down)
This is what I'm getting. So my result is suposed to be a 64 by 64 double image. The reason my shape is to the left is because my coordinates also contain negative values. My shape is in the positive side.
This is what my code looks like to make the slice. X_pixels, Y_pixels etc are the coordinates I'm checking.

6 commentaires

Matt J
Matt J le 18 Avr 2021
Modifié(e) : Matt J le 18 Avr 2021
Where did the surface triangulation originate from? Maybe it would be easier to triangulate the slice than to slice the triangulation.
Nnebunne Melisa
Nnebunne Melisa le 18 Avr 2021
Hello...I don't understand what you mean.
Matt J
Matt J le 18 Avr 2021
How did you generate the first figure, with the two triangulated spheres? What original data was it derived from?
Nnebunne Melisa
Nnebunne Melisa le 18 Avr 2021
It was from the orginal shape. I used contours at the Z value I wanted.
I know I can do it this way but I want to use the coordinates of my XY plane
Matt J
Matt J le 18 Avr 2021
Modifié(e) : Matt J le 18 Avr 2021
Please post code in the form of text (in a code-well like the one below) rather than as an image. It makes it easier for us to copy/paste/run.
[X,Y,Z]=sphere;
X_axis=X*2
Nnebunne Melisa
Nnebunne Melisa le 19 Avr 2021
oh I'm sorry

Connectez-vous pour commenter.

 Réponse acceptée

Matt J
Matt J le 18 Avr 2021
Modifié(e) : Matt J le 18 Avr 2021
It seems like it would be better if you would just generate your spheres direclty as a 3D image volume. Then you could just use the slice() commnd to get get the slice images that you want.
xl=(-3:.03:3);
[yl,zl]=deal((-2:0.03:2));
[X,Y,Z]=ndgrid( xl,yl,zl);
Spheres=((X+1.1).^2+Y.^2+Z.^2)<=2^2 | (X-1.1).^2 + Y.^2 +Z.^2<=2^2;
imshow(Spheres(:,:,20).');

10 commentaires

Nnebunne Melisa
Nnebunne Melisa le 19 Avr 2021
What if I want to show the part of the image that intersects
Nnebunne Melisa
Nnebunne Melisa le 19 Avr 2021
And please can you explain the code more. I'm new to matlab so it is a bit unfamiliar
This will show the intersection:
xl=(-3:.03:3);
[yl,zl]=deal((-2:0.03:2));
[X,Y,Z]=ndgrid( xl,yl,zl);
Spheres=(((X+1.1).^2+Y.^2+Z.^2)<=2^2) + ((X-1.1).^2 + Y.^2 +Z.^2<=2^2);
imagesc(Spheres(:,:,20).'); axis image; colormap(gray)
Nnebunne Melisa
Nnebunne Melisa le 19 Avr 2021
Modifié(e) : Nnebunne Melisa le 19 Avr 2021
Please can you explain the last two lines of code. From " spheres = ..."
Also What if I want to visualize the "spheres" shape in 3d?
Matt J
Matt J le 19 Avr 2021
Modifié(e) : Matt J le 19 Avr 2021
Please can you explain the last two lines of code. From " spheres = ..."
Well, the region of a sphere satisfies the inequality . We've simply used that inequality to create two binary image volumes containing spheres at different center locations and added them together.
Also What if I want to visualize the "spheres" shape in 3d?
You've already done that in the mesh plot you posted. But you can also use volumeViewer or volshow().
Nnebunne Melisa
Nnebunne Melisa le 20 Avr 2021
what of the last sentence "Imshow..."
Matt J
Matt J le 20 Avr 2021
It just displays Spheres(:,:,20).'
Nnebunne Melisa
Nnebunne Melisa le 21 Avr 2021
why does the z say 20? The axis is not up to 20. And why does it end with " .' "?
I'm sorry for all the questions. I'm just trying to understand
Matt J
Matt J le 21 Avr 2021
Modifié(e) : Matt J le 21 Avr 2021
It's a 3D array with 134 slices.
whos Spheres
Name Size Bytes Class Attributes Spheres 201x134x134 3609156 logical
I just picked the 20th slice arbitrarily. The .' transposes the slice, so that it's longest side is displayed horizontally, but you don't have to do that if you prefer to view the untransposed slice.
Nnebunne Melisa
Nnebunne Melisa le 23 Avr 2021
Thank you!

Connectez-vous pour commenter.

Plus de réponses (0)

Community Treasure Hunt

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

Start Hunting!

Translated by