Python社群纽带关系谱和图神经

news2024/5/18 12:30:32

🎯要点

  1. 图神经网络:🎯网络中顶点的潜在表征学习实现:🖊创建节点表征,使用连续skip-gram模型 | 🖊使用节点嵌入算法Node2vec实现,示例:电影筛选推荐系统。🖊多层感知节点和边特征学习分类节点 | 🖊图卷积神经层使用节点回归预测网络流量 | 🖊图注意力网络模型测试自动引文索引系统数据 | 🖊使用邻域采样算法和聚合器归纳学习蛋白质-蛋白质相互作用图数据 | 🖊魏斯费勒·莱曼图同构检验表达性,图同构网络模型从蛋白质图数据分类出酶类型 | 🖊链接预测:变分图自动编码器、使用子图嵌入和属性框架 | 🖊生成图数据:弱表达性图:使用埃尔多斯-雷尼模型,使用小世界模型,强表达性图:生成分子结构图 | 🖊分层自注意力网络(异构图)| 🖊 时空图神经网络:递归图卷积神经网络预测网站流量,多层感知和长短期记忆模型预测感染数量 | 🖊可解释性图神经解释化合物的图表征,实现积分梯度算法解释性图神经社交粉丝群 | 🖊注意力时间图卷积神经预测公路交通流量 | 🖊异构图检测网络攻击,绘制结果多类流分类的混淆矩阵图 | 🖊简化和增强图卷积神经模型协作过滤方法推荐书籍。
  2. 图论数学逻辑和代码分析:🖊深度优先遍历算法和广度优先遍历算法巴拉巴西-阿尔伯特模型(无标度网络模型) | 🖊Dijkstra 算法分析瓦茨-斯特罗加茨模型(小世界随机模型) 。🎯社交网络数学逻辑和代码实现:🖊无标度网络模型图和小世界模型图,角色数据采样。🎯节点层分析算法和代码实现:🖊自我网络分析算法分析社区人口,直方图绘制分布程度 | 🖊自我网络分析算法分析巴拉巴西-阿尔伯特模型 | 🖊自我网络分析算法分析节目角色关系谱 | 🖊度中心性算法分析个人社交群中关联个体 | 🖊度中心性算法分析节目中谁是关键角色 | 🖊紧密中心性算法分析个人社交群中个体纽带关系 | 🖊紧密中心性算法分析节目中关键角色间紧密度 | 🖊介数中心性算法分析个人社交群中中间人,节目关键角色中间人 | 🖊特征向量中心性算法分析个人社交群中与关键人联系紧密的,节目中与关键角色紧密的 | 🖊随机链接可能性算法分析社交中可能形成的关系网。🎯群体层分析算法:🖊派系分析社交群中个人类别 | 🖊聚类系数分析社交群体中信任朋友比例 | 🖊传递性分析社群中非关联个体之间的关联可能性 | 🖊层次聚类寻找类似社群 | 🖊块模型分析群体CT检测群体病患分散后小群体病患。

🍇Python埃尔多斯-雷尼模型

模型定义:此随机图模型有两个密切相关的变体。

  • G ( n , M ) G(n, M) G(n,M) 模型中,从具有 n n n 个节点和 M M M 个边的所有图的集合中均匀随机选择一个图。节点被认为是有标签的,这意味着通过排列顶点而彼此获得的图被认为是不同的。例如,在 G ( 3 , 2 ) G(3,2) G(3,2) 模型中,三个标记顶点上存在三个二边图(二边路径中中间顶点的每个选择一个),并且这三个图中的每一个都是包含概率 1 3 \frac{1}{3} 31
  • G ( n , p ) G(n, p) G(n,p)模型中,通过随机连接标记节点来构建图。每条边都以 p p p 的概率包含在图中,且独立于所有其他边。同样,生成具有 n n n 个节点和 M M M 个边的每个图的概率为 p M ( 1 − p ) ( n 2 ) − M p^M(1-p)^{\binom{n}{2}-M} pM(1p)(2n)M

该模型中的参数 p p p可以被认为是一个加权函数;随着 p p p 从 0 增加到 1 ,模型变得越来越可能包含具有更多边的图,而越来越不可能包含具有较少边的图。特别是, p = 1 2 p=\frac{1}{2} p=21 的情况对应于以相等概率选择 n n n 个顶点上的所有 2 ( n 2 ) 2^{\binom{n}{2}} 2(2n) 图的情况。

随机图的行为通常在顶点数 n n n 趋于无穷大的情况下进行研究。虽然在这种情况下 p p p M M M可以是固定的,但它们也可以是依赖于 n n n的函数。例如, G ( n , 2 ln ⁡ ( n ) / n ) G(n, 2 \ln (n) / n) G(n,2ln(n)/n) 中的几乎每个图都是连通的,这意味着,当 n n n 趋于无穷大时, n n n 上的图与边相连的概率 2 ln ⁡ ( n ) / n 2 \ln (n) / n 2ln(n)/n​ 连接的概率趋于 1。

代码实现

