如何在matlab中绘制三维有向图
我有一个上三角邻接矩阵,它表示一组连接的节点。每个节点由三个地理坐标定义:x y z。 我的目标是通过考虑边缘的方向来绘制网络,以查看它的外观 如果不考虑z坐标,我可以轻松显示结果: 获得此结果的代码行包括:如何在matlab中绘制三维有向图,matlab,plot,graph,3d,adjacency-matrix,Matlab,Plot,Graph,3d,Adjacency Matrix,我有一个上三角邻接矩阵,它表示一组连接的节点。每个节点由三个地理坐标定义:x y z。 我的目标是通过考虑边缘的方向来绘制网络,以查看它的外观 如果不考虑z坐标,我可以轻松显示结果: 获得此结果的代码行包括: A = [0 1 1 0 0 0 0; 0 0 1 1 0 0 0; 0 0 0 1 1 1 0; 0 0 0 0 1 1 0; 0 0 0 0 0 0 1; 0 0 0 0 0 0 1; 0 0 0 0 0 0 0]; x
A = [0 1 1 0 0 0 0;
0 0 1 1 0 0 0;
0 0 0 1 1 1 0;
0 0 0 0 1 1 0;
0 0 0 0 0 0 1;
0 0 0 0 0 0 1;
0 0 0 0 0 0 0];
xyz = [ 0 0 0;
-15 20 5;
17 24 -3;
-5 36 7;
-14 50 -8;
16 56 3;
3 70 -1];
F = digraph(A);
figure
p = plot(F,'XData',xyz(:,2),'YData',xyz(:,1)); axis equal;
highlight(p,1,'NodeColor','g'); highlight(p,size(A,1),'NodeColor','r');
view([0 90])
我应该如何修改我的代码,以便将z坐标也指定给图形,这样我就可以拥有一个3d图形?(记住我也想显示边缘方向!!)
我想做的是:
p = plot3(F,'XData',xyz(:,2),'YData',xyz(:,1),'ZData',xyz(:,3));
但是我没有成功。这个问题很酷。我有一些空闲时间制作了这个:
close all
clear all
A = [0 1 1 0 0 0 0;
0 0 1 1 0 0 0;
0 0 0 1 1 1 0;
0 0 0 0 1 1 0;
0 0 0 0 0 0 1;
0 0 0 0 0 0 1;
0 0 0 0 0 0 0];
xyz = [ 0 0 0;
-15 20 5;
17 24 -3;
-5 36 7;
-14 50 -8;
16 56 3;
3 70 -1];
figure; hold on
for jj=1:size(A,1) %cycle on nodes
conn=find(A(jj,:)); %find connections for each node
if numel(conn>0) %if there are non null connections
for kk=1:numel(conn) %plot them
a=conn(kk);
lh=quiver3(xyz(jj,1),xyz(jj,2),xyz(jj,3),...
xyz(a,1)-xyz(jj,1),xyz(a,2)-xyz(jj,2),xyz(a,3)-xyz(jj,3),0,'maxheadsize',0.5);
set(lh,'linewidth',4);
set(lh,'color',[1,0,0]);
end
end
end
scatter3(xyz(:,1),xyz(:,2),xyz(:,3),800,'b','.') %plot nodes
%number the nodes
for ii=1:size(xyz,1)
text(xyz(ii,1),xyz(ii,2),xyz(ii,3),num2str(ii),'Color','k','FontWeight','bold',...
'FontSize',14, 'HorizontalAlignment','right', 'VerticalAlignment','bottom')
end
xlabel('x')
ylabel('y')
zlabel('z')
view(-15,18)
grid on
我觉得这很像你想要的:
编辑
如果希望箭头位于两个节点的中点,可以使用:
line([xyz(a,1) xyz(jj,1)],[xyz(a,2) xyz(jj,2)],[xyz(a,3) xyz(jj,3)],'color',[1 0 0],'linewidth',3)
lh=quiver3(xyz(jj,1),xyz(jj,2),xyz(jj,3),...
xyz(a,1)-xyz(jj,1),xyz(a,2)-xyz(jj,2),xyz(a,3)-xyz(jj,3),.5,'maxheadsize',0.5);
这将首先绘制一条直线,并叠加一个到达中点的箭头(注意0.5
quiver命令中的比例因子):
在最新的MATLAB版本(R2016b)中,现在可以通过选择不同的布局方法,或直接指定x、y和z坐标,在3d中绘制节点链接图。在您的示例中,将打印线替换为
p = plot(F,'XData',xyz(:,2),'YData',xyz(:,1),'ZData',xyz(:,3));
结果图:
我想您必须编写一个自定义的
plot3
方法。查看plot
对于digraph
(edit@digraph/plot
)的实现,你可能会发现一些有用的东西。我的答案解决了你的问题吗?@shamalaia你的答案很有帮助;我仍在等待更多的最终答案,如果没有其他人给出其他选择,我将确认你的答案是正确的。。。顺便问一下,你知道如何把箭头放在红色段中间吗?