④-1单细胞学习-cellchat单数据代码补充版

目录

1,数据输入及处理

①载入包和数据

②CellChat输入数据准备

③构建CellChat对象

④数据预处理

2,细胞通讯预测

①计算细胞通讯概率

②提取配受体对细胞通讯结果表

③提取信号通路水平的细胞通讯表

④细胞互作关系可视化

1)细胞亚群间配受体数目网络图

2)细胞亚群间配受体概率/强度网络图

3)每个细胞亚群的配受体通讯概率进行单独展示

​编辑4)数量和强度弦图合并

3,信号通路水平的细胞通讯分析

4,信号通路相关配受体对水平的细胞通讯分析

5,多个配受体对/信号通路水平介导的细胞通讯可视化

①指定信号通路

②参与目标信号通路的基因在各细胞亚群的表达分布展示

③气泡图

1,数据输入及处理
①载入包和数据

官方学习:focuslyj/CellChat - 码云 - 开源中国 (gitee.com)

这里提供的应该是counts data数据

rm(list=ls())
library(CellChat)
library(patchwork)
library(ggplot2)
library(Seurat)
library(ggalluvial)#绘制桑基图
library(expm)
library(sna)
library(NMF)
options(stringsAsFactors = FALSE)##输入数据不自动转换成因子(防止数据格式错误)
load("data_humanSkin.Rdata")#数据加载:这里是count data数据
CellChat输入数据准备
#需标准化的基因表达量矩阵和细胞分组信息文件
#不同输入格式处理方式不同
data.input = data_humanSkin$data#需标准化的基因表达量矩阵和细胞分组信息文件
meta = data_humanSkin$meta
data.input[1:6,1:3]#表达count
head(meta);table(meta$condition) #含normal(NL)和diseases(LS)
cell.use = rownames(meta)[meta$condition == 'LS'] #提取LS的细胞名称
data.input = data.input[, cell.use]#提取LS表达矩阵
meta = meta[cell.use, ]#提取LS细胞信息
identical(rownames(meta),colnames(data.input)) #检查矩阵列名和分组文件行名是否一致
unique(meta$labels) #检查细胞亚群标签类型
构建CellChat对象
#接下来构建CellChat对象
cellchat <- createCellChat(object = data.input, #支持normalized表达矩阵,Seurat对象,和SingleCellExperiment对象
                           meta = meta, #meta文件
                           group.by = 'labels') #meta中的细胞分类列
#cellchat <- addMeta(cellchat, meta = meta)#创建CellChat对象未 cellmeta信息时添加信息
cellchat <- setIdent(cellchat, ident.use = 'labels') #将label设置为显示的默认顺序
levels(cellchat@idents) #查看celltype和factor顺序
table(cellchat@idents) #每个celltype中的细胞数

#设置配受体数据库(CellChatDB):
CellChatDB <- CellChatDB.human #(CellChatDB.human) (CellChatDB.mouse)
showDatabaseCategory(CellChatDB) #查看描述该数据库组成的饼状图
dplyr::glimpse(CellChatDB$interaction) #查看数据库结构

#直接使用CellChatDB全库进行细胞通讯分析:
##CellChatDB.use <- CellChatDB # simply use the default CellChatDB
#选择数据库中特定子集进行细胞通讯分析:
CellChatDB.use <- subsetDB(CellChatDB, 
                           search = 'Secreted Signaling') #可选择Secreted Signaling、ECM-Receptor或Cell-Cell Contact
cellchat@DB <- CellChatDB.use#将数据库添加到CellChat对象中(DB)
④数据预处理
#数据预处理;信号基因的表达矩阵子集化,节省计算成本
cellchat <- subsetData(cellchat) #必选的step,取上一步CellChatDB.use中信号基因的表达矩阵子集,赋值到cellchat@data.Signaling
#future::plan('multiprocess', workers = 4) # do parallel (可以不用选择平行计算)
#鉴定与每个细胞亚群相关的过表达信号基因:基于表达该基因的细胞比例、差异倍数和p值判定。
cellchat <- identifyOverExpressedGenes(cellchat,
                                       only.pos = TRUE, #仅返回positive markers
                                       thresh.pc = 0, #细胞比例阈值
                                       thresh.fc = 0, #差异倍数
                                       thresh.p = 0.05) #P-Value
