Python matplotlibで学ぶ…グラフ描画プログラム 新しいページはコチラ

提供: yonewiki
移動: 案内, 検索
(26行目~29行目)
(22行目/23行目)
 
1行: 1行:
 
== '''概要''' ==
 
== '''概要''' ==
 +
[[Python matplotlibを使って学ぶ統計処理 正規分布]]へ戻る
 +
 +
 
 pythonによるグラフ描画プログラムを以下に示します。
 
 pythonによるグラフ描画プログラムを以下に示します。
  
105行: 108行:
 
#fp=FontProperties(fname=r'/private/var/mobile/Containers/Shared/AppGroup/133F326C-1CD8-49C6-9B85-7BBA53194CA4/Pythonista3/Documents/site-packages/ipaexg.ttf')
 
#fp=FontProperties(fname=r'/private/var/mobile/Containers/Shared/AppGroup/133F326C-1CD8-49C6-9B85-7BBA53194CA4/Pythonista3/Documents/site-packages/ipaexg.ttf')
 
</syntaxhighlight2>
 
</syntaxhighlight2>
 #でコメント化をしていますが、iPadのPythonista3でpythonプログラムをする場合はこちらを有効化して使うべき例として記述しました。但し、ipaexg.ttfは自分でデプロイ(deploy)つまりは配置ひなければならず、ipaexgで検索してipaフォントサイトよりダウンロードする必要があります。ipaフォントはダサダサですので、できればシステムフォントのヒラギノ角ゴProを使い所です。しかしコチラのシステムフォントを使うための詳細は明かされておらず、簡単に使うことはできないです。
+
 #でコメント化をしていますが、iPadのPythonista3でpythonプログラムをする場合はこちらを有効化して使うべき例として記述しました。但し、ipaexg.ttfは自分でデプロイ(deploy)つまりは配置しなければならず、ipaexgで検索してipaフォントサイトよりダウンロードする必要があります。ipaフォントはダサダサですので、できればシステムフォントのヒラギノ角ゴProを使いたいところです。しかしコチラのシステムフォントを使うための詳細は明かされておらず、簡単に使うことはできないです。
  
  
131行: 134行:
 
=== '''1行目から10行目は''' ===
 
=== '''1行目から10行目は''' ===
  
 
+
 
 
 各種ライブラリを読み込む命令でfromの後ろの文字列がライブラリから一部を読み込むことを宣言していてimportの後ろの部分の文字列のライブラリを読み込みます。つまりimportの後ろに来る文字列が読み込むライブラリ名でfromをおおもとのもっと大きなライブラリ名。それでasの後ろにくる文字列はエイリアスとも言いますが、読み込むライブラリに対して代わりの名前を命名することができます。ライブラリ名が長い場合にはasの後ろに文字列を任意でつけて使います。一部だけを読み込んだときも親のライブラリ名を省いて利用できるので、エイリアスを付けたのと同じような効果があります。
 
 各種ライブラリを読み込む命令でfromの後ろの文字列がライブラリから一部を読み込むことを宣言していてimportの後ろの部分の文字列のライブラリを読み込みます。つまりimportの後ろに来る文字列が読み込むライブラリ名でfromをおおもとのもっと大きなライブラリ名。それでasの後ろにくる文字列はエイリアスとも言いますが、読み込むライブラリに対して代わりの名前を命名することができます。ライブラリ名が長い場合にはasの後ろに文字列を任意でつけて使います。一部だけを読み込んだときも親のライブラリ名を省いて利用できるので、エイリアスを付けたのと同じような効果があります。
  
153行: 156行:
 
 mathはnumpyと同じようなものですが、数学処理に特化した関数を提供します。ここではmath.eというネイピア数を返す定数用に呼び出しましたが、numpy.eもあります。簡単に違いを述べるとnumpyは数学関数の引数に配列を受け取ることができて、一括の計算ができる便利な機能が豊富でmathは配列ではない変数を受け取る簡単な関数になっていますが、同じ関数がある場合mathの方が演算が早いので繰り返しの単純演算はmathやpython本体が持つ関数での演算が速度が速く向いているということになっています。
 
 mathはnumpyと同じようなものですが、数学処理に特化した関数を提供します。ここではmath.eというネイピア数を返す定数用に呼び出しましたが、numpy.eもあります。簡単に違いを述べるとnumpyは数学関数の引数に配列を受け取ることができて、一括の計算ができる便利な機能が豊富でmathは配列ではない変数を受け取る簡単な関数になっていますが、同じ関数がある場合mathの方が演算が早いので繰り返しの単純演算はmathやpython本体が持つ関数での演算が速度が速く向いているということになっています。
  
 
+
 
 
 sysは環境変数やpythonそのものの状態やプログラムの実行状態の取得のような、まさにシステム関連の処理をするモジュールになっています。このプログラムでは使っていません。
 
 sysは環境変数やpythonそのものの状態やプログラムの実行状態の取得のような、まさにシステム関連の処理をするモジュールになっています。このプログラムでは使っていません。
  
  
 
 
 
 
 +
 
=== '''19行目''' ===
 
=== '''19行目''' ===
 
<syntaxhighlight2 lang="python">
 
<syntaxhighlight2 lang="python">
166行: 170行:
 
逆に下地のグラフを消して追加する場合は、plt.subplot(1,1,1, zorder=0)とします。では1行1列以外に配置するパターンを一応確認しましょう。そんなに沢山グラフを配置するかなってところまで、突き詰めてみます。
 
逆に下地のグラフを消して追加する場合は、plt.subplot(1,1,1, zorder=0)とします。では1行1列以外に配置するパターンを一応確認しましょう。そんなに沢山グラフを配置するかなってところまで、突き詰めてみます。
  
 
+
 
 
 以下の例ではplt.subplot(1,1,1)→fig.add_subplot(3,3,1)→fig.add_subplot(3,3,9)とした場合です。
 
 以下の例ではplt.subplot(1,1,1)→fig.add_subplot(3,3,1)→fig.add_subplot(3,3,9)とした場合です。
  
201行: 205行:
  
 
 と、このように複雑な結合を行うことが出来ます。1:の後ろの数字は終わりまでという意味で省略していますが、1:2と明記しても良いですし、ax5やax7を定義しないで、歯抜けのままにしても良いです。
 
 と、このように複雑な結合を行うことが出来ます。1:の後ろの数字は終わりまでという意味で省略していますが、1:2と明記しても良いですし、ax5やax7を定義しないで、歯抜けのままにしても良いです。
 
  
 
=== '''22行目/23行目''' ===
 
=== '''22行目/23行目''' ===
231行: 234行:
 
