はじめに
jupyter notebookの対話的にパラメータを調整できる機能(ipywidgets DropdownおよびSelect)で、画像を任意のcmapで表示する方法について説明する。
コード
data:image/s3,"s3://crabby-images/1a982/1a98206c0211b8eb89c1280bbd72515a4aa6b24a" alt=""
解説
モジュールのインポートなど
バージョン
cmapの順序付き辞書の作成
下記ページに記載のものをそのまま用いた。
Choosing Colormaps in Matplotlib — Matplotlib 3.2.1 documentation
データの生成
画像データは下記記事と同じコードにより生成した。
data:image/s3,"s3://crabby-images/a0d5b/a0d5b68beebf357fdc35fb100f3bda32b66ec49b" alt=""
[matplotlib] 57. plt.imshow()で軸を画像から離して表示
matplotlibのplt.imshowで画像を表示する際に、軸を画像から離して表示する方法について説明する。
画像の表示
ax.imshowで画像を表示し、make_axes_locatableでカラーバーを表示する。
セレクトボックスの設定
辞書のキーをセレクトボックスに設定する。Layoutにより幅と高さの調整ができる。
ドロップダウンボックスの設定
options=cmaps[s.value]でセレクトボックスで選択したキーの要素がドロップダウン形式で選択できるようになる。
セレクトボックスを変更した場合
observeを用いてwidgetsを動作させる。変更した場合にchange[‘new’]の部分に選択した要素が入るので、ドロップダウンのoptionsとvalueをそれぞれ変更する。
ドロップダウンボックスを変更した場合
img.set_cmap(change[‘new’])でドロップダウンで選択した要素を画像のcmapに反映させる。
widgetsの表示
HBoxで横に並べてdisplayで表示する。
Example
Perceptually Uniform Sequential
data:image/s3,"s3://crabby-images/1a982/1a98206c0211b8eb89c1280bbd72515a4aa6b24a" alt=""
Sequential
data:image/s3,"s3://crabby-images/d94b1/d94b1810e7036167723114aefa5cf7a05d841124" alt=""
Sequential (2)
data:image/s3,"s3://crabby-images/fd2c9/fd2c9a0ea09ce4e5fbe5095d92c4346ddc5b8ff2" alt=""
Diverging
data:image/s3,"s3://crabby-images/e1d98/e1d98c5f848c4fc259f540dbd37760e25fcbc773" alt=""
Cyclic
data:image/s3,"s3://crabby-images/412e0/412e0bd2300622e5c3e1d03124bdf695c92e458f" alt=""
Qualitative
data:image/s3,"s3://crabby-images/c1955/c1955e6aed7ac1992dd400428585e513336f878f" alt=""
Miscellaneous
data:image/s3,"s3://crabby-images/6a63a/6a63a05837198423486bfa7f341f7788e147a64e" alt=""
参考
Widget Events — Jupyter Widgets 8.1.5 documentation
Widget List — Jupyter Widgets 8.1.5 documentation
コメント