当前位置: 首页 > news >正文

【R语言+Gephi】利用R语言和Gephi实现共发生网络的可视化

【R语言+Gephi】利用R语言和Gephi实现共发生网络的可视化

注:本文仅作为自己的学习记录以备以后复习查阅

一 概述

Gephi是一款开源免费的多平台网络分析软件,在Windows、Linux和Mac os上均可以运行,像他们官网所说的,他们致力于创造像Photoshop一样的图表绘制软件。

软件特点如下:

符合人体工程学的界面:无需编程技能

高性能:内置渲染引擎。

原生文件格式:GDF (GUESS)、GraphML (NodeXL)、GML、NET (Pajek)、GEXF 等。

可通过插件进行自定义:布局、指标、数据源、操作工具、渲染预设等。

Gephi官方下载地址:https://gephi.org/users/download/
在这里插入图片描述

二 Gephi网络可视化及美化

在Gephi中我们可以通过边文件点文件创建网络图,步骤如下:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
此时可以对网络图进行美化,Fruchterman Reingold是最常用的网络布局,当然大家也可以试试看其他的布局运行出来是什么样的。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在统计模块,我们可以进行如下图所示的计算,这些也是比较常用的,大家可以根据自己的需求进行计算:
在这里插入图片描述
美化后的呈现效果如下:
在这里插入图片描述

三 R语言数据预处理

其实有时候当你将数据预处理好了后,数据可视化反而是最容易的步骤。最常见的共发生网络分析过程是先计算相关系数矩阵,接着使用生成的gml/graphml格式的文件导入Gephi中使用上述过程进行可视化和个性化调整。当然了,强大如R语言,这个过程是完全可以用R语言完成的,如果你数据量不多你也可以手动编写边文件和点文件,在这里介绍如何用R语言完成这个数据准备的过程。

首先加载所需要的包并设置工作路径(也可以不设置,那么后面导入数据时需要写绝对路径),如果没有的用install.packages("包名")语句先安装:

library(igraph)
library(Hmisc)
setwd("G:\\desktop\\准博一方向摸索\\R+Gephi网络可视化")

接下来导入数据(如果是我们自己的数据建议先另存为CSV-UTF-8的格式,不然后面导入的时候可能会报错,并且注意数据文件不要有多余的空行,多检查一下)并将其转换为矩阵,再对其进行一定的数据过滤(这一步可以根据自己数据的需求进行修改):

otu=read.table("otu_data.xls" ,header=T,row.names = 1,sep = "\t")
otu<-as.matrix(otu)
#将丰度值大于1的值替换为1
dt<-otu
dt[dt>1]<-1
#将样本发现率低于20%的过滤掉;
no<-which(rowSums(dt)/ncol(dt)>0.2)
length(no)
otu<-otu[no,]

下面进行相关性的计算:

sp.cor<-rcorr(t(otu),type="spearman") # 这里也可以用Pearson
r.cor<-sp.cor$r
p.cor<-sp.cor$P#使用Benjamini-Hochberg("FDR-BH")法进行多重检验校正(对p值的矫正);
p.adj <- p.adjust(p.cor, method="BH")#指定阈值;
r.cutoff=0.6
p.cutoff=0.001

对相关矩阵进行一定的处理:

r.matrix<-r.cor
p<-p.adj r.matrix[which(r.cor <= r.cutoff)]=0
r.matrix[which(p.adj>p.cutoff)]=0r.matrix<-r.matrix[which(rowSums(r.matrix)!=1),]
r.matrix<-r.matrix[,which(colSums(r.matrix)!=0)]#查看过滤后的矩阵;
dim(r.matrix)
r.matrix[1:7,1:7]

接下来就可以用我们处理好的相关性矩阵进行网络的创建了:

# 创建网络
g1<-graph.adjacency(r.matrix,weight=T,mode="undirected")
g1<-simplify(g1)# 生成网络图的结点标签(OTU id)和degree属性
V(g1)$label <- V(g1)$name
V(g1)$degree <- degree(g1)# 查看网络图的对象结构
print(g1)# 将网络图导出
write_graph(g1, "g1.graphml", format = "graphml") # 也可以导出为gml格式的

