写在前面

不知何时起,我总是喜欢在推文前面写上写在前面,可能是表达我的一种心境吧。在家里的日子在不断的测试和完善流程,每当我累了的时候,总想去google找一些新鲜东西,然后修改,最后适合自己的模子,变成对自己功能强大的样子,慢慢的这种方式变成了习惯。

华夫饼干图

在本文中,我将展示如何使用ggplot2绘图包在R中创建各种样式的“华夫饼”图。我定义了超过物种华夫饼图的元素,这些元素当然都会来自ggplot和相关的R包,然后修改了一个gihub上的函数,用于出图,因为后面微生物领域需要哟一些华夫饼图的需求,所以我这里做了一些尝试,希望可以有一些思考。

首先,我将为模拟数据创建一个数据框,初始化数据类型:

library(dplyr)
d <- data_frame(date = as.Date(1:813, origin = "2018-01-01"),year = format(date, "%Y"),week = as.integer(format(date, "%W")) + 1,  # Week starts at 1day = factor(weekdays(date, TRUE),levels = rev(c("周一","周二","周三","周四","周五","周六","周日"))),hours = 0)
d
## # A tibble: 813 x 5
##    date       year   week day   hours
##    <date>     <chr> <dbl> <fct> <dbl>
##  1 2018-01-02 2018      2 周二      0
##  2 2018-01-03 2018      2 周三      0
##  3 2018-01-04 2018      2 周四      0
##  4 2018-01-05 2018      2 周五      0
##  5 2018-01-06 2018      2 周六      0
##  6 2018-01-07 2018      2 周日      0
##  7 2018-01-08 2018      3 周一      0
##  8 2018-01-09 2018      3 周二      0
##  9 2018-01-10 2018      3 周三      0
## 10 2018-01-11 2018      3 周四      0
## # ... with 803 more rows

然后模拟每个日期的工作时间。我将模拟周末和工作日分别工作的小时数,以使生成的数据更加真实,并模拟数据的缺失值(即没有工作的天数)。

set.seed(1)
# Simulate weekends
weekends <- dplyr::filter(d, grepl("S(at|un)", day))
# Hours worked are (might be) poisson distributed
weekends$hours <- rpois(nrow(weekends), lambda = 4)
# Simulate missing days with probability .7
weekends$na <- rbinom(nrow(weekends), 1, 0.7)
weekends$hours <- ifelse(weekends$na, NA, weekends$hours)# Simulate weekdays
weekdays <- filter(d, !grepl("S(at|un)", day))
weekdays$hours <- rpois(nrow(weekdays), lambda = 8)  # Greater lambda
weekdays$na <- rbinom(nrow(weekdays), 1, 0.1)  # Smaller p(missing)
weekdays$hours <- ifelse(weekdays$na, NA, weekdays$hours)# Concatenate weekends and weekdays and arrange by date
d <- bind_rows(weekends, weekdays) %>%arrange(date) %>%  # Arrange by dateselect(-na)  # Remove na column
d
## # A tibble: 813 x 5
##    date       year   week day   hours
##    <date>     <chr> <dbl> <fct> <int>
##  1 2018-01-02 2018      2 周二     NA
##  2 2018-01-03 2018      2 周三      7
##  3 2018-01-04 2018      2 周四      8
##  4 2018-01-05 2018      2 周五     NA
##  5 2018-01-06 2018      2 周六     NA
##  6 2018-01-07 2018      2 周日     12
##  7 2018-01-08 2018      3 周一     13
##  8 2018-01-09 2018      3 周二      9
##  9 2018-01-10 2018      3 周三      9
## 10 2018-01-11 2018      3 周四      4
## # ... with 803 more rows

华夫饼图功能函数

然后,我将创建一个绘制华夫饼图的函数。如果您具有类似的结构化数据,则可以复制粘贴该函数并将其用于数据)。

