2D Matrix revolution

조회 수: 1 (최근 30일)
Felipe Bayona
Felipe Bayona 2019년 11월 18일
댓글: darova 2019년 11월 19일
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
darova
darova 2019년 11월 18일
Which axis do you want to rotate?
Felipe Bayona
Felipe Bayona 2019년 11월 18일
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'

댓글을 달려면 로그인하십시오.

답변 (2개)

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

댓글을 달려면 로그인하십시오.


Philippe Lebel
Philippe Lebel 2019년 11월 18일
  댓글 수: 1
Felipe Bayona
Felipe Bayona 2019년 11월 18일
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)

댓글을 달려면 로그인하십시오.

카테고리

Help CenterFile Exchange에서 Triangulation Representation에 대해 자세히 알아보기

제품

Community Treasure Hunt

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

Start Hunting!

Translated by