Loading [MathJax]/jax/input/TeX/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >ggplot2|玩转Manhattan图-你有被要求这么画吗?

ggplot2|玩转Manhattan图-你有被要求这么画吗?

作者头像
生信补给站
发布于 2020-08-06 03:23:26
发布于 2020-08-06 03:23:26
1.5K00
代码可运行
举报
文章被收录于专栏:生信补给站生信补给站
运行总次数:0
代码可运行

Manhattan图算是GWAS分析的标配图了,可参考Bio|manhattan图 进行绘制。

由于Manhattan点太多,后期AI/PS修改的话难度有点大,如果可以“个性化”绘制的话那是极好的!

一 载入R包,数据

1)载入数据处理的tidyverse包,使用qqman中gwasResults示例数据集

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#载入R包
#install.packages("qqman")
library(qqman)
library(tidyverse)
#查看原始数据
head(gwasResults)
 SNP CHR BP         P
1 rs1   1  1 0.9148060
2 rs2   1  2 0.9370754
3 rs3   1  3 0.2861395
4 rs4   1  4 0.8304476
5 rs5   1  5 0.6417455
6 rs6   1  6 0.5190959

我们知道Manhattan图实际就是点图,横坐标是chr,纵坐标是-log(Pvalue) ,原始P值越小,-log转化后的值越大,在图中就越高。

原始数据中重要的“元素”都有了 ,我们自己的数据也是只需要这四列就可以了。注意绘制前需要转化一下:

2)处理原始数据---计算SNP的累计位置
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
# 1)计算chr长度
chr_len <- gwasResults %>% 
  group_by(CHR) %>% 
  summarise(chr_len=max(BP))
# 2) 计算每条chr的初始位置
chr_pos <- chr_len  %>% 
  mutate(total = cumsum(chr_len) - chr_len) %>%
  select(-chr_len)
#3)计算累计SNP的位置
Snp_pos <- chr_pos %>%
  left_join(gwasResults, ., by="CHR") %>%
  arrange(CHR, BP) %>%
  mutate( BPcum = BP + total)

#查看转化后的数据
head(Snp_pos,2)

  SNP CHR BP         P total BPcum
1 rs1   1  1 0.9148060     0     1
2 rs2   1  2 0.9370754     0     2

数据准备完成,开始绘图。

二 ggplot2绘制Manhattan图

1 纵坐标为P值转-log10()

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
ggplot(Snp_pos, aes(x=BPcum, y=-log10(P))) +
    geom_point( aes(color=as.factor(CHR)))

基本图形出来了,但是有点怪;不急,一点点改进:

  • 横坐标标签设置在每个chr中间位置;
  • 背景色去掉,线去掉等
  • 去掉点和X轴之间的 “gap” (很多地方可用)
  • 添加阈值线
2 绘制加强版Manhattan图

1) 准备X轴标签位置--在每条chr的中间

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
X_axis <-  Snp_pos %>% group_by(CHR) %>% summarize(center=( max(BPcum) + min(BPcum) ) / 2 )

2)绘制“改良版”Manhattan图

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
p <- ggplot(Snp_pos, aes(x=BPcum, y=-log10(P))) +
#设置点的大小,透明度
    geom_point( aes(color=as.factor(CHR)), alpha=0.8, size=1.3) +
#设置颜色
    scale_color_manual(values = rep(c("grey", "skyblue"), 22 )) +
#设定Xscale_x_continuous( label = X_axis$CHR, breaks= X_axis$center ) +
#去除绘图区和X轴之间的gap
    scale_y_continuous(expand = c(0, 0) ) +  
#添加阈值线
    geom_hline(yintercept = c(6, -log10(0.05/nrow(Snp_pos))), color = c('green', 'red'), size = 1.2, linetype = c("dotted", "twodash")) + 
#设置主题
    theme_bw() +
    theme(
      legend.position="none",
      panel.border = element_blank(),
      axis.line.y = element_line(),
      panel.grid.major.x = element_blank(),
      panel.grid.minor.x = element_blank()
    )

