pyOpt( Python-based package for formulating and solving nonlinear constrained optimization problems)は,Python専用に設計されたフリーの最適化ライブラリ群であり,数理計画法からヒューリスティクスはまで幅広い最適化アルゴリズムを網羅している。残念ながら,開発自体は20014年でストップしており,元ソースはPython2.7以下までにしか対応していないが,Python3系でも使用できるように藤田が改良したソースを
ここに公開するので,こちらをbuild&installすればPython3以降でも使用することが可能となる。
pyOptはソースコードを直接buildする作業が必要となり,インストールの難易度は高い。1つずつ順を追って説明していく。
まず,インストール前の準備段階として,fortranコンパイラとswigを導入する必要がある。いずれも,condaでインストールできる。
-
DOS画面を開く(スタートメニューで"cmd"と検索してEnterを押せばOK)。
data:image/s3,"s3://crabby-images/fcede/fcede3faad56874a56f394a2a8369859bf74d71f" alt=""
-
DOS画面にてconda install m2w64-gcc-fortranとタイプしEnter。
data:image/s3,"s3://crabby-images/12ed8/12ed8fd1cd903173364fec16f1e7cb2459668241" alt=""
-
YesかNoか聞かれるのでyとタイプしEnter。
data:image/s3,"s3://crabby-images/d17ef/d17efe29fd890e852e8c06bc00db83d5956ac86c" alt=""
-
以上の操作でfortranコンパイラのインストールは終了。
data:image/s3,"s3://crabby-images/5df7f/5df7ffbb1ae5b06031944036ad66cf4fdcf77610" alt=""
-
DOS画面を開く(スタートメニューで"cmd"と検索してEnterを押せばOK)。
data:image/s3,"s3://crabby-images/fcede/fcede3faad56874a56f394a2a8369859bf74d71f" alt=""
-
DOS画面にてconda install -c anaconda swigとタイプしEnter。
data:image/s3,"s3://crabby-images/d82ed/d82ed43a476cb47fb77809daf1e5cb9ac81a9541" alt=""
-
YesかNoか聞かれるのでyとタイプしEnter。
data:image/s3,"s3://crabby-images/1424f/1424fb95b617cdde43cc47ea9dc0a2e31c7c91cd" alt=""
-
以上の操作でswigのインストールは終了。
data:image/s3,"s3://crabby-images/ee85e/ee85ec3d5f7b82dd4f5345d58096b0d9b6983af4" alt=""
fortranコンパイラとswigがインストール出来たら,いよいよPyOptのインストールを行っていく。
-
まず,藤田が独自に改良したPython3対応のpyOptをここからダウンロードする
(※研究室の学生は,更に改良を加えたこちらをダウンロードする)。
-
ダウンロードしたファイルを展開し,ディレクトリパスをコピーする。
data:image/s3,"s3://crabby-images/84d68/84d68f5b2814c25e2e64052069237f06906dcf7e" alt=""
-
DOS画面を開く(スタートメニューで"cmd"と検索してEnterを押せばOK)。
data:image/s3,"s3://crabby-images/fcede/fcede3faad56874a56f394a2a8369859bf74d71f" alt=""
-
DOS画面にてcd 先ほどのディレクトリパスとタイプしEnter(pyOptディレクトリへの移動)。
data:image/s3,"s3://crabby-images/3ec2c/3ec2c3b6baa6d80dd7d88df3a7e05dd787dd7fd7" alt=""
-
DOS画面にてchcp 65001とタイプしEnter(文字コードをSHIFT-JISからUTF-8に変更する操作)。
data:image/s3,"s3://crabby-images/7f578/7f57868ba2cc8668f121b437de204d83bf9bcd87" alt=""
-
DOS画面にてpython setup.py install --compiler=mingw32とタイプしEnter。
data:image/s3,"s3://crabby-images/7d714/7d714cd74d2f57dab828fe08c63b6c81a51e4834" alt=""
-
以上の操作でpyOptのインストールは終了。
data:image/s3,"s3://crabby-images/527fa/527fad3bdf9027de4dfb2becbdd17d182b1e58a7" alt=""
正しくインストールされたかの動作確認を行うため,次のような最適化問題を様々な最適化アルゴリズムで解いてみよう。
\begin{align}
\begin{array}{ll}
\textrm{minimize}&-x_1\cdot x_2\cdot x_3\\
\textrm{subject to}&x_1+2x_2+2x_3-72\le 0\\
&-x_1-2x_2-2x_3\le 0\\
&0\le x_i\le 42,\quad i=1,2,3
\end{array}
\end{align}
この最適化問題は,\(\boldsymbol{x}=[x_1,x_2,x_3]=[24, 12, 24]\)のときに最小値\(f=-3456\)をとる。
上記を解く以下のプログラムを実行し,結果が正しいことを確かめる(ソースはpyOptのexample内にある)。
tp037.py
#!/usr/bin/env python
'''
Solves Schittkowski's TP37 Constrained Problem.
min -x1*x2*x3
s.t.: x1 + 2.*x2 + 2.*x3 - 72 <= 0
- x1 - 2.*x2 - 2.*x3 <= 0
0 <= xi <= 42, i = 1,2,3
f* = -3456 , x* = [24, 12, 12]
'''
# =============================================================================
# Standard Python modules
# =============================================================================
import os, sys, time
import pdb
# =============================================================================
# Extension modules
# =============================================================================
#from pyOpt import *
from pyOpt import Optimization
from pyOpt import PSQP
from pyOpt import SLSQP
from pyOpt import CONMIN
from pyOpt import COBYLA
from pyOpt import SOLVOPT
from pyOpt import KSOPT
from pyOpt import NSGA2
from pyOpt import ALGENCAN
from pyOpt import FILTERSD
# =============================================================================
#
# =============================================================================
def objfunc(x):
f = -x[0]*x[1]*x[2]
g = [0.0]*2
g[0] = x[0] + 2.*x[1] + 2.*x[2] - 72.0
g[1] = -x[0] - 2.*x[1] - 2.*x[2]
fail = 0
return f,g, fail
# =============================================================================
#
# =============================================================================
# Instantiate Optimization Problem
opt_prob = Optimization('TP37 Constrained Problem',objfunc)
opt_prob.addVar('x1','c',lower=0.0,upper=42.0,value=10.0)
opt_prob.addVar('x2','c',lower=0.0,upper=42.0,value=10.0)
opt_prob.addVar('x3','c',lower=0.0,upper=42.0,value=10.0)
opt_prob.addObj('f')
opt_prob.addCon('g1','i')
opt_prob.addCon('g2','i')
print opt_prob
# Instantiate Optimizer (PSQP) & Solve Problem
psqp = PSQP()
psqp.setOption('IPRINT',0)
psqp(opt_prob,sens_type='FD')
print(opt_prob.solution(0))
# Instantiate Optimizer (SLSQP) & Solve Problem
slsqp = SLSQP()
slsqp.setOption('IPRINT',-1)
slsqp(opt_prob,sens_type='FD')
print(opt_prob.solution(1))
# Instantiate Optimizer (CONMIN) & Solve Problem
conmin = CONMIN()
conmin.setOption('IPRINT',0)
conmin(opt_prob,sens_type='CS')
print(opt_prob.solution(2))
# Instantiate Optimizer (COBYLA) & Solve Problem
cobyla = COBYLA()
cobyla.setOption('IPRINT',0)
cobyla(opt_prob)
print(opt_prob.solution(3))
# Instantiate Optimizer (SOLVOPT) & Solve Problem
solvopt = SOLVOPT()
solvopt.setOption('iprint',-1)
solvopt(opt_prob,sens_type='FD')
print(opt_prob.solution(4))
# Instantiate Optimizer (KSOPT) & Solve Problem
ksopt = KSOPT()
ksopt.setOption('IPRINT',0)
ksopt(opt_prob,sens_type='FD')
print(opt_prob.solution(5))
# Instantiate Optimizer (NSGA2) & Solve Problem
nsga2 = NSGA2()
nsga2.setOption('PrintOut',0)
nsga2(opt_prob)
print(opt_prob.solution(6))
# Instantiate Optimizer (ALGENCAN) & Solve Problem
algencan = ALGENCAN()
algencan.setOption('iprint',0)
algencan(opt_prob)
print(opt_prob.solution(7))
# Instantiate Optimizer (FILTERSD) & Solve Problem
filtersd = FILTERSD()
filtersd.setOption('iprint',0)
filtersd(opt_prob)
print opt_prob.solution(8)
このプログラムを実行すると,pyOptが正しくインストールされていれば以下の出力が得られる。
Optimization Problem -- TP37 Constrained Problem
================================================================================
Objective Function: objfunc
Objectives:
Name Value Optimum
f 0 0
Variables (c - continuous, i - integer, d - discrete):
Name Type Value Lower Bound Upper Bound
x1 c 10.000000 0.00e+00 4.20e+01
x2 c 10.000000 0.00e+00 4.20e+01
x3 c 10.000000 0.00e+00 4.20e+01
Constraints (i - inequality, e - equality):
Name Type Bounds
g1 i -1.00e+21 <= 0.000000 <= 0.00e+00
g2 i -1.00e+21 <= 0.000000 <= 0.00e+00
PSQP Solution to TP37 Constrained Problem
================================================================================
Objective Function: objfunc
Solution:
--------------------------------------------------------------------------------
Total Time: 0.0010
Total Function Evaluations: 42
Sensitivities: FD
Objectives:
Name Value Optimum
f -3456 0
Variables (c - continuous, i - integer, d - discrete):
Name Type Value Lower Bound Upper Bound
x1 c 24.000000 0.00e+00 4.20e+01
x2 c 12.000000 0.00e+00 4.20e+01
x3 c 12.000000 0.00e+00 4.20e+01
Constraints (i - inequality, e - equality):
Name Type Bounds
g1 i -1.00e+21 <= 0.000000 <= 0.00e+00
g2 i -1.00e+21 <= -72.000000 <= 0.00e+00
--------------------------------------------------------------------------------
SLSQP Solution to TP37 Constrained Problem
================================================================================
Objective Function: objfunc
Solution:
--------------------------------------------------------------------------------
Total Time: 0.0010
Total Function Evaluations: 0
Sensitivities: FD
Objectives:
Name Value Optimum
f -3456 0
Variables (c - continuous, i - integer, d - discrete):
Name Type Value Lower Bound Upper Bound
x1 c 24.000000 0.00e+00 4.20e+01
x2 c 12.000000 0.00e+00 4.20e+01
x3 c 12.000000 0.00e+00 4.20e+01
Constraints (i - inequality, e - equality):
Name Type Bounds
g1 i -1.00e+21 <= 0.000000 <= 0.00e+00
g2 i -1.00e+21 <= -72.000000 <= 0.00e+00
--------------------------------------------------------------------------------
CONMIN Solution to TP37 Constrained Problem
================================================================================
Objective Function: objfunc
Solution:
--------------------------------------------------------------------------------
Total Time: 0.0010
Total Function Evaluations: 88
Sensitivities: CS
Objectives:
Name Value Optimum
f -3456 0
Variables (c - continuous, i - integer, d - discrete):
Name Type Value Lower Bound Upper Bound
x1 c 23.989921 0.00e+00 4.20e+01
x2 c 12.002518 0.00e+00 4.20e+01
x3 c 12.002518 0.00e+00 4.20e+01
Constraints (i - inequality, e - equality):
Name Type Bounds
g1 i -1.00e+21 <= -0.000006 <= 0.00e+00
g2 i -1.00e+21 <= -71.999994 <= 0.00e+00
--------------------------------------------------------------------------------
COBYLA Solution to TP37 Constrained Problem
================================================================================
Objective Function: objfunc
Solution:
--------------------------------------------------------------------------------
Total Time: 0.0010
Total Function Evaluations: 112
Objectives:
Name Value Optimum
f -3456 0
Variables (c - continuous, i - integer, d - discrete):
Name Type Value Lower Bound Upper Bound
x1 c 24.000000 0.00e+00 4.20e+01
x2 c 11.999999 0.00e+00 4.20e+01
x3 c 12.000000 0.00e+00 4.20e+01
Constraints (i - inequality, e - equality):
Name Type Bounds
g1 i -1.00e+21 <= 0.000000 <= 0.00e+00
g2 i -1.00e+21 <= -72.000000 <= 0.00e+00
--------------------------------------------------------------------------------
SOLVOPT Solution to TP37 Constrained Problem
================================================================================
Objective Function: objfunc
Solution:
--------------------------------------------------------------------------------
Total Time: 0.0070
Total Function Evaluations: 201
Sensitivities: FD
Objectives:
Name Value Optimum
f -3456 0
Variables (c - continuous, i - integer, d - discrete):
Name Type Value Lower Bound Upper Bound
x1 c 23.999011 0.00e+00 4.20e+01
x2 c 12.000860 0.00e+00 4.20e+01
x3 c 11.999634 0.00e+00 4.20e+01
Constraints (i - inequality, e - equality):
Name Type Bounds
g1 i -1.00e+21 <= -0.000000 <= 0.00e+00
g2 i -1.00e+21 <= -72.000000 <= 0.00e+00
--------------------------------------------------------------------------------
KSOPT Solution to TP37 Constrained Problem
================================================================================
Objective Function: objfunc
Solution:
--------------------------------------------------------------------------------
Total Time: 0.0110
Total Function Evaluations: 2187
Sensitivities: FD
Objectives:
Name Value Optimum
f -3453.73 0
Variables (c - continuous, i - integer, d - discrete):
Name Type Value Lower Bound Upper Bound
x1 c 23.995259 0.00e+00 4.20e+01
x2 c 11.997588 0.00e+00 4.20e+01
x3 c 11.996896 0.00e+00 4.20e+01
Constraints (i - inequality, e - equality):
Name Type Bounds
g1 i -1.00e+21 <= -0.015771 <= 0.00e+00
g2 i -1.00e+21 <= -71.984229 <= 0.00e+00
--------------------------------------------------------------------------------
NSGA-II Solution to TP37 Constrained Problem
================================================================================
Objective Function: objfunc
Solution:
--------------------------------------------------------------------------------
Total Time: 0.0688
Total Function Evaluations: 0
Objectives:
Name Value Optimum
f -3455.25 0
Variables (c - continuous, i - integer, d - discrete):
Name Type Value Lower Bound Upper Bound
x1 c 24.259110 0.00e+00 4.20e+01
x2 c 11.858676 0.00e+00 4.20e+01
x3 c 12.010719 0.00e+00 4.20e+01
Constraints (i - inequality, e - equality):
Name Type Bounds
g1 i -1.00e+21 <= -0.002100 <= 0.00e+00
g2 i -1.00e+21 <= -71.997900 <= 0.00e+00
--------------------------------------------------------------------------------
ALGENCAN Solution to TP37 Constrained Problem
================================================================================
Objective Function: objfunc
Solution:
--------------------------------------------------------------------------------
Total Time: 0.0030
Total Function Evaluations: 0
Lambda: [144.00000063 0. ]
Sensitivities: FD
Objectives:
Name Value Optimum
f -3456 0
Variables (c - continuous, i - integer, d - discrete):
Name Type Value Lower Bound Upper Bound
x1 c 24.000000 0.00e+00 4.20e+01
x2 c 12.000000 0.00e+00 4.20e+01
x3 c 12.000000 0.00e+00 4.20e+01
Constraints (i - inequality, e - equality):
Name Type Bounds
g1 i -1.00e+21 <= 0.000000 <= 0.00e+00
g2 i -1.00e+21 <= -72.000000 <= 0.00e+00
--------------------------------------------------------------------------------
FILTERSD Solution to TP37 Constrained Problem
================================================================================
Objective Function: objfunc
Solution:
--------------------------------------------------------------------------------
Total Time: 0.0010
Total Function Evaluations: 69
Lambda: [0. 0.]
Sensitivities: FD
Objectives:
Name Value Optimum
f -3456 0
Variables (c - continuous, i - integer, d - discrete):
Name Type Value Lower Bound Upper Bound
x1 c 24.000000 0.00e+00 4.20e+01
x2 c 12.000000 0.00e+00 4.20e+01
x3 c 12.000000 0.00e+00 4.20e+01
Constraints (i - inequality, e - equality):
Name Type Bounds
g1 i -1.00e+21 <= 0.000000 <= 0.00e+00
g2 i -1.00e+21 <= -72.000000 <= 0.00e+00
--------------------------------------------------------------------------------
matplotlibのデフォルトのフォント設定では,labelやtitleに日本語を使用すると文字化けしてしまう。
matplotlibで日本語を使用するには,日本語に対応したフォントを使用する必要がある。
matplotlibで使用できるフォントの一覧は以下のコードで確認することができる。
import matplotlib.font_manager as fm
fonts=fm.findSystemFonts()
for font in fonts:print(fm.FontProperties(fname=font).get_name())
上記を実行すると,matplotlibで使用できるフォントの一覧が出力されるので,その中から日本語対応フォントを選択すればよい。
私個人のPC環境下では,以下のようなフォントが日本語に対応していた(かなり少ない)。
Yu Mincho
HGMaruGothicMPRO
IPAexGothic
Malgun Gothic
HGSeikaishotaiPRO
|
気に入ったフォントが見つからない場合は,外部からダウンロードしてくると良い。matplotlib対応の日本語フリーフォントで有名なものとして,IPAexフォントがある。
ここからダウンロードできる。ダウンロードしたファイルを解凍すると
ipaexg.ttfというTrueTypeフォントファイルがあるので,それを
'lib\\site-packages\\matplotlib\\mpl-data\\fonts'以下にコピーすれば使用できるようになる。
使用する日本語フォントを決めたら,プログラム上で呼び出す。matplotlibで使用するすべてのフォントを一括で指定する場合は,
プログラムの冒頭で次のように記述すればよい。
import matplotlib.pyplot as plt
plt.rcParams['font.family'] = 'IPAexGothic' #全体のフォントを設定
以降,グラフのタイトルやラベル,目盛りなどはすべて日本語対応フォントである
IPAexGothicで記述される。
一方で,グラフの特定の文字のみフォントを変更したい場合は,次のようにすると良い。
ax.set_title('title',**{'family':'IPAexGothic'}) #タイトルのフォントのみをIPAexGothicに指定
ax.set_xlabel('x label',**{'family':'IPAexGothic'}) #X軸ラベルのフォントのみをIPAexGothicに指定
毎回のプログラムソースの中でフォントを指定するのは面倒だという場合は,matplotlibの設定ファイルを編集してデフォルトのフォント自体を変更することもできる。
デフォルトでは,
'lib\\site-packages\\matplotlib\\mpl-data\\matplotlibrc'に設定ファイルがある。
この設定ファイルを直接編集しても良いのだが,編集を誤った時にmatplotlibが正しく動作しなくなる恐れがあるので,
これを
'C:\Users\your_name\.matplotlib\'以下にコピー&ペーストそちらを編集する方が無難。
'C:\Users\your_name\.matplotlib\matplotlibrc'をテキストエディタで開くと,196行目付近に
# The font.size property is the default font size for text, given in pts.
# 10 pt is the standard value.
#
font.family : sans-serif
#font.style : normal
#font.variant : normal
#font.weight : medium
#font.stretch : normal
のようにデフォルトのフォント設定がsans-serifとなっていることが分かる。これをコメントアウトして,次のように変更したいフォントにすれば良い。
# The font.size property is the default font size for text, given in pts.
# 10 pt is the standard value.
#
#font.family : sans-serif
font.family : IPAexGothic
#font.style : normal
#font.variant : normal
#font.weight : medium
#font.stretch : normal
以下のプログラムを実行することで,読み込んでいるmatplotlibの設定ファイルの場所を探すことができる。
import matplotlib
print(matplotlib.matplotlib_fname())
ここまでの作業が完了していれば,出力として
'C:\Users\your_name\.matplotlib\'が表示されるはずである。
ファイルの入出力を行う場合,EXCELとの親和性の高さを考えれば,csvファイルとして入出力を行うと良い。
例えば次のようなcsvファイル
test.csv がソースと同じディレクトリの
datain というフォルダに用意されているとする。
test.csv
X,Y,Z
0,0,0
1,1,1
2,2,2
,,
I,J,
0,1,
1,2,
これを読み込み,節点座標を
rという配列に格納し,要素節点関係を
ijという配列に格納するプログラムは次のようになる。
import csv
filename='test.csv'
foldername='datain'
reader=csv.reader(open(foldername+'/'+filename))
r,ij=[],[] #rとijのリスト定義
next(reader) #ラベル行を読み飛ばす
for row in reader:
if row[0]=='': break #空欄になるまで読み込む
r.append([float(row[0]),float(row[1]),float(row[2])]) #座標を実数として読み込み
next(reader) #ラベル行を読み飛ばす
for row in reader:
if row[0]=='': break #空欄になるまで読み込む
ij.append([int(row[0]),int(row[1])]) #要素節点関係を整数として読み込み
print(r) #試しに出力してみる
print(ij) #試しに出力してみる
上記を実行すれば,以下の出力がなされる。
[[0.0, 0.0, 0.0], [1.0, 1.0, 1.0], [2.0, 2.0, 2.0]]
[[0, 1], [1, 2]]
今度は逆に,python内の数値データをcsvファイルとして出力する場合を考える。
先ほどのプログラムの続きに,以下のコードを追記してみよう。
import os
output_filename='test2.csv'
output_foldername='dataout'
try:os.stat(output_foldername)#dataoutという名前のフォルダの有無を調査
except:os.mkdir(output_foldername)#なければ新規にdataoutという名前のフォルダを作成する
writer=csv.writer(open(output_foldername+'/'+output_filename,'w',newline=''))
writer.writerow(['X','Y','Z']) #ラベル行を出力
for ri in r:
writer.writerow([ri[0],ri[1],ri[2]]) #rの値を1行ずつ出力
writer.writerow(['','','']) #改行
writer.writerow(['I','J']) #ラベル行を出力
for eij in ij:
writer.writerow([eij[0],eij[1]]) #ijの値を1行ずつ出力
正しく実行できれば,ソースコードと同じディレクトリに新たに
dataoutというフォルダが作成され,その中に次のようなcsvファイルが生成される。
test2.csv
X,Y,Z
0.0,0.0,0.0
1.0,1.0,1.0
2.0,2.0,2.0
,,
I,J
0,1
1,2
pythonにはmatplotlibというグラフ描画のための強力なライブラリがあり,これを用いれば科学技術計算分野で必要とされるグラフのほとんどを表現することができる。
折れ線グラフを描画する最もシンプルなプログラムは以下の通り。
import matplotlib.pyplot as plt #2次元グラフ描画のためのモジュールの読み込み
x=[0,1,2,3,4,5] #x座標
y=[3,5,1,4,2,8] #y座標
plt.plot(x,y) #グラフの書込み
plt.show() #描画
これを実行すれば以下のような折れ線グラフが描画される。
色を変えたい場合や,マーカーを付加したい場合などは次のように自由にカスタマイズできる。
例えば,線を幅0.5の黒の破線にし,エッジの色が青で太さが1で塗りつぶしの色がピンクで大きさが10の星マークのマーカーを付加したグラフを各場合は次のようにオプションをつければよい。
import matplotlib.pyplot as plt #2次元グラフ描画のためのモジュールの読み込み
x=[0,1,2,3,4,5] #x座標
y=[3,5,1,4,2,8] #y座標
plt.plot(x,y,linestyle='dashed',linewidth=0.5,color='black',
marker='*',markeredgewidth=1,markeredgecolor='blue',
markersize=10,markerfacecolor='pink') #グラフの書込み(描画オプション付き)
plt.show() #描画
これを実行すれば以下のような折れ線グラフが描画される。
グラフの縦横比を揃えたい場合は次のようにする。
import matplotlib.pyplot as plt #2次元グラフ描画のためのモジュールの読み込み
x=[0,1,2,3,4,5] #x座標
y=[3,5,1,4,2,8] #y座標
plt.axes().set_aspect('equal') #縦横比を揃える
plt.plot(x,y,linestyle='dashed',linewidth=0.5,color='black',
marker='*',markeredgewidth=1,markeredgecolor='blue',
markersize=10,markerfacecolor='pink') #グラフの書込み(描画オプション付き)
plt.show() #描画
これを実行すれば以下のような折れ線グラフが描画される。
凡例やタイトルを入れたい場合は次のようにする。
import matplotlib.pyplot as plt #2次元グラフ描画のためのモジュールの読み込み
x=[0,1,2,3,4,5] #x座標
y=[3,5,1,4,2,8] #y座標
plt.axes().set_aspect('equal') #縦横比を揃える
plt.plot(x,y,linestyle='dashed',linewidth=0.5,color='black',
marker='*',markeredgewidth=1,markeredgecolor='blue',
markersize=10,markerfacecolor='pink',label='test') #グラフの書込み(描画オプション付き)
plt.title('graph example') #グラフタイトル
plt.xlabel('X-axis') #X軸ラベル
plt.ylabel('Y-axis') #Y軸ラベル
plt.legend() #凡例の描画(plt.plotでlabelを指定する必要がある)
plt.show() #描画
これを実行すれば以下のような折れ線グラフが描画される。
凡例やタイトルの位置はオプションで自由に指定可能。詳しく知りたい人は公式サイトを参照のこと。
また,逆にグラフの軸が不要な場合は次のようにすれば消去することもできる。
import matplotlib.pyplot as plt #2次元グラフ描画のためのモジュールの読み込み
x=[0,1,2,3,4,5] #x座標
y=[3,5,1,4,2,8] #y座標
plt.axes().set_aspect('equal') #縦横比を揃える
plt.plot(x,y,linestyle='dashed',linewidth=0.5,color='black',
marker='*',markeredgewidth=1,markeredgecolor='blue',
markersize=10,markerfacecolor='pink',label='test') #グラフの書込み(描画オプション付き)
plt.tick_params(labelbottom=False,bottom=False) # x軸の削除
plt.tick_params(labelleft=False,left=False) # y軸の削除
plt.box(False) #枠の消去
plt.show() #描画
これを実行すれば以下のような折れ線グラフが描画される。