前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >🤪 Harmony | 完美整合单细胞测序数据(部分交集数据的整合)(二)

🤪 Harmony | 完美整合单细胞测序数据(部分交集数据的整合)(二)

作者头像
生信漫卷
发布2023-02-24 14:02:11
1.5K0
发布2023-02-24 14:02:11
举报

1写在前面

对于只有只有部分重叠的datasets,合并方法我们依然可以采用SeuratHarmonyrliger包,本期介绍一下Harmony包的用法。🤩

2用到的包

代码语言:javascript
复制
rm(list = ls())
library(Seurat)
library(SeuratDisk)
library(SeuratWrappers)
library(patchwork)
library(harmony)
library(rliger)
library(RColorBrewer)
library(tidyverse)
library(reshape2)
library(ggsci)
library(ggstatsplot)

3示例数据

这里我们提供13’ PBMC dataset1whole blood dataset。🥰

代码语言:javascript
复制
umi_gz <- gzfile("./GSE149938_umi_matrix.csv.gz",'rt')  
umi <- read.csv(umi_gz,check.names = F,quote = "")

matrix_3p    <- Read10X_h5("./3p_pbmc10k_filt.h5",use.names = T)

创建Seurat对象。🐶

代码语言:javascript
复制
srat_wb <- CreateSeuratObject(t(umi),project = "whole_blood")
srat_3p <- CreateSeuratObject(matrix_3p,project = "pbmc10k_3p")
rm(umi_gz)
rm(umi)
rm(matrix_3p)
srat_wb
srat_3p

4修改metadata

为了方便后续分析,这里我们对metadata进行一下注释修改

代码语言:javascript
复制
colnames(srat_wb@meta.data)[1] <- "cell_type"
srat_wb@meta.data$orig.ident <- "whole_blood"
srat_wb@meta.data$orig.ident <- as.factor(srat_wb@meta.data$orig.ident)
head(srat_wb[[]])

5初步合并

5.1 简单合并

这里我们先用merge2个数据集简单合并在一起。(这里我们默认做过初步过滤了哈,具体的大家可以看一下上期的教学。)😘

代码语言:javascript
复制
wb_harmony  <- merge(srat_3p,srat_wb)

5.2 标准操作

我们在这里做一下Normalization,寻找高变基因等等标准操作。👀

代码语言:javascript
复制
wb_harmony <- NormalizeData(wb_harmony, verbose = F)
wb_harmony <- FindVariableFeatures(wb_harmony, selection.method = "vst", nfeatures = 2000, verbose = F)
wb_harmony <- ScaleData(wb_harmony, verbose = F)
wb_harmony <- RunPCA(wb_harmony, npcs = 30, verbose = F)
wb_harmony <- RunUMAP(wb_harmony, reduction = "pca", dims = 1:30, verbose = F)

6harmony合并数据

6.1 合并前

代码语言:javascript
复制
p1 <- DimPlot(object = wb_harmony, reduction = "pca", 
              pt.size = .1, group.by = "orig.ident") + 
  scale_color_npg()+
  NoLegend()

p2 <- VlnPlot(object = wb_harmony, features = "PC_1", 
              group.by = "orig.ident", pt.size = .1) + 
  scale_color_npg()+
  NoLegend()

p1+p2

代码语言:javascript
复制
DimPlot(wb_harmony,reduction = "umap",
        group.by = "orig.ident") + 
  scale_color_npg()+
  plot_annotation(title = "10k 3' PBMC and whole blood, before integration")

6.2 开始合并

代码语言:javascript
复制
wb_harmony <- wb_harmony %>% 
  RunHarmony("orig.ident", plot_convergence = T)

6.3 查看信息

代码语言:javascript
复制
harmony_embeddings <- Embeddings(wb_harmony, 'harmony')
harmony_embeddings[1:5, 1:5]

6.4 可视化-harmony

harmony合并后。

代码语言:javascript
复制
p1 <- DimPlot(object = wb_harmony, reduction = "harmony", pt.size = .1, group.by = "orig.ident") + 
  scale_color_npg()+
  NoLegend()

p2 <- VlnPlot(object = wb_harmony, features = "harmony_1", group.by = "orig.ident", pt.size = .1) + 
  scale_fill_npg()+
  NoLegend()
p1 +p2

6.5 可视化-UMAP

harmony合并后。

代码语言:javascript
复制
wb_harmony <- SetIdent(wb_harmony,value = "orig.ident")
DimPlot(wb_harmony,reduction = "umap") + 
  scale_color_npg()+
  plot_annotation(title = "10k 3' PBMC and whole blood, after integration (Harmony)")

7降维与聚类

7.1 寻找clusters

代码语言:javascript
复制
wb_harmony <- wb_harmony %>% 
  RunUMAP(reduction = "harmony", dims = 1:30, verbose = F) %>% 
  FindNeighbors(reduction = "harmony", k.param = 10, dims = 1:30) %>% 
  FindClusters() %>% 
  identity()

代码语言:javascript
复制
wb_harmony <- SetIdent(wb_harmony,value = "seurat_clusters")

ncluster <- length(unique(wb_harmony[[]]$seurat_clusters))

mycol <- colorRampPalette(brewer.pal(8, "Set2"))(ncluster)

DimPlot(wb_harmony,label = T,
        cols = mycol, repel = T) + 
  NoLegend()

7.3 具体查看及可视化

我们看下各个clusters在两个datasets各有多少细胞。

代码语言:javascript
复制
count_table <- table(wb_harmony@meta.data$seurat_clusters, wb_harmony@meta.data$orig.ident)
count_table

#### 可视化
count_table %>% 
  as.data.frame() %>% 
  ggbarstats(x = Var2, 
             y = Var1,
             counts = Freq)+
  scale_fill_npg()

最后祝大家早日不卷!~


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

本文分享自 生信漫卷 微信公众号,前往查看

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

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

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1写在前面
  • 2用到的包
  • 3示例数据
  • 4修改metadata
  • 5初步合并
    • 5.1 简单合并
      • 5.2 标准操作
      • 6harmony合并数据
        • 6.1 合并前
          • 6.2 开始合并
            • 6.3 查看信息
              • 6.4 可视化-harmony
                • 6.5 可视化-UMAP
                • 7降维与聚类
                  • 7.1 寻找clusters
                    • 7.3 具体查看及可视化
                    领券
                    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档