使用 ggbreak 包进行 Y 轴多次截断

简介: 使用 ggbreak 包进行 Y 轴多次截断

简介

最近在科研中需要比较不同模型的预测性能,我们使用相对偏差,均方根误差等来比较结果。此时,可能会得到以下结果:

上图出现以下问题:

  • 问题一:由于经典模型(Normal)在复杂数据中的预测效果不好,会出现预测非常差的情况,从而导致图形Y轴刻度被拉长,可视化效果不佳。
  • 问题二:相似方法预测结果相同,无法清晰看出之间的差异性。
  • 问题三:柱状图准确数字未知,只能通过主观方式估计最终结果。

基于以上问题,小编分别做了以下润色工作:

  1. 问题一二可以通过使用 ggbreak 包[1] 进行多次 Y 轴截断。
  2. 添加每个柱状图的准确数值结果来解决问题三。
  3. 简单修改图形颜色,删除图例,使其变得更加美观。

最后得到以下图形:

接下来给出可复现的代码供大家参考,读者可以根据自己数据进行调整。

使用教程

数据产生

为了方便读者复现,小编手动产生一些样例数据:

com_cost = c(17.64,4.89,5.13,8.43,5.32)
com_cost_re = data.frame("Method" = c("Normal","TS","Linear","Power","Exp"),"Value"= round(com_cost,3))
com_cost_re$Method <- factor(com_cost_re$Method, levels = c("Normal","Power","Exp","Linear","TS"))

可视化

首先,对该数据进行可视化,并做了些细节调整。例如:修改配色、添加文本、删除图例等。

gg1 = ggplot(com_cost_re, aes(x = Method, y = Value)) +
  geom_bar(stat = "identity", aes(fill = Method),alpha = 0.8) +
  scale_fill_viridis(discrete = T)+ # 修改配色
  geom_text(aes(label = Value), position = position_dodge(width = 0.8), 
            vjust = 2, size = 4,color = "white") +  # 添加文本
  coord_cartesian(ylim = c(4,18)) +  
  theme_bw() +  # 设置主题
  theme(panel.grid = element_blank(),legend.position = "none") + # 删除图例
  labs(title = "", x = "Method", y = "Criteria")
gg1

此时,图形美观度基本完成,接下来使用 ggbreak 包进行多次 Y 轴截断。主要使用 scale_y_break() 函数。

注意:关于  scale_y_break() 的其他参数设置可参考:ggbreak官网教程[2],这里不做过多重复介绍。

gg2 = gg1 + scale_y_break(c(5.35, 8.34)) + 
  scale_y_break(c(0, 4.7)) + 
  scale_y_break(c(8.5, 17.5))

此时得到的结果为:

小编有话说

本文主要是小编在科研中存在的一个问题,最终通过一些简单搜索和调包解决问题。供大家参考~

参考资料

[1]

ggbreak 包: https://github.com/YuLab-SMU/ggbreak

[2]

ggbreak官网教程: https://cran.r-project.org/web/packages/ggbreak/vignettes/ggbreak.html

目录
相关文章
|
算法 测试技术 C#
C++前缀和算法应用:矩形区域不超过 K 的最大数值和
C++前缀和算法应用:矩形区域不超过 K 的最大数值和
|
JavaScript 数据处理
👻关于ECharts的那些事儿(数据超出Y轴最大值max又不想它隐藏)
👻关于ECharts的那些事儿(数据超出Y轴最大值max又不想它隐藏)
1274 0
|
算法 C# C++
HOperatorSet.GenRectangle1 参数是负数的矩形
HOperatorSet.GenRectangle1 参数是负数的矩形
|
3月前
如何设置条件格式以填充颜色?
【10月更文挑战第21天】如何设置条件格式以填充颜色?
118 2
|
8月前
|
Python
Python批量求取多景栅格文件之间的像素差值
【2月更文挑战第18天】本文介绍基于Python语言,针对一个含有大量遥感影像栅格文件的文件夹,从其中第2景遥感影像开始,分别用每一景影像减去其前一景影像,从而求取二者的差值,并将每一个所得到的差值结果保存为新的一景遥感影像文件的方法~
Python批量求取多景栅格文件之间的像素差值
|
8月前
leetcode-363:矩形区域不超过 K 的最大数值和
leetcode-363:矩形区域不超过 K 的最大数值和
44 0
|
8月前
|
Python
python输入位置的坐标(即经纬度),计算两点的距离结果保留两位
python输入位置的坐标(即经纬度),计算两点的距离结果保留两位
[虚幻引擎 UE5] EditableText(单行可编辑文本) 限制只能输入数字并且设置最小值和最大值
本蓝图函数可以格式化 EditableText 控件输入的数据,让其只能输入一定范围内的整数。
553 0
ENVI按行数、列数或像元个数裁剪栅格图像
本文介绍基于ENVI软件,实现栅格遥感影像按照像元行列号与个数进行指定矩形区域裁剪的方法~
249 1
ENVI按行数、列数或像元个数裁剪栅格图像

热门文章

最新文章