Seurat 源码学习之VlnPlot

2023-10-08 07:40
文章标签 源码 学习 seurat vlnplot

本文主要是介绍Seurat 源码学习之VlnPlot,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

今天很好奇Seurat里的Vlnplot是怎么画的,花了一个上午研究一下这个画图,其实还是很简单的哈, 以官网的pbmc3k为例

#
library(dplyr)
library(Seurat)
library(patchwork)
setwd("/Users/xiaokangyu/Desktop/Seurat_raw_code/")
pbmc.data = Read10X("/Users/xiaokangyu/Desktop/test_dataset/pbmc_3k/filtered_gene_bc_matrices/hg19/")pbmc = CreateSeuratObject(counts = pbmc.data,project = "pbmc3k",min.cells=3,min.features = 200)
pbmcpbmc[["percent.mt"]] <- PercentageFeatureSet(pbmc, pattern = "^MT-")pbmc <- subset(pbmc, subset = nFeature_RNA > 200 & nFeature_RNA < 2500 & percent.mt < 5)pbmc <- NormalizeData(pbmc)pbmc <- FindVariableFeatures(pbmc, selection.method = "vst", nfeatures = 2000)all.genes <- rownames(pbmc)pbmc <- ScaleData(pbmc, features = all.genes)pbmc <- RunPCA(pbmc, features = VariableFeatures(object = pbmc))pbmc <- FindNeighbors(pbmc, dims = 1:10)pbmc <- FindClusters(pbmc, resolution = 0.5)pbmc <- RunUMAP(pbmc, dims = 1:10)new.cluster.ids <- c("Naive CD4 T", "Memory CD4 T", "CD14+ Mono", "B", "CD8 T", "FCGR3A+ Mono", "NK", "DC", "Platelet")names(new.cluster.ids) <- levels(pbmc)pbmc <- RenameIdents(pbmc, new.cluster.ids)pbmc[['cell_type']] <- pbmc@active.identlevels(pbmc)saveRDS(pbmc, file = "./pbmc.rds")# p =DimPlot(pbmc, reduction = "umap", group.by = "cell_type")#画batch图
# print(p)
# 
# pp=DimPlot(pbmc, reduction = "umap", group.by = "cell_type", label.size = 5,label=T)+ggtitle("annotated Celltype")+NoLegend()
# print(pp)
# 
# print(p+pp)
# p1=FeaturePlot(pbmc, features = c("MS4A1", "GNLY", "CD3E", "CD14", "FCER1A", "FCGR3A", "LYZ", "PPBP",
#                                   "CD8A"))
# 
# p2=FeaturePlot(pbmc, features = c("MS4A1", "CD79A"))
# print(p2)
# 
# p3=VlnPlot(pbmc, features = c("MS4A1", "CD79A"))p4 = VlnPlot(pbmc,features = c("MS4A1"))print(p4)
# pbmc@active.assay

结果如下
在这里插入图片描述在这里插入图片描述

可以看到这个结果很好哈,现在研究这个小提琴图是怎么画的

首先注意一点本地mac电脑可以直接调试,而服务器的rstudio打上断点后没有调试的相关按钮,很奇怪
在这里插入图片描述而在服务器上
在这里插入图片描述
注意在R里的调试有一个好处,虽然我直接安装了Seurat,直接使用调试按钮直接进入函数,但是python里有的包你是进不去的,首先进入的
在这里插入图片描述可以看到Vlnplot调用的是ExIplot函数,接着调用的是SingleExIPlot函数
在这里插入图片描述在这里插入图片描述这里可以看到真正的画图函数,代码还是很简单的

下面是我自己复现的代码

rm(list=ls())
library(Seurat)
library(ggplot2)
library(cowplot)pbmc = readRDS("./pbmc.rds")
set.seed(42)
feature ="MS4A1"
data_all = pbmc@assays$RNA@data # 取出来上dgcMatrix是稀疏矩阵,没法取行列
data_df = data.frame(data_all)
data = data.frame(t(data_df[feature,])) # 取feature 基因对应的表达
data$ident =pbmc@meta.data$cell_type # 我这里发现一个R的bug,就是对于因子类型的变量
#如果写入csv文件再读取,那么这个factor对应的level的顺序可能会自己变化,不再是开始保存时的结果了,
#如果要保存level对应的信息时,还是应该使用saveRDS而不是write.csvnoise <- rnorm(n = length(x = data[, feature]))/1e+05
data[, feature] <- data[, feature] + noisept.size = 0.1154295
x="ident"
y="`MS4A1`"
fill ="ident"
xlab="Identity"
feature = "MS4A1"
ylab ="Expression Level"jitter <- geom_jitter(height = 0, size = pt.size, show.legend = FALSE)
plot <- ggplot(data = data, mapping = aes_string(x = x, y = y, fill = fill)[c(2, 3, 1)]) + labs(x = xlab, y = ylab, title = feature, fill = NULL) + theme_cowplot() + theme(plot.title = element_text(hjust = 0.5))geom <- list(geom_violin(scale = "width", adjust = 1, trim = TRUE), theme(axis.text.x = element_text(angle = 45, hjust = 1)))plot <- do.call(what = "+", args = list(plot, geom))plot = plot + jitter
print(plot)

在这里插入图片描述这个结果和Seurat画出来的是一样的,嘿嘿

我的环境如下

sessionInfo()
R version 4.1.2 (2021-11-01)
Platform: x86_64-apple-darwin17.0 (64-bit)
Running under: macOS 13.1Matrix products: default
LAPACK: /Library/Frameworks/R.framework/Versions/4.1/Resources/lib/libRlapack.dyliblocale:
[1] en_US.UTF-8/en_US.UTF-8/en_US.UTF-8/C/en_US.UTF-8/en_US.UTF-8attached base packages:
[1] stats4    stats     graphics  grDevices utils     datasets  methods   base     other attached packages:[1] cowplot_1.1.1               patchwork_1.1.2             SeuratObject_4.1.3         [4] Seurat_4.3.0                dplyr_1.1.0                 ggplot2_3.4.1              [7] splatter_1.18.2             SingleCellExperiment_1.16.0 SummarizedExperiment_1.24.0
[10] Biobase_2.54.0              GenomicRanges_1.46.1        GenomeInfoDb_1.30.1        
[13] IRanges_2.28.0              S4Vectors_0.32.4            BiocGenerics_0.40.0        
[16] MatrixGenerics_1.6.0        matrixStats_0.63.0         loaded via a namespace (and not attached):[1] ggbeeswarm_0.7.1       Rtsne_0.16             colorspace_2.0-3      [4] deldir_1.0-6           ellipsis_0.3.2         ggridges_0.5.4        [7] XVector_0.34.0         rstudioapi_0.14        spatstat.data_3.0-0   [10] farver_2.1.1           leiden_0.4.3           listenv_0.9.0         [13] ggrepel_0.9.2          fansi_1.0.3            R.methodsS3_1.8.2     [16] codetools_0.2-18       splines_4.1.2          polyclip_1.10-4       [19] jsonlite_1.8.4         ica_1.0-3              cluster_2.1.2         [22] R.oo_1.25.0            png_0.1-8              uwot_0.1.14           [25] shiny_1.7.4            sctransform_0.3.5      spatstat.sparse_3.0-0 [28] compiler_4.1.2         httr_1.4.4             backports_1.4.1       [31] Matrix_1.5-1           fastmap_1.1.0          lazyeval_0.2.2        [34] cli_3.6.0              later_1.3.0            htmltools_0.5.4       [37] tools_4.1.2            igraph_1.3.5           gtable_0.3.1          [40] glue_1.6.2             GenomeInfoDbData_1.2.7 RANN_2.6.1            [43] reshape2_1.4.4         Rcpp_1.0.10            scattermore_0.8       [46] vctrs_0.5.2            spatstat.explore_3.0-5 nlme_3.1-153          [49] progressr_0.13.0       lmtest_0.9-40          spatstat.random_3.0-1 [52] stringr_1.5.0          globals_0.16.2         mime_0.12             [55] miniUI_0.1.1.1         lifecycle_1.0.3        irlba_2.3.5.1         [58] goftest_1.2-3          future_1.30.0          zlibbioc_1.40.0       [61] MASS_7.3-54            zoo_1.8-11             scales_1.2.1          [64] promises_1.2.0.1       spatstat.utils_3.0-1   parallel_4.1.2        [67] RColorBrewer_1.1-3     reticulate_1.27        pbapply_1.6-0         [70] gridExtra_2.3          ggrastr_1.0.1          stringi_1.7.8         [73] checkmate_2.1.0        BiocParallel_1.28.3    rlang_1.1.0           [76] pkgconfig_2.0.3        bitops_1.0-7           lattice_0.20-45       [79] ROCR_1.0-11            purrr_1.0.1            tensor_1.5            [82] labeling_0.4.2         htmlwidgets_1.6.1      tidyselect_1.2.0      [85] parallelly_1.33.0      RcppAnnoy_0.0.20       plyr_1.8.8            [88] magrittr_2.0.3         R6_2.5.1               generics_0.1.3        [91] DelayedArray_0.20.0    DBI_1.1.3              withr_2.5.0           [94] pillar_1.8.1           fitdistrplus_1.1-8     survival_3.2-13       [97] abind_1.4-5            RCurl_1.98-1.9         sp_1.5-1              
[100] tibble_3.2.1           future.apply_1.10.0    crayon_1.5.2          
[103] KernSmooth_2.23-20     utf8_1.2.2             spatstat.geom_3.0-3   
[106] plotly_4.10.1          locfit_1.5-9.7         grid_4.1.2            
[109] data.table_1.14.6      digest_0.6.31          xtable_1.8-4          
[112] tidyr_1.3.0            httpuv_1.6.7           R.utils_2.12.2        
[115] munsell_0.5.0          beeswarm_0.4.0         viridisLite_0.4.1     
[118] vipor_0.4.5     

这篇关于Seurat 源码学习之VlnPlot的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Go学习记录之runtime包深入解析

《Go学习记录之runtime包深入解析》Go语言runtime包管理运行时环境,涵盖goroutine调度、内存分配、垃圾回收、类型信息等核心功能,:本文主要介绍Go学习记录之runtime包的... 目录前言:一、runtime包内容学习1、作用:① Goroutine和并发控制:② 垃圾回收:③ 栈和

Android学习总结之Java和kotlin区别超详细分析

《Android学习总结之Java和kotlin区别超详细分析》Java和Kotlin都是用于Android开发的编程语言,它们各自具有独特的特点和优势,:本文主要介绍Android学习总结之Ja... 目录一、空安全机制真题 1:Kotlin 如何解决 Java 的 NullPointerExceptio

8种快速易用的Python Matplotlib数据可视化方法汇总(附源码)

《8种快速易用的PythonMatplotlib数据可视化方法汇总(附源码)》你是否曾经面对一堆复杂的数据,却不知道如何让它们变得直观易懂?别慌,Python的Matplotlib库是你数据可视化的... 目录引言1. 折线图(Line Plot)——趋势分析2. 柱状图(Bar Chart)——对比分析3

重新对Java的类加载器的学习方式

《重新对Java的类加载器的学习方式》:本文主要介绍重新对Java的类加载器的学习方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、介绍1.1、简介1.2、符号引用和直接引用1、符号引用2、直接引用3、符号转直接的过程2、加载流程3、类加载的分类3.1、显示

Android实现一键录屏功能(附源码)

《Android实现一键录屏功能(附源码)》在Android5.0及以上版本,系统提供了MediaProjectionAPI,允许应用在用户授权下录制屏幕内容并输出到视频文件,所以本文将基于此实现一个... 目录一、项目介绍二、相关技术与原理三、系统权限与用户授权四、项目架构与流程五、环境配置与依赖六、完整

Android实现定时任务的几种方式汇总(附源码)

《Android实现定时任务的几种方式汇总(附源码)》在Android应用中,定时任务(ScheduledTask)的需求几乎无处不在:从定时刷新数据、定时备份、定时推送通知,到夜间静默下载、循环执行... 目录一、项目介绍1. 背景与意义二、相关基础知识与系统约束三、方案一:Handler.postDel

Java学习手册之Filter和Listener使用方法

《Java学习手册之Filter和Listener使用方法》:本文主要介绍Java学习手册之Filter和Listener使用方法的相关资料,Filter是一种拦截器,可以在请求到达Servl... 目录一、Filter(过滤器)1. Filter 的工作原理2. Filter 的配置与使用二、Listen

Java 正则表达式URL 匹配与源码全解析

《Java正则表达式URL匹配与源码全解析》在Web应用开发中,我们经常需要对URL进行格式验证,今天我们结合Java的Pattern和Matcher类,深入理解正则表达式在实际应用中... 目录1.正则表达式分解:2. 添加域名匹配 (2)3. 添加路径和查询参数匹配 (3) 4. 最终优化版本5.设计思

Java调用C++动态库超详细步骤讲解(附源码)

《Java调用C++动态库超详细步骤讲解(附源码)》C语言因其高效和接近硬件的特性,时常会被用在性能要求较高或者需要直接操作硬件的场合,:本文主要介绍Java调用C++动态库的相关资料,文中通过代... 目录一、直接调用C++库第一步:动态库生成(vs2017+qt5.12.10)第二步:Java调用C++

Python实现无痛修改第三方库源码的方法详解

《Python实现无痛修改第三方库源码的方法详解》很多时候,我们下载的第三方库是不会有需求不满足的情况,但也有极少的情况,第三方库没有兼顾到需求,本文将介绍几个修改源码的操作,大家可以根据需求进行选择... 目录需求不符合模拟示例 1. 修改源文件2. 继承修改3. 猴子补丁4. 追踪局部变量需求不符合很