码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Rliger | 完美整合单细胞测序数据(部分交集数据的整合)(三)


    alt

    11. 写在前面

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

    22.用到的包

    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)
    • 1

    33. 示例数据

    这里我们提供1个3’ PBMC dataset和1个whole blood dataset。🤗

    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)
    • 1

    创建Seurat对象。 🧐

    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
    • 1
    alt

    alt

    44. 修改metadata

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

    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[[]])
    • 1
    alt

    55. 初步合并

    5.1 简单合并

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

    wb_liger <- merge(srat_3p,srat_wb)
    • 1

    5.2 标准操作

    我们在这里做一下Normalization,寻找高变基因等等标准操作。👀 Note! 这里需要跟大家说下,rlinger在ScaleData时没有将数据中心化,我们需要设置为F。

    wb_liger  <- NormalizeData(wb_liger)
    wb_liger <- FindVariableFeatures(wb_liger)
    wb_liger <- ScaleData(wb_liger, split.by = "orig.ident", do.center = F)
    • 1
    alt

    5.3 合并数据

    wb_liger <- RunOptimizeALS(wb_liger, k = 30, lambda = 5, split.by = "orig.ident")
    wb_liger <- RunQuantileNorm(wb_liger, split.by = "orig.ident")
    • 1
    alt

    66. 降维与聚类

    6.1 寻找clusters

    wb_liger <- FindNeighbors(wb_liger,reduction = "iNMF",k.param = 10,dims = 1:30)
    wb_liger <- FindClusters(wb_liger)
    • 1
    alt

    6.2 聚类可视化

    wb_liger    <- RunUMAP(wb_liger, dims = 1:ncol(wb_liger[["iNMF"]]), 
    reduction = "iNMF",verbose = F)

    wb_liger <- SetIdent(wb_liger,value = "orig.ident")

    p1 <- DimPlot(wb_liger,reduction = "umap") +
    scale_color_npg()+
    plot_annotation(title = "10k 3' PBMC and 10k 5' PBMC cells, after integration (LIGER)")

    p2 <- DimPlot(wb_liger, reduction = "umap",
    group.by = "orig.ident", pt.size = .1, split.by = 'orig.ident') +
    scale_color_npg()+
    NoLegend()

    p1 + p2
    • 1
    alt

    wb_liger <- SetIdent(wb_liger,value = "seurat_clusters")

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

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

    DimPlot(wb_liger,reduction = "umap",label = T,
    cols = mycol, repel = T) +
    NoLegend()
    • 1
    alt

    6.3 具体查看及可视化

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

    count_table <- table(wb_liger@meta.data$seurat_clusters, wb_liger@meta.data$orig.ident)
    count_table

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

    青椒
    最后祝大家早日不卷!~

    需要示例数据的小伙伴,在公众号回复Merge2获取吧!

    点个在看吧各位~ ✐.ɴɪᴄᴇ ᴅᴀʏ 〰

    📍 往期精彩

    📍 🤩 ComplexHeatmap | 颜狗写的高颜值热图代码!
    📍 🤥 ComplexHeatmap | 你的热图注释还挤在一起看不清吗!?
    📍 🤨 Google | 谷歌翻译崩了我们怎么办!?(附完美解决方案)
    📍 🤩 scRNA-seq | 吐血整理的单细胞入门教程
    📍 🤣 NetworkD3 | 让我们一起画个动态的桑基图吧~
    📍 🤩 RColorBrewer | 再多的配色也能轻松搞定!~
    📍 🧐 rms | 批量完成你的线性回归
    📍 🤩 CMplot | 完美复刻Nature上的曼哈顿图
    📍 🤠 Network | 高颜值动态网络可视化工具
    📍 🤗 boxjitter | 完美复刻Nature上的高颜值统计图
    📍 🤫 linkET | 完美解决ggcor安装失败方案(附教程)
    📍 ......

    alt

    本文由 mdnice 多平台发布

  • 相关阅读:
    正则表达式
    IPv4地址转换成整数
    【前端面试必知】对插槽(slot)的理解
    java基础之什么是面向对象?[11]
    接口测试和功能测试有什么区别
    【RTOS学习】精简RTOS源码 | 认识RTOS | 任务的创建和删除
    云资产管理之CF利用框架
    C语言从头学16——数据类型(二)
    排序算法:选择排序,分别用c++、java、python实现
    android源码-ContentProvider实现原理分析
  • 原文地址:https://blog.csdn.net/m0_72224305/article/details/127712762
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号