跟着PC学作图 | 小提琴图+Tufte箱形图+折线图的绘制教程

2023-11-10 18:10

本文主要是介绍跟着PC学作图 | 小提琴图+Tufte箱形图+折线图的绘制教程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、 数据

本期教程是基于ggplot()绘制,数据类型也符合ggplot()函数类型即可。

本期,直接使用的文章中的数据。

二、绘图

导入相关包

library(ggplot2)
library(tidyverse)
library(reshape)
library(agricolae)library(ggthemes)

导入数据

diam <- read.csv("inputdata.csv", header = TRUE, sep = ',', stringsAsFactors=FALSE)
head(diam)

数据整理

此步更具自己数据需求操作

### Add groups to the data
diam$Groups <- paste(diam$Species,diam$CO2,diam$Day,sep="_")
diam$Groups <- factor(diam$Groups,levels = unique(gtools::mixedsort(diam$Groups)))

差异比较

maxDiam = diam %>% group_by(Groups) %>% summarize(MaxDiameter=max(diameter))### Do tukey tests
hsd_diameter=HSD.test(aov(diameter~Groups,data=diam), "Groups", group=T)
hsd_diameter$groups <- hsd_diameter$groups[levels(diam$Groups),]
tukeyDiameter <- data.frame(rownames(hsd_diameter$groups),do.call("rbind",strsplit(rownames(hsd_diameter$groups),"_")),hsd_diameter$groups,stringsAsFactors = T)
colnames(tukeyDiameter) <- c("Groups","Species","CO2","Day","median_diameter","groups")tukeyDiameter <- left_join(tukeyDiameter,meanDiam,by="Groups")
head(tukeyDiameter)
> head(tukeyDiameter)Groups Species      CO2 Day median_diameter groups
M82_ambient_7     M82_ambient_7     M82  ambient   7        321.9840     bc
M82_ambient_10   M82_ambient_10     M82  ambient  10        390.9108     ab
M82_ambient_13   M82_ambient_13     M82  ambient  13        430.4615      a
M82_elevated_7   M82_elevated_7     M82 elevated   7        316.3562     bc
M82_elevated_10 M82_elevated_10     M82 elevated  10        448.0713      a
M82_elevated_13 M82_elevated_13     M82 elevated  13        443.9278      a

ggplot绘图

  1. 箱线图
plotGG <- ggplot(diam,aes(x=Groups,y=diameter)) +scale_fill_manual(values=c("skyblue1", "black")) + scale_color_manual(values=c("skyblue1", "black")) +geom_violin(aes(color=paste(CO2)),position=position_dodge(1),trim = F,width=1)

Tufte箱形图

plotGG + geom_tufteboxplot(position=position_dodge(1),outlier.colour="transparent", width = 1,color="black")

line图

plotGG02 + geom_line(data=tukeyDiameter, aes(x=Groups, y=median_diameter,group = paste(CO2,Species)),alpha=0.5)

添加显著性差异

plotGG03 <- plotGG02 + geom_text(data=tukeyDiameter, aes(x=Groups, y=(maxDiam$MaxDiameter)*1.25,label=groups,group=NULL),vjust=0,color="black")

进行美化

