繁体   English   中英

如何在Matlab中绘制3D有向图

[英]How to plot 3d directed graph in matlab

我有一个上三角相邻矩阵,它表示一组连接的节点。 每个节点由三个地理坐标定义:xy 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];

 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);

这首先画一条线,然后叠加一个到达中点的箭头(注意quiver命令中的0.5缩放比例):

在最新的MATLAB版本(R2016b)中,现在可以通过选择其他布局方法或直接指定x,y和z坐标在3d中绘制节点链接图。 在您的示例中,将绘图线替换为

p = plot(F,'XData',xyz(:,2),'YData',xyz(:,1),'ZData',xyz(:,3));

结果图:

图形数据的3维图

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM