質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Jupyter

Jupyter (旧IPython notebook)は、Notebook形式でドキュメント作成し、プログラムの記述・実行、その実行結果を記録するツールです。メモの作成や保存、共有、確認などもブラウザ上で行うことができます。

Anaconda

Anacondaは、Python本体とPythonで利用されるライブラリを一括でインストールできるパッケージです。環境構築が容易になるため、Python開発者間ではよく利用されており、商用目的としても利用できます。

Matplotlib

MatplotlibはPythonのおよび、NumPy用のグラフ描画ライブラリです。多くの場合、IPythonと連携して使われます。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

1回答

4275閲覧

Python ヒートマップの補助線,軸目盛りについて

Kinsho

総合スコア18

Jupyter

Jupyter (旧IPython notebook)は、Notebook形式でドキュメント作成し、プログラムの記述・実行、その実行結果を記録するツールです。メモの作成や保存、共有、確認などもブラウザ上で行うことができます。

Anaconda

Anacondaは、Python本体とPythonで利用されるライブラリを一括でインストールできるパッケージです。環境構築が容易になるため、Python開発者間ではよく利用されており、商用目的としても利用できます。

Matplotlib

MatplotlibはPythonのおよび、NumPy用のグラフ描画ライブラリです。多くの場合、IPythonと連携して使われます。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2020/10/16 12:37

編集2020/10/24 08:36

前提・実現したいこと

Pythonのseabornでヒートマップを6枚作成し並べています.
ヒートマップの作成や6枚並べるところまではできたのですが,これに加えて
①x軸とy軸(ここではvx軸とvy軸となっていますが)に波線を入れるとともに,
②それぞれの軸の目盛りが0を含むように(例えば以下の図の場合,x軸の目盛りが-100,-89,...,-1,10,...となっており0が飛ばされていて困っています)したいです.
補助線をペイントツールなどで手動で添えるのはあまりに不格好なので方法を教えてください.

イメージ説明

下のコードを実行するためのサンプルcsvはこちらになりますoutputxy0.csv

よろしくお願いします.

該当のソースコード

Python

1import seaborn as sns 2import pandas as pd 3import numpy as np 4import matplotlib.pyplot as plt 5import matplotlib.patches as patches 6 7fig, axes = plt.subplots(2,3, figsize=(15,10), sharex=True, sharey=True) 8data0= pd.read_csv('outputxy0.csv', index_col = 0) 9data1= pd.read_csv('outputxy0.csv', index_col = 0)#質問をシンプルにするために6枚の読み取りcsvファイルを全て同じにしてあります. 10data2= pd.read_csv('outputxy0.csv', index_col = 0) 11data3= pd.read_csv('outputxy0.csv', index_col = 0) 12data4= pd.read_csv('outputxy0.csv', index_col = 0) 13data5= pd.read_csv('outputxy0.csv', index_col = 0) 14sns.heatmap(data0, ax = axes[0,0], cmap = 'CMRmap_r'); 15axes[0,0].set(xlabel = 'vx(10^6m/s)', ylabel = 'vy(10^6m/s)', title = 't=0(ns)') 16c = patches.Circle(xy = (100, 100), radius = 50, ec = 'r', fill = False,linestyle='dashed') 17axes[0,0].add_patch(c) 18sns.heatmap(data1, ax = axes[0,1], cmap = 'CMRmap_r'); 19axes[0,1].set(xlabel = 'vx(10^6m/s)', ylabel = 'vy(10^6m/s)', title = 't=1(ns)') 20c = patches.Circle(xy = (100, 100), radius = 50, ec = 'r', fill = False,linestyle='dashed') 21axes[0,1].add_patch(c) 22sns.heatmap(data2, ax = axes[0,2], cmap = 'CMRmap_r'); 23axes[0,2].set(xlabel = 'vx(10^6m/s)', ylabel = 'vy(10^6m/s)', title = 't=2(ns)') 24c = patches.Circle(xy = (100, 100), radius = 50, ec = 'r', fill = False,linestyle='dashed') 25axes[0,2].add_patch(c) 26sns.heatmap(data3, ax = axes[1,0], cmap = 'CMRmap_r'); 27axes[1,0].set(xlabel = 'vx(10^6m/s)', ylabel = 'vy(10^6m/s)', title = 't=3(ns)') 28c = patches.Circle(xy = (100, 100), radius = 50, ec = 'r', fill = False,linestyle='dashed') 29axes[1,0].add_patch(c) 30sns.heatmap(data4, ax = axes[1,1], cmap = 'CMRmap_r'); 31axes[1,1].set(xlabel = 'vx(10^6m/s)', ylabel = 'vy(10^6m/s)', title = 't=4(ns)') 32c = patches.Circle(xy = (100, 100), radius = 50, ec = 'r', fill = False,linestyle='dashed') 33axes[1,1].add_patch(c) 34sns.heatmap(data5, ax = axes[1,2], cmap = 'CMRmap_r'); 35axes[1,2].set(xlabel = 'vx(10^6m/s)', ylabel = 'vy(10^6m/s)', title = 't=5(ns)') 36c = patches.Circle(xy = (100, 100), radius = 50, ec = 'r', fill = False,linestyle='dashed') 37axes[1,2].add_patch(c)