埃尔多斯-雷尼模型模型用于在社交网络上创建随机网络或图表。在模型中,每条边都有固定的存在和不存在概率,与网络中的边无关。

# Import Required modules 
import networkx as nx 
import matplotlib.pyplot as plt 
import random

创建模型的分布图。

# Distribution graph for Erdos_Renyi model 
def distribution_graph(g): 
	print(nx.degree(g)) 
	all_node_degree = list(dict((nx.degree(g))).values()) 

	unique_degree = list(set(all_node_degree)) 
	unique_degree.sort() 
	nodes_with_degree = [] 
	for i in unique_degree: 
		nodes_with_degree.append(all_node_degree.count(i)) 

	plt.plot(unique_degree, nodes_with_degree) 
	plt.xlabel("Degrees") 
	plt.ylabel("No. of nodes") 
	plt.title("Degree distribution") 
	plt.show()

取 N,即用户的节点数。

print("Enter number of nodes") 
N = int(input())

取 P 即用户获取边缘的概率。

print("Enter value of probability of every node") 
P = float(input())

创建一个具有 N 个节点且没有任何边的图

# Create an empty graph object 
g = nx.Graph() 

# Adding nodes 
g.add_nodes_from(range(1, N + 1))

随机向图中添加边,取一对节点,得到一个随机数 R。如果 R<P(概率),则添加一条边。对所有可能的节点对重复上述步骤,然后显示形成的整个社交网络(图)。

# Add edges to the graph randomly. 
for i in g.nodes(): 
	for j in g.nodes(): 
		if (i < j): 
			
			# Take random number R. 
			R = random.random() 
			
			# Check if R<P add the edge 
			# to the graph else ignore. 
			if (R < P): 
				g.add_edge(i, j) 
	pos = nx.circular_layout(g) 
	
	# Display the social network 
	nx.draw(g, pos, with_labels=1) 
	plt.show()

显示连接节点。

distribution_graph(g)

参阅一:计算思维

参阅二:亚图跨际

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1641538.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

目标检测算法YOLOv5简介

没有关于YOLOv5的直接论文&#xff0c;YOLOv5由Ultralytics维护&#xff0c;源码见&#xff1a;https://github.com/ultralytics/yolov5 &#xff0c;于2020年6月发布v1.0版本&#xff0c;最新发布版本为v7.0&#xff0c;License为AGPL-3.0. 以下内容主要来自&#xff1a; 1. U…

MyScaleDB:SQL+向量驱动大模型和大数据新范式

大模型和 AI 数据库双剑合璧&#xff0c;成为大模型降本增效&#xff0c;大数据真正智能的制胜法宝。 大模型&#xff08;LLM&#xff09;的浪潮已经涌动一年多了&#xff0c;尤其是以 GPT-4、Gemini-1.5、Claude-3 等为代表的模型你方唱罢我登场&#xff0c;成为当之无愧的风口…

【R语言数据分析】卡方检验

目录 交叉卡方检验 配对卡方检验 趋势卡方检验 交叉卡方检验 交叉卡方表用于比较组间“率”的差异。适用于分类型变量&#xff0c;被检验的分类变量应该是无序分类变量&#xff0c;分组变量可以是有序分组也可以是无序分组。比如比较两种药物治疗某个疾病的效率&#xff0c;…

Bartender 5 - MacBook菜单栏图标管理软件

当 macOS 桌面图标太多时&#xff0c;既不美观又经常会相互遮盖&#xff0c;非常影响操作。 苹果现在还把「刘海屏」发扬光大&#xff0c;MacBook 的菜单栏是越来越不方便了&#xff01; 如果你希望 Mac 的菜单栏干净清爽、又方便易用&#xff0c;那「Bartender 5」你一定要试…

第15章 基于规格说明的测试技术

一、概述 &#xff08;一&#xff09;依据 《软件需求规格说明书》以及对应的模型或用户需求。 &#xff08;二&#xff09;特点 不考虑内部结构和内部特征 &#xff08;三&#xff09;测试用例满足的标准 利用黑盒测试技术导出测试用例 &#xff08;四&#xff09;测试…

基于 Wireshark 分析 ICMP 协议

一、ICMP 协议 ICMP&#xff08;Internet Control Message Protocol&#xff09;即互联网控制报文协议&#xff0c;是TCP/IP协议簇的一个子协议。它主要用于在IP主机、路由器之间传递控制消息&#xff0c;这些消息涉及网络是否通畅、主机是否可达、路由是否可用等关于网络本身…

2024年北京高校后勤餐饮博览会|北京餐饮展览会

高联采高校后勤餐饮博览会 暨第25届北京高校后勤餐饮联合招标采购大会 同期举办&#xff1a;中国北京餐饮供应链博览会 主 题&#xff1a; 因为FOOD校园GOOD / 同创高校大舞台共享精彩高联采 时 间&#xff1a;2024年9月21日-22日 地 点&#xff1a;中国国际展览中心&…

利用大模型提升个性化推荐的异构知识融合方法