plotGG03 +theme_bw()+ggtitle("Root diameter change by species in response to eCO2 over time") + xlab('')+ylab(expression(paste("Root diameter (",mu,"m)"))+theme(#legend.position="bottom",legend.text = element_text(size=12),axis.text.y = element_text(size=12, colour="black", family = "sans", angle = 0), axis.text.x = element_text(size=12, colour="black", family = "sans", angle = 45, hjust = 1),axis.title= element_text(size=12),strip.text.x = element_text(size=12, angle = 0),strip.text.y = element_text(size=12, angle = 0),plot.title = element_text(size=12, angle = 0))

绘图全部代码

ggplot(diam,aes(x=Groups,y=diameter)) +scale_fill_manual(values=c("skyblue1", "black")) + scale_color_manual(values=c("skyblue1", "black")) +geom_violin(aes(color=paste(CO2) ),position=position_dodge(1),trim = F,width=1) + #geom_boxplot(aes(color=paste(CO2)),position=position_dodge(1),width=0.09,outlier.shape = NA) + geom_tufteboxplot(position=position_dodge(1),outlier.colour="transparent", width = 1,color="black") + #geom_dotplot(aes(fill=CO2),binaxis='y', stackdir='center',position=position_dodge(1),dotsize = 0.5)  + #Looks cleaner than with#geom_jitter(aes(color=paste(CO2)),width = 0.05,size=0.75) + geom_line(data=tukeyDiameter, aes(x=Groups, y=median_diameter,group = paste(CO2,Species)),alpha=0.5) +facet_grid(.~Species,scales = "free_x",as.table = T) +coord_cartesian(ylim = c(min(diam$diameter)*.6, max(diam$diameter)*1.5)) +theme(axis.text.x = element_text(angle = 45, hjust = 1)) +## 添加显著性差异geom_text(data=tukeyDiameter, aes(x=Groups, y=(maxDiam$MaxDiameter)*1.25,label=groups,group=NULL),vjust=0,color="black")+theme_bw()+ggtitle("Root diameter change by species in response to eCO2 over time") + xlab('')+ylab(expression(paste("Root diameter (",mu,"m)")))+theme(#legend.position="bottom",legend.text = element_text(size=12),axis.text.y = element_text(size=12, colour="black", family = "sans", angle = 0), axis.text.x = element_text(size=12, colour="black", family = "sans", angle = 45, hjust = 1),axis.title= element_text(size=12),strip.text.x = element_text(size=12, angle = 0),strip.text.y = element_text(size=12, angle = 0),plot.title = element_text(size=12, angle = 0))

往期文章:

1. 最全WGCNA教程(替换数据即可出全部结果与图形)

WGCNA分析 | 全流程分析代码 | 代码一

WGCNA分析 | 全流程分析代码 | 代码二

WGCNA分析 | 全流程代码分享 | 代码三


2. 精美图形绘制教程

精美图形绘制教程


小杜的生信筆記,主要发表或收录生物信息学的教程,以及基于R的分析和可视化(包括数据分析,图形绘制等);分享感兴趣的文献和学习资料!!

这篇关于跟着PC学作图 | 小提琴图+Tufte箱形图+折线图的绘制教程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/384391

相关文章

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Makefile简明使用教程

文章目录 规则makefile文件的基本语法:加在命令前的特殊符号:.PHONY伪目标: Makefilev1 直观写法v2 加上中间过程v3 伪目标v4 变量 make 选项-f-n-C Make 是一种流行的构建工具,常用于将源代码转换成可执行文件或者其他形式的输出文件(如库文件、文档等)。Make 可以自动化地执行编译、链接等一系列操作。 规则 makefile文件

【WebGPU Unleashed】1.1 绘制三角形

一部2024新的WebGPU教程,作者Shi Yan。内容很好,翻译过来与大家共享,内容上会有改动,加上自己的理解。更多精彩内容尽在 dt.sim3d.cn ,关注公众号【sky的数孪技术】,技术交流、源码下载请添加微信号:digital_twin123 在 3D 渲染领域,三角形是最基本的绘制元素。在这里,我们将学习如何绘制单个三角形。接下来我们将制作一个简单的着色器来定义三角形内的像素

SWAP作物生长模型安装教程、数据制备、敏感性分析、气候变化影响、R模型敏感性分析与贝叶斯优化、Fortran源代码分析、气候数据降尺度与变化影响分析

查看原文>>>全流程SWAP农业模型数据制备、敏感性分析及气候变化影响实践技术应用 SWAP模型是由荷兰瓦赫宁根大学开发的先进农作物模型,它综合考虑了土壤-水分-大气以及植被间的相互作用;是一种描述作物生长过程的一种机理性作物生长模型。它不但运用Richard方程,使其能够精确的模拟土壤中水分的运动,而且耦合了WOFOST作物模型使作物的生长描述更为科学。 本文让更多的科研人员和农业工作者

Flutter 进阶:绘制加载动画

绘制加载动画:由小圆组成的大圆 1. 定义 LoadingScreen 类2. 实现 _LoadingScreenState 类3. 定义 LoadingPainter 类4. 总结 实现加载动画 我们需要定义两个类:LoadingScreen 和 LoadingPainter。LoadingScreen 负责控制动画的状态,而 LoadingPainter 则负责绘制动画。

沁恒CH32在MounRiver Studio上环境配置以及使用详细教程

目录 1.  RISC-V简介 2.  CPU架构现状 3.  MounRiver Studio软件下载 4.  MounRiver Studio软件安装 5.  MounRiver Studio软件介绍 6.  创建工程 7.  编译代码 1.  RISC-V简介         RISC就是精简指令集计算机(Reduced Instruction SetCom

前端技术(七)——less 教程

一、less简介 1. less是什么? less是一种动态样式语言,属于css预处理器的范畴,它扩展了CSS语言,增加了变量、Mixin、函数等特性,使CSS 更易维护和扩展LESS 既可以在 客户端 上运行 ,也可以借助Node.js在服务端运行。 less的中文官网:https://lesscss.cn/ 2. less编译工具 koala 官网 http://koala-app.

【Shiro】Shiro 的学习教程(三)之 SpringBoot 集成 Shiro

目录 1、环境准备2、引入 Shiro3、实现认证、退出3.1、使用死数据实现3.2、引入数据库,添加注册功能后端代码前端代码 3.3、MD5、Salt 的认证流程 4.、实现授权4.1、基于角色授权4.2、基于资源授权 5、引入缓存5.1、EhCache 实现缓存5.2、集成 Redis 实现 Shiro 缓存 1、环境准备 新建一个 SpringBoot 工程,引入依赖:

利用matlab bar函数绘制较为复杂的柱状图,并在图中进行适当标注

示例代码和结果如下:小疑问:如何自动选择合适的坐标位置对柱状图的数值大小进行标注?😂 clear; close all;x = 1:3;aa=[28.6321521955954 26.2453660695847 21.69102348512086.93747104431360 6.25442246899816 3.342835958564245.51365061796319 4.87

Windows环境利用VS2022编译 libvpx 源码教程

libvpx libvpx 是一个开源的视频编码库,由 WebM 项目开发和维护,专门用于 VP8 和 VP9 视频编码格式的编解码处理。它支持高质量的视频压缩,广泛应用于视频会议、在线教育、视频直播服务等多种场景中。libvpx 的特点包括跨平台兼容性、硬件加速支持以及灵活的接口设计,使其可以轻松集成到各种应用程序中。 libvpx 的安装和配置过程相对简单,用户可以从官方网站下载源代码