这时候是不是就可以了,?。

当然了既然是ggplot2绘制的Manhattan图(点图),那么关于点,线,坐标,主题的设置当然都可以设置了,看这里

ggplot2|详解八大基本绘图要素

ggplot2|theme主题设置,详解绘图优化-“精雕细琢”

3 玩转Manhattan图
1) 利用数据集自带的snpsOfInterest标示显著的位点,展示重要的基因信息
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
library(ggrepel)
#准备数据
data <- Snp_pos %>%
# 添加高亮和注释信息:snpsOfInterest中的rs编号和P值大于6的点
  mutate( is_highlight=ifelse(SNP %in% snpsOfInterest, "yes", "no")) %>%
  mutate( is_annotate=ifelse(-log10(P)>6, "yes", "no"))

#绘图

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
p1 <- ggplot(data, aes(x=BPcum, y=-log10(P))) +
    geom_point( aes(color=as.factor(CHR)), alpha=0.8, size=1.3) +
    scale_color_manual(values = rep(c("grey", "skyblue"), 22 )) +
    scale_x_continuous( label = X_axis$CHR, breaks= X_axis$center ) +
    scale_y_continuous(expand = c(0, 0) ) +  
    # 添加高亮点
    geom_point(data=subset(data, is_highlight=="yes"), color="orange", size=2) +
    # 添加高亮label,且防止重叠
    geom_label_repel( data=subset(data, is_annotate=="yes"), aes(label=SNP), size=2) +
    theme_bw() + 
    theme(
      legend.position="none",
      panel.border = element_blank(),
      panel.grid.major.x = element_blank(),
      panel.grid.minor.x = element_blank()
    )

如果我们自己的gwas结果数据是Gene的话,label更改即可标示基因。

2) 自定义重要的基因,标示

如果有某些“目的基因”,想查看这些基因的P值呢?

新加gene和gene_annotate列即可!

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#准备数据,使用基础函数
data <- Snp_pos
#根据目的基因的位置,新加gene和gene_annotate列
data$gene[data$CHR == 3 & data$BP == 366] <- "geneA"
data$gene_annotate[data$CHR == 3 & data$BP == 366] <- "yes"
data$gene[data$SNP == "rs4064"] <- "geneB"
data$gene_annotate[data$SNP == "rs4064"] <- "yes"
# 绘图
p2 <- ggplot(data, aes(x=BPcum, y=-log10(P))) +
    geom_point( aes(color=as.factor(CHR)), alpha=0.8, size=1.3) +
    scale_color_manual(values = rep(c("grey", "skyblue"), 22 )) +
    scale_x_continuous( label = X_axis$CHR, breaks= X_axis$center ) +
    scale_y_continuous(expand = c(0, 0) ) +  
    geom_label_repel( data=subset(data, gene_annotate=="yes"), aes(label=gene), size=4, col = "red") +
    theme_bw() + 
    theme(
      legend.position="none",
      panel.border = element_blank(),
      panel.grid.major.x = element_blank(),
      panel.grid.minor.x = element_blank()
    )
3)区域放大展示

重点展示某一区域的P值情况

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
library(ggforce)data <- Snp_pos %>%# 添加高亮和注释信息:snpsOfInterest中的rs编号和P值大于6的点
 mutate( is_highlight=ifelse(SNP %in% snpsOfInterest, "yes", "no")) %>%
 mutate( is_annotate=ifelse(-log10(P)>6, "yes", "no"))
  
  p3 <- ggplot(data, aes(x=BPcum, y=-log10(P))) +
   geom_point( aes(color=as.factor(CHR)), alpha=0.8, size=1.3) +
   scale_color_manual(values = rep(c("grey", "skyblue"), 22 )) +
   scale_x_continuous( label = X_axis$CHR, breaks= X_axis$center ) +
   scale_y_continuous(expand = c(0, 0) ) +   
   geom_point(data=subset(data, is_highlight=="yes"), color="orange", size=2) +facet_zoom(x = BPcum >= 3000 & BPcum <=3500)+
   theme_bw() + 
