R: 使用CHAMP包进行甲基化数据的差异分析(QC, CNV, DMP, DMR等)

2023-11-23 03:50

本文主要是介绍R: 使用CHAMP包进行甲基化数据的差异分析(QC, CNV, DMP, DMR等),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

CHAMP: 甲基化数据的差异分析

本文介绍如何使用CHAMP包对自己的甲基化数据进行分析(QC, CNV, DMP, DMR等)
包的安装

setwd('E:/wu/R')
#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~#
source("http://bioconductor.org/biocLite.R")
##if faild, try the following one
install.packages("BiocInstaller",repos="http://bioconductor.org/packages/3.7/bioc")
library(BiocInstaller)
##安装一些依赖包
biocLite(c('kernlab',"minfi","ChAMPdata","Illumina450ProbeVariants.db","sva","IlluminaHumanMethylation450kmanifest","limma","RPMM","DNAcopy","preprocessCore","impute","marray","wateRmelon","goseq","plyr","GenomicRanges","RefFreeEWAS","qvalue","isva","doParallel","bumphunter","quadprog","shiny","shinythemes","plotly","RColorBrewer","DMRcate","dendextend","IlluminaHumanMethylationEPICmanifest","FEM","matrixStats","missMethyl","combinat"))
##安装ChAMP
biocLite("ChAMP")
#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
library('ChAMP')

安装好依赖的包之后,就可以进行分析了。在分析过程中,如果有提示说缺少某某包,那就另外再使用biocLite安装一下即可。

数据导入

#载入数据
testDir = "E:/wu/R/OE2018Q1084N_CNV/raw"
myLoad <- champ.load(testDir,arraytype = 'EPIC')

其中,raw文件夹内的文件为自己的850K芯片原始文件
在这里插入图片描述
Sample_Sheet.csv的内容如下:
在这里插入图片描述

质控分析

champ.QC()

该命令会直接在R的工作路径下生成一个叫CHAMP_QCimages 的文件夹,里面为质控绘图结果。
在这里插入图片描述
三张图如下所示:
在这里插入图片描述在这里插入图片描述在这里插入图片描述

标准化


myNorm <- champ.norm(arraytype="EPIC")
##myNorm <- champ.norm(beta=myLoad$beta,arraytype="EPIC",cores=5)
##cores默认3
#保存标准化数
write.csv(myNorm,file="./Normalization Data.csv",quote=F,row.names = T)

说明:该过程会自动生成一个CHAMP_Normalization 的文件夹,但是有时候往往是空的,可以使用上述代码自己保存标准化数据。

CNV 分析


##CNV分析
myCNA <- champ.CNA(intensity=myLoad$beta,pheno=myLoad$pd$Sample_Group,controlGroup='control',arraytype="EPIC")
#保存差异CNV结果
write.csv(myCNA$groupResult,file="./CNV_analysis_result.csv",quote=F,row.names = F)

该过程会自动生成一个CHAMP_CNA 文件夹,里面是实验组每个样本的CNV绘图结果,如下图所示。
在这里插入图片描述
另外还可以做实验组的整体变化情况


myCNA <- champ.CNA(intensity=myLoad$beta,pheno=myLoad$pd$Sample_Group,sampleCNA = FALSE,controlGroup='control',arraytype="EPIC")

在这里插入图片描述
这个图还是比较丑的,没有conumee包绘制的图漂亮。后续会介绍conumee这个包的使用。

DMP分析


##DMP分析
myDMP <- champ.DMP(arraytype="EPIC")
##交互式结果展示
DMP.GUI()

弹出一个交互式界面,可以进行查询等操作。以下是一些界面的示意图。
在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述

DMR分析


myDMR <- champ.DMR(arraytype="EPIC")
DMR.GUI()

也是非常 简单的,结果与DMP分析结果类似,也是交互式界面,这里就不演示结果了。

其他的具体细节可以参考CHAMP官方网站:
http://www.bioconductor.org/packages/release/bioc/html/ChAMP.html

这篇关于R: 使用CHAMP包进行甲基化数据的差异分析(QC, CNV, DMP, DMR等)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Linux中的计划任务(crontab)使用方式

《Linux中的计划任务(crontab)使用方式》:本文主要介绍Linux中的计划任务(crontab)使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、前言1、linux的起源与发展2、什么是计划任务(crontab)二、crontab基础1、cro

kotlin中const 和val的区别及使用场景分析

《kotlin中const和val的区别及使用场景分析》在Kotlin中,const和val都是用来声明常量的,但它们的使用场景和功能有所不同,下面给大家介绍kotlin中const和val的区别,... 目录kotlin中const 和val的区别1. val:2. const:二 代码示例1 Java

C++变换迭代器使用方法小结

《C++变换迭代器使用方法小结》本文主要介绍了C++变换迭代器使用方法小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1、源码2、代码解析代码解析:transform_iterator1. transform_iterat

C++中std::distance使用方法示例

《C++中std::distance使用方法示例》std::distance是C++标准库中的一个函数,用于计算两个迭代器之间的距离,本文主要介绍了C++中std::distance使用方法示例,具... 目录语法使用方式解释示例输出:其他说明:总结std::distance&n编程bsp;是 C++ 标准

Python获取中国节假日数据记录入JSON文件

《Python获取中国节假日数据记录入JSON文件》项目系统内置的日历应用为了提升用户体验,特别设置了在调休日期显示“休”的UI图标功能,那么问题是这些调休数据从哪里来呢?我尝试一种更为智能的方法:P... 目录节假日数据获取存入jsON文件节假日数据读取封装完整代码项目系统内置的日历应用为了提升用户体验,

vue使用docxtemplater导出word

《vue使用docxtemplater导出word》docxtemplater是一种邮件合并工具,以编程方式使用并处理条件、循环,并且可以扩展以插入任何内容,下面我们来看看如何使用docxtempl... 目录docxtemplatervue使用docxtemplater导出word安装常用语法 封装导出方

Linux换行符的使用方法详解

《Linux换行符的使用方法详解》本文介绍了Linux中常用的换行符LF及其在文件中的表示,展示了如何使用sed命令替换换行符,并列举了与换行符处理相关的Linux命令,通过代码讲解的非常详细,需要的... 目录简介检测文件中的换行符使用 cat -A 查看换行符使用 od -c 检查字符换行符格式转换将

Go标准库常见错误分析和解决办法

《Go标准库常见错误分析和解决办法》Go语言的标准库为开发者提供了丰富且高效的工具,涵盖了从网络编程到文件操作等各个方面,然而,标准库虽好,使用不当却可能适得其反,正所谓工欲善其事,必先利其器,本文将... 目录1. 使用了错误的time.Duration2. time.After导致的内存泄漏3. jsO

使用Jackson进行JSON生成与解析的新手指南

《使用Jackson进行JSON生成与解析的新手指南》这篇文章主要为大家详细介绍了如何使用Jackson进行JSON生成与解析处理,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 核心依赖2. 基础用法2.1 对象转 jsON(序列化)2.2 JSON 转对象(反序列化)3.

使用Python实现快速搭建本地HTTP服务器

《使用Python实现快速搭建本地HTTP服务器》:本文主要介绍如何使用Python快速搭建本地HTTP服务器,轻松实现一键HTTP文件共享,同时结合二维码技术,让访问更简单,感兴趣的小伙伴可以了... 目录1. 概述2. 快速搭建 HTTP 文件共享服务2.1 核心思路2.2 代码实现2.3 代码解读3.