R语言画图 | 如何看已知基因list的细胞类型特异性表达?

2023-10-19 23:50

本文主要是介绍R语言画图 | 如何看已知基因list的细胞类型特异性表达?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

自己学东西,觉得举步维艰。网上的资源太多了,反而让人很容易陷入一种焦躁和慌乱中。不知道从哪里理出头绪来。是碎片化的,不成体系的。自己需要对信息进行过滤,整合成自己的方法。

目标:加载作者的处理过的有细胞类型标签的数据,对数据进行差异表达分析,找到特定的组织中差异表达的基因。

注明以下使用到的数据来源:http://development.psychencode.org/files/processed_data/scRNA-seq/Sestan.fetalHuman.Psychencode.Rdata

该数据为这篇文章中作者用到的,胎儿的大脑数据。
在Rdata中存放有三个数据矩阵。

  • count2:原始count值
  • cpm2:归一化处理后的数据矩阵
  • meta2:关于细胞与样本的详细注释信息,里面有作者已经分类后的每一个细胞对应的数据类型
    整体上这个数据有60155行,762列。

我们需要在上述已有数据的基础上,实现我们的目标。

load("F:/Rworkplace/celltype_specifc/Sestan.fetalHuman.Psychencode.Rdata")
library(dplyr)
library(Seurat)
library(patchwork)
dim(count2)
[1] 60155 762
data<-CreateSeuratObject(counts=count2,project = "fetal",meta.data = meta2,min.cells=0,min.features=0)
#data@meta.data<-meta2
data<-NormalizeData(data,normalization.method="RC",scale.factor = 1000000) #这里就是计算了cpm的值
#这里实际上进行了cpm的转换#筛选标准:该基因至少在300个细胞中表达,每一个细胞中至少有300个基因表达,对这个matrix进行行列层面的筛选。

将原先meta.data中的celltype的变量赋值到Idents中。得到细胞的类型标签。

Idents(object=data)<-data@meta.data$ctype #这一步是成功的第一步,已有的细胞注释的结果
levels(x=data)

到这一步的话,似乎就是利用原始的数据来做的。

我之所以举步维艰,是因为:
(1)我不知道每一步的含义,是否可以视特殊情况而去除;
(2)我不知道更多的函数应该怎样使用;

接着进行差异表达基因分析。

markers<-FindAllMarkers(data,only.pos = TRUE ,logfc.threshold = 2,min.pct = 0.25,test.use="roc")
write.csv(markers,"DEG_all2.csv")
VlnPlot(object=data,feature=c("ENSG00000189238-LINC00943"),log = T)

到这里虽然还不知道如何使用cpm后的数据进行差异表达分析。
但是比较欣慰的是,可以确保找到的差异表达基因与作者的基因是一样的了。即,得到的DEG_all.csv这个list是有意义的。
使用roc进行差异表达分析,似乎效果更好。【首选:有时间要总结一下差异表达分析常用的方法】

得到这个list之后,我们与我们自己的list进行比照,看看我们的list中,有多少是在这个细胞类型特异性的差异表达基因中的。

DEG<-read.csv("DEG_all2.csv")
library(stringr)
gene_split<-as.data.frame(str_split_fixed(DEG$gene,"-",n=2))
head(gene_split)
head(DEG)
DEG_m<-cbind(DEG,gene_split)
interest<-read.table("result_coding_gene_id_2.txt")
DEG_interest<-merge(DEG_m,interest) #112/4205
write.csv(DEG_interest$gene,"DEG_interest_celltype.csv")

得到了一些基因在特定的细胞类型中表达。

table(DEG_interest_2$cluster) 112/4205

Astro Endo ExN1 ExN2 ExN3 InN1 IPC1
6 26 2 7 9 2 4
IPC2 Microglia NasN1 NasN5 NasN6 NEPRGC1 NEPRGC2
1 20 2 1 1 1 2
NEPRGC3 Oligo OPC1 Pericyte
2 4 2 20

根据这些基因,绘制heatmap。

DEG_interest_2<-DEG_interest[order(DEG_interest$cluster,decreasing =FALSE ),]
DoHeatmap(data,features = DEG_interest_2$gene,draw.lines = TRUE,label = T,size = 2)+NoLegend()

可能这个工具还没有用熟悉,所以画出来的图是真的很丑(后面再进行润色和调整)。
在这里插入图片描述保存这次的处理结果。

DEG_interest_2<-DEG_interest[order(DEG_interest$cluster,decreasing =FALSE ),]
a<-subset(DEG_interest_2,select=c("gene","cluster"))
tissue<-rep("fetal",dim(DEG_interest_2)[1])
d<-cbind(a,tissue)
colnames(d)<-c("gene","cell_type","label")
write.csv(d,"DEG_interest_celltype2.csv")

