图与网络可视化实战(matlab实现)

2023-05-16

本篇以2020年数学建模美赛D题的足球传球网络可视化为例,分三大步骤来简单讲解一下matlab在图与网络可视化方面的应用:

Step1 构图:

首先根据输入数据构造邻接矩阵,然后调用matlab中的graph(无向图)或digraph(有向图)函数进行构图。

构图函数有两种常见的使用方法:

G = digraph(A) %其中A是图的邻接矩阵表示,该函数返回digraph对象G
G = digraph(EdgeTable,NodeTable) %利用边信息表和节点信息表构图
其中,EdgeTable一般包含边所连接的两个节点以及边的权重等信息,NodeTable一般包含节点的标号以及节点的度等信息

Step2 创建Graphplot对象:

调用plot函数返回一个Graphplot对象,Graphplot对象包含线型、标号、颜色、坐标等多种属性,我们可以通过后续调整Graphplot对象的相关属性来改变图像的显示效果。

p = plot(G) %返回一个Graphplot对象p

Step3 调整Graphplot对象的相关属性

(1)指定线条与点的颜色与类型

p=plot(H1,'-b')%指定线条的类型,'-'为线条形状,'b'为线条颜色
p.Marker = 's';%指定节点的形状为正方形
p.NodeColor = 'r';%指定节点的颜色为红色
p.MarkerSize =10;%指定节点的大小为10

(2)自定义节点标号

Labels1={'F1','F2','D1','D2','D3','D4','D6','M1','M2','M3','M4','M6','M7','G1'};
p.NodeLabel=Labels1;

(3)指定图像布局

p=plot(H1,'-b','Layout','circle')%指定Layout为circle来更改图像布局

(4)使边的粗细反映边的权重

LWidths1 = 10*H1.Edges.Weight/max(H1.Edges.Weight);
p.LineWidth = LWidths1;

(5)使节点的大小与颜色反映节点的度数

改变节点的属性需要重新构图,因为如果我们直接使用邻接矩阵来构图的话,NodeTable一般是空的,既不含有节点标签信息也不含有节点的度数,所以我们要首先计算每个节点的度数并将其与节点标签对应建立新的NodeTable,然后重新调用diagraph函数进行构图。

%增加节点信息重新构图
EdgeTable=H1.Edges;
NodeWeight=indegree(H1)+outdegree(H1);
Labels1={'F1','F2','F3','D1','D2','D3','D4','D5','M1','M2','M3','M4','M5','G1'}';
NodeTable=table(Labels1,NodeWeight);
H2=digraph(EdgeTable,NodeTable);
...
...
...
p.MarkerSize = log(H2.Nodes.NodeWeight+1.1)*15;%节点大小
p.NodeCData=H2.Nodes.NodeWeight;               %节点颜色
colorbar                                       %显示颜色样条

(6)添加坐标

p.XData=meanx;
p.YData=meany;
%限定坐标系范围
xlim([0 100])
ylim([0 100])
%指定坐标刻度
xticks(0:10:100); 
yticks(0:10:100); 

(7)添加背景底图

%背景
img = imread('BackGround.jpg');
% 设置图片在绘制时的尺寸
min_x = 0;
max_x = 100;
min_y = 0;
max_y = 100;
%插入背景图
imagesc([min_x max_x],[min_y max_y], flipdim(img,1));
hold on;

(8)将图像输出并保存

%打开图窗
f1=figure(1)
%输出保存
print(f1,'-djpeg',sprintf('Distance%d.jpg',order))

 

可视化部分代码:

clc,clear
order=1;
A=xlsread(sprintf('passinginfo_%d.xlsx',order));
%输入节点个数
m=14;
num=size(A,1);
H1=zeros(m,m);
meanx=zeros(1,m);
meany=zeros(1,m);
count=zeros(1,m);
%构建传球网络有向图的邻接矩阵
for i=1:num
    if A(i,4)~=1
        if A(i,1)==1
            if A(i,2)==A(i,3)
                H1(A(i,2),A(i,3))=0;
            else
                H1(A(i,2),A(i,3))=H1(A(i,2),A(i,3))+1;
            end
            meanx(A(i,2))=meanx(A(i,2))+A(i,7);
            meany(A(i,2))=meany(A(i,2))+A(i,8);
            meanx(A(i,3))=meanx(A(i,3))+A(i,9);
            meany(A(i,3))=meany(A(i,3))+A(i,10);
            count(A(i,2))=count(A(i,2))+1;
            count(A(i,3))=count(A(i,3))+1;
        end
    end
end
for i=1:m
    meanx(i)=meanx(i)/count(i);
    meany(i)=meany(i)/count(i);
