百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

R 数据可视化——ggplot 螺旋图

liuian 2025-05-25 14:04 42 浏览

前言

螺旋图是一种沿着阿基米德螺旋线绘制图形,从螺旋的中心向外螺旋式延伸。

螺旋图比较多变,可以使用条形、线或点几何对象。适用于显示较大的数据集或周期性数据。

示例

使用 ggplot2 绘制螺旋线,本质上还是要自己先对数据进行整理,如下图

group_by(bit_data, year, month) %>%
  summarise(value = mean(High), high = sd(High)) %>%
  mutate(
    x = month,
    # y 轴坐标随着月份的增加均匀升高,
    # 同时不同年份之间的高度首尾连续
    y = (year - 2015) * 11 + month - 1
  ) %>%
  ggplot(aes(x, y, group = year, colour = value)) +
  geom_line() +
  # coord_polar() +
  scale_colour_gradientn(colours = rainbow(3)) +
  scale_y_continuous("year", breaks = seq(0, 36, 12), labels = 2015:2018) +
  scale_x_continuous("month", breaks = 1:12, labels = 1:12)

4 条线分别代表 2015-2018 年份,x 轴代表的是月份,颜色表示的是比特币的价格。

我们需要以梯度的方式,各分组之间具有相同的斜率,且两条相邻的线条之间的前端与末端之间的高度是一样的

进行极坐标系变换之后,如下图

coord_polar() +
theme(
    panel.background = element_blank()
  )

将线条换成点图

如果要使用条形图,则会更麻烦一些,如果直接使用 geom_tile

看起来被割裂了一样,我们看看在笛卡尔坐标系下的样子

看起来我们应该将每个条形的右边坐标上提,也就是绘制底边平行的平行四边形

首先,我们需要计算出四边形的四个顶点,然后将右边的两个顶点向上平移,同时为条形图添加了随机的高度,用来模拟比特币价格在该月份中的波动范围

data <- group_by(bit_data, year, month) %>%
  summarise(value = mean(High)) %>%
  mutate(
    xmin = month,
    xmax = month + 1,
    ymin = (year - 2015) * 12 + month,
    ymax = ymin + runif(n(), min = 0.5, max = 1)
  ) %>%
  # 根据每行的四个坐标,构建成 4 行,代表 4 个点
  # 因为 geom_polygon 是逆时针连接起来的,所以点
  # 的顺序也要依次排列
  rowwise() %>%
  do(with(., tibble(
    year = year,
    month = month,
    value = value,
    x = c(xmin, xmax, xmax, xmin),
    y = c(ymin, ymin + 1, ymax + 1, ymax)
  )))

构建完数据之后,我们看看其在直角坐标系下的样子

ggplot(data, aes(x, y, group = paste(year, month))) +
  geom_polygon(fill = "green", colour = "black")

在这里,设置 group 参数非常重要。我们要每个月份作为一组,绘制一个平行四边形,所以需要根据年份与月份两列来进行分组

然后,将它旋起来

ggplot(data, aes(x, y, group = paste(year, month))) +
  geom_polygon(aes(fill = value), colour = "black") +
  coord_polar() +
  scale_x_continuous("month", breaks = seq(1.5, 12.5, 1), labels = month.name) +
  scale_fill_gradientn(values = seq(0,1,0.2), colours = c('cyan','blue','green','orange','red')) +
  ylim(c(-6, 60)) +
  theme(
    panel.background = element_blank(),
    axis.ticks = element_blank(),
    axis.title = element_blank(),
    axis.text.y = element_blank()
  )

换个配色

gcolors <- c("#8dd3c7", "#ffffb3", "#bebada", "#fb8072", "#80b1d3")

如果要绘制螺旋热图的话,可以将条形的高度设置为 12

# ymax = ymin + runif(n(), min = 3, max = 10)
ymax = ymin + 12
gcolors

也可以绘制螺旋面积图

首先构造数据

df <- tibble(
  date = seq(as.Date("2015-01-01"), as.Date("2019-12-31"), "days"),
  value = runif(length(date), min = 50, max = 300)
) %>%
  mutate(year = year(date), month = month(date), day = yday(date)) %>%
  # 去除闰年多出的一天
  filter(day != 366) %>%
  mutate(
    # 构造 y 轴梯度
    ymin = (year - 2015) * 364 + day, 
    ymax = ymin + value
  )

绘制图形

ggplot(df, aes(x = day, group = year)) +
  geom_ribbon(aes(ymin = ymin, ymax = ymax), fill = "orange") +
  geom_line(aes(y = ymin)) +
  geom_line(aes(y = ymax), colour = "grey40") +
  coord_polar(start = 1) +
  scale_x_continuous(
    breaks = c(1,31,59,90,120,151,181,212,243,273,304,334),
    labels = month.name
  ) +
  theme(
    panel.background = element_blank(),
    panel.grid.major.x = element_line(colour = "grey20", size = 0.25),
    axis.ticks = element_blank(),
    axis.title = element_blank(),
    axis.text.y = element_blank()
  )

如果想要添加渐变色,可以将 geom_ribbon 替换为 geom_linerange