在这里插入图片描述
有了R帮我们做的预处理生的.graphml文件我们就可以直接双击在Gephi中进行调整了,美化后的图如下所示:
在这里插入图片描述
在这里插入图片描述

四 参考资料

1、https://www.omicshare.com/forum/thread-6116-1-1.html
2、Dissolved organic matter transformation mechanisms and process optimization of wastewater sludge hydrothermal humification treatment for producing plant biostimulants. https://doi.org/10.1016/j.watres.2023.119910

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • Web3时代的数字身份认证:安全性与隐私保护探讨
  • Python面试题:如何在 Python 中发送 HTTP 请求?
  • 复合机器人:手脚眼脑的完美结合
  • 一文了解java中Optional
  • Quartz 核心
  • 在误装Windows server2019 后如何利用Windows.old恢复?
  • Python面试题:如何在 Python 中进行正则表达式操作?
  • C++笔试真题
  • FFmpeg 初级操作—打印日志,文件目录操作
  • 数学基础 -- 函数的连续性
  • 帕金森患者营养小贴士
  • 昇思25天学习打卡营第17天|SSD目标检测
  • Apache AGE 安装部署
  • 如何在 SwiftUI 中开发定制 MapKit 功能
  • 如何在 Windows 10 上恢复未保存的 Word 文档
  • JS 中的深拷贝与浅拷贝
  • 《用数据讲故事》作者Cole N. Knaflic:消除一切无效的图表
  • 2019年如何成为全栈工程师?
  • Javascript基础之Array数组API
  • Javascript设计模式学习之Observer(观察者)模式
  • socket.io+express实现聊天室的思考(三)
  • springMvc学习笔记(2)
  • Spring技术内幕笔记(2):Spring MVC 与 Web
  • SpriteKit 技巧之添加背景图片
  • 程序员最讨厌的9句话,你可有补充?
  • 基于Vue2全家桶的移动端AppDEMO实现
  • 聊聊flink的BlobWriter
  • 全栈开发——Linux
  • 如何利用MongoDB打造TOP榜小程序
  • 腾讯优测优分享 | 你是否体验过Android手机插入耳机后仍外放的尴尬?
  • 为物联网而生:高性能时间序列数据库HiTSDB商业化首发!
  • 小程序、APP Store 需要的 SSL 证书是个什么东西?
  • 《码出高效》学习笔记与书中错误记录
  • elasticsearch-head插件安装
  • ​低代码平台的核心价值与优势
  • ​软考-高级-系统架构设计师教程(清华第2版)【第12章 信息系统架构设计理论与实践(P420~465)-思维导图】​
  • ​直流电和交流电有什么区别为什么这个时候又要变成直流电呢?交流转换到直流(整流器)直流变交流(逆变器)​
  • # 执行时间 统计mysql_一文说尽 MySQL 优化原理
  • #stm32驱动外设模块总结w5500模块
  • ( )的作用是将计算机中的信息传送给用户,计算机应用基础 吉大15春学期《计算机应用基础》在线作业二及答案...
  • (3)nginx 配置(nginx.conf)
  • (C语言)求出1,2,5三个数不同个数组合为100的组合个数
  • (LeetCode C++)盛最多水的容器
  • (Python) SOAP Web Service (HTTP POST)
  • (超详细)语音信号处理之特征提取
  • (二开)Flink 修改源码拓展 SQL 语法
  • (附源码)ssm高校社团管理系统 毕业设计 234162
  • (附源码)ssm考试题库管理系统 毕业设计 069043
  • (附源码)小程序 交通违法举报系统 毕业设计 242045
  • (回溯) LeetCode 78. 子集
  • (每日持续更新)信息系统项目管理(第四版)(高级项目管理)考试重点整理 第13章 项目资源管理(七)
  • (三)Pytorch快速搭建卷积神经网络模型实现手写数字识别(代码+详细注解)
  • (十八)用JAVA编写MP3解码器——迷你播放器
  • (十七)Flink 容错机制
  • (提供数据集下载)基于大语言模型LangChain与ChatGLM3-6B本地知识库调优:数据集优化、参数调整、Prompt提示词优化实战