end
meanx(find(isnan( meanx)==1)) = 0
meany(find(isnan(meany)==1)) = 0
H1=digraph(H1);
EdgeTable=H1.Edges;
NodeWeight=indegree(H1)+outdegree(H1);
Labels1={'F1','F2','F3','D1','D2','D3','D4','D5','M1','M2','M3','M4','M5','G1'}';
NodeTable=table(Labels1,NodeWeight);
H2=digraph(EdgeTable,NodeTable);
%打开图窗
f1=figure(1)
%背景
img = imread('BackGround.jpg');
% 设置图片在绘制时的尺寸
min_x = 0;
max_x = 100;
min_y = 0;
max_y = 100;
%插入背景图
imagesc([min_x max_x],[min_y max_y], flipdim(img,1));
hold on;
%绘制网络
LWidths1 = 10*H2.Edges.Weight/max(H2.Edges.Weight);
p = plot(H2,'-w','LineWidth',LWidths1)
p.NodeLabel=H2.Nodes.Labels1
p.MarkerSize = log(H2.Nodes.NodeWeight+1.1)*15;
p.NodeCData=H2.Nodes.NodeWeight;
p.LineWidth=LWidths1;
p.XData=meanx;
p.YData=meany;
%限定坐标系范围
xlim([0 100])
ylim([0 100])
%指定坐标刻度
xticks(0:10:100); 
yticks(0:10:100); 
colorbar
print(f1,'-djpeg',sprintf('Distance%d.jpg',order))

 

更多matlab图与网络相关请参考mathworks官网:

https://ww2.mathworks.cn/help/matlab/graph-and-network-algorithms.html?s_tid=CRUX_lftnav

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

