9 绘图实例(1) Drawing example(1)

(代码下载)
本文主要讲述seaborn官网相关函数绘图实例。具体内容有:

  1. Anscombe’s quartet(lmplot)
  2. Color palette choices(barplot)
  3. Different cubehelix palettes(kdeplot)
  4. Distribution plot options(distplot)
  5. Timeseries plot with error bands(lineplot)
  6. FacetGrid with custom projection(FacetGrid)
  7. Facetting histograms by subsets of data(FacetGrid)
  8. Line plots on multiple facets(relplot)
  9. Grouped barplots(catplot)
  10. Grouped boxplots(boxplot)
# import packages
# from IPython.core.interactiveshell import InteractiveShell
# InteractiveShell.ast_node_interactivity = "all"
import numpy as np
import matplotlib.pyplot as plt
import pandas as pd
import seaborn as sns
sns.set(style="ticks")

1. Anscombe’s quartet(lmplot)

# Load the example dataset for Anscombe's quartet
df = sns.load_dataset("anscombe")
df.head()
# Show the results of a linear regression within each dataset 显示各组的回归拟合结果
# col确认分组类别,hue设置绘图颜色类别.col_wrap设置每行多少图像
# ci置信区间大小,palette颜色设置,height设置每张图的尺寸
sns.lmplot(x="x", y="y", col="dataset", hue="dataset", data=df,
col_wrap=2, ci=None, palette="muted", height=4,
scatter_kws={"s": 50, "alpha": 1});

2. Color palette choices(barplot)

#context控制上下文本参数
sns.set(style="white", context="talk")
rs = np.random.RandomState(8)
# Set up the matplotlib figure 设置matplotlib绘图参数
f, (ax1, ax2, ax3) = plt.subplots(3, 1, figsize=(7, 5), sharex=True) # Generate some sequential data 建立数据集
x = np.array(list("ABCDEFGHIJ"))
y1 = np.arange(1, 11) # 第一个条形图
sns.barplot(x=x, y=y1, palette="rocket", ax=ax1);
# 绘制平行于x轴的水平参考线
ax1.axhline(0, color="k", clip_on=False)
# 添加标签
ax1.set_ylabel("Sequential") # Center the data to make it diverging
y2 = y1 - 5.5
sns.barplot(x=x, y=y2, palette="vlag", ax=ax2)
ax2.axhline(0, color="k", clip_on=False)
ax2.set_ylabel("Diverging") # Randomly reorder the data to make it qualitative 生成数据
y3 = rs.choice(y1, len(y1), replace=False)
sns.barplot(x=x, y=y3, palette="deep", ax=ax3)
ax3.axhline(0, color="k", clip_on=False)
ax3.set_ylabel("Qualitative") # Finalize the plot 绘图最后参数调整
# 去掉了上、右和下边界。注意,这里despine()函数默认会去除上方和右侧的边界,
# 如果想要去掉左边和下方的边界,就需要额外指定left=True, bottom=True
sns.despine(bottom=True)
# 去除了所有的纵轴刻度尺
plt.setp(f.axes, yticks=[])
# ight_layout设置了每行坐标轴(子图)之间的间隔,h_pad确定上下间隔
plt.tight_layout(h_pad=2)

3. Different cubehelix palettes(kdeplot)

sns.set(style="dark")
rs = np.random.RandomState(50) # Set up the matplotlib figure 设置图像
f, axes = plt.subplots(3, 3, figsize=(9, 9), sharex=True, sharey=True) # Rotate the starting point around the cubehelix hue circle
for ax, s in zip(axes.flat, np.linspace(0, 3, 10)): # Create a cubehelix colormap to use with kdeplot 颜色设置
cmap = sns.cubehelix_palette(start=s, light=1, as_cmap=True) # Generate and plot a random bivariate dataset
x, y = rs.randn(2, 50)
# 核函数估计图制作
sns.kdeplot(x, y, cmap=cmap, shade=True, cut=5, ax=ax)
ax.set(xlim=(-3, 3), ylim=(-3, 3)) f.tight_layout()

4. Distribution plot options(distplot)