gcolors = c("#8dd3c7", "#ffffb3", "#bebada", "#fb8072", "#80b1d3")

geom_linerange(aes(ymin = ymin, ymax = ymax, colour = value)) +
scale_colour_gradientn(values = seq(0,1,0.2), 
                         colours = gcolors)

这种颜色也挺好看的

gcolors = c('#7fc97f','#beaed4','#fdc086','#ffff99','#386cb0')

相关推荐

最好的在线影视免费(哪个网站能看到免费的电视剧)

在线网站看电影不卡顿1.欧西电影它是一个很好用的追剧网站,里面都是一些高清免费的电影,但是只能在线观看,不能够去下载,不过它还支持手机观看哦,非常的方便,只要网络好就没问题了。2.思古影视这是一个可以...

解除安全模式dnf(解除安全模式怎么解除)
  • 解除安全模式dnf(解除安全模式怎么解除)
  • 解除安全模式dnf(解除安全模式怎么解除)
  • 解除安全模式dnf(解除安全模式怎么解除)
  • 解除安全模式dnf(解除安全模式怎么解除)
路由器更换密码(mw300r路由器初始密码)

打开浏览器,在地址栏输入192.168.1.1(一般路由器地址是这个或者查看路由器背面的登录信息)进路由-输入用户名,密码,(默认一般是admin)。2、点击:系统工具--登陆口令--修改---保存...

如何设置无线路由器的wifi密码

1、首先连接、开启路由器,使它可以正常工作;其次把网线的两头分别与路由器的外网接口、电脑的内网接口相接;最后开启浏览器,进入路由器的设置主页,在密码管理选项中,输入相应的账户名称、密码,点击保存就设置...

如何给电脑软件加密(如何给电脑软件加密码锁)

电脑可以通过以下几种方式给应用程序加锁:1. 使用操作系统自带的功能:在Windows操作系统中,可以使用“家长控制”功能对特定应用程序进行限制,包括设置密码、限制使用时间等。在Mac...

window10中文语言包下载(win10 语言包下载)

1、进入的这个程序“steam”游戏库中打开巫师3的中文设置。单击右键,找到属性,再打开的属性弹窗中,找到语言,再语言列表中就可以选择我们想要的语言,可以看到没有简体中文。2、最后进入游戏中选择选项,...

win10任务管理器灰色打不开(windows10任务管理器打不开怎么办)

是的,任务管理器可能会出现灰色的情况。这是因为在某些电脑中,系统管理员有权限限制普通用户使用任务管理器。此外,有一些病毒或恶意软件也会禁止用户打开任务管理器,以防其被检测和结束。如果用户想要打开任务管...

请重试(请重试无法验证你的设备)

通常出现这个情况的原因是文档是被保护的。取消文档加密步骤:点击0ffice按钮-准备-加密文档删除密码-确定取消工作表保护如果Excel2007工作表已保护起来,“保护工作表”按钮将自动变化为“取消工...

免费注册个人邮箱账号(免费注册邮箱号码)
  • 免费注册个人邮箱账号(免费注册邮箱号码)
  • 免费注册个人邮箱账号(免费注册邮箱号码)
  • 免费注册个人邮箱账号(免费注册邮箱号码)
  • 免费注册个人邮箱账号(免费注册邮箱号码)
下载机系统(下载机有什么用)

1、点亮手机屏幕,找到【系统工具】文件夹,点击打开。2、进入系统工具界面,找到【文件管理】选项,点击打开。3、在文件管理界面,选择【手机版】选项,点击打开。4、在此界面,向下方滑动找到【downloa...

备份整个硬盘为镜像(备份分区到镜像)

1、尝试过,TimeMachine可以备份到移动硬盘的其中一个分区。2、如果希望移动硬盘既可用于TimeMachine备份,也可用于Windows系统,我是这样做的:首先为移动硬盘分区(至少2个分...

佳能打印机驱动安装视频教程

电脑搜索“佳能驱动”。02进入首页点击“服务于支持”。03然后选择“下载与支持”点击进入。04然后选择你使用的打印机种类图片。05然后在选择产品页面逐一选择产品的种类、系列、型号、下载的文件类型。06...

班级优化大师官网登录(班级优化大师官网登录网址)

班级优化大师可以在另一个手机上重新下载安装该应用,并使用之前绑定的账户进行登录操作,即可同步之前的班级信息和配置。如果之前未绑定账户,则需要通过“找回密码”或“注册新账户”的方式来登录应用,并重新配置...

什么是chatgpt(什么是ai技术)

ChatGPT是由美国人工智能实验室OpenAI开发的一个对话AI模型,于2022年11月正式推出。它能够通过学习和理解人类的语言来进行对话互动,并协助人类完成一系列任务。chatGPT实际上是美国o...

无线网显示不可上网是怎么回事

可能有几下几方面原因:1、无线路由器网络参数设置错误,无法拨通ISP运营商的局端设备,无法接入互联网;2、宽带线路出现故障,路由器无法拨通ISP运营商的局端设备,无法连通;3、宽带DNS服务器由于某种...