Circle plotting on different Planes
显示 更早的评论
Hey,
I am trying to plot a series of 2D circle in a 3D plot, which are all on slightly different planes (orientated at different angles).
The information I have is;
Centers of the circles;
X = [2 4 5 7];
Y = [0 2 1 0];
Z = [1 3 5 7];
The radii for the circles are the same at 0.5 units.
When I plot these circles I want to see them orientated so that the normal from each circle is pointing in the direction of the next circle. In other words, the plane the circle is drawn on will be perpendicular to the line joining the centers.
the final picture would look like a small section of a pipe.
How could I achieve this?
All help is greatly appreciated.
采纳的回答
更多回答(2 个)
Matt J
2013-9-10
You could start by plotting a prototype circle in the xy plane. Then roto-translate them in 3D using a transformation
R*points + t
where R is a 3x3 rotation matrix and t is a translation vector. This FEX file might help with that
Finally, use scatter3() to plot the transformed points.
4 个评论
Mazhar
2013-9-10
For example, in the following, I plot circles of radius 5 in a 45 degree tilted plane. Just adjust the transformation parameters to your liking.
r=5;
theta=linspace(0,2*pi,1000);
t=reshape(0:4,1,1,[]); %translations
xyz=[r*cos(theta);r*sin(theta); zeros(1,1000)]; %prototype circles
xyz=bsxfun(@plus,xyz,t);
xyz=reshape(xyz,3,[]);
XYZ=num2cell(AxelRot(xyz,45,[1,0,0],[]),2); %transformed circles
scatter3(XYZ{:});
Mazhar
2013-9-10
Mazhar
2013-9-10
Grzegorz Knor
2013-9-10
编辑:Grzegorz Knor
2013-9-10
Try this code:
X = [2 4 5 7];
Y = [0 2 1 0];
Z = [1 3 5 7];
r = 0.5;
[x,y,z] = cylinder(r*ones(size(X)),100);
hold on
for k=length(X):-1:1
x(k,:) = x(k,:)+X(k);
y(k,:) = y(k,:)+Y(k);
z(k,:) = z(k,:)+Z(k);
h(k) = plot3(x(k,:),y(k,:),z(k,:),'r-');
direction = rand(1,3);
alpha = randi(90);
rotate(h(k),direction,alpha)
end
hold off
view(3)
axis equal
I've used random rotation directions and angles. Just calculate the proper values and replace in the code above.
3 个评论
Mazhar
2013-9-10
Grzegorz Knor
2013-9-10
First of all there is a small mistake, should be:
z(k,:) = Z(k);
instead of:
z(k,:) = z(k,:)+Z(k);
Each circle should be perpendicular to the line connecting its center point with the center point of the next circle, right? And what about last circle and its orientation?
Mazhar
2013-9-10
类别
在 帮助中心 和 File Exchange 中查找有关 2-D and 3-D Plots 的更多信息
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!