:::::[https://matplotlib.org/examples/color/named_colors.html https://matplotlib.org/examples/color/named_colors.html]
 
:::::[https://matplotlib.org/examples/color/named_colors.html https://matplotlib.org/examples/color/named_colors.html]
 
:::*16進数表記
 
:::*16進数表記
:::::'#xxxxxx'のxxに00~FFの値を適用してR(Red) G(Green) B(Blue)に対応し、すべての値が大きいほど白く、全ての値が小さいほど白くなる表記です。
+
:::::'#xxxxxx'のxxに00~FFの値を適用してR(Red) G(Green) B(Blue)に対応し、すべての値が大きいほど黒く、全ての値が小さいほど白くなる表記です。
 
:::*KRGB表記
 
:::*KRGB表記
 
::::[x.0,x.0,x.0,x.0]と配列にK白黒度合いを0~1.0の小数で指定します。RGBも同様です。
 
::::[x.0,x.0,x.0,x.0]と配列にK白黒度合いを0~1.0の小数で指定します。RGBも同様です。
242行: 245行:
 
*labelsize
 
*labelsize
 
::数値でラベルの大きさを設定します。主目盛りに対して表示される数字の大きさです。
 
::数値でラベルの大きさを設定します。主目盛りに対して表示される数字の大きさです。
 
  
 
=== '''26行目~29行目''' ===
 
=== '''26行目~29行目''' ===
271行: 273行:
 
ax.spines['bottom(=pos_str)'].set_position('zero(=keyword)')
 
ax.spines['bottom(=pos_str)'].set_position('zero(=keyword)')
 
</syntaxhighlight2>
 
</syntaxhighlight2>
 +
 +
 +
 ※(=xxxxxxx)という表記は引数の説明用に記載していますので、実際のプログラムでは記述しないで下さい。
 +
 +
 
'''set_position('zero(=keyword)')'''
 
'''set_position('zero(=keyword)')'''
 
:枠線の設定を左右上下毎に表示位置を設定できる。プログラムでは枠の下はゼロ位置に、左もゼロ位置に表示させるように設定をしています。
 
:枠線の設定を左右上下毎に表示位置を設定できる。プログラムでは枠の下はゼロ位置に、左もゼロ位置に表示させるように設定をしています。
293行: 300行:
  
  
'''set_linewidth(0.8(=float))'''
+
'''set_color('#xxxxxx'(=color))'''
:枠線の太さを設定します。
+
:枠線の色を設定します。
  
*(=float)部
+
*(=color)部
:小数数値で太さを指定します。
+
:各種カラー設定方法で色を指定します。
 +
 
 +
=== '''50行目~51行目''' ===
 +
<syntaxhighlight2 lang="python">
 +
ax.yaxis.set_label_coords(-0.03(=x_float),  0.50(=y_float))
 +
</syntaxhighlight2>
 +
 
 +
 ※(=xxxxxxx)という表記は引数の説明用に記載していますので、実際のプログラムでは記述しないで下さい。
 +
 
 +
 
 +
 軸の名前(ラベル)を表示する場所を指定します。ax.yaxisでy軸をax.xaxisでx軸について調整できます。引数で、ラベル位置を設定します。
 +
 
 +
*(=x_float)部
 +
:subplotのX方向の幅の全体を1として、その割合を指定します。この例ではx方向については少し後ろ側にy軸の軸名を記述したい事を意味しています。
 +
 
 +
 
 +
*(=x_float)部
 +
:subplotのY方向の幅の全体を1として、その割合を指定します。この例ではy方向については中央にy軸の軸名を記述したい事を意味しています。
 +
 
 +
 
 +
=== '''54行目~57行目''' ===
 +
<syntaxhighlight2 lang="python">
 +
ax.annotate(s='',xy=(0, 3.01),xytext=(0, -3.01),xycoords='data',\
 +
            arrowprops=dict(facecolor='black',arrowstyle='->, head_width=0.3',lw=0.5,shrinkA=0,shrinkB=0))
 +
</syntaxhighlight2>
 +
 
 +
 グラフに矢印のついた線を挿入しています。引数で矢印の書式や種類を設定できます。annotateは注釈という意味でこの関数も注釈としての働きをメインとしているので、文字列を表示させることが出来ます。矢印を描くのは、オプションの機能に過ぎないのですが、これで矢印だけを描くという使い方も多くの人が取り入れている感じです。ちなみにテキストを挿入するだけのax.textのような関数もあります。注釈とテキスト。むむむな感じはあります。
 +
 
 +
 
 +
*s
 +
:文字列で表示させる文字を設定します。矢印だけを描きたい場合は、''のようにnull stringを設定します。
 +
 
 +
 
 +
*xy
 +
:xytextのパラメータを省略すれば、テキストを表示させる位置にもなりますが、xytextを設定した場合はxyに設定した座標とxytextの座標に間に線が引かれます。xytextが省略された場合はxyパラメータと同じ値になっているとイメージした方が良いかもしれません。xytextの座標位置に文字列が表示されます。=(x座標, y座標)のように設定しています。
 +
 
 +
 
 +
*xytext
 +
:省略もできますが、矢印線を描く場合は省略すると、線のない矢印になってしまいます。先述のxyの位置からxytextの位置の間に線が引かれます。
 +
 
 +
 
 +
*xycoords, textcoords
 +
:xyの座標系をxycoords、xytextの座標系をtextcoordsに文字列キーワードで設定します。
 +
:*'data' グラフ座標によって指定する座標系を使います。(規定値)
 +
:*'figure points' 図全体における左下を0,0とするポイント単位の座標指定
 +
:*'figure pixels' 図全体における左下を0,0とするピクセル単位の座標指定 
 +
:*'figure fraction' 図全体における左下を0,0と右上を1,1とする割合による座標指定  
 +
:*'axes points'  サブプロット部分における左下を0,0とするポイント単位の座標指定
 +
:*'axes pixels'  サブプロット部分における左下を0,0とするピクセル単位の座標指定
 +
:*'axes fraction'  サブプロット部分における左下を0,0と右上を1,1とする割合による座標指定
 +
 
 +
::ピクセル単位指定と割合指定は、わかるとして、ポイント単位って何?という人が多いと思います。ややこしいかもしれませんが、恐れず説明すると72dpi(72pixcelが1inchi)という印刷設定で、72pointが1文字・1インチで、1ポイントと1ピクセルは同じになります。1文字の大きさという活版印刷界隈でよく利用される単位です。但しmatplotlibではfig.dpiに1インチを何ピクセルで扱うかという定義がされていてデフォルトでは100dpiと定義されているので、1ポイントは100/72ピクセルとなります。72ポイントが1文字という考え方に基づく単位系だと考えればよいと思います。デフォルトでは1ピクセルより1ポイントの方が大きく感じるはずです。要するに?1文字を基準に1文字72ポイントの意識を強く考えて1ポイントという長さで指定する単位系ですね。そういう風に考えると正しく線を引けない人はピクセルや割合の単位を使うのが良いでしょう。
 +
 
 +
 
 +
::このプログラムではtextcoordsの設定は省略していますが、textcoords='data'が設定されているのと同じ動きになります。
 +
 
 +
 
 +
*\
 +
:関数の引数表記が長くなるような場合に改行をいれてスクロールしなくても良い程度の視認性を保ったコードにしたいときに \ をいれることで改行しても次の行と繋がっていることに出来ます。
 +
 
 +
 
 +
*arrowprops
 +
:複数のキーと値をdict()の中で記述でき、設定を指定できます。dict(...)は違う変数に代入する形で設定できるため以下のような方法でも設定できます。
 +
<syntaxhighlight2 lang="python">
 +
dict_arrows = dict(facecolor = 'black', arrowstyle = '->, head_width=0.3', lw = 0.5, shrinkA = 0, shrinkB = 0)
 +
ax.annotate(s = '', xy = (0, 3.01), xytext = (0, -3.01), xycoords = 'data', arrowprops = dict_arrows)
 +
</syntaxhighlight2>
 +
 
 +
:*facecolor
 +
::カラー設定値を指定します。線および矢印の色を指定できます。
 +
 
 +
 
 +
:*edgecolor
 +
::カラー設定値を指定します。線および矢印の淵の色を指定できます。
 +
 
 +
 
 +
:*arrowstyle
 +
::矢印のカタチをキーワードで指定します。左側がxytextで指定した座標側、右側がxyで指定した側の先端の矢印のカタチを意味するキーワードになっています。この設定値を使った場合、矢印の長さや矢印の大きさ幅はこのキーワードの中でhead_width=xx(=float), head_length=xx(=float)のように指定しなければ有効になりません。
 +
::*'-, …' 矢印そのものが無い普通の線
 +
::*'wedge, …' 先端に矢印のカタチが無い尖った線 xy側が尖る
 +
::*'simple, …' いたって普通の太目の矢印で塗り三角が付いたような矢印 xy側に矢印
 +
::*'fancy, …' 線が先細っているところに塗り三角が付いた矢印 xy側に矢印
 +
::*'<|-|>, …' 細い線に両側が塗り三角が付いた矢印
 +
::*'<|-, …' 細い線にxytext座標側に塗り三角が付いた矢印
 +
::*'-|>, …' 細い線にxy座標側に塗りが付いた矢印
 +
::*'<->, …' 細い線に両側が2本の広がった線で表した矢印
 +
::*'<-, …' 細い線にxytext座標側が2本の広がった線で表した矢印
 +
::*'->, …' 細い線にxy側が2本の広がった線で表した矢印
 +
::*'|-|, …' 細い線で両側がTの字になった形。矢印とは言えない形
 +
::*'|-, …' ありそうな感じですが、存在しないキーワードです。
 +
::*'-|, …' ありそうな感じですが、存在しないキーワードです。
 +
::*']-[, …' 細い線で両側がコの字になった形。矢印とは言えない形
 +
::*']-, …' 細い線でxytext側がコの字になった形。矢印とは言えない形
 +
::*'-[, …' 細い線でxy側がコの字になった形。矢印とは言えない形
 +
 
 +
 
 +
 [[ファイル:Subplot pattern3.png| | |none|subplot_pattern3]]
 +
 
 +
 
 +
:::"|-"と"-|"も存在するんじゃないかと思ったのですが、説明書どおりで、ありませんでした。
 +
 
 +
 
 +
:::*head_width
 +
::::矢印の横幅を数値で指定します。"]-[","-[","-[","|-|","wedge"には使えません。arrowstyleのリテラルの中で定義するモノです。arrowstyle='simple, head_width=0.5'のようにします。シングルクォーテーションの位置に注意してみて下さい。
 +
 
 +
 
 +
:::*head_length
 +
::::矢印部分の長さを数値で指定します。"]-[","-[","-[","|-|","wedge"には使えません。これもarrowstyleのリテラルの中で定義するモノです。arrowstyle='simple, head_width=0.5, head_length=0.5'のようにします。シングルクォーテーションの位置に注意して下さい。
 +
 
 +
 
 +
:::*tail_width
 +
::::矢印の線の始まりの部分の幅を数値で指定します。"fancy"と"simple"と"wedge"だけに適用できます。これもarrowstyleのリテラルの中で定義するモノです。arrowstyle='simple, head_width=0.5, head_length=0.5, tail_width=0.4'のようにします。シングルクォーテーションの位置に注意して下さい。
 +
 
 +
 
 +
:::*shrink_factor
 +
::::wedgeの矢印に膨らみや細り具合数値で指定します。0.0~0.5が細った状態で小さい値ほど細りが出ます。0.5より大きくなると膨らみが出ます。これもarrowstyleのリテラルの中で定義するモノです。
 +
 
 +
 
 +
 
 +
:::*widthA
 +
::::"|-|","]-[","]-"のxytext側(テキストがある側)のマークの幅を数値で指定します。これもarrowstyleのリテラルの中で定義するモノです。
 +
 
 +
 
 +
:::*widthB
 +
::::"|-|","]-[","-["のxy側(テキストが無い側)のマークの幅を数値で指定します。これもarrowstyleのリテラルの中で定義するモノです。
 +
 
 +
 
 +
:::*lengthA
 +
::::"|-|","]-[","]-"のxytext(テキストがある側)のマーク部の長さを数値で指定します。これもarrowstyleのリテラルの中で定義するモノです。
 +
 
 +
 
 +
:::*lengthB
 +
::::"|-|","]-[","-["のxytext(テキストが無い側)のマーク部の長さを数値で指定します。これもarrowstyleのリテラルの中で定義するモノです。
 +
 
 +
 
 +
:::*angleA
 +
:::*angleB
 +
::::"-["や"]-[","]-"において使えるオプションになっていますが、angleA・Bの両方とも謎の設定です。これもarrowstyleのリテラルの中で定義するモノとなっています。どういう変化が起こるはずなのか?わかったら記事を更新したいと思います。
 +
 
 +
※arrowstyleオプションを定義すると、annotateの引数のlw,linewidthやls,linestyle、width、headwidth、headlengthを使っても無視されます。なので、arrowstyleオプションを使うと線幅が指定できなくなると考えてよいと思います。
 +
 
 +
 
 +
::*width
 +
:::xyとxytextの座標が異なる場合の矢印の線の横幅を数値で指定します。linestyleが定義されていない場合に有効です。
 +
 
 +
 
 +
::*headwidth
 +
:::矢印の横幅を数値で指定します。linestyleが定義されていない場合に有効です。
 +
 
 +
 
 +
::*headlength
 +
:::矢印部の長さを数値で指定します。linestyleが定義されていない場合に有効です。
 +
 
 +
 
 +
::*shrink
 +
::xyとxytextの座標が異なる場合の矢印の線の長さを縮めさせる具合を数値で指定します。0.0~0.5の間で指定すると0.0は縮まない0.5は線がなくなるほどに縮む設定になります。0.5以降は座標同士の中心からxy側を終点とする矢印になり、0.5から1より小さい値に応じて、中心からの始点だったものがxy側に始点をずらしていくような効果があります。座標と座標の間ときっちり指定するのが普通なのでshrinkを使う場面は少なさそうですが、線の上に文字や図形がある場合に角度を変えずに手軽に長さを調整できますが、0.0から0.5の間の値でも両側が縮むので扱いにくい部分もあると思います。linestyleが定義されていない場合に有効です。
 +
 
 +
 
 +
ここまでの設定パラメータだけでは、simple以外の矢印で線の太さが設定できないことになります。もっと言えば、edgecolorの色を指定しなければ、線が表示されません。edgecolorを設定していれば、lwやlsと言ったパラメータによって線の太さや線の種類も設定できるようになります。複雑な書式になると一つのannotateだけでは難しい部分があるので、2つのannotateで矢印が無い線のと複雑な矢印設定とを同じ座標を持つ2つに対して設定するのがやりやすいと思います。
 +
 
 +
 
 +
::*facecolor
 +
:::矢印の塗り部分の色をカラー設定値で指定します。
 +
 
 +
::*edgecolor
 +
:::矢印の淵の線部分の色をカラー設定値で指定します。
 +
 
 +
 
 +
::*linewidth、lw
 +
:::edgeのライン幅を数値で指定します。
 +
 
 +
 
 +
::*linestyle、ls
 +
:::edgeのライン形式をラインスタイルのキーワード文字列で指定します。
 +
:::*'-' or 'solid' 実線
 +
:::*'--' or 'dashed' 破線
 +
:::*'-.' or 'dashdot' 1点鎖線
 +
:::*':' or 'dotted' 点線
 +
 
 +
 
 +
:arrowstyleはarrowprops同様に変数に格納して付与することが出来ます。
 +
<syntaxhighlight2 lang="python">
 +
from matplotlib.patches import ArrowStyle
 +
arrow_style = ArrowStyle('<|-|>', head_length=1, head_width=1)
 +
ax.annotate(s = '', xy = (0, 3.01), xytext = (0, -3.01), xycoords = 'data', arrowprops = dict( facecolor = 'black', arrowstyle = arrow_style, lw = 0.5, shrinkA = 0, shrinkB = 0))
 +
</syntaxhighlight2>
 +
:上記のようにarrowstyleに代入できます。このときの最初の引数には各種スタイルキーワードと遂になったキーワード文字列があります。
 +
::*'-'    = 'Curve'
 +
::*'simple'= 'Simple'
 +
::*'wedge' = 'Wedge'
 +
::*'fancy' = 'Fancy'
 +
::*'<|-|>' = 'CurveFilledAB'
 +
::*'<|-'  = 'CurveFilledA'
 +
::*'-|>'  = 'CurveFilledB'
 +
::*'<->'  = 'CurveAB'
 +
::*'<-'    = 'CurveA'
 +
::*'->'    = 'CurveB'
 +
::*']-['  = 'BracketAB'
 +
::*']-'    = 'BracketA'
 +
::*'-['    = 'BracketB'
 +
::*'|-|'  = 'BarAB'
 +
 
 +
:したがって、上記で示したプログラムのArrowStyle関数部分は
 +
<syntaxhighlight2 lang="python">
 +
arrow_style = ArrowStyle('CurveFilledAB', head_length=1, head_width=1)
 +
</syntaxhighlight2>
 +
:のように書くことも出来ます。
 +
 
 +
 
 +
::*ShrinkA
 +
::*ShrinkB
 +
:::Aはxytext側、Bはxy側の線を縮める量を数値で指定します。
 +
 
 +
 
 +
:annotateの設定は多種多様の設定があり、この項目だけでも、かなり長くなってきましたが、まだ線の2段の折り曲げやカーブの設定ができるangleとかarmの設定、テキストに囲みができる設定を紹介するので、もう少し長くなります(汗
 +
 
 +
 
 +
:*connectionstyle
 +
::矢印の線のつなぎ方をキーワードで指定します。接続の向きに関する設定や途中の折れ曲がる位置や曲点における設定はこのキーワードの中でangleA=xx(=float), angleB=xx(=float),rad=xのように指定しなければなりません。
 +
::*angle 主にL字のような線のつなぎ方をする。パラメータはxytext側の線の角度とxy側の角度と曲がるところのラウンド量
 +
::*angle3 滑らかなカーブを描くつなぎ方をする。パラメータはxytext側の線の角度とxy側の角度
 +
::*arc 2つの折り曲げ点をもつ線でのつなぎ方をする パラメータはxytext側の線の角度とxy側の角度と曲がるところのラウンド量と線の4分の1点の角度と4分の3点の角度
 +
::*arc3 弓状のつなぎ方をする。パラメータはxyからxytextという向きに対して左側に膨らむのがプラス、右側がマイナスとなる数値
 +
::*bar コの字のつなぎ方をする。パラメータはxyからxytextという向きに対して左側にコになるのがプラス、右側がマイナスとなる数値。とコの字を階段状にするパラメータ
 +
 
 +
::それぞれのパラメータ説明
 +
::*angle
 +
:::*angleA xytext側の角度を示す数値。xyが示す角度側に無い場合は、その反対の180度反転した方向になります。
 +
:::*angleB xy側の角度を示す数値。angleAの線が指定した角度の方向に無い場合はその反対の180度反転した方向になります。
 +
:::*rad xyから伸びた線とxytextから伸びた線の交わるところでのラウンド(丸まり)を数値で指定します。
 +
 
 +
 
 +
::*angle3
 +
:::*angleA xytext側の角度を示す数値。angleBで指定した角度に向かって曲線が描かれます。
 +
:::*angleB xy側の角度を示す数値。angleAで指定した角度に向かって曲線が描かれます。
 +
 
 +
 
 +
::*arc
 +
:::*angleA xytext側の角度を示す数値。xyが示す角度側に無い場合は、その反対の180度反転した方向になります。
 +
:::*angleB xy側の角度を示す数値。angleAの線が指定した角度の方向に無い場合はその反対の180度反転した方向になります。
 +
:::*armA xytext側と中心の半分の位置の角度を示す数値。armBが示す角度側に無い場合は、その反対の180度反転した方向になります。
 +
:::*armB xy側の中心の半分の位置の角度を示す数値。armAの線が指定した角度の方向に無い場合はその反対の180度反転した方向になります。
 +
:::*rad 線の曲がるところでのラウンド(丸まり)を数値で指定します。
 +
 
 +
 
 +
::*arc3
 +
:::*rad 弓状になる具合を数値で指定します。パラメータはxyからxytextという向きに対して左側に膨らむのがプラス、右側がマイナスとなる数値です。
 +
 
 +
 
 +
::*bar
 +
:::*fraction xytext側のコの字になる深さを数値で指定します。パラメータはxyからxytextという向きに対して左側に深くなるのがプラス、右側がマイナスとなる数値です。
 +
:::*angle 180と設定するとxyとxytextが斜めの位置関係にあれば、階段状の接続になります。仕組みとしては、コの字を描こうとするところのfractonで設定した値だけxytextで線を描いた後の折れ曲がるときの角度がここで設定している値で、ここからの長さは、90度、あるいは-90度に折れ曲がった線がxyが到達するところで、線が曲がって、ラインがxyに到達して、コの字あるいは階段型の線を形成します。コの字になるか階段状になるかは、xy側の線の長さを示す値と一致するようになっていて、xyとxytextの距離より長い場合や短い場合で切り替わります。方向はfractionで説明したとおりの向きに従います。
 +
 
 +
 
 +
:::以下にここまでで説明したとおりの形状変化がわかるようなサンプルを示します。
 +
 
 +
 [[ファイル:Subplot pattern4.png| | |none|subplot_pattern4]]
 +
 
 +
:::あら、一番右下の赤矢印がコの字なるはずが途切れちゃいました。プログラム動作時には見えていても、プログラムのグラフ図を保存する処理に任せると見切れちゃうみたいです。みなさんは気を付けてください。作り直せばいいじゃんと思いますが、自分のような、雑な人間は、こうなるという反面教師になるように、このままにしておきます。
 +
 
 +
 
 +
:*bbox
 +
::矢印の線のテキストの修飾を各種キーワードで指定します。テキストボックスの線の太さや塗りの色の設定といった更に細かい設定はこのキーワードの中でbbox=dict(boxstyle="キーワード", lw=xx(=float), ls=xx(=keyword),fc='#xxxxx')のように指定しなければなりません。
 +
 
 +
::boxstyleキーワード一覧
 +
::*circle 円
 +
::*darrow 両側矢印
 +
::*larrow 左矢印
 +
::*rarrow 右矢印
 +
::*round 丸角四角
 +
::*round4 丸角四角で、全体に膨らみあり
 +
::*roundtooth 波線
 +
::*sawtooth のこぎり線
 +
::*square 四角
 +
 
 +
 [[ファイル:Subplot pattern5.png| | |none|subplot_pattern5]]
 +
 
 +
::boxstyleに
 +
<syntaxhighlight2 lang="python">
 +
bbox = dict(boxstyle = "square, pad = 0.9")
 +
</syntaxhighlight2>
 +
 
 +
::というように文字列で付け足すキーワードでpad つまり四角の大きさが余白部分の大きさを元に設定できます。0.9が上記の状態です。
 +
 
 +
 
 +
::上記のようなキーワードには他にroundとround4で使えるrouding_size(丸みが強くなる)、さらにroundtoothとsawtooth(波やのこぎりが大きくなる)で使えるtooth_sizeがあります。
 +
 
 +
 
 +
::他にdict()の中で設定できるパラメータがあり、mutation_scaleで余白の拡大ができます。拡大だけでなく、文字が入らなくなるえげつない設定も可能です。mutation_aspect = 0.5 のようにして縦と横の比率を変化させようとするものもあります。
 +
 
 +
 
 +
::設定を一覧していきましょう。
 +
::*facecolor 塗りの色をカラー設定値で指定します。
 +
::*edgecolor 塗りの淵の色をカラー設定値で指定します。
 +
::*color 文字の色をカラー設定値で指定します。
 +
::*linewidth 塗りの淵の線の太さを数値で指定します。
 +
 
 +
::*linestyle 線のスタイルを線スタイルキーワードで指定します。
 +
:::*'-' or 'solid' 実線
 +
:::*'--' or 'dashed' 破線
 +
:::*'-.' or 'dashdot' 1点鎖線
 +
:::*':' or 'dotted' 点線
 +
 
 +
::*hatch 塗りのスタイルを塗りスタイルキーワードで指定します。
 +
:::*'/' 右上がり斜線 ///のように増やしていくと間隔が狭くなります。
 +
:::*'\' 左上がり斜線
 +
:::*'|' 縦線
 +
:::*'-' 横線
 +
:::*'+' クロス
 +
:::*'x' 斜めクロス
 +
:::*'o' 丸中模様
 +
:::*'O' 丸大大模様
 +
:::*'.' 点模様
 +
:::*'*' 星模様
 +
::::※いずれのパターンも**********連続して記述するほと間隔が狭くなります。9連くらいまでは効果があります。
 +
 
 +
::*alpha 塗りの透明度を数値で指定します。
 +
 
 +
といった感じですね。
 +
 
 +
 
 +
=== '''60行目''' ===
 +
<syntaxhighlight2 lang="python">
 +
ax.set_axisbelow(True)
 +
</syntaxhighlight2>
 +
 
 +
axisbelow(True)で軸やグリッドをプロットの後ろに隠してくれます。
 +
 
 +
 
 +
=== '''63行目''' ===
 +
<syntaxhighlight2 lang="python">
 +
ax.grid(True, zorder=-1)
 +
</syntaxhighlight2>
 +
グリッド線の表示を有効化しています。
 +
 
 +
 
 +
=== '''66行目''' ===
 +
<syntaxhighlight2 lang="python">
 +
ax.set_position([0.2, 0.2, 0.7, 0.6])
 +
</syntaxhighlight2>
 +
グラフの枠の位置を設定しています。引数には4要素の配列を指定します。[枠の左辺, 枠の下辺, 枠の横幅, 枠の高さ]のようにします。
 +
 
 +
 
 +
=== '''69行目~71行目''' ===
 +
<syntaxhighlight2 lang="python">
 +
ax.set_xlabel('x [-]', fontsize = 6, fontdict={'family': 'Meiryo'})
 +
</syntaxhighlight2>
 +
グラフの各種ラベルの文字の設定をします。
 +
:*set_xlabel x軸の下のラベル
 +
:*set_ylabel y軸の横のラベル
 +
:*set_title グラフの上のタイトルのラベル
 +
:それぞれの関数の引数で書式の設定ができます。
 +
::*第一引数の文字列で表示した文字を入力します。日本語を設定する場合は、fontdictや随分手前で紹介したfontpropertiesで日本語フォントファミリーを設定する必要があります。
 +
::*fontsize 文字の大きさを数値で設定します。
 +
::*fontdict フォントの設定を連想配列で['family':'Meiryo',…]とすることでMeiryoフォントを指定できます。フォント指定をするfamilyキーの他にfontweightで文字の太字設定やsizeあるいはfontsizeで文字の大きさcolorで色の設定ができます。"fontproperties"キーへの値でフォント設定をだいぶ前で説明したfont_managerオブジェクトの変数を値にしたような設定も出来ます。
 +
 
 +
 
 +
=== '''74行目~91行目''' ===
 +
いよいよプロット部分の説明です。ここでプロットして連続する値としてプロット値を実線でつなぐグラフを描画しています。ここではsigmaを可変できるようにされていて76行目 while文をつかっています。実際のプログラムではsigma = 1で始まって、判定式はsigma < 2で終了なのでsigmaが1のときの1回の処理になっています。whileの繰り返し範囲はpythonの制御構造ではインデントがそろっている範囲が繰り返し範囲になります。xの連続する値の配列に対してyの配列を生成するのが81行目の以下の部分です。
 +
<syntaxhighlight2 lang="python">
 +
y = 1 / (np.sqrt(2 * np.pi) * sigma) * np.power(math.e ,-1 / (2 * np.power(sigma, 2))  * np.power((x - u), 2))
 +
</syntaxhighlight2>
 +
xとyの配列の大きさは同じで、上記の式で一括してすべてのx配列値に対する結果がyの配列として生成されます。
 +
 
 +
 
 +
そして以下のような87行目でプロット処理がされます。
 +
<syntaxhighlight2 lang="python">
 +
ax.plot(x, y, linestyle='solid', linewidth = 0.8, zorder = 15 + sigma)
 +
</syntaxhighlight2>
 +
上記ではlinestyleは実線、linewidthは0.8と定義されています。
 +
 
 +
 
 +
ここまでの各種関数の全てに言えますが、zorder=整数値で重なりを制御できます。このように設定していれば、繰り返すたびにzorder値が大きくなるため上からかぶさるように描画されます。
 +
 
 +
 
 +
84行目でグラフプロットとしては少し複雑な処理を入れています。y軸と関数とが囲む領域に斜線のハッチング(線塗り)がされるように設定しています。
 +
<syntaxhighlight2 lang="python">
 +
plt.fill_between(x, y, facecolor="none", alpha=0.8, edgecolor='#1f77b4', hatch="//////", zorder = 15)
 +
</syntaxhighlight2>
 +
 
 +
 
 +
pltのfill_between関数でxとyのプロット値とy軸の間を塗る場合は、最初の2つの引数で x, y を与えます。以降は塗りに関する設定です。これまでにも使われたようなキーワードですので、理解はしやすいと思いますので、説明は省略します。
 +
 
 +
 
 +
これでグラフを描くことができました。
 +
 
 +
 
 +
=== '''94行目''' ===
 +
<syntaxhighlight2 lang="python">
 +
plt.show()
 +
</syntaxhighlight2>
 +
 
 +
上記の命令で標準出力にたいして、これまでの描画処理結果をディスプレイに表示することが出来ます。
 +
 
 +
 
 +
plt.savefig("name.png", bbox_inches = 'tight', pad_inches = 0)
 +
 
 +
 
 +
ちなみに上記のようにすると、png形式画像として出力できます。
 +
 
 +
 
 +
[[Python matplotlibを使って学ぶ統計処理 正規分布]]へ戻る

2020年9月18日 (金) 00:00時点における最新版



個人用ツール
名前空間

変種
操作
案内
ツールボックス