2D Matrix revolution

2 Ansichten (letzte 30 Tage)
Felipe Bayona
Felipe Bayona am 18 Nov. 2019
Kommentiert: darova am 19 Nov. 2019
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:
untitled.jpg
Cylinder shows this:
untitled.jpg
  2 Kommentare
darova
darova am 18 Nov. 2019
Which axis do you want to rotate?
Felipe Bayona
Felipe Bayona am 18 Nov. 2019
I would like to know the general method, where i can specify the axis. In this particular example, I need to do it around the z-axis, to obtain the 'Mexican hat'

Melden Sie sich an, um zu kommentieren.

Antworten (2)

darova
darova am 18 Nov. 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 Kommentare
darova
darova am 18 Nov. 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
darova am 19 Nov. 2019
Maybe z and r should be switched?
z = X(i,:); % axis
r = rc(i,:); % radius

Melden Sie sich an, um zu kommentieren.


Philippe Lebel
Philippe Lebel am 18 Nov. 2019
  1 Kommentar
Felipe Bayona
Felipe Bayona am 18 Nov. 2019
This only alows to rotate a y=f(x) funtion
My matrix is composed by many curves, because my function is z=f(x,y)

Melden Sie sich an, um zu kommentieren.

Produkte

Community Treasure Hunt

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

Start Hunting!

Translated by