2D Matrix revolution
3 Ansichten (letzte 30 Tage)
Ältere Kommentare anzeigen
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 Kommentare
Antworten (2)
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
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
am 19 Nov. 2019
Maybe z and r should be switched?
z = X(i,:); % axis
r = rc(i,:); % radius
Siehe auch
Kategorien
Mehr zu Triangulation Representation finden Sie in Help Center und File Exchange
Produkte
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!