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

相关文章

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验

自定义类型:结构体(续)

目录 一. 结构体的内存对齐 1.1 为什么存在内存对齐? 1.2 修改默认对齐数 二. 结构体传参 三. 结构体实现位段 一. 结构体的内存对齐 在前面的文章里我们已经讲过一部分的内存对齐的知识,并举出了两个例子,我们再举出两个例子继续说明: struct S3{double a;int b;char c;};int mian(){printf("%zd\n",s

【编程底层思考】垃圾收集机制,GC算法,垃圾收集器类型概述

Java的垃圾收集(Garbage Collection,GC)机制是Java语言的一大特色,它负责自动管理内存的回收,释放不再使用的对象所占用的内存。以下是对Java垃圾收集机制的详细介绍: 一、垃圾收集机制概述: 对象存活判断:垃圾收集器定期检查堆内存中的对象,判断哪些对象是“垃圾”,即不再被任何引用链直接或间接引用的对象。内存回收:将判断为垃圾的对象占用的内存进行回收,以便重新使用。

flume系列之:查看flume系统日志、查看统计flume日志类型、查看flume日志

遍历指定目录下多个文件查找指定内容 服务器系统日志会记录flume相关日志 cat /var/log/messages |grep -i oom 查找系统日志中关于flume的指定日志 import osdef search_string_in_files(directory, search_string):count = 0

两个月冲刺软考——访问位与修改位的题型(淘汰哪一页);内聚的类型;关于码制的知识点;地址映射的相关内容

1.访问位与修改位的题型(淘汰哪一页) 访问位:为1时表示在内存期间被访问过,为0时表示未被访问;修改位:为1时表示该页面自从被装入内存后被修改过,为0时表示未修改过。 置换页面时,最先置换访问位和修改位为00的,其次是01(没被访问但被修改过)的,之后是10(被访问了但没被修改过),最后是11。 2.内聚的类型 功能内聚:完成一个单一功能,各个部分协同工作,缺一不可。 顺序内聚:

C语言 | Leetcode C语言题解之第393题UTF-8编码验证

题目: 题解: static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num & MASK1) == 0) {return

MiniGPT-3D, 首个高效的3D点云大语言模型,仅需一张RTX3090显卡,训练一天时间,已开源

项目主页:https://tangyuan96.github.io/minigpt_3d_project_page/ 代码:https://github.com/TangYuan96/MiniGPT-3D 论文:https://arxiv.org/pdf/2405.01413 MiniGPT-3D在多个任务上取得了SoTA,被ACM MM2024接收,只拥有47.8M的可训练参数,在一张RTX