#计算结果赋值到cellchat@var.features:
head(cellchat@var.features$features) #过表达信号基因名
head(cellchat@var.features$features.info) #差异计算结果表
#识别过表达基因配体-受体互作:
cellchat <- identifyOverExpressedInteractions(cellchat)
head(cellchat@LR$LRsig) #计算结果赋值位置
#将基因表达数据映射到PPI网络(可跳过):
cellchat <- projectData(cellchat, PPI.human) #返回结果:cellchat@data.project
2,细胞通讯预测
①计算细胞通讯概率
#细胞通讯预测##############################################
cellchat <- computeCommunProb(cellchat, raw.use = TRUE) #返回结果:cellchat@options$parameter
##默认使用原始表达数据(cellchat@data.Signaling),若想使用上一步PPI矫正数据,设置raw.use = TALSE
cellchat <- filterCommunication(cellchat, min.cells = 10) #细胞通讯过滤(设置每个亚群中进行细胞间通讯所需的最小细胞数)
提取配受体对细胞通讯结果表
#提取配受体对细胞通讯结果表:
df.net <- subsetCommunication(cellchat, slot.name = 'net')
head(df.net) #得到配受体对细胞通讯结果表

#或访问其它感兴趣/特定的细胞通讯结果:
df.net1 <- subsetCommunication(cellchat,
                               sources.use = c('LC'),
                               targets.use = c('FBN1+ FIB')) #访问特定细胞对子集
head(df.net1)

df.net2 <- subsetCommunication(cellchat, signaling = c('CD40')) #访问特定信号通路子集
head(df.net2)
提取信号通路水平的细胞通讯表

提取配受体对细胞通讯结果表:subsetCommunication函数

提取信号通路水平的细胞通讯表:computeCommunProbPathway函数

#提取信号通路水平的细胞通讯表:
cellchat <- computeCommunProbPathway(cellchat) #计算信号通路水平上的通讯概率
df.netp <- subsetCommunication(cellchat, slot.name = 'netP') #得到信号通路水平细胞通讯表
head(df.netp)
细胞互作关系可视化
1)细胞亚群间配受体数目网络图
cellchat <- aggregateNet(cellchat)#计算细胞对间通讯的数量和概率强度
#不同细胞亚群间的互作数量与概率/强度可视化:
groupSize <- as.numeric(table(cellchat@idents))##细胞亚群间配受体数目网络图:
par(mfrow = c(1,1), xpd = TRUE)
netVisual_circle(cellchat@net$count,
                 vertex.weight = groupSize,
                 weight.scale = T,
                 label.edge = F,
                 title.name = 'Number of interactions')

细胞通讯| 02.CellChat基础分析教程_哔哩哔哩_bilibili

2)细胞亚群间配受体概率/强度网络图
##细胞亚群间配受体概率/强度网络图:
par(mfrow = c(1,1), xpd = TRUE)
netVisual_circle(cellchat@net$weight,
                 vertex.weight = groupSize,
                 weight.scale = T,
                 label.edge= F,
                 title.name = 'Interaction weights/strength')

3)每个细胞亚群的配受体通讯概率进行单独展示

这里需要注意R绘图画板范围,可以将前面的绘图进行保存和devoff后再进行作图

#检查单个细胞亚群的互作信号强度;每个细胞进行单独展示##
mat <- cellchat@net$weight
par(mfrow = c(3,4), xpd = TRUE)
for (i in 1:nrow(mat)) {
  mat2 <- matrix(0, nrow = nrow(mat), ncol = ncol(mat), dimnames = dimnames(mat))
  mat2[i, ] <- mat[i, ]
  netVisual_circle(mat2, vertex.weight = groupSize, weight.scale = T, edge.weight.max = max(mat), title.name = rownames(mat)[i])
}
4)数量和强度弦图合并
#数量和强度弦图合并
par(mfrow = c(1,2), xpd = TRUE)
netVisual_circle(cellchat@net$count,
                 vertex.weight = groupSize,
                 weight.scale = T,
                 label.edge = F,
                 title.name = 'Number of interactions')
