空转分析代码备忘录:seurat可视化代码雕琢

作者:ahworld
链接:空转分析代码备忘录:seurat可视化代码雕琢
来源:微信公众号seqyuan
著作权归作者所有,任何形式的转载都请联系作者。

简介

目前常见的空间转录组数据技术平台有:

seurat软件以其简单易用性,通过特定的矩阵格式转换,能够兼容大多数平台的数据格式。为了发表文章,图片美化的需要,在做项目过程中经常用到一些优化的代码,在这里做个备忘。

1. 可视化图片保持空转切片长宽比

有时候我们做空转分析采用SpatialFeaturePlotSpatialDimPlot画图,经常发现图片的长宽比例与原始切片相比有压缩或者拉伸,下面的代码能够帮助我们解决这个问题。

下面图是这个芯片采用stereropy软件可视化的效果(让我们对这个切片有一个感官的了解)。

我们下载处理了这个STO切片的数据,设置bin50转换成了seurat能够读取的rds对象。

SS200000135TL_D1.tissue.gem.gz转换成bin50分辨率seurat rds的过程不是这篇文章的内容。

suppressPackageStartupMessages({
    library(Seurat)
    library(ggplot2)
    library(viridis)
    library(patchwork)
    library(RColorBrewer)
})

# 读取数据
rds <- readRDS('./mouse_brain_sto.rds')

图片长宽比修正

下面左图为正常可视化结果,正常的可视化会使图片的长宽比失真,我们加一些修饰代码使可视化的结果保持切片的长宽比。

options(repr.plot.width=7, repr.plot.height=4)

p1 <- SpatialFeaturePlot(rds, features = "nCount_Spatial")
p2 <- p1 + theme_gray()+xlab("")+ylab("")+theme(axis.text = element_blank(),axis.ticks=element_blank())

p1+p2

[图片上传失败...(image-4974cd-1706604409823)]

去除point黑色边圈

默认的可视化会把spot加上黑边,当spot点很密集的时候整个图片会显示的比较暗,可以设置stroke=NA来使图片变得明亮。

p1 <- SpatialDimPlot(rds)
p2 <- SpatialDimPlot(rds, stroke=NA) 
p2 <- p2 + guides(color=guide_legend(override.aes = list(size=8), ncol=2))
p2 <- p2 + theme_gray()+xlab("")+ylab("")
p2 <- p2 + theme(axis.text = element_blank(),axis.ticks=element_blank())

p1+p2

2. 用seurat单细胞的函数实现空转spot分布

  • 在seurat中FeaturePlot, DimPlot是单细胞数据可视化的函数
  • SpatialDimPlot, SpatialFeaturePlot是空转数据可视化的函数

下面的操作可以使空转的数据能够用单细胞的函数(FeaturePlot, DimPlot)进行可视化,以达到高度定制图片的目的。

有这个想法,是因为前一阵做数据探索时,发现下载的一篇宫颈癌STO的文章数据就这这种结构,能够非常方便的进行定制化修改。

spatial_corr <- rds@images$slice1@coordinates[,c('col', 'row')]
colnames(spatial_corr) <- c('s_1', 's_2')
spatial_corr <- as.matrix(spatial_corr)
rds[["spatial"]] <- CreateDimReducObject(embeddings=spatial_corr, key = "s_", assay = "Spatial")

options(repr.plot.width=10.5, repr.plot.height=4)

p1 <- FeaturePlot(rds, features = "nCount_Spatial", reduction='spatial') + 
    scale_y_reverse() + 
    scale_colour_viridis(option="inferno") + theme_void()
p2 <- FeaturePlot(rds, features = "Neurod6", reduction='spatial') +
    scale_y_reverse() + 
    scale_colour_viridis(option="D") + theme_void()

mycolor <- colorRampPalette(brewer.pal(8,'Set2'))(18)

p3 <- DimPlot(rds, reduction='spatial', cols=mycolor) + 
    guides(color=guide_legend(override.aes = list(size=6), ncol=2)) +
    theme_void() + scale_y_reverse()

p1+p2+p3+plot_layout(ncol=3, nrow=1)

Nature Genetics 文章图风格复现

前面提到的宫颈癌STO数据就是来源于下面要复现的文章,文章在2023年3月发表在Nature Genetics杂志,切片数据为sterero-seq平台产生,作者提供的是seurat的rds对象格式供研究者使用。文章doi: 10.1038/s41588-023-01570-0

下面图是文章中的原图截图

这个对象的空间信息并没有保存在images里而是像我们前面一样保存在了reductions里面,关键字是spatial。所以我们能用seurat中单细胞的可视化函数对这个数据进行可视化。

suppressPackageStartupMessages({
    library(Seurat)
    library(ggplot2)
    library(viridis)
    library(patchwork)
    library(RColorBrewer)
    library(paletteer)
})

Newf <- function(RDS, feature, ad=1, limits=1){
    viridis_plasma_light_high <- as.vector(x = paletteer_c(palette = "viridis::inferno", n = 250, direction = 1))
    viridis_plasma_light_high <- c( rep("black", ad), viridis_plasma_light_high)

    p <- FeaturePlot(RDS, features = feature, reduction='spatial')
    p <- p + theme_void()+ theme(
                axis.ticks=element_blank(),
                axis.text.x = element_blank(),
                axis.text.y = element_blank(),
                axis.line = element_blank(),
                panel.border = element_rect(color = "white", fill = NA, size =2),
            ) + 
        DarkTheme() +
        xlab(NULL) + 
        ylab(NULL)
    if (length(limits)==1){
        p <- p + scale_colour_gradientn(colours=viridis_plasma_light_high, na.value = "black") 
    }else{
        p <- p + scale_colour_gradientn(colours=viridis_plasma_light_high, na.value = "black",limits=limits)
    }

    return (p)
}

# 读取下载的数据
ca <- readRDS('spatial.rds')

p1 <- Newf(ca, "CD4 T")
p2 <- Newf(ca, "CD8 T")
p3 <- Newf(ca, "B")
p4 <- Newf(ca, "DC")
p5 <- Newf(ca, "Macro")
p6 <- Newf(ca, "Endothelial")
p7 <- Newf(ca, "Fibroblast")
p8 <- Newf(ca, "Program_C6")
p9 <- Newf(ca, "Program_C7")

options(repr.plot.width=8.5, repr.plot.height=10)
p <- p1+p2+p3+p4+p5+p6+p7+p8+p9 + plot_layout(ncol=3, nrow=3)
p
#ggsave("out.pdf", p, w=8.5, h=10)

trick: 和文章图还有一点差别,这个差别就是为什么我们定义的Newf函数有一个ad参数和背景用黑色原因,设置ad参数能够在colorbar系列的小值增加黑色,这样一些低表达的spot就被隐藏在黑色背景里了,当我们要突出切片轮廓时,可以设置ad=0

总结以上用到的备忘知识点:

  1. 还原图片的长宽比
  2. 黑圈消失术
  3. legend点放大术
  4. rds对象根据自定义坐标增加reduction
  5. 低表达spot隐藏术
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,236评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,867评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,715评论 0 340
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,899评论 1 278
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,895评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,733评论 1 283
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,085评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,722评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,025评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,696评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,816评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,447评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,057评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,009评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,254评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,204评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,561评论 2 343

推荐阅读更多精彩内容