Ellipsoid Mask based on user input of dimension and euler angle

Actually I am trying to generate a 3d ellipsoid mask based on the user input of semi axes and euler angles. But in my code to do this I am calculating the distance of each pixel from the centre of the ellipse and then based on the ellipse equation pixels falling inside this ellipse are assigned true values. But the problem is that this operation is very tedious as I am scanning each and every pixel.
Any other way to do this which reduces the time complexity of this problem.

 Risposta accettata

Matt J
Matt J il 2 Mag 2024
Modificato: Matt J il 2 Mag 2024
An ellipsoid obeys the inequality (x-c)'*Q*(x-c)<=1 for some appropriate 3x3 matrix Q and 3x1 vector c (which is also the center of the ellipsoid). If you have it expressed this way, generation of the mask is very simple:
[dx,dy,dz]=ndgrid((1:nx)-c(1), (1:ny)-c(2)), (1:nz)-c(3) );
X=[dx(:),dy(:),dz(:)]';
mask = sum(X.*(Q*X))<=1;
mask=reshape(mask,nx, ny,nz);

2 Commenti

To obtain Q from the euler angles, one way would be,
R=eul2rotm(angles); %Needs Robotics Toolbox
Q=R'\diag([a,b,c].^2)*R;
Thanks a lot sir, this was very helpful.

Accedi per commentare.

Più risposte (0)

Categorie

Scopri di più su Interactions, Camera Views, and Lighting in Centro assistenza e File Exchange

Richiesto:

il 2 Mag 2024

Modificato:

il 3 Mag 2024

Community Treasure Hunt

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

Start Hunting!

Translated by