news 2025/12/25 10:07:06

多个性状曼哈顿图

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
多个性状曼哈顿图
library(qqman)# 创建示例数据 - 改为3个染色体set.seed(123)n_snps<-900n_chr<-3# 创建数据data<- data.frame(SNP=paste0("rs",1:n_snps), CHR=rep(1:n_chr, each=n_snps/n_chr), BP=unlist(lapply(1:n_chr, function(x)sort(sample(1:2e6, n_snps/n_chr)))), P1=runif(n_snps), P2=runif(n_snps), P3=runif(n_snps))# 计算-log10(P)data$logP1<- -log10(data$P1)data$logP2<- -log10(data$P2)data$logP3<- -log10(data$P3)# 第一步:计算染色体边界,增加间距data$x_pos<- NA lastbase<-0ticks<- NULL chr_ends<- c()# 增加染色体间距的倍数space_multiplier<-0.3# 控制间距大小,值越大间距越大for(iin1:n_chr){chr_data<- data[data$CHR==i,]chr_length<- max(chr_data$BP, na.rm=TRUE)- min(chr_data$BP, na.rm=TRUE)if(i==1){data$x_pos[data$CHR==i]<- data$BP[data$CHR==i]}else{# 增加间距:前一个染色体的长度 + 间距lastbase<- lastbase + max(data$BP[data$CHR==(i-1)], na.rm=TRUE)+(chr_length * space_multiplier)data$x_pos[data$CHR==i]<- data$BP[data$CHR==i]+ lastbase}# 记录染色体结束位置chr_ends<- c(chr_ends, max(data$x_pos[data$CHR==i], na.rm=TRUE))# 计算染色体中心位置(用于x轴标签)ticks<- c(ticks,(min(data$x_pos[data$CHR==i], na.rm=TRUE)+ max(data$x_pos[data$CHR==i], na.rm=TRUE))/2)}# 第二步:创建空绘图区域par(mar=c(5,5,4,2))pdf(file="1.pdf")plot(NA, xlim=c(min(data$x_pos, na.rm=TRUE), max(data$x_pos, na.rm=TRUE)), ylim=c(0, max(c(data$logP1, data$logP2, data$logP3), na.rm=TRUE)+1), xlab="Chromosome", ylab=expression(-log[10](italic(p))), xaxt="n",# 不显示默认x轴yaxt="n",# 不显示默认y轴bty="n", main="Three Chromosomes with Increased Spacing", cex.main=1.2)# 第三步:为每个性状单独绘制# 性状1 - 用三角形points(data$x_pos, data$logP1, col=adjustcolor("blue", alpha.f=0.7), pch=17, cex=0.8)# 性状2 - 用圆形points(data$x_pos, data$logP2, col=adjustcolor("red", alpha.f=0.7), pch=19, cex=0.8)# 性状3 - 用方形points(data$x_pos, data$logP3, col=adjustcolor("green", alpha.f=0.7), pch=15, cex=0.8)# 添加染色体分隔线(更明显)if(n_chr>1){for(iin1:(n_chr-1)){# 染色体间的分隔线abline(v=chr_ends[i]+(min(data$x_pos[data$CHR==(i+1)], na.rm=TRUE)- chr_ends[i])/2, col="gray60", lty=2, lwd=1.5)}}# 添加x轴axis(1, at=ticks, labels=paste("Chr",1:n_chr), cex.axis=1, font=2)# 添加y轴y_ticks<- pretty(c(0, max(c(data$logP1, data$logP2, data$logP3), na.rm=TRUE)))axis(2, at=y_ticks, las=1, cex.axis=0.9)# 添加网格线abline(h=y_ticks, col="gray90", lty=3, lwd=0.5)# 添加显著线abline(h=-log10(5e-8), col="red", lty=2, lwd=2)text(x=max(data$x_pos, na.rm=TRUE)*0.05, y=-log10(5e-8)+0.2, labels="5e-8", col="red", cex=0.8)# 添加图例legend("topright", legend=c("Trait 1","Trait 2","Trait 3"), col=c("blue","red","green"), pch=c(17,19,15), bty="o", box.col="gray",bg="white", cex=0.9, pt.cex=1.2)# 添加边框box(col="gray60", lwd=1)dev.off()

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2025/12/22 16:35:43

从零集成Open-AutoGLM插件到生产环境:完整流程与避坑指南

第一章&#xff1a;Open-AutoGLM插件概述Open-AutoGLM是一款专为大语言模型&#xff08;LLM&#xff09;任务自动化设计的开源插件&#xff0c;旨在提升自然语言处理流程的智能化水平。该插件基于AutoGLM架构&#xff0c;结合了提示工程、任务分解与外部工具调用能力&#xff0…

作者头像 李华
网站建设 2025/12/22 16:34:34

Packet Tracer汉化实战案例:校园网实验环境配置

打通网络学习“语言关”&#xff1a;用汉化版Packet Tracer搭建校园网实验环境 你有没有过这样的经历&#xff1f;刚打开Cisco Packet Tracer&#xff0c;面对满屏英文菜单一头雾水&#xff1a;“Switch Port”是啥&#xff1f;“Encapsulation dot1Q”怎么念&#xff1f;连“A…

作者头像 李华
网站建设 2025/12/22 16:34:28

Bypass Paywalls Clean终极指南:轻松解锁付费内容

在信息时代&#xff0c;优质内容往往被付费墙层层包裹&#xff0c;让许多读者望而却步。Bypass Paywalls Clean作为一款革命性的浏览器扩展&#xff0c;让普通用户也能轻松访问150主流新闻网站的完整内容。这款工具凭借其智能化的技术方案和用户友好的设计理念&#xff0c;已经…

作者头像 李华
网站建设 2025/12/22 16:33:24

5种高效解锁付费内容的实用技术方案深度解析

5种高效解锁付费内容的实用技术方案深度解析 【免费下载链接】bypass-paywalls-chrome-clean 项目地址: https://gitcode.com/GitHub_Trending/by/bypass-paywalls-chrome-clean 在信息爆炸的时代&#xff0c;优质内容往往被付费墙层层包裹&#xff0c;让求知者望而却步…

作者头像 李华
网站建设 2025/12/22 16:30:35

智能内容解锁工具:轻松访问付费资源的完整指南

智能内容解锁工具&#xff1a;轻松访问付费资源的完整指南 【免费下载链接】bypass-paywalls-chrome-clean 项目地址: https://gitcode.com/GitHub_Trending/by/bypass-paywalls-chrome-clean 在当今信息爆炸的时代&#xff0c;优质内容往往被付费墙所阻挡。智能内容解…

作者头像 李华