netVisual_circle(cellchat@net$weight,
                 vertex.weight = groupSize,
                 weight.scale = T,
                 label.edge= F,
                 title.name = 'Interaction weights/strength')

#保存cellchat对象:
save(cellchat, groupSize, file = c('humanSkin_CellChat.Rdata'))

3,信号通路水平的细胞通讯分析
cellchat@netP$pathways##信号通路查看
pathways.show <- c('GALECTIN')##以'GALECTIN'信号通路展示为例
#层级图(Hierarchy plot)绘制
levels(cellchat@idents)#查看细胞亚群及factor顺序:
#选择其中感兴趣的细胞亚群:
vertex.receiver = c(3,8,9,10)#为画图第一列的source列
par(mfrow = c(1,1))
netVisual_aggregate(cellchat,
                    layout = c('hierarchy'), #"circle", "hierarchy", "chord"
                    signaling = pathways.show,
                    vertex.receiver = vertex.receiver)#选择展示的通路

别的图

par(mfrow = c(1,1))#展示网络图
netVisual_aggregate(cellchat,
                    layout = c('circle'),
                    signaling = pathways.show)
par(mfrow=c(1,1))#展示弦图
netVisual_aggregate(cellchat,
                    layout = c('chord'),
                    signaling = pathways.show)
par(mfrow=c(1,1))#展示热图
netVisual_heatmap(cellchat,
                  signaling = pathways.show,
                  color.heatmap = c("white", "#b2182b"))

4,信号通路相关配受体对水平的细胞通讯分析
netAnalysis_contribution(cellchat, 
                         signaling = pathways.show) #配受体对贡献条形图
pairLR.CXCL <- extractEnrichedLR(cellchat,  #提取细胞对
                                 signaling = pathways.show,
                                 geneLR.return = FALSE)
LR.show <- pairLR.CXCL[1,] #以贡献度top1的配受体对为例
pairLR.CXCL; LR.show

别的图

netVisual_individual(cellchat,#Hierarchy plot:
                     layout = c('hierarchy'),
                     signaling = pathways.show, #目标信号通路
                     pairLR.use = LR.show, #目标配受体对
                     vertex.receiver = vertex.receiver) #感兴趣的细胞亚群
#Circle plot:
netVisual_individual(cellchat,
                     layout = c('circle'),
                     signaling = pathways.show,
                     pairLR.use = LR.show)
#Chord diagram:
netVisual_individual(cellchat,
                     layout = c('chord'),
                     signaling = pathways.show,
                     pairLR.use = LR.show)

5,多个配受体对/信号通路水平介导的细胞通讯可视化
指定信号通路
多个配受体对/信号通路水平介导的细胞通讯可视化######
levels(cellchat@idents)#指定信号通路
netVisual_bubble(cellchat,
                 sources.use = 4,
                 targets.use = c(5:11),
                 signaling = c("CCL","CXCL"), #指定CCL和CXCL两个信号通路
                 remove.isolate = FALSE)
#指定配受体对:
pairLR.use <- extractEnrichedLR(cellchat, 
                                signaling = c("CCL","CXCL","FGF")) #确定在目标信号通路中有重要作用的配受体对
pairLR.use
netVisual_bubble(cellchat,
                 sources.use = 4,
                 targets.use = c(5:11),
                 pairLR.use = pairLR.use,#指定的受体对
                 remove.isolate = TRUE)

②参与目标信号通路的基因在各细胞亚群的表达分布展示
#参与目标信号通路的基因在各细胞亚群的表达分布展示:
plotGeneExpression(cellchat, signaling = 'GALECTIN', 
                   type = 'violin') #小提琴图

③气泡图
plotGeneExpression(cellchat, 
                   signaling = 'GALECTIN', type = 'dot', color.use = c("white", "#b2182b")) #气泡图

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/694717.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

java线程相关知识点

Java多线程涉及以下几个关键点 1.线程生命周期&#xff1a;理解线程从创建到销毁的各个阶段&#xff0c;包括新建、运行、阻塞、等待、计时等待和终止。 2.线程同步&#xff1a;掌握如何使用synchronized关键字和Lock接口来同步代码&#xff0c;防止数据竞争和死锁。 3.线程间通…

