指数随机图模型 ERGM(Exponential Random Graph Models)

指数随机图模型 ERGM(Exponential Random Graph Models)

指数随机图模型(Exponential Random Graph Models,ERGM),也称为 p* 模型,是一种用于分析网络数据的统计模型。该模型通过考虑图中节点和边之间的依赖关系,来捕捉网络结构的复杂性。ERGM 的基本思想是,通过定义一系列统计量(称为图统计量),这些统计量反映了图的结构特征,然后使用这些统计量来描述网络的生成过程。
ERGM 的主要步骤包括:

  1. 定义图统计量
    图统计量是网络中结构特征的定量表示,例如节点的度数分布、三角形闭包、节点属性的同质性等。这些统计量反映了网络中的局部和全局结构特征。

  2. 构建概率模型
    ERGM 假设给定图统计量的线性组合(加权和)可以用于描述网络的概率分布。具体来说,ERGM 模型的形式可以表示为:
    P(Y = y) = \frac{\exp(\theta^T g(y,X))}{c(\theta)}

  • Y 是随机关系集;y 是特定的关系集,当Y=1时表示有连接,Y=0 时表示无连接,这种连接既可以是有向的,也可以是无向的。
  • \theta是模型参数,g(y,X)是模型对应的统计量,X是影响因素,c(\theta)是归一化常数,确保概率和为 1。
  • 给定该分布中的特定图y,它出现的概率可以通过该公式进行推导,并且依赖于网络y中的统计值 g(y,X)和对应参数θ,因此,ERGM可以解释某一网络中的各种可能结构规律。
  1. 参数估计
    通过最大似然估计(MLE)或贝叶斯方法来估计模型参数 \theta。由于归一化常数c(\theta) 的计算涉及所有可能图的遍历,因此参数估计过程通常需要使用蒙特卡罗方法或伪似然估计。

  2. 模型检验和诊断
    通过检查模型的拟合优度和残差来评估模型的合理性。例如,可以使用 MCMC 方法生成样本网络,并将其与实际网络进行比较,以验证模型的拟合情况。

ERGM 的优点在于它能够灵活地捕捉网络中的复杂依赖关系和结构特征。然而,由于模型的计算复杂性,特别是对于大规模网络,模型的估计和检验过程可能会比较耗时。

应用领域

ERGM 被广泛应用于社会网络分析、生物网络研究、通信网络建模等领域。例如,在社会网络分析中,ERGM 可以用于研究社交网络中的节点之间的关系模式和影响因素,识别关键节点和社区结构。

示例

假设我们有一个包含 10 个节点的社交网络,节点之间的连边表示友谊关系。我们可以定义一些图统计量,如节点的度数(表示每个节点的朋友数量)、三角形闭包(表示朋友的朋友也是朋友的情况)。通过这些统计量,ERGM 可以用来分析和预测网络的结构特征,例如预测哪些节点更可能形成新的友谊关系。

参考文献

  • Robins, G., Pattison, P., Kalish, Y., & Lusher, D. (2007). An introduction to exponential random graph (p*) models for social networks. Social Networks, 29(2), 173-191.
  • Wasserman, S., & Faust, K. (1994). Social Network Analysis: Methods and Applications. Cambridge University Press.
library(statnet)
library(ergm)
library(sna)
# 读取数据
data("faux.magnolia.high")
fmh <- faux.magnolia.high
plot(fmh,displayisolates=FALSE,vertex.cex=0.8)
Relational Graph.png
# 读取数据成分--》计算度数和节点个数之间的关联
table(component.dist(fmh)$csize)
Degree-Count Matrix.png
# 描述图
summary(fmh)
network attributes.png

vertex attributes.png
# 按类别绘制不同颜色的图
plot(fmh,displayisolates=TRUE,vertex.col="Grade",vertex.cex=0.8)
Classified By Grade.png
# 节点度的计算
fmh.degreedist <- table(degree(fmh,cmode="indegree"))
fmh.degreedist
Degree Matrix.png
#根据分类变量来查看度数分布情况
summary(fmh ~ degree(0:8,"Sex"))
# 内含三元组
summary(fmh ~ triangle)
# 内含边+三元组
summary(fmh ~ edges + triangle)
# 混合矩阵
mixingmatrix(fmh,"Grade")
mixingmatrix(fmh,"Race")
Results.png
# ermg
model_ergm<-ergm(fmh ~ edges)
summary(model_ergm)
# 网络密度
exp(-6.998)/(1+exp(-6.998))
# 模型结果
names(model_ergm)
model_ergm$coefficients
ergm results.png
# 拟合结构=增加星形==>模型退化
model_ergm1<-ergm(fmh ~ edges+kstar(2)+kstar(3))
summary(model_ergm1)
# 拟合结构=增加三角形==>模型退化
model_ergm2<-ergm(fmh ~ edges+triangle)
summary(model_ergm2)
simu<-simulate(model_ergm1,burnin=1e+6,verbose = TRUE,seed = 9)
mixingmatrix(simu,"Race")
mixingmatrix(fmh,"Race")
# 采用图形观测实际值和观测值之间的拟合差异
plot(summary(fmh ~ degree(0:10)),type="l",lty=1,lwd=2,xlab="Degree",ylab="Count")
lines(summary(simu ~ degree(0:10)),type="l",lty=2,lwd=3,xlab="Degree",ylab="Count")
legend("topright",legend = c("observed","simulated"),lwd = 2:3,lty =1:2)
Comparision between Simulates Data and Actual Data.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,324评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,303评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,192评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,555评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,569评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,566评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,927评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,583评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,827评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,590评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,669评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,365评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,941评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,928评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,159评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,880评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,399评论 2 342

推荐阅读更多精彩内容