当前位置:首页 > 技术知识 > 正文内容

R语言折线图+散点图可视化数据时间动态

maynowei9个月前 (08-16)技术知识132
图1 颗粒物的C:P和N:P比对供应比中的氮磷比(N:P)较为敏感,而 C:N 比则相对稳定( Seelen EA , et al. (2025). Nitrogen and phosphorus differentially control marine biomass production and stoichiometry . Nature Communications, 16, 5713 .
# 加载必要的包library(ggplot2)library(vegan)library(cowplot)library(dplyr)
# --------------------------# (1) 模拟数据生成(控制变异性)# --------------------------
# 1.1 折线图数据(减小随机波动范围)set.seed(123)n_replicates <- 3 # 每个组合的重复数df_line <- expand.grid( Day = c(0, 5, 10, 15, 25, 30), Treatment = LETTERS[1:5], Replicate = 1:n_replicates)
# 为每个处理-时间点生成更集中的数据(减小标准差)for (i in 1:nrow(df_line)) { day <- df_line$Day[i] treatment <- df_line$Treatment[i] base_value <- 15 + day * 0.2 # 基础值随天数轻微增加 df_line$Part.C[i] <- rnorm(1, mean = base_value, sd = 1.5) # 标准差从3减小到1.5}
# 计算均值和标准差df_summary <- df_line %>% group_by(Day, Treatment) %>% summarise( Mean = mean(Part.C), SD = sd(Part.C), .groups = "drop" )
# 1.2 PCoA 数据(保持不变)set.seed(456)n_samples <- 30n_otus <- 10otu_table <- matrix(rpois(n_samples * n_otus, lambda = 10), nrow = n_samples, ncol = n_otus)rownames(otu_table) <- paste0("Sample", 1:n_samples)metadata <- data.frame( Sample = rownames(otu_table), Treatment = rep(LETTERS[1:5], each = 6), Day = rep(c(0, 5, 10, 15, 25, 30), times = 5))
# --------------------------# (2) 绘制折线图(误差棒缩小)# --------------------------p_line <- ggplot(df_summary, aes(x = Day, y = Mean, color = Treatment, group = Treatment)) + geom_line(linewidth = 1) + geom_point(size = 4,shape=18) + geom_errorbar( aes(ymin = Mean - SD, ymax = Mean + SD), width = 0, linewidth = 0.8 ) + scale_color_manual(values = c("#FFC95E", "#FC7E86", "#507564", "#73C5DC", "#000000")) + labs( x = "Day", y = "Concentration (Part.C)", title = "" ) + theme_bw()+theme(panel.grid.major=element_blank(),panel.grid.minor=element_blank())+ theme(axis.text=element_text(colour='black',size=9))+ theme( legend.position = "NA", plot.title = element_text(face = "bold", hjust = 0) )
# --------------------------# (3) PCoA 分析及绘图(图B,保持不变)# --------------------------dist_matrix <- vegdist(otu_table, method = "bray")pcoa_result <- cmdscale(dist_matrix, k = 2, eig = TRUE)pcoa_scores <- as.data.frame(pcoa_result$points)colnames(pcoa_scores) <- c("PCo1", "PCo2")pcoa_scores$Treatment <- metadata$Treatmentpcoa_scores$Day <- metadata$Dayvariance <- round(pcoa_result$eig / sum(pcoa_result$eig) * 100, 1)
p_pcoa <- ggplot(pcoa_scores, aes(x = PCo1, y = PCo2, color = Treatment, shape = factor(Day))) + geom_point(size = 4, shape=24, alpha = 1) + scale_color_manual(values = c("#FFC95E", "#FC7E86", "#507564", "#73C5DC", "#000000")) + scale_shape_manual(values = c(16, 17, 15, 18, 8, 3)) + labs( x = paste0("PCo1 (", variance[1], "%)"), y = paste0("PCo2 (", variance[2], "%)"), title = "", shape = "Day" ) + theme_bw()+theme(panel.grid.major=element_blank(),panel.grid.minor=element_blank())+ theme(axis.text=element_text(colour='black',size=9))+ theme( legend.position = "right", plot.title = element_text(face = "bold", hjust = 0) )
# --------------------------# (4) 组合图形# --------------------------library(cowplot)cowplot::plot_grid(p_line, p_pcoa ,ncol= 2, rel_widths = c(1, 1.4))

相关文章

IT博物馆之Objective-C诞生(micro博物馆)

1984年,Objective-C诞生。设计者:布莱德·考克斯(Brad Cox)、汤姆·洛夫(Tom Love)Objective-C是面向对象的通用、高级编程语言。它扩展了标准的 ANSI C,将...

[三菱PLC] 用&quot;C语言&quot;玩转PLC,三菱PLC使用ST语言超详细教程

ST语言,全称为结构化文本(Structured Text),是一种高级编程语言,专为工业自动化和控制系统设计。我们学习PLC一般是用梯形图,梯形图学会后,学习SFC,但是我发现梯形图和SFC虽然简单...

有了这份900多页的Android面试指南,你离大厂Offer还远吗?

前言对于大部分程序员来说,一线互联网是的工作经历是毕生的追求,实际上大厂对于学历的要求远远没有我们想象的那么高,近几年来,互联网公司更注重技术,所以提升自身技术水平才是斩获offer的制胜关键。一线互...

如何正确理解Java领域中的并发锁,我们应该具体掌握到什么程度?

苍穹之边,浩瀚之挚,眰恦之美; 悟心悟性,善始善终,惟善惟道! —— 朝槿《朝槿兮年说》写在开头对于Java领域中的锁,其实从接触Java至今,我相信每一位Java Developer都会有这样的一个...

Linux系统编程:条件变量为什么要用锁

条件变量可以解决线程同步和共享资源访问的问题,条件变量是对互斥锁的补充,它允许一个线程阻塞并等待另一个线程发送的信号,当收到信号时,阻塞的线程被唤醒并试图锁定与之相关的互斥锁。具体定义如下:等待:in...

Linux C++实现多线程同步的四种方式(超级详细)

背景问题:在特定的应用场景下,多线程不进行同步会造成什么问题?通过多线程模拟多窗口售票为例:#include <iostream>#include<pthread.h>#inc...