sns.set(style="white", palette="muted", color_codes=True)
rs = np.random.RandomState(10) # Set up the matplotlib figure 设置matplolitlib参数
f, axes = plt.subplots(2, 2, figsize=(7, 7), sharex=True)
# 去除边框
sns.despine(left=True) # Generate a random univariate dataset
d = rs.normal(size=100) # Plot a simple histogram with binsize determined automatically 直方图
sns.distplot(d, kde=False, color="b", ax=axes[0, 0]) # Plot a kernel density estimate and rug plot 画核密度曲线
sns.distplot(d, hist=False, rug=True, color="r", ax=axes[0, 1]) # Plot a filled kernel density estimate
sns.distplot(d, hist=False, color="g", kde_kws={"shade": True}, ax=axes[1, 0]) # Plot a historgram and kernel density estimate
sns.distplot(d, color="m", ax=axes[1, 1]) # 隐藏y轴
plt.setp(axes, yticks=[])
plt.tight_layout()

5. Timeseries plot with error bands(lineplot)

sns.set(style="darkgrid")

# Load an example dataset with long-form data
fmri = sns.load_dataset("fmri") # Plot the responses for different events and regions 线条图
sns.lineplot(x="timepoint", y="signal",
hue="region", style="event",
#置信区间设置
#ci=None,
data=fmri);

6. FacetGrid with custom projection(FacetGrid)

sns.set()

# Generate an example radial datast 随机生成数据
r = np.linspace(0, 10, num=100)
df = pd.DataFrame({'r': r, 'slow': r, 'medium': 2 * r, 'fast': 4 * r}) # Convert the dataframe to long-form or "tidy" format
df = pd.melt(df, id_vars=['r'], var_name='speed', value_name='theta') # Set up a grid of axes with a polar projection 建立坐标轴
# col表示使用什么分图,这里是speed,并用hue设置不同类对应不同颜色
# subplot_kws确定坐标类型,这里是极坐标
g = sns.FacetGrid(df, col="speed", hue="speed",
subplot_kws=dict(projection='polar'), height=4.5,
sharex=False, sharey=False, despine=False) # Draw a scatterplot onto each axes in the grid
# 在实例化后的坐标轴上画图
g.map(sns.scatterplot, "theta", "r");

7. FacetGrid with custom projection(FacetGrid)

sns.set(style="darkgrid")

tips = sns.load_dataset("tips")
# 初始化坐标轴,margin_titles行变量的标题被绘制到最后一列的右侧
g = sns.FacetGrid(tips, row="sex", col="time", margin_titles=True)
bins = np.linspace(0, 60, 13)
g.map(plt.hist, "total_bill", color="steelblue", bins=bins);

8. Line plots on multiple facets(relplot)

sns.set(style="ticks")

dots = sns.load_dataset("dots")

# Define a palette to ensure that colors will be
# shared across the facets
# 设置颜色
palette = dict(zip(dots.coherence.unique(),
sns.color_palette("rocket_r", 6))) # Plot the lines on two facets
sns.relplot(x="time", y="firing_rate",
hue="coherence", size="choice", col="align",
# size_order画图顺序
size_order=["T1", "T2"], palette=palette,
# aspect图的比例,facet_kws每个图参数设置
height=5, aspect=0.75, facet_kws=dict(sharex=False),
# kind画图类型,legend图例类型
kind="line", legend="brief", data=dots);

9. Grouped barplots(catplot)

sns.set(style="whitegrid")

# Load the example Titanic dataset 读取数据
titanic = sns.load_dataset("titanic") # Draw a nested barplot to show survival for class and sex
# catplot分类数据作图
g = sns.catplot(x="class", y="survived", hue="sex", data=titanic,
height=6, kind="bar", palette="muted")
# 设置轴框
g.despine(left=True)
# 设置标签
g.set_ylabels("survival probability");

10. Grouped boxplots(boxplot)

sns.set(style="ticks", palette="pastel")

# Load the example tips dataset
tips = sns.load_dataset("tips") # Draw a nested boxplot to show bills by day and time
# 画箱形图 hue颜色
sns.boxplot(x="day", y="total_bill",
hue="smoker", palette=["m", "g"],
data=tips)
# offset 两轴偏移绝对距离,trim只显示主要刻度
sns.despine(offset=10,trim=True)