最后测试一下分类标签是否正确。

VlnPlot(object=data,feature=c("ENSG00000122547-EEPD1"),log = T)

在这里插入图片描述完成目标。

现在存在的疑惑就是,是否需要吧ExN1、ExN2、ExN3这些都属于ExN细胞的细胞类型合并起来进行差异表达分析。
现在先这样,可能后期,还有再加上这些大的class(如,ExN/NasN/IPC)所共有的相对于其他class而言的差异基因。


接下来想处理adult的数据,没想到遇到了不能避免的数据太大的问题。

load("F://Rworkplace//celltype_specifc//phyEncode_adult//Sestan.adultHumanNuclei.Psychencode.Rdata")
library(dplyr)
library(Seurat)
library(patchwork)

报错:

Error: cannot allocate vector of size 3.0 Gb

只能回到服务器上操作。但是服务器上,我连seurat的包都安装不了,哭泣!看来,那边是必然要解决的问题,有必要可以求助师兄!

这篇关于R语言画图 | 如何看已知基因list的细胞类型特异性表达?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Java中List的contains()方法的使用小结

《Java中List的contains()方法的使用小结》List的contains()方法用于检查列表中是否包含指定的元素,借助equals()方法进行判断,下面就来介绍Java中List的c... 目录详细展开1. 方法签名2. 工作原理3. 使用示例4. 注意事项总结结论:List 的 contain

Spring Boot 配置文件之类型、加载顺序与最佳实践记录

《SpringBoot配置文件之类型、加载顺序与最佳实践记录》SpringBoot的配置文件是灵活且强大的工具,通过合理的配置管理,可以让应用开发和部署更加高效,无论是简单的属性配置,还是复杂... 目录Spring Boot 配置文件详解一、Spring Boot 配置文件类型1.1 applicatio

C语言中的数据类型强制转换

《C语言中的数据类型强制转换》:本文主要介绍C语言中的数据类型强制转换方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C语言数据类型强制转换自动转换强制转换类型总结C语言数据类型强制转换强制类型转换:是通过类型转换运算来实现的,主要的数据类型转换分为自动转换

利用Go语言开发文件操作工具轻松处理所有文件

《利用Go语言开发文件操作工具轻松处理所有文件》在后端开发中,文件操作是一个非常常见但又容易出错的场景,本文小编要向大家介绍一个强大的Go语言文件操作工具库,它能帮你轻松处理各种文件操作场景... 目录为什么需要这个工具?核心功能详解1. 文件/目录存javascript在性检查2. 批量创建目录3. 文件

C语言实现两个变量值交换的三种方式

《C语言实现两个变量值交换的三种方式》两个变量值的交换是编程中最常见的问题之一,以下将介绍三种变量的交换方式,其中第一种方式是最常用也是最实用的,后两种方式一般只在特殊限制下使用,需要的朋友可以参考下... 目录1.使用临时变量(推荐)2.相加和相减的方式(值较大时可能丢失数据)3.按位异或运算1.使用临时

java streamfilter list 过滤的实现

《javastreamfilterlist过滤的实现》JavaStreamAPI中的filter方法是过滤List集合中元素的一个强大工具,可以轻松地根据自定义条件筛选出符合要求的元素,本文就来... 目录1. 创建一个示例List2. 使用Stream的filter方法进行过滤3. 自定义过滤条件1. 定

使用C语言实现交换整数的奇数位和偶数位

《使用C语言实现交换整数的奇数位和偶数位》在C语言中,要交换一个整数的二进制位中的奇数位和偶数位,重点需要理解位操作,当我们谈论二进制位的奇数位和偶数位时,我们是指从右到左数的位置,本文给大家介绍了使... 目录一、问题描述二、解决思路三、函数实现四、宏实现五、总结一、问题描述使用C语言代码实现:将一个整

Python如何查看数据的类型

《Python如何查看数据的类型》:本文主要介绍Python如何查看数据的类型方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录python查看数据的类型1. 使用 type()2. 使用 isinstance()3. 检查对象的 __class__ 属性4.

Python容器类型之列表/字典/元组/集合方式

《Python容器类型之列表/字典/元组/集合方式》:本文主要介绍Python容器类型之列表/字典/元组/集合方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 列表(List) - 有序可变序列1.1 基本特性1.2 核心操作1.3 应用场景2. 字典(D

C语言字符函数和字符串函数示例详解

《C语言字符函数和字符串函数示例详解》本文详细介绍了C语言中字符分类函数、字符转换函数及字符串操作函数的使用方法,并通过示例代码展示了如何实现这些功能,通过这些内容,读者可以深入理解并掌握C语言中的字... 目录一、字符分类函数二、字符转换函数三、strlen的使用和模拟实现3.1strlen函数3.2st