2D Matrix revolution
Mostrar comentarios más antiguos
Hi community
How can I revolutionize a 2D matrix around an axis to obtain a solid?
Supose a NxN matrix. In each row are the points of a kind of gaussian curve with less amplitude and higher width. Plotting this surface shows something like a half bell that decays to zero. (See Bottom)
I want to obtain a 3D image revolutionazing that matrix, so the solid looks like a complete bell, or a mexican hat.
Notice that each curve in the matrix rows are different.
I have already try with cylinder(), but i can't define the rotation axis, and the result is a segmented solid.
Possible solutions so I can get the 3D image and define the rotation axis?
Thanks a lot
The surface to revolutioniye looks like this:

Cylinder shows this:

2 comentarios
darova
el 18 de Nov. de 2019
Which axis do you want to rotate?
Felipe Bayona
el 18 de Nov. de 2019
Respuestas (2)
darova
el 18 de Nov. de 2019
Use cylinder for each curve separately:
z = linspace(-1,1,20); % axis
r = sqrt(1-z.^2); % radius
[x,y,~] = cylinder(r,length(z)-1); % convert to cylinder system
zz = repmat(z',[1 20]); % create 2D matrix for Z matrix
surf(x,y,zz) % sphere
4 comentarios
Felipe Bayona
el 18 de Nov. de 2019
darova
el 18 de Nov. de 2019
attach the data
darova
el 18 de Nov. de 2019
And what is the problem?
x = linspace(0,40,41);
[X,T, rc] = normalDiffusion(4, 1, 1, x, 20);
z = X(i,:); % axis
r = rc(i,:); % radius
[x,y,~] = cylinder(r,length(z)-1); % convert to cylinder system
zz = repmat(z',[1 length(r)]); % create 2D matrix for Z matrix
surf(x,y,zz) % sphere
darova
el 19 de Nov. de 2019
Maybe z and r should be switched?
z = X(i,:); % axis
r = rc(i,:); % radius
Philippe Lebel
el 18 de Nov. de 2019
0 votos
Have you tried this function?
1 comentario
Felipe Bayona
el 18 de Nov. de 2019
Categorías
Más información sobre Repeated Measures and MANOVA en Centro de ayuda y File Exchange.
Productos
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!