試したこと

①xmin,xmaxを設定して各画像のc=patches.Circle~のすぐ下の行に加えていくやり方は最後の(右下の)画像にしか反映されませんでした.
plt.hlines(0,xmin, xmax, "blue", linestyle="dashed")
②0を含む方法についてはそれらしき記事に到達さえできませんでした.

失敗例

添付コード途中を以下に変更
sns.heatmap(data1, ax = axes[0,1], cmap = 'CMRmap_r');
axes[0,1].set(xlabel = 'vx(10^6m/s)', ylabel = 'vy(10^6m/s)', title = 't=1(ns)')
c = patches.Circle(xy = (100, 100), radius = 50, ec = 'r', fill = False,linestyle='dashed')
axes[0,1].add_patch(c)
plt.plot([-10, 10], [0, 0])

結果イメージ説明

失敗例2

イメージ説明

Python

1import seaborn as sns 2import pandas as pd 3import numpy as np 4import matplotlib.pyplot as plt 5import matplotlib.patches as patches 6 7fig, axes = plt.subplots(2,3, figsize=(15,10), sharex=True, sharey=True) 8data0= pd.read_csv('outputxy0.csv', index_col = 0) 9data1= pd.read_csv('outputxy0.csv', index_col = 0) 10data2= pd.read_csv('outputxy0.csv', index_col = 0) 11data3= pd.read_csv('outputxy0.csv', index_col = 0) 12data4= pd.read_csv('outputxy0.csv', index_col = 0) 13data5= pd.read_csv('outputxy0.csv', index_col = 0) 14sns.heatmap(data0, ax = axes[0,0], cmap = 'CMRmap_r'); 15axes[0,0].set(xlabel = 'vx(10^6m/s)', ylabel = 'vy(10^6m/s)', title = 't=0(ns)') 16c = patches.Circle(xy = (100, 100), radius = 50, ec = 'r', fill = False,linestyle='dashed') 17axes[0,0].add_patch(c) 18y = (plt.yticks()[0][0] + plt.yticks()[0][-1]) / 2 19plt.axhline(y=y, linewidth=2, color="r") 20sns.heatmap(data1, ax = axes[0,1], cmap = 'CMRmap_r'); 21axes[0,1].set(xlabel = 'vx(10^6m/s)', ylabel = 'vy(10^6m/s)', title = 't=1(ns)') 22c = patches.Circle(xy = (100, 100), radius = 50, ec = 'r', fill = False,linestyle='dashed') 23axes[0,1].add_patch(c) 24sns.heatmap(data2, ax = axes[0,2], cmap = 'CMRmap_r'); 25axes[0,2].set(xlabel = 'vx(10^6m/s)', ylabel = 'vy(10^6m/s)', title = 't=2(ns)') 26c = patches.Circle(xy = (100, 100), radius = 50, ec = 'r', fill = False,linestyle='dashed') 27axes[0,2].add_patch(c) 28y = (plt.yticks()[0][0] + plt.yticks()[0][-1]) / 2 29plt.axhline(y=y, linewidth=2, color="r") 30sns.heatmap(data3, ax = axes[1,0], cmap = 'CMRmap_r'); 31axes[1,0].set(xlabel = 'vx(10^6m/s)', ylabel = 'vy(10^6m/s)', title = 't=3(ns)') 32c = patches.Circle(xy = (100, 100), radius = 50, ec = 'r', fill = False,linestyle='dashed') 33axes[1,0].add_patch(c) 34sns.heatmap(data4, ax = axes[1,1], cmap = 'CMRmap_r'); 35axes[1,1].set(xlabel = 'vx(10^6m/s)', ylabel = 'vy(10^6m/s)', title = 't=4(ns)') 36c = patches.Circle(xy = (100, 100), radius = 50, ec = 'r', fill = False,linestyle='dashed') 37axes[1,1].add_patch(c) 38sns.heatmap(data5, ax = axes[1,2], cmap = 'CMRmap_r'); 39axes[1,2].set(xlabel = 'vx(10^6m/s)', ylabel = 'vy(10^6m/s)', title = 't=5(ns)') 40c = patches.Circle(xy = (100, 100), radius = 50, ec = 'r', fill = False,linestyle='dashed') 41axes[1,2].add_patch(c)

