單細胞轉(zhuǎn)錄組數(shù)據(jù)分析|| scanpy教程:可視化套件

在數(shù)據(jù)分析中離不開結(jié)果的呈現(xiàn)净刮,像seurat一樣,scanpy也提供了大量的可視化的函數(shù)印蔗。在python生態(tài)中,繪圖主要由matplotlib和seaborn來完成。數(shù)據(jù)可視化是一門藝術(shù)游昼,每一種可視化的呈現(xiàn)都給我們一個解讀數(shù)據(jù)的視角仪缸,也為我們下一步數(shù)據(jù)分析提供了視覺上的依據(jù)。

今天痴荐,我們就來看看scanpy的可視化結(jié)果吧血柳。

import scanpy as sc
import pandas as pd
from matplotlib import rcParams
import numpy as np 

sc.set_figure_params(dpi=80, color_map='viridis')
sc.settings.verbosity = 2
sc.logging.print_versions()
scanpy==1.4.5.1
 anndata==0.7.1 
umap==0.3.10 
numpy==1.18.2 
scipy==1.3.1 
pandas==0.25.1 
scikit-learn==0.21.3
 statsmodels==0.10.1 
python-igraph==0.8.0

在前面的學習中我們發(fā)現(xiàn)scanpy的可視化函數(shù)都是pl來指引的如:sc.pl.violin,我們就來看看這個pl是如何寫的:

from ._anndata import scatter, violin, ranking, clustermap, stacked_violin, heatmap, dotplot, matrixplot, tracksplot, dendrogram, correlation_matrix

from ._preprocessing import filter_genes_dispersion, highly_variable_genes

from ._tools.scatterplots import embedding, pca, diffmap, draw_graph, tsne, umap
from ._tools import pca_loadings, pca_scatter, pca_overview, pca_variance_ratio
from ._tools.paga import paga, paga_adjacency, paga_compare, paga_path
from ._tools import dpt_timeseries, dpt_groups_pseudotime
from ._tools import rank_genes_groups, rank_genes_groups_violin
from ._tools import rank_genes_groups_dotplot, rank_genes_groups_heatmap, rank_genes_groups_stacked_violin, rank_genes_groups_matrixplot, rank_genes_groups_tracksplot
from ._tools import sim
from ._tools import embedding_density

from ._rcmod import set_rcParams_scanpy, set_rcParams_defaults
from . import palettes

from ._utils import matrix
from ._utils import timeseries, timeseries_subplot, timeseries_as_heatmap

from ._qc import highest_expr_genes

我們看到pl其實是一些函數(shù)的接口生兆,所有的繪圖函數(shù)匯總难捌,預處理函數(shù)匯總,計算工具匯總鸦难,這樣便于代碼閱讀:

# some technical stuff
import sys
from ._utils import pkg_version, check_versions, annotate_doc_types

__author__ = ', '.join([
    'Alex Wolf',
    'Philipp Angerer',
    'Fidel Ramirez',
    'Isaac Virshup',
    'Sergei Rybakov',
    'Gokcen Eraslan',
    'Tom White',
    'Malte Luecken',
    'Davide Cittaro',
    'Tobias Callies',
    'Marius Lange',
    'Andrés R. Mu?oz-Rojas',
])
__email__ = ', '.join([
    'f.alex.wolf@gmx.de',
    'philipp.angerer@helmholtz-muenchen.de',
    # We don’t need all, the main authors are sufficient.
])
try:
    from setuptools_scm import get_version
    __version__ = get_version(root='..', relative_to=__file__)
    del get_version
except (LookupError, ImportError):
    __version__ = str(pkg_version(__name__))

check_versions()
del pkg_version, check_versions

# the actual API
from ._settings import settings, Verbosity  # start with settings as several tools are using it
from . import tools as tl
from . import preprocessing as pp
from . import plotting as pl
from . import datasets, logging, queries, external, get

from anndata import AnnData
from anndata import read_h5ad, read_csv, read_excel, read_hdf, read_loom, read_mtx, read_text, read_umi_tools
from .readwrite import read, read_10x_h5, read_10x_mtx, write
from .neighbors import Neighbors

set_figure_params = settings.set_figure_params

# has to be done at the end, after everything has been imported
annotate_doc_types(sys.modules[__name__], 'scanpy')
del sys, annotate_doc_types

我們看到一種新的語法: from . import XXX根吁,這是什么意思呢?

在當前程序所在文件夾里__init_-.py程序中導入XXX合蔽,如果當前程序所在文件夾里沒有_init_.py文件的話击敌,就不能這樣寫,而應(yīng)該寫成from .A import XXX辈末,A是指當前文件夾下你想導入的函數(shù)(或者其他的)的python程序名愚争。所以有時候我們也可能看到 from .. import XXX(即上一個文件夾中的__init_.py)映皆,或者from ..A import XXX(即上一個文件夾中的文件A)。