图与网络可视化实战(matlab实现) 的相关文章

  • [csp模拟1]咕咕东的奇遇——(一)

    目录 题意InputOutput输入样例输出样例提示 分析总结代码 题意 咕咕东是个贪玩的孩子 xff0c 有一天 xff0c 他从上古遗迹中得到了一个神奇的圆环 这个圆环由字母表组成首尾相接的环 xff0c 环上有一个指针 xff0c 最
  • Linux挂载镜像的一些命令

    Linux挂载镜像的一些命令 在Linux中 xff0c 可以用losetup命令来设置无分区空白镜像到loop设备上 xff0c 用kpartx 来kpartx映射分区的镜像到loop设备上 之后通过mount命令将loop设备与系统文件
  • [week5]平衡字符串——尺取法

    目录 题意InputOutput输入样例输出样例提示 分析总结代码 题意 一个长度为 n 的字符串 s xff0c 其中仅包含 Q W E R 四种字符 如果四种字符在字符串中出现次数均为 n 4 xff0c 则其为一个平衡字符串 现可以将
  • [csp模拟2]T4——咕咕东的奇妙序列

    文章目录 题意InputOutput输入样例输出样例提示 分析总结代码 题意 咕咕东 正在上可怕的复变函数 xff0c 但对于稳拿A Plus的 咕咕东 来说 xff0c 她早已不再听课 xff0c 此时她在睡梦中 突然想到了一个奇怪的无限
  • [week9]签到题(长凳)——贪心算法

    文章目录 题意InputOutput输入样例输出样例提示 分析总结代码 题意 SDUQD 旁边的滨海公园有 x 条长凳 第 i 个长凳上坐着 a i 个人 这时候又有 y 个人将来到公园 xff0c 他们将选择坐在某些公园中的长凳上 xff
  • [week14] Q老师与十字叉

    文章目录 题意InputOutput输入样例输出样例提示 分析总结代码 题意 Q老师 得到一张 n 行 m 列的网格图 xff0c 上面每一个格子要么是白色的要么是黑色的 Q老师认为失去了 十字叉 的网格图莫得灵魂 一个十字叉可以用一个数对
  • [week15] ZJM 与霍格沃兹 —— 字符串哈希

    文章目录 题意InputOutput输入样例输出样例提示 分析总结代码 题意 ZJM 为了准备霍格沃兹的期末考试 xff0c 决心背魔咒词典 xff0c 一举拿下咒语翻译题 题库格式 xff1a 魔咒 对应功能 背完题库后 xff0c ZJ
  • [week14] D - Q老师染砖(选做) —— 矩阵快速幂优化DP

    文章目录 题意InputOutput输入样例输出样例提示 分析总结代码 题意 衣食无忧的 Q老师 有一天突发奇想 xff0c 想要去感受一下劳动人民的艰苦生活 具体工作是这样的 xff0c 有 N 块砖排成一排染色 xff0c 每一块砖需要
  • [week14] E - Q老师度假(选做)—— 矩阵快速幂优化DP(拓展)

    文章目录 题意InputOutput输入样例输出样例提示 分析总结代码 题意 忙碌了一个学期的 Q老师 决定奖励自己 N 天假期 假期中不同的穿衣方式会有不同的快乐值 已知 Q老师 一共有 M 件衬衫 xff0c 且如果昨天穿的是衬衫 A
  • [week15] B - ZJM与生日礼物(选做)—— 字典树

    文章目录 题意InputOutput输入样例输出样例提示 分析总结代码 题意 ZJM 收到了 Q老师 送来的生日礼物 xff0c 但是被 Q老师 加密了 只有 ZJM 能够回答对 Q老师 的问题 xff0c Q老师 才会把密码告诉 ZJM
  • [week15] C - ZJM与纸条(选做)—— KMP算法

    文章目录 题意InputOutput输入样例输出样例提示 分析总结代码 题意 ZJM 的女朋友是一个书法家 xff0c 喜欢写一些好看的英文书法 有一天 ZJM 拿到了她写的纸条 xff0c 纸条上的字暗示了 ZJM 的女朋友 想给 ZJM
  • 51按键外部中断控制流水灯

    实验二 外部按键输入 一 实验目的 1 了解单片机检测口方法 2 了解单片机外部中断原理 3 了解按键输入原理 二 实验内容 1 完成按键扫描控制流水灯 2 完成按键外部中断控制流水灯 三 实验原理 四 实验电路与程序 1 软件实验一 xf
  • 树莓派4B构建debian镜像UEFI启动

    树莓派4B构建debian镜像UEFI启动 前言 今天按照大佬的博客树莓派俱乐部官方 Debian 系统镜像 支持UEFI跑了遍 完整的UEFI镜像构建过程 包括镜像分区 挂载 xff0c 根文件系统的制作 xff0c 内核的移植 xff0
  • Linux修改主机名问题

    记一次修改主机名不成功原因 场景 虽然使用hostname命令可以修改主机名 xff0c 但如果重启主机之后主机名还会变为之前的 xff0c 所以需要把修改的主机名称写到配置文件中 假设修改后的主机名为 new hostname 1 修改配
  • mybatisPlus分页插件报错,sql后面拼接多了一个limit。

    原本 用的mybatisPlus版本为3 1 0 xff0c 后来升级到3 4 2了 xff0c 使用分页的时候报错 解决 xff1a mybatisPlus 3 1 0 所用到的分页插件为 而mybatisPlus 3 4 2版本pagi
  • Deep Knowledge Tracing (深度知识追踪)

    boss又让我看这块的内容了 xff0c 刚开学 xff0c 还不太适应实验室的学习生活 xff0c 假期闲散惯了操 目录 1 概述2 表示3 1 DKT的优势3 2 DKT的不足4 模型5 序列的输入和输出输入输出 6 优化及应用7 三个
  • C程序代码

    一 C语言概述有算法 1 输出一行信息 span class token macro property span class token directive hash span span class token directive keyw
  • 【C语言-10】.求10 个整数中最大值。 (数组定义法和函数调用法)

    数组定义法 首先定义一个一维数组存放输入的数字 xff0c 然后将键盘输入的数字依次存入一维数组 xff1b 假定数组中某一元素为最大值 xff0c 将其与其他元素逐一比较 xff0c 得到最大的数为max值 xff1b 最后得到的max为
  • 【工程实践】解决 nvcc: command not found

    1 nvcc nvcc 是The main wrapper for the NVIDIA CUDA Compiler suite Used to compile and link both host and gpu code NVIDIA
  • hdu 5119(dp题)

    题目链接 xff1a http acm hdu edu cn showproblem php pid 61 5119 题目 xff1a Matt has N friends They are playing a game together