csrf与xss差别 别在弄乱了 直接靶场实操pikachu的csrf题 token绕过可以吗???

我们现在来说说这2个之间的关系&#xff0c;因为昨天的我也没有弄清楚这2者的关系&#xff0c;总感觉迷迷糊糊的。 xss这个漏洞是大家并不怎么陌生&#xff0c;导致xss漏洞的产生是服务器没有对用户提交数据过滤不严格&#xff0c;导致浏览器把用户输入的当作js代码返回客户端…

HCIA--NAT地址转换(复习)

先交换后路由&#xff1a; 1&#xff1a;在交换机上创建vlan&#xff0c;进入接口划分vlan&#xff0c;接着在交换机连接路由器的接口上建立trunk干道 2&#xff1a;在路由器上&#xff0c;先配置物理接口IP&#xff0c;接着在路由器上创建两个子接口&#xff0c;将建立的vla…

Fences 5 激活码 - 电脑桌面整理软件

提起桌面整理&#xff0c;经典老牌工具 Fences 必有一席之地&#xff0c;Stardock 发布了最新的 Fences 5 版本。 可以将文件和图标归类放入各个栅栏分区&#xff0c;并支持文件夹展开至桌面、分区置顶、淡化隐藏图标等功能&#xff0c;能让你的桌面焕然一新&#xff0c;不再混…

请求 响应

在web的前后端分离开发过程中&#xff0c;前端发送请求给后端&#xff0c;后端接收请求&#xff0c;响应数据给前端 请求 前端发送数据进行请求 简单参数 原始方式 在原始的web程序中&#xff0c;获取请求参数&#xff0c;需要通过HttpServletRequest 对象手动获取。 代码…

数据库四种隔离等级

持续更新以及完善中… 数据库事务隔离 首先&#xff0c;为什么要有事务隔离呢&#xff1f; 在单线程下&#xff0c;没什么大碍&#xff0c;但是我们想要提高效率&#xff0c;采用多线程并发时&#xff0c;便会出现一些问题。 **下面的问题一定要当作一个事务来看待&#xf…

vscode中执行python语句dir(torch)不返回结果

输入半天&#xff0c;发现在IDLE运行后的shell界面输入语句就会返回一大串。但是在vscode中老是不返回值。 结果恍然发现这没加print&#xff08;&#xff09;。 无语惨了。 家人们&#xff0c;这是python&#xff0c;而不是matlab。思维还没转换过来&#xff0c;笑死

电影制作中的版本控制:Perforce Helix Core帮助某电影短片避免灾难性文件损坏,简化艺术资产管理

Zubaida Nila是来自马来西亚的一名视觉特效师和虚拟制作研究员&#xff0c;她参加了Epic Games的一个为期六周的虚拟培训和指导项目——女性创作者计划。该计划提供了虚幻引擎工作流程的实践经验以及其他课程。Zubaida希望从中获得更多关于虚幻引擎的灯光、后期处理和特效技能方…

279 基于matlab的粒子群集法对铁路电能质量控制系统的容量避行优化设计

基于matlab的粒子群集法对铁路电能质量控制系统的容量避行优化设计。计算出满足功率因素、电压不平衡度等电能指标的条件下。RPC所需要的补偿功率。求得所需最小的系统客量。该设计能快速计算出符合系统设定指标的各项最优补偿功率。并通过sumulink份真。检验设计参数的准确性。…

Pytorch 实现目标检测二(Pytorch 24)

一 实例操作目标检测 下面通过一个具体的例子来说明锚框标签。我们已经为加载图像中的狗和猫定义了真实边界框&#xff0c;其中第一个 元素是类别&#xff08;0代表狗&#xff0c;1代表猫&#xff09;&#xff0c;其余四个元素是左上角和右下角的(x, y)轴坐标&#xff08;范围…

极域卸载不干净导致无法重新安装问题:独家解决方案