補足情報(FW/ツールのバージョンなど)

Python,Anacondaは質問直前に最新のバージョンにしました.

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

meg_

2020/10/24 03:00

> ①x軸とy軸(ここではvx軸とvy軸となっていますが)に波線を入れる これについては[0, 0]座標から垂直な線と水平な線を破線で描画すれば良いかと思います。
Kinsho

2020/10/24 03:29

ご回答ありがとうございます。1つ1つにplotをかけるという感じでしょうか?色々試したけどうまく線がかからないので方法を教えていただけますと嬉しいです.
meg_

2020/10/24 04:11

例えば「plt.plot([-10, 10], [0, 0])」で直線が書かれませんか?
Kinsho

2020/10/24 04:25

それだと追加した写真のように右下のやつだけに微妙に線が入るだけなんですよね...困ったところです
meg_

2020/10/24 05:04

グラフはheatmapなのですね。軸の数値はあくまでラベルってことですね。
guest

回答1

0

ベストアンサー

seabornで描いたheatmapの中央に水平線を書きました。
※データは適当なものです

Python

1import pandas as pd 2import numpy as np 3import seaborn as sns 4import matplotlib.pyplot as plt 5 6data0 = pd.DataFrame(np.linspace(-100, 100, 100)) 7sns.heatmap(data0, cmap = 'CMRmap_r'); 8y = (plt.yticks()[0][0] + plt.yticks()[0][-1]) / 2 9plt.axhline(y=y, linewidth=2, color="w")

![イメージ説明


【追記】
最初のグラフ部分のみです。

Python

1data0= pd.read_csv('outputxy0.csv', index_col = 0) 2fig, axes = plt.subplots(2,3, figsize=(15,10), sharex=True, sharey=True) 3sns.heatmap(data0, ax = axes[0,0], cmap = 'CMRmap_r',yticklabels = 10) 4y = (axes[0,0].get_yticks()[0] + axes[0,0].get_yticks()[-1]) / 2 5axes[0,0].axhline(y=y, linewidth=2, color="k") 6x = (axes[0,0].get_xticks()[0] + axes[0,0].get_xticks()[-1]) / 2 7axes[0,0].axvline(x=x, linewidth=2, color="k") 8axes[0,0].set(xlabel = 'vx(10^6m/s)', ylabel = 'vy(10^6m/s)', title = 't=0(ns)') 9c = patches.Circle(xy = (100, 100), radius = 50, ec = 'r', fill = False,linestyle='dashed') 10axes[0,0].add_patch(c)

イメージ説明

投稿2020/10/24 05:05

編集2020/10/24 10:51
meg_

総合スコア10760

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Kinsho

2020/10/24 08:37

回答ありがとうございます.ただこれを例えば左上の画像と右上の画像に対して使っても,以前の試行と同様に最後(右下)の画像にしか反映されません.上の失敗例2みたいになっています. 6枚すべての画像に対して追加する方法はないでしょうか?
Kinsho

2020/10/24 11:58

思ってた通りに完成しました! 1週間ぐらいずっと考えてたのでうまくできてよかったです. 本当にありがとうございます!!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問