随机推荐

  • word(doc/docx)转markdown:使用Typora的插件

    打开你的Typora xff0c 选择文件 gt 导入 第一次导入会让你下载 pandoc 插件 下载链接如下 xff1a https github com jgm pandoc releases download 2 14 1 pando
  • 案例描述:update中,MySQL inner join 和 left join的区别,小结果集驱动大结果集

    场景描述 以一个场景为例 xff1a 单据A xff1a 下游子表 xff08 数据量级小 xff09 单据B xff1a 下游主表 xff08 数据量级小 xff09 单据C xff1a 中游子表 xff08 数据量级小 xff09 单据
  • Hadoop生态圈(一)- Hadoop详解

    目录 前言1 Hadoop概述1 1 Hadoop是什么1 2 Hadoop发展简史1 2 Hadoop三大发行版本1 3 Hadoop优势1 4 Hadoop的组成1 4 1 Hadoop1 x 2 x 3 x区别1 4 2 HDFS架构
  • arduino硬件总结

    文章目录 arduino硬件总结串口通讯I2CSPI中断函数基本了解实现测速 ADC读取光敏传感器的值 pwm舵机控制 arduino硬件总结 arduino 支持中断 xff0c ADC PWM xff0c I2C xff0c spi x
  • 文件上传 - Apache SSI远程命令执行

    文章目录 一 漏洞原理二 漏洞场景 挖掘思路三 触发条件四 漏洞复现4 1 启动环境4 2 访问环境4 3 复现过程 五 防御措施 一 漏洞原理 在测试任意文件上传漏洞的时候 xff0c 目标服务端可能不允许上传php jsp asp后缀的
  • Linux:chmod -R 777 *含义

    Linux xff1a chmod R 777 首先 xff0c chmod命令是linux上用于改变权限的命令 xff0c R 是递归遍历子目录 xff0c 因为你要操作的文件使用的 通配符 777 xff0c 第一个7代表文件所属者的权
  • STM32HAL库学习笔记七——I2C通信

    HAL库快速部署I2C 本文主要介绍如何使用STM32CubeMX快速部署I2C通信 xff0c 并与EEPROM进行数据收发 文章目录 HAL库快速部署I2CI2C简介EEPROM简介HAL库部署IIC通信实现多字节写入一 CubeMX配
  • python报错Statements must be separated by newlines or semicolons解决方法

    今天做练习时遇到这样的报错 xff1a Statements must be separated by newlines or semicolons 翻译一下就是 xff1a 语句必须用换行符或分号分隔 首先按报错提示 xff0c 我把cl
  • python自然语言处理之spacy详解

    spaCy简介 spaCy号称工业级Python自然语言处理 xff08 NLP xff09 软件包 xff0c 可以对自然语言文本做词性分析 命名实体识别 依赖关系刻画 xff0c 以及词嵌入向量的计算和可视化等 spaCy模块有4个非常
  • anaconda创建env报错 ResolvePackageNotFound

    具体错误 如图 xff1a 按照其他博主 xff08 方法详情 xff09 提供的方法操作了还是有部分报错 xff1a 解决策略 继续上面解决剩下的部分报错 xff0c 打开 yaml文件 xff0c 记事本打开就行 将报错列出的几个包移到
  • LDA主题建模过程及参数详解

    平台及工具 语言 xff1a python 平台 xff1a anaconda 43 jupyter notebook 语料库 xff1a 近三百篇英文文献的摘要 主要代码 首先 xff0c pandas处理csv数据 span class
  • 已经成功安装了但是jupyter notebook仍然找不到模块

    问题描述 工具 语言 jupyter notebook 43 anaconda python 有时会遇到这样的情况 xff0c 命名已经install了模块 xff0c notebook还是报找不到模块错误 再装已经提示satisfied
  • pyecharts 地图绘制

    环境描述 win11 jupyter notebook 目标效果 世界地图 43 按数据进行分级着色 xff1b 最终效果图如下 xff1a pyecharts 绘制地图时注意点 可以实现目标地图绘制效果的python库很多 xff0c 这
  • 指定wb用户在指定日期范围内的wb内容抓取

    一 操作步骤 只记录过程 xff0c 不讲述原理 1 获取用户ID和cookie 用户ID在进入个人主页时导航栏中就会有显示 xff0c 例如下面这样 xff1a cookie获取 xff08 有的代码无需cookie也能运行 xff09
  • 中介变量、调节变量与协变量

    在平时看论文过程中偶会接触到这几个概念 xff0c 然而都没想过弄明白 xff0c 每次总觉得只要看明白个大概反正自己又不用这种方法 作为科研人 xff0c 还是应该保持谦逊 xff0c 保持学习 一 中介变量 1 概念 中介变量 xff0
  • linux环境搭建

    文章目录 linux环境搭建基础工具环境docker镜像docker 的基本操作git amp amp sshbash脚本 python 环境 linux环境搭建 基础工具环境 docker镜像 Docker CE 镜像源站 docker如
  • 【Linux】状态机

    Linux 状态机 首先感谢阅读 xff0c 作者是在工作中学习与积累 xff0c 每一个笔记都是心得和积累 xff0c 希望可以和大家一起交流学习 学习咱们先定好计划 xff0c 需要了解的都一样 xff0c 有 xff1a xff08
  • MyBatisPlus源码

    MyBatisPlus源码 文章目录 MyBatisPlus源码1 通用Mapper 96 BaseMapper 96 2 顶级Mapper 96 Mapper 96 3 通用Service 96 IService 96 4 通用Servi
  • bomb二进制炸弹拆除实验(MIPS)

    上学期计算机系统基础课程的一个实验 xff0c 在这里再简略整理一下 xff1a 实验要求 xff1a 仅给定一个MIPS二进制可执行文件bomb xff0c 要求运用GDB调试工具 xff0c 通过分析反汇编代码来输入正确的参数以拆除炸弹
  • 图与网络可视化实战(matlab实现)

    本篇以2020年数学建模美赛D题的足球传球网络可视化为例 xff0c 分三大步骤来简单讲解一下matlab在图与网络可视化方面的应用 xff1a Step1 构图 xff1a 首先根据输入数据构造邻接矩阵 xff0c 然后调用matlab中