[seaborn] seaborn学习笔记9-绘图实例(1) Drawing example(1)的更多相关文章

  1. [seaborn] seaborn学习笔记11-绘图实例(3) Drawing example(3)

    11 绘图实例(3) Drawing example(3)(代码下载) 本文主要讲述seaborn官网相关函数绘图实例.具体内容有: Plotting a diagonal correlation m ...

  2. [seaborn] seaborn学习笔记12-绘图实例(4) Drawing example(4)

    文章目录 12 绘图实例(4) Drawing example(4) 1. Scatterplot with varying point sizes and hues(relplot) 2. Scat ...

  3. [seaborn] seaborn学习笔记10-绘图实例(2) Drawing example(2)

    文章目录 10 绘图实例(2) Drawing example(2) 1. Grouped violinplots with split violins(violinplot) 2. Annotate ...

  4. webgl学习笔记二-绘图多点

    写在前面 建议先看下第一篇webgl学习笔记一-绘图单点 第一篇文章,介绍了如何用webgl绘图一个点.接下来本文介绍的是如何绘制多个点.形成一个面. webgl提供了一种很方便的机制,即缓冲区对象, ...

  5. Android应用开发学习笔记之绘图

    作者:刘昊昱 博客:http://blog.csdn.net/liuhaoyutz 一.绘图常用类介绍 在Android中绘图时,常用到的几个类是Paint.Canvas.Bitmap和Bitmapt ...

  6. iOS学习笔记08-Quartz2D绘图

    一.Quartz2D简单介绍 在iOS中常用的绘图框架就是Quartz2D,Quartz2D是Core Graphics框架的一部分,我们日常开发使用的所有UIKit组件都是由Core Graphic ...

  7. tensorflow学习笔记三:实例数据下载与读取

    一.mnist数据 深度学习的入门实例,一般就是mnist手写数字分类识别,因此我们应该先下载这个数据集. tensorflow提供一个input_data.py文件,专门用于下载mnist数据,我们 ...

  8. XML学习笔记7——XSD实例

    在前面的XSD笔记中,基本上是以数据类型为主线来写的,而在我的实际开发过程中,是先设计好了XML的结构(元素.属性),并写好了一份示例,然后再反过来写XSD文件(在工具生成的基础上修改),也就是说,是 ...

  9. python学习笔记-练手实例

    1.题目:输出 9*9 乘法口诀表.     程序分析:分行与列考虑,共9行9列,i控制行,j控制列     代码: for i in range(1,10): print ('\r') for j ...

随机推荐

  1. Atcoder CODE FESTIVAL 2016 Grand Final E - Water Distribution

    Atcoder CODE FESTIVAL 2016 Grand Final E - Water Distribution 题目链接:https://atcoder.jp/contests/cf16- ...

  2. 齐博x1换服务器如何转移网站?

    如果你要把网站从本机传到服务器,又或者要更换服务器,请按下面的操作处理 第一步,必须要在原网站后台备份数据. 第二步,把备份好的网站所有文件,传到新服务器或空间 特别要注意 \cache\ 目录下建议 ...

  3. 独立按键控制led灯

    #include "regx51.h"typedef unsigned int u16; void delay_us(u16 time){ while(time--){} }voi ...

  4. 将java装进u盘指南

    将java装入u盘指南 idea 将下载好的idea的文件夹移动到u盘中.在idea的bin目录里找到idea.properties文件,在最后添加以下两行 idea.config.path=U:/I ...

  5. CSP2022游记

    第一次几乎完全没有准备的比赛 也是倒数第二场比赛 Day -1 上了一天文化课,晚上还有强基班. 强基班上完之后来机房写了几个板子就开始颓废了 基本上就抱着摆烂的心态 不过是第一次在学校拿到手机 还在 ...

  6. 远程桌面报错credssp

    远程桌面连接的时候有时出现"出现身份验证错误.要求的函数不受支持:这可能是由于CredSSP 加密 Oracle 修正"的提示, 针对这种情况有以下两种版本的操作系统解决方案: w ...

  7. 快速构建页面结构的 3D Visualization

    对 Chrome 扩展功能熟悉的小伙伴,可能都有用过 Chrome 的 3D 展示页面层级关系这个功能. 可以通过 控制台 --> 右边的三个小点 --> More Tools --> ...

  8. [论文阅读] 颜色迁移-Linear Monge-Kantorovitch(MKL)

    [论文阅读] 颜色迁移-Linear Monge-Kantorovitch(MKL) 文章: The Linear Monge-Kantorovitch Linear Colour Mapping f ...

  9. 【大数据-课程】高途-天翼云侯圣文-Day3-实时计算原理解析

    〇.老师及课程介绍 一.今日内容 二.实时计算理论解析 1.什么是实时计算 微批处理.流式处理.实时计算 水流和车流的例子 spark streaming就是一种微批处理,水满了才处理,进入下一个地方 ...

  10. 【每日一题】【判断栈是否为空的方法】2022年1月9日-NC76 用两个栈实现队列的出队入队【入队简单】

    描述用两个栈来实现一个队列,使用n个元素来完成 n 次在队列尾部插入整数(push)和n次在队列头部删除整数(pop)的功能. 队列中的元素为int类型.保证操作合法,即保证pop操作时队列内已有元素 ...