在推荐系统中&#xff0c;分析和挖掘用户行为是至关重要的&#xff0c;尤其是在美团外卖这样的平台上&#xff0c;用户行为表现出多样性&#xff0c;包括不同的行为主体&#xff08;如商家和产品&#xff09;、内容&#xff08;如曝光、点击和订单&#xff09;和场景&#xff0…

【Hadoop】--基于hadoop和hive实现聊天数据统计分析,构建聊天数据分析报表[17]

目录 一、需求分析 1、背景介绍 2、目标 3、需求 4、数据内容 5、建库建表 二、ETL数据清洗 1、数据问题 2、需求 3、实现 4、扩展概念&#xff1a;ETL 三、指标计算 1、指标1&#xff1a;统计今日消息总量 2、指标2&#xff1a;统计每小时消息量、发送量和接收用…

python学习笔记----面向对象(十)

一、什么是类 类是一个抽象的模板&#xff0c;用于创建具体的实例。可以将类理解为一个蓝图&#xff0c;它定义了一系列对象共有的属性&#xff08;数据&#xff09;和方法&#xff08;函数&#xff09;。类是对一组具有相同属性和功能的对象的抽象。例如&#xff0c;你可以定…

FIFO Generate IP核使用——Native读写接口信号详解

Native FIFO接口信号是用于FIFO IP核与外部电路进行通信的信号。当FIFO支持独立的写和读时钟时&#xff0c;这些信号可以包括标准端口和可选端口。 1 当FIFO具有独立时钟时的接口信号 当FIFO具有独立的时钟时&#xff0c;其接口信号会相应地有所变化。特别是关于复位信号rst…

政安晨:【Keras机器学习示例演绎】(三十二)—— 在 Vision Transformers 中学习标记化

目录 导言 导入 超参数 加载并准备 CIFAR-10 数据集 数据扩增 位置嵌入模块 变压器的 MLP 模块 令牌学习器模块 变换器组 带有 TokenLearner 模块的 ViT 模型 培训实用程序 使用 TokenLearner 培训和评估 ViT 实验结果 参数数量 最终说明 政安晨的个人主页&…

Ubuntu TeamViewer安装与使用

TeamViewer是一款跨平台的专有应用程序&#xff0c;允许用户通过互联网连接从全球任何地方远程连接到工作站、传输文件以及召开在线会议。它适用于多种设备&#xff0c;例如个人电脑、智能手机和平板电脑。 TeamViewer在交通不便或偏远地区使用电脑问题时&#xff0c;将发挥重…

从零开始搭建Springboot项目脚手架1:新建项目

1、技术栈 SpringBoot 3.2.5&#xff1a; 2、 新建项目 使用SpringInitializr 选择Lombok、Configuration Processor、Spring Web&#xff0c;同时IDEA也要安装Lombok插件 删除多余的Maven目录、Maven文件&#xff0c;把HELP.md改成README.md。 当然前提是已经安装好Maven和配…

论文辅助笔记:Tempo之modules/prompt.py

1 get_prompt_param_cls 2 get_prompt_value 3 Prompt 类 3.1 _init_weights 3.2 forward

Windows设置Redis为开机自启动

前言 Redis作为当前最常用的当前缓存技术&#xff0c;基本上Web应用中都有使用。所以&#xff0c;每次我们在本地启动项目前&#xff0c;都必须将Redis服务端启动&#xff0c;否则项目就会启动失败。但是&#xff0c;每次都要去启动Redis就很麻烦&#xff0c;有没有办法做到开…

向量体系结构(5):步幅集中一分散

笔记来源《计算机体系结构 量化研究方法》 回答上一篇最后留下的问题 向量体系结构&#xff1a;向量执行时间-CSDN博客 &#xff08;1&#xff09;如何有效向量化多维矩阵运算&#xff1f; &#xff08;2&#xff09;向量处理器如何高效处理稀疏矩阵&#xff1f; 步幅 步…

一文了解python机器学习Sklearn

1.3 安装和配置Sklearn 要使用Sklearn库&#xff0c;首先需要安装Python和相应的库。在本教程中&#xff0c;我们将使用Python 3.x版本。可以使用以下命令安装Sklearn库&#xff1a; pip install scikit-learn安装完成后&#xff0c;可以在Python代码中导入Sklearn库&#xf…

WIN10 anaconda 安装 CondaError: Run ‘conda init‘ before ‘conda activate‘

1 下载 https://www.anaconda.com/download/success 2 安装 3 修改环境变量 安装后修改环境变量 4 winrun 进入命令窗口 输入cmd 输入 conda info 5 创建 虚拟环境 conda create -n yolov8 python3.8 -y 6 CondaError: Run ‘conda init’ before ‘conda activate’ c…

架构每日一学 2:架构师六个生存法则之一:架构必须有且仅有一个目标(一)

本文首发于公众号&#xff1a;腐烂的橘子 为什么有的架构活动没有正确的目标&#xff1f; 在每个架构活动启动之前&#xff0c;必须有且仅有一个正确的目标&#xff0c;这是架构设计的起点[1]。何为正确&#xff1f;正确就是要与公司的战略目标相匹配。否则系统会变得复杂和无…