Python+Matplotlib繪制小提琴圖的示例代碼
小提琴圖 (Violin Plot) 類似紡錘,小提琴圖是一種用來顯示數(shù)據(jù)分布和概率密度的圖形,結(jié)合了箱線圖和核密度圖的特點。小提琴圖的中間部分是一個箱線圖,顯示了數(shù)據(jù)的中位數(shù)、四分位數(shù)和異常值。小提琴圖的兩側(cè)是一個核密度圖,顯示了數(shù)據(jù)的分布形狀。小提琴圖可以用來比較不同類別或分組的數(shù)據(jù),展示數(shù)據(jù)的差異和相似性。
示例如下:

源碼如下:
#!/usr/bin/env python
# -- coding: utf-8 --
"""
Copyright (c) 2022. All rights reserved.
Created by C. L. Wang on 2023/6/6
"""
import os
import matplotlib.pyplot as plt
import pandas as pd
import seaborn as sns
from myutils.project_utils import read_excel_to_df
from root_dir import DATA_DIR
def draw_violin_plot(
df, score_col_name, label_col_name,
x_label="", y_label="", title="",
is_show=False, save_name=""):
"""
繪制小提琴圖
:param df: 數(shù)據(jù)格式,至少包括兩列,即數(shù)據(jù)值列score,標簽列l(wèi)abel,相同類別的標簽相同
:param score_col_name: 數(shù)值列名稱
:param label_col_name: 標簽列名稱
:param x_label: 顯示的x標簽
:param y_label: 顯示的y標簽
:param title: 顯示的圖名稱
:param is_show: 是否IDE顯示
:param save_name: 是否存儲文件,tight格式
:return:
"""
plt.figure(figsize=(16, 10), dpi=80)
sns.violinplot(x=label_col_name, y=score_col_name, data=df, inner='quartile')
plt.xlabel(xlabel=x_label)
plt.ylabel(ylabel=y_label)
if title:
plt.title(title, fontsize=12)
if save_name:
# transparent=True
plt.savefig(save_name, bbox_inches='tight', format='png')
if is_show:
plt.show()
def main():
df = read_excel_to_df(os.path.join(DATA_DIR, "ourbest_20230601_tmscore_56.xls"))
# df = read_excel_to_df(os.path.join(DATA_DIR, "ourbest_20230605_dockq_9_final.xls"))
# df.info()
# 加工數(shù)據(jù)格式,滿足數(shù)值和標簽的格式
score1 = df["m0-score"]
score2 = df["m1-score"]
score3 = df["cur-score"]
label_col = ["SOTA" for _ in range(df["m0-score"].size)] + \
["Baseline" for _ in range(df["m1-score"].size)] + \
["Our Best" for _ in range(df["cur-score"].size)]
score_list = pd.concat([score1, score2, score3])
score_name = "DockQ"
data = {score_name: score_list, "label": label_col}
new_df = pd.DataFrame(data)
# df.info()
draw_violin_plot(new_df, score_col_name=score_name, label_col_name="label",
x_label="", y_label=score_name,
is_show=True, save_name="xxx.png")
if __name__ == '__main__':
main()
到此這篇關于Python+Matplotlib繪制小提琴圖的示例代碼的文章就介紹到這了,更多相關Python Matplotlib繪制小提琴圖內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Django中STATIC_ROOT和STATIC_URL及STATICFILES_DIRS淺析
這篇文章主要給大家介紹了關于Django中STATIC_ROOT和STATIC_URL及STATICFILES_DIRS的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面來一起看看吧2018-05-05
使用Python實現(xiàn)PDF文本的自動替換或修改功能
在處理PDF文檔時,我們有時會遇到需要更新文檔中文字內(nèi)容的情況,手動打開 PDF 文件,逐一查找并修改文字內(nèi)容是一項繁瑣且容易出錯的工作,這篇文章將介紹如何使用Python實現(xiàn)PDF文本的自動替換,需要的朋友可以參考下2025-02-02
python中requests庫+xpath+lxml簡單使用
這篇文章主要介紹了python中requests庫+xpath+lxml簡單使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-04-04
Python壓縮包處理模塊zipfile和py7zr操作代碼
目前對文件的壓縮和解壓縮比較常用的格式就是zip格式和7z格式,這篇文章主要介紹了Python壓縮包處理模塊zipfile和py7zr,需要的朋友可以參考下2022-06-06
python正則表達式re.sub各個參數(shù)的超詳細講解
Python 的 re 模塊提供了re.sub用于替換字符串中的匹配項,下面這篇文章主要給大家介紹了關于python正則表達式re.sub各個參數(shù)的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下2022-07-07
Windows系統(tǒng)下安裝Python的SSH模塊教程
這篇文章主要介紹了Windows系統(tǒng)下安裝Python的SSH模塊教程,本文涵蓋了pycrypto、ecdsa、paramiko、OpenSSH、SSH等模塊的安裝,需要的朋友可以參考下2015-02-02