library(ggplot2)
library(viridis)  # Color palette
library(ggthemes)
library(ggcor)
gh_waffle <- function(data, pal = "D", dir = -1,type = 21){p <- ggplot(data, aes(x = week, y = day, fill = hours)) +scale_fill_viridis(name="Hours",option = pal,  # Variable color palettedirection = dir,  # Variable color directionna.value = "grey93",limits = c(0, max(data$hours))) +# geom_tile(color = "white", size = 0.4) +facet_wrap("year", ncol = 1) +scale_x_continuous(expand = c(0, 0),breaks = seq(1, 52, length = 12),labels = c("Jan", "Feb", "Mar", "Apr", "May", "Jun","Jul", "Aug", "Sep", "Oct", "Nov", "Dec")) +theme_tufte(base_family = "Helvetica") +theme(axis.title = element_blank(),axis.ticks = element_blank(),legend.position = "bottom",legend.key.width = unit(1, "cm"),strip.text = element_text(hjust = 0.01, face = "bold", size = 12))#圆形
if(type == 21){p = p +geom_point(color = "white", size = 4,pch = 21) }
#方形
if(type == 22){p = p +geom_point(color = "white", size = 3,pch = 22)}
#菱方形
if(type == 23){p = p +geom_point(color = "white", size = 3,pch = 23) }
#上三角
if(type == 24){p = p +geom_point(color = "white", size = 3,pch = 24) }
#下三角
if(type == 25){p = p +geom_point(color = "white", size = 3,pch = 25) }#星形状图
if(type == "star"){p = p +geom_star() }
#饼图
if(type == "pie2"){p = p + geom_pie2(size = 0.5) }print(p)
}

使用华夫饼图功能

gh_waffle()接受三个参数,第一个data是具有以下列的数据框date:(类型:日期),year(数字或字符),week(数字),day(使日期从图的顶部到底部连续的有序因素)和hours(数字) 。第二个选项来pal指定由所使用的四个色调色板一个viridis,并且可以是“A”,“B”,“C”,或“D”。默认值为“ D”,这也是GitHub所使用的。最后一个选项dir指定色标的方向,可以是-1或1。GitHub的默认值为-1。

使用gh_waffle()默认设置,仅提供数据框d,将得到以下结果:

gh_waffle(d,pal = "D", dir = -1,type = 21)

方形

gh_waffle(d,pal = "D", dir = -1,type = 22)

菱形华夫饼图

gh_waffle(d,pal = "D", dir = -1,type = 23)

三角形华夫饼图

gh_waffle(d,pal = "D", dir = -1,type = 24)

gh_waffle(d,pal = "D", dir = -1,type = 25)

五角星的华夫饼图

厚哥的包,让我们可以使用五角星的华夫饼图

gh_waffle(d,pal = "D", dir = -1,type = "star")

饼图类型华夫饼图

gh_waffle(d,pal = "D", dir = -1,type = "pie2")

尝试不同配色方案

for (pal in c("A", "B", "C")) {gh_waffle(d,pal, dir = -1,type = "star")
}

reference

https://vuorre.netlify.com/post/2016/03/24/github-style-waffle-plots-in-r/

猜你喜欢

10000+:菌群分析 宝宝与猫狗 梅毒狂想曲 提DNA发Nature Cell专刊 肠道指挥大脑

系列教程:微生物组入门 Biostar 微生物组  宏基因组

专业技能:学术图表 高分文章 生信宝典 不可或缺的人

一文读懂:宏基因组 寄生虫益处 进化树

必备技能:提问 搜索  Endnote

文献阅读 热心肠 SemanticScholar Geenmedical

扩增子分析:图表解读 分析流程 统计绘图

16S功能预测   PICRUSt  FAPROTAX  Bugbase Tax4Fun

在线工具:16S预测培养基 生信绘图

科研经验:云笔记  云协作 公众号

编程模板: Shell  R Perl

生物科普:  肠道细菌 人体上的生命 生命大跃进  细胞暗战 人体奥秘

写在后面

为鼓励读者交流、快速解决科研困难,我们建立了“宏基因组”专业讨论群,目前己有国内外5000+ 一线科研人员加入。参与讨论,获得专业解答,欢迎分享此文至朋友圈,并扫码加主编好友带你入群,务必备注“姓名-单位-研究方向-职称/年级”。PI请明示身份,另有海内外微生物相关PI群供大佬合作交流。技术问题寻求帮助,首先阅读《如何优雅的提问》学习解决问题思路,仍未解决群内讨论,问题不私聊,帮助同行。

学习16S扩增子、宏基因组科研思路和分析实战,关注“宏基因组”

点击阅读原文,跳转最新文章目录阅读

让我们定义一个ggplot版本的华夫饼图吧相关推荐

  1. AOV网--拓扑排序(必须是一个有向无环图)

     特点: 1.  AOV网用顶点表示活动,用弧表示活动之间优先关系, 2. AOV网中的弧表示活动之间存在某种制约关系, 3. AOV网中不能出现回路(如果有回路,说明某项活动以自己作为先决条件,不允 ...

  2. 定义一个Employee类并排序(完整版本)

    定义一个Employee类,属性:name:String,age:int,salary:double <span style="white-space:pre"> &l ...

  3. linux gcc 宏定义 __GNUC__ __GNUC_MINOR__ 版本区分

    今天在看Linux系统编程这本书的代码的时候看到了__GNUC__,不太清楚这个宏所以去查了一下,以此记录.GNU C预定义了一系列的宏,这些宏都是以双下划线开始的,这里只讲一下__GNUC__  _ ...

  4. C++20 - 下一个大版本功能确定

    C++20的功能特性已经于3月份冻结,显然这次终于来了一波大的改进,而不再是像之前C++14/C++17那般小打小闹的做小步快跑,尤其是三个讨论很久的大feature终于被合入主干:并且这些featu ...

  5. php定义一个名为Vehicles,php的扩展和嵌入--c++类的扩展开发

    配置文件:config.m4 1 PHP_ARG_ENABLE(vehicles, 2 [Whether to enable the "vehicles" extension], ...

  6. 我们讨论的是《战争之城》的一个简单版本。如果地图上只有空旷的空间,河流,钢墙和砖墙。你的任务是尽快得到奖金,假设没有敌人会打扰你(见下图) 你的坦克不能穿过河流和墙壁,但它可以通过射击摧毁砖墙。当你击

    我们讨论的是<战争之城>的一个简单版本.如果地图上只有空旷的空间,河流,钢墙和砖墙.你的任务是尽快得到奖金,假设没有敌人会打扰你(见下图) 你的坦克不能穿过河流和墙壁,但它可以通过射击摧毁 ...

  7. 手把手带你利用栈来实现一个简易版本的计算器

    手把手带你利用栈来实现一个简易版本的计算器 什么是栈 栈的实现 通过数组实现 通过队列实现 实现思路 栈的经典应用场景 浏览器前进后退 括号配对 leetcode 20 题 表达式求值 leetcod ...

  8. NodeJs——(16)用Nodejs 4.X版本,制作一个微博网站(多图,详细步骤)(已完成)

    博文已完成,版本号v1.0 范例网址已移除,请下载源码(下载后需要自行设置mysql) 附完整源代码下载链接(0积分下载):http://download.csdn.net/detail/qq2000 ...

  9. 易语言- 定义一个系统范围的热键 RegisterHotKey UnregisterHotKey

    .版本 2 .DLL命令 UnregisterHotKey, 整数型, , "UnregisterHotKey"     .参数 hWnd, 整数型     .参数 HotKeyI ...

最新文章

  1. p和li之间的应用上的区别
  2. ISO base media file format---iso 基础媒体文件格式(专业名称)
  3. 一次完整较为渗透过程
  4. Linux 0-1 修改主机名及IP地址
  5. mysql5.7是测试版本吗_mysql免安装版本测试(mysql-5.7.18-winx64)
  6. 抓包红色_抓包三部曲 WebSocket 协议原理抓包分析
  7. redis 分页_Redis排行榜的设计与实现
  8. (8)UART发送verilog与Systemverilog编码
  9. WORD 同一位置连续引用多个参考文献编辑技巧
  10. WPF 模拟UI 键盘录入
  11. .Net中的Placeholder控件
  12. 使用Java将图片转成Base64编码,并压缩至40k
  13. 软件测试和调试的区别
  14. 使用python做手机app后台
  15. python自动剪视频_python剪切视频与合并视频的实现
  16. Linux下操作Excel表格,xlsx表格
  17. 极客漫画-网络篇(二)
  18. 王道计算机组成原理第六章---总线总结
  19. 知识工作效率八段锦 【51PPT】
  20. 广西大学oj1037(小西的c语言作业)

热门文章

  1. 离开互联网大厂的年轻人都去了哪儿?
  2. 推荐10个腾讯系大佬!第一个从华为离职,写了2本畅销书!
  3. 去某大厂三面总监面,因为迟到了5分钟,面试官当着我的面把简历扔垃圾桶了...
  4. 淘宝亿级高并发分布式架构演进之路
  5. 如何拿到高薪数据分析师offer?从精准解读一篇招聘信息开始!
  6. Java架构体系学习路线图,这六点尤为重要!
  7. 互联网架构为什么要做服务化
  8. 推荐8个鲜为人知,但是很有意思的工具,简洁又好用!
  9. 假3D场景逼真到火爆外网!超1亿像素无死角,被赞AI渲染新高度
  10. 结构光系统标定方法详解