文章目录 一、问题二、解决1.网上常规方法2.本贴特殊之处 三、致谢 一、问题 极域卸载不干净&#xff0c;导致无法重新安装。 二、解决 1.网上常规方法 1.regedit命令注册表删除 topdomain、mythware、{5FB4EEDF-6A79-45C3-B049-EF327CA03FCD} 2.删除极域对应tmp文件 网上…

稀疏高效扩散模型:推动扩散模型的部署与应用

数据驱动的世界中&#xff0c;生成模型扮演着至关重要的角色&#xff0c;尤其是在需要创建逼真样本的任务中。扩散模型&#xff08;Diffusion Models, DM&#xff09;&#xff0c;以其卓越的样本质量和广泛的模式覆盖能力&#xff0c;已经成为众多数据生成任务的首选。然而&…

ToonCrafter - AI 生成动画越来越简单了,两张照片生成动画视频 本地一键整合包

动画制作对很多人来说应该都是一项非常专业且复杂的工作&#xff0c;需要学习专门的知识&#xff0c;掌握特定的工具&#xff0c;并且投入大量的时间精力才能得到成果&#xff0c;不过最近出现的一款 AI 动画制作工具 ToonCrafter 则有希望改变这一现状。它只需 2 张图像就生成…

Spring之SpringMVC源码

SpringMVC源码 一、SpringMVC的基本结构 1.MVC简介 以前的纯Servlet的处理方式&#xff1a; Overrideprotected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {String type req.getParameter(Constant.REQUEST_PA…

策略模式的理解和运用

在之前的小游戏项目中&#xff0c;处理websocket长连接请求的时候&#xff0c;需要根据传递数据包的不同类型&#xff0c;进行不同的处理。为了实现这个场景&#xff0c;比较简单的方法就是使用if-else或者switch-case语句&#xff0c;根据条件进行判断。但是这导致了项目代码复…

【网络安全】【深度学习】【入侵检测】SDN模拟网络入侵攻击并检测,实时检测,深度学习

文章目录 1. 前言2. Mininet 和 Ryu 的区别2.1 Mininet2.2 Ryu2.3 总结 3. 模拟攻击3.1 环境准备3.2 创建 Mininet 网络拓扑3.2 启动 Ryu 控制器3.3 模拟网络攻击3.4 捕获流量 4. 实时异常检测4.1 在 Ryu 控制器中4.2 在 h2 机器上的实验结果4.3 深度学习模型部署上h2机器 帮助…

日进2000,我怎么做到的

昨天遇到一个有意思的项目&#xff0c;让我一天进账2000&#xff0c;一个字&#xff1a;爽。 这几天接洽了一位新客户&#xff0c;主要诉求就是优化系统&#xff0c;基于LNMP的系统优化。正好这个领域我比较熟悉&#xff0c;以前都是在公司做项目&#xff0c;也不怎么涉猎系统优…

展会邀请 | 龙智即将亮相2024上海国际嵌入式展,带来安全合规、单一可信数据源、可追溯、高效协同的嵌入式开发解决方案

2024年6月12日至14日&#xff0c;备受全球嵌入式系统产业和社群瞩目的2024上海国际嵌入式展&#xff08;embedded world china 2024&#xff09;即将盛大开幕&#xff0c;龙智将携行业领先的嵌入式开发解决方案亮相 640展位 。 此次参展&#xff0c;龙智将全面展示专为嵌入式行…

[C++]基于C++opencv结合vibe和sort tracker实现高空抛物实时检测

【vibe算法介绍】 ViBe算法是一种高效的像素级视频背景建模和前景检测算法。以下是对该算法的详细介绍&#xff1a; 一、算法原理 ViBe算法的核心思想是通过为每个像素点存储一个样本集&#xff0c;利用该样本集与当前像素值进行比较&#xff0c;从而判断该像素是否属于背景…

SpringBoot的学习要点

目录 SpringBoot 创建项目 配置文件 注解 命名规范 SpringBoot整合第三方技术 …… 中文文档&#xff1a;Spring Boot 中文文档 SpringBoot Spring Boot 是基于 Spring 框架的一种快速构建微服务应用的方式它主要提供了自动配置、简化配置、运行时应用监控等功能它…