R语言桑基图

桑基图,也称桑基图(Sankey Diagram),是一种用于展示数据流动的可视化工具。在R语言中,可以使用多种包来创建桑基图,最常用的包括networkD3ggalluvialriverplot等。以下是如何使用这些包创建桑基图的简单示例。

使用networkD3包创建桑基图

首先,确保你已经安装并加载了networkD3包:

R 复制代码
install.packages("networkD3")
library(networkD3)

接下来,准备数据并创建桑基图:

R 复制代码
# 准备数据
nodes <- data.frame(name = c("A", "B", "C", "D", "E", "F"))

links <- as.data.frame(matrix(c(
  0, 1, 10,
  0, 2, 20,
  1, 3, 30,
  2, 3, 40,
  2, 4, 10,
  3, 5, 10,
  4, 5, 10
), byrow = TRUE, ncol = 3))
names(links) <- c("source", "target", "value")

# 创建桑基图
sankey <- sankeyNetwork(Links = links, Nodes = nodes, Source = "source", 
                        Target = "target", Value = "value", NodeID = "name", 
                        sinksRight = FALSE)

# 展示桑基图
sankey

使用ggalluvial包创建桑基图

首先,确保你已经安装并加载了ggalluvial包:

R 复制代码
install.packages("ggalluvial")
library(ggalluvial)

接下来,准备数据并创建桑基图:

R 复制代码
# 准备数据
data <- data.frame(
  stage1 = c("A", "A", "B", "B", "C"),
  stage2 = c("X", "Y", "X", "Y", "Y"),
  freq = c(5, 10, 15, 20, 25)
)

# 创建桑基图
ggplot(data = data, aes(axis1 = stage1, axis2 = stage2, y = freq)) +
  geom_alluvium(aes(fill = stage1)) +
  geom_stratum() +
  geom_text(stat = "stratum", aes(label = after_stat(stratum))) +
  scale_x_discrete(limits = c("Stage 1", "Stage 2")) +
  theme_minimal()

使用riverplot包创建桑基图

首先,确保你已经安装并加载了riverplot包:

R 复制代码
install.packages("riverplot")
library(riverplot)

接下来,准备数据并创建桑基图:

R 复制代码
# 准备数据
nodes <- data.frame(ID = c("A", "B", "C", "D", "E", "F"))
edges <- data.frame(
  N1 = c("A", "A", "B", "C", "C", "D", "E"),
  N2 = c("B", "C", "D", "D", "E", "F", "F"),
  Value = c(10, 20, 30, 40, 10, 10, 10)
)

# 创建桑基图
river <- makeRiver(nodes, edges)
plot(river)

这些示例展示了如何在R语言中使用不同的包创建桑基图,你可以根据自己的需求选择合适的包进行可视化。如果有更具体的需求或问题,请告诉我,我可以提供进一步的帮助。

相关推荐
醇氧16 分钟前
【Linux】Java 服务生产级部署指南:实现常驻后台、开机自启与系统服务化管理
java·开发语言
凡人叶枫28 分钟前
Effective C++ 条款16:成对使用 new 和 delete 时要采取相同形式
开发语言·c++·effective c++
不吃土豆的马铃薯44 分钟前
C++ 高性能网络缓冲区 Buffer 源码解析
linux·服务器·开发语言·网络·c++
数据法师1 小时前
QuickSay :基于 Qt 的轻量级快捷短语管理工具
开发语言·qt
caimouse1 小时前
Reactos 第1章 概述
c语言·开发语言·架构
.千余1 小时前
【C++】C++继承入门(下):友元、静态成员与菱形继承的底层逻辑
开发语言·c++·笔记·学习·其他
小短腿的代码世界2 小时前
行情快照与增量更新引擎:Qt在高频交易数据分发中的核心架构——你的行情推送为什么延迟了500ms?
开发语言·qt·架构
初中就开始混世的大魔王2 小时前
6 Fast DDS-传输层
开发语言·c++·中间件·信息与通信
啊森要自信2 小时前
【GUI自动化测试】控件、鼠标键盘操作与多场景自动化
c语言·开发语言·python·adb·ipython
花北城2 小时前
【C#】ABP框架服务端开发
开发语言·c#·abp