theme(
     legend.position="none",
     panel.border = element_blank(),
     panel.grid.major.x = element_blank(),
     panel.grid.minor.x = element_blank()
  )

可参考ggforce|绘制区域轮廓-区域放大-寻找你的“onepiece”

4)plotly 交互展示

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
library(plotly)
  data <- Snp_pos %>%
  mutate( is_highlight=ifelse(SNP %in% snpsOfInterest, "yes", "no")) %>% filter(-log10(P)>0.5) #过滤一些点,交互式压力小
# 准备SNP展示的text信息
data$text <- paste("SNP: ", data$SNP, "\nPosition: ", data$BP, "\nChromosome: ", data$CHR, "\nLOD score:", -log10(data$P) %>% round(2), "\nWhat else do you wanna know", sep="")

p4 <- ggplot(data, aes(x=BPcum, y=-log10(P), text=text)) +
    geom_point( aes(color=as.factor(CHR)), alpha=0.8, size=1.3) +
    scale_color_manual(values = rep(c("grey", "skyblue"), 22 )) +
    scale_x_continuous( label = X_axis$CHR, breaks= X_axis$center ) +
    scale_y_continuous(expand = c(0, 0) ) +
    ylim(0,9) +
    geom_point(data=subset(data, is_highlight=="yes"), color="orange", size=2) +
    theme_bw() +
    theme(
      legend.position="none",
      panel.border = element_blank(),
      panel.grid.major.x = element_blank(),
      panel.grid.minor.x = element_blank()
    )
ggplotly(p4, tooltip="text")

好吧,其实这个用处不太大,,,

以上就是ggplot2绘制一些常见的Manhattan图,好处当然就是兼容ggplot2的参数,也就可以根据需要自行设置。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2019-12-10,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 生信补给站 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
Android APP拉起小程序、分享小程序、小程序打开APP
配置参考:https://blog.csdn.net/yechaoa/article/details/78469539 APP拉起小程序 private void launchMiniProgram(String path) { String appId = "你的appid"; // 填应用AppId IWXAPI api = WXAPIFactory.createWXAPI(PinDanActivity.this, appId); WXLaunchM
yechaoa
2022/06/10
5.2K0
app唤起小程序_微信小程序支付轮训
在同一开放平台账号下的移动应用及小程序无需关联即可完成跳转,非同一开放平台账号下的小程序需与移动应用(APP)成功关联后才支持跳转。
全栈程序员站长
2022/09/20
1.9K0
Android App跳转微信小程序教程
最近,有一个App跳转小程序的需求,参考微信的官方文档,接入还是比较简单的,不过中途遇到了一个坑,所以记录一下。
PHP开发工程师
2022/05/06
5K0
Android App跳转微信小程序教程
ios应用接入微信开放平台
公众平台针对的是公众账号,除了提供管理后台之外。也开放了若干接口,让微信server和开发人员自己的应用系统可以对接
全栈程序员站长
2022/07/07
8040
安卓app和微信授权登录及分享完整对接
注册微信开放平台,创建移动应用,填写一系列的信息,在应用平台填写app签名和包名,审核通过之后,取得AppID和 AppSecret
chuchur
2022/10/25
1.7K0
Android 微信登录授权、微信分享
1.先去微信开放平台注册账号,然后创建应用,签名工具下载(在页面最下面),不细说。
yechaoa
2022/06/10
6K0
Android 微信登录授权、微信分享
HarmonyOS NEXT实战:接入微信SDK
##HarmonyOS Next实战##HarmonyOS SDK应用服务##教育##
中雨
2025/06/26
1540
iOS微信之简单文本分享(集成官方SDK)
前期准备工作:可以参考这篇博文http://www.jianshu.com/p/839dc30f2250 iOS版本只需要提供Bundle Id即可
专注APP开发
2019/11/07
2.1K0
iOS微信之简单文本分享(集成官方SDK)
开发必读:盘点与业务转化息息相关的小程序能力(二)
小程序跳转内外部的能力在日常开发中用得非常多,上周为大家分享了小程序跳转到外部的一系列能力,本周继续为大家分享外部跳回小程序的能力。场景和实现方式不一定完全,也欢迎大家补充。
海岛船长加西亚
2023/12/19
4430
Android十八章:5分钟接入微信支付
现在app最流行微信支付,支付宝支付,都是大部分消费类型app计费方式首选。现在5分钟教你接入微信支付。
ppjun
2018/09/05
1.1K0
android 微信支付 简单实用
最后,关于测试,因为前面是线上的,所以本地测试是非常不方便的,这里有个小技巧,我们只要本地环境使用线上签名就行了。
yechaoa
2022/06/10
8380
android 微信支付 简单实用
unity3d+androidstudio:接微信官方分享sdk
1.得到的签名在微信后台一定要填对,不然返回-6 2.如果测试微信调不起来,清除微信缓存,即可,因为上次的错误信息保存了
立羽
2023/08/24
3040
unity3d+androidstudio:接微信官方分享sdk
iOS 微信支付开发流程
项目中要用到支付功能,需要支付宝支付、支付宝网页支付、微信支付、银联支付、Apple_pay,所以打算总结一下,方便以后的查阅,也方便大家, 用到的地方避免再次被坑。 今天我们就主要介绍一下微信支付,其他支付也写了对应教程,并且给出了连接。
网罗开发
2021/01/29
1.7K0
iOS 微信支付开发流程
iOS微信支付简单的使用
APP微信商户申请APPID步骤地址 微信支付 SDK与 Demo地址下载 微信SDK与 Demo 把微信支付 SDK 拖到工程上 SDK 添加微信支付依赖库
LeeCen
2018/10/11
1K0
iOS微信支付简单的使用
Android关于微信小程序的唤起和分享
最近做了一些有关于微信小程序的项目,涉及了微信小程序的唤起和分享微信小程序。 所有的内容都来源于 微信开放平台 public class WXProxy { private IWXAPI mShareAPI; /** * 构造为api * @param context 上下文环境 * @param isPublic 微信公众账号的key,还是微信登录的key */ public WXProxy(Context context, boolean
静默加载
2020/05/29
9890
android微信登录,分享
这几天开发要用到微信授权的功能,所以就研究了一下。可是微信开放平台接入指南里有几个地方写的不清不楚。在此总结一下,以便需要的人。 很多微信公众平台的应用如果移植到app上的话就需要微信授权登陆了。       目前移动应用上微信登录只提供原生的登录方式,需要用户安装微信客户端才能配合使用。也就是如果第三方应用需要微信授权登陆的话就必须在本机上安装了微信。而后续授权登陆或调用接口之类的相当于app和微信两个应用之间通话。 1、首先需要注册微信开放平台,然后获取开发者认证。审批通过之后再创建一个移动应用同
xiangzhihong
2018/02/01
4.2K0
android微信登录,分享
第三方微信授权登录APP接入_使用第三方应用打开是什么意思
在微信开放平台 https://open.weixin.qq.com/ 注册成为开发者,具体步骤略
全栈程序员站长
2022/09/20
1.6K0
第三方微信授权登录APP接入_使用第三方应用打开是什么意思
Android微信之简单文本分享(集成官方SDK-Android Studio)
1.帐号申请 https://open.weixin.qq.com/ 首先登录微信开放平台,注册一个帐号 2.提交APP审核 为什么必须提交app审核呢?
专注APP开发
2019/11/07
2K0
Android微信之简单文本分享(集成官方SDK-Android Studio)
iOS开发中微信支付集成
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/u010105969/article/details/77881920
用户1451823
2018/09/13
1.9K0
iOS开发中微信支付集成
手把手教你Android端微信支付接入
  在你的package目录下,创建wxapi目录,比如说我使用的demo项目,wxapi就在目录net.sourceforge.simcpux目录下
顾翔
2019/12/12
1.3K0
手把手教你Android端微信支付接入
相关推荐
Android APP拉起小程序、分享小程序、小程序打开APP
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档