如果細看的話轰枝,可能今天我們一張圖也看不到了捅彻。

讀入之前我們處理過的數(shù)據(jù):

results_file = 'E:\learnscanpy\write\pbmc3k.h5ad'
sdata = sc.read_h5ad(results_file)
sdata

AnnData object with n_obs × n_vars = 2223 × 2208 
    obs: 'n_genes', 'percent_mito', 'n_counts', 'percent_mito1', 'leiden'
    var: 'gene_ids', 'feature_types', 'n_cells', 'highly_variable', 'means', 'dispersions', 'dispersions_norm'
    uns: 'leiden', 'leiden_colors', 'leiden_sizes', 'neighbors', 'paga', 'pca', 'rank_genes_groups', 'umap'
    obsm: 'X_pca', 'X_umap'
    varm: 'PCs'
堆積小提琴圖

核心的可視化基本都是針對marker 基因的,所以我們先讀進來一套:

marker_genes = ['CD79A', 'MS4A1', 'CD8A', 'CD8B', 'LYZ',  'LGALS3', 'S100A8', 'GNLY', 'NKG7', 'KLRB1',
                'FCGR3A', 'FCER1A', 'CST3']

ax = sc.pl.stacked_violin(sdata, marker_genes, groupby='leiden',
                         var_group_positions=[(7, 8)], var_group_labels=['6'])

可以看出所給基因在每個分組中的表達分布鞍陨,也可以對分群聚類:

ax = sc.pl.stacked_violin(sdata, marker_genes, groupby='leiden', swap_axes=True, dendrogram=True)
點圖

給定marker基因列表步淹,可以看出他們在指定分組中的表達占比情況。

marker_genes_dict = {'1': ['CD79A', 'MS4A1'],
                     '2': ['PDXK'],
                     '3': ['CD8A', 'CD8B'],
                     '4': ['GNLY', 'NKG7'],
                     '5': ['CST3', 'LYZ'],
                     '6': ['FCGR3A'],
                     '7': ['FCER1A']}
ax = sc.pl.dotplot(sdata, marker_genes_dict, groupby='leiden')
ax = sc.pl.dotplot(sdata, marker_genes, groupby='leiden', dendrogram=True, dot_max=0.5, dot_min=0.3, standard_scale='var')

自定義顏色主題:

ax = sc.pl.dotplot(sdata, marker_genes_dict, groupby='leiden', dendrogram=True,
                   standard_scale='var', smallest_dot=40, color_map='Blues', figsize=(8,5))

強調(diào)展示某些gene列表:

ax = sc.pl.dotplot(sdata, marker_genes, groupby='leiden',
              var_group_positions=[(0,1), (11, 12)],
              var_group_labels=['1', '2'],
              figsize=(12,4), var_group_rotation=0, dendrogram='dendrogram_leiden')
熱圖
gs = sc.pl.matrixplot(sdata, marker_genes_dict, groupby='leiden')
gs = sc.pl.matrixplot(sdata, marker_genes_dict, groupby='leiden', dendrogram=True, standard_scale='var')
marker_genes_2 = [x for x in marker_genes if x in sdata.var_names]

marker_genes_2
Out[30]: 
['CD79A',
 'MS4A1',
 'CD8A',
 'CD8B',
 'LYZ',
 'LGALS3',
 'S100A8',
 'GNLY',
 'NKG7',
 'KLRB1',
 'FCGR3A',
 'FCER1A',
 'CST3']
gs = sc.pl.matrixplot(sdata, marker_genes_2, groupby='leiden', dendrogram=True,
                      use_raw=False, vmin=-3, vmax=3, cmap='bwr',  swap_axes=True, figsize=(5,6))
ax = sc.pl.heatmap(sdata,marker_genes_dict, groupby='leiden')
ax = sc.pl.heatmap(sdata, marker_genes, groupby='leiden', figsize=(5, 8),
              var_group_positions=[(0,1), (11, 12)], use_raw=False, vmin=-3, vmax=3, cmap='bwr',
              var_group_labels=['1', '2'], var_group_rotation=0, dendrogram='dendrogram_leiden')
tracksplot
import numpy as np
ad = sdata.copy()
ad.X.data = np.exp(ad.X.data)
ax = sc.pl.tracksplot(ad,marker_genes, groupby='leiden')
ax = sc.pl.tracksplot(sdata,marker_genes, groupby='leiden')
應(yīng)用在自己的差異基因中

不同的計算差異基因方法:

import warnings
warnings.simplefilter(action='ignore', category=FutureWarning)
sc.tl.rank_genes_groups(sdata, groupby='leiden', method='logreg',key_added = "logreg")
sc.tl.rank_genes_groups(sdata, groupby='leiden', method='wilcoxon',key_added ='wilcoxon')
sc.tl.rank_genes_groups(sdata, groupby='leiden', method='t-test',key_added = 't-test')

venn圖比較不同方法的異同:

from matplotlib_venn import venn3

wc = sdata.uns['wilcoxon']['names']['NK']
tt = sdata.uns['t-test']['names']['NK']
lr = sdata.uns['logreg']['names']['NK']

venn3([set(wc),set(tt),set(lr)], ('Wilcox','T-test','logreg') )
plt.show()

看到這個結(jié)果诚撵,作何感想缭裆?

rcParams['figure.figsize'] = 4,4
rcParams['axes.grid'] = True

sc.pl.rank_genes_groups(sdata)
sc.pl.rank_genes_groups_dotplot(sdata, n_genes=4)
axs = sc.pl.rank_genes_groups_dotplot(sdata, groupby='leiden', n_genes=10, dendrogram='dendrogram_leiden')
axs = sc.pl.rank_genes_groups_matrixplot(sdata, n_genes=10, standard_scale='var', cmap='Blues')

axs = sc.pl.rank_genes_groups_matrixplot(sdata, n_genes=10, use_raw=False, vmin=-3, vmax=3, cmap='bwr')

sc.pl.rank_genes_groups_stacked_violin(sdata, n_genes=3)

sc.pl.rank_genes_groups_stacked_violin(sdata, n_genes=3, row_palette='slateblue')

sc.pl.rank_genes_groups_stacked_violin(ad, n_genes=3, swap_axes=True, figsize=(6, 10), width=0.4)

sc.pl.rank_genes_groups_heatmap(sdata, n_genes=3, standard_scale='var')

sc.pl.rank_genes_groups_heatmap(sdata, n_genes=10, use_raw=False, swap_axes=True, show_gene_labels=False,
                                vmin=-3, vmax=3, cmap='bwr')

sc.pl.rank_genes_groups_tracksplot(ad, n_genes=20)
ax = sc.pl.dendrogram(sdata, 'leiden')
sc.tl.dendrogram(sdata, 'leiden', var_names=marker_genes, use_raw=False)
ax = sc.pl.dendrogram(sdata, 'leiden', orientation='left')
ax = sc.pl.correlation_matrix(sdata, 'leiden')
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市寿烟,隨后出現(xiàn)的幾起案子澈驼,更是在濱河造成了極大的恐慌,老刑警劉巖筛武,帶你破解...
    沈念sama閱讀 217,185評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件缝其,死亡現(xiàn)場離奇詭異,居然都是意外死亡徘六,警方通過查閱死者的電腦和手機内边,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,652評論 3 393
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來待锈,“玉大人漠其,你說我怎么就攤上這事「鸵簦” “怎么了和屎?”我有些...
    開封第一講書人閱讀 163,524評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長谍失。 經(jīng)常有香客問我眶俩,道長,這世上最難降的妖魔是什么快鱼? 我笑而不...
    開封第一講書人閱讀 58,339評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮纲岭,結(jié)果婚禮上抹竹,老公的妹妹穿的比我還像新娘。我一直安慰自己止潮,他們只是感情好窃判,可當我...
    茶點故事閱讀 67,387評論 6 391
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著喇闸,像睡著了一般袄琳。 火紅的嫁衣襯著肌膚如雪询件。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,287評論 1 301
  • 那天唆樊,我揣著相機與錄音宛琅,去河邊找鬼。 笑死逗旁,一個胖子當著我的面吹牛嘿辟,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播片效,決...
    沈念sama閱讀 40,130評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼红伦,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了淀衣?” 一聲冷哼從身側(cè)響起昙读,我...
    開封第一講書人閱讀 38,985評論 0 275
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎膨桥,沒想到半個月后蛮浑,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,420評論 1 313
  • 正文 獨居荒郊野嶺守林人離奇死亡国撵,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,617評論 3 334
  • 正文 我和宋清朗相戀三年陵吸,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片介牙。...
    茶點故事閱讀 39,779評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡壮虫,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出环础,到底是詐尸還是另有隱情囚似,我是刑警寧澤,帶...
    沈念sama閱讀 35,477評論 5 345
  • 正文 年R本政府宣布线得,位于F島的核電站饶唤,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏贯钩。R本人自食惡果不足惜募狂,卻給世界環(huán)境...
    茶點故事閱讀 41,088評論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望角雷。 院中可真熱鬧祸穷,春花似錦、人聲如沸勺三。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,716評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽吗坚。三九已至祈远,卻和暖如春呆万,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背车份。 一陣腳步聲響...
    開封第一講書人閱讀 32,857評論 1 269
  • 我被黑心中介騙來泰國打工谋减, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人躬充。 一個月前我還...
    沈念sama閱讀 47,876評論 2 370
  • 正文 我出身青樓逃顶,卻偏偏與公主長得像,于是被迫代替她去往敵國和親充甚。 傳聞我的和親對象是個殘疾皇子以政,可洞房花燭夜當晚...
    茶點故事閱讀 44,700評論 2 354

推薦閱讀更多精彩內(nèi)容