たまたま面白いツールを見つけた。機械学習のパラメータをいじるとインタラクティブに学習結果が可視化して見れるお勉強アプリ。
MLDemos – A visualization tool for machine learning
MLDemosは、機械学習でのクラス分類、回帰、クラスタリング、次元削減、力学系、報酬最大化を行うそれぞれのアルゴリズムのパラメータが、学習結果にどのように影響しているのかを勉強・理解するための教材として開発されたオープンソースの可視化ツールです。
MLDemosはオープンソースで、個人・アカデミック用途なら無料で利用できます。
可視化結果が美しい。
ペイント感覚でデータの分布を作成できるのも面白いね。
初学者が機械学習のイメージを掴むにはちょうどいいかもしれない。パラメータの調整の感覚も分かってくるかも。プロットしたデータを3Dでグリグリ回して見れるのが個人的に好き。
残念ながらDeep Learningは実装されてないけど、結構いろんな手法が実装されてるみたい。
実装されているアルゴリズム一覧
クラス分類
- Support Vector Machine (SVM)
(C, nu, Pegasos)- Relevance Vector Machine (RVM)
- Gaussian Mixture Models (GMM)
- Multi-Layer Perceptron + BackPropagation
- Gentle AdaBoost + Naive Bayes
- Approximate K-Nearest Neighbors (KNN)
- Gaussian Process Classification (GP)
- Random Forests
回帰
- Support Vector Regression (SVR)
- Relevance Vector Regression (RVR)
- Gaussian Mixture Regression (GMR)
- MLP + BackProp
- Approximate KNN
- Gaussian Process Regression (GPR)
- Sparse Optimized Gaussian Processes (SOGP)
- Locally Weighed Scatterplot Smoothing (LOWESS)
- Locally Weighed Projection Regression (LWPR)
力学系
- GMM+GMR
- LWPR
- SVR
- SEDS
- SOGP (Slow!)
- MLP
- KNN
- Augmented-SVM (ASVM)
クラスタリング
- K-Means
- Soft K-Means
- Kernel K-Means
- K-Means++
- GMM
- One Class SVM
- FLAME
- DBSCAN
射影
- Principal Component Analysis (PCA)
- Kernel PCA
- Independent Component Analysis (ICA)
- Canonical Correlation Analysis (CCA)
- Linear Discriminant Analysis (LDA)
- Fisher Linear Discriminant
- EigenFaces to 2D (using PCA)
報酬最大化 (強化学習)
- Random Search
- Random Walk
- PoWER
- Genetic Algorithms (GA)
- Particle Swarm Optimization
- Particle Filters
- Donut
- Gradient-Free Methods (nlopt)
オイラはまだそれぞれの手法の日本語名を知らない…
謝辞に書かれているこのツールの実装に使われたライブラリがまた面白そう。
謝辞
このプログラムに搭載されているそれぞれのアルゴリズムを実装してくださった方々の労力無しにこのプログラムは完成しませんでした。
- Florent D’Hallouin (GMM + GMR) – LASA
- Dan Grollman (SOGP) – LASA
- Mohammad Khansari (SEDS + DSAvoid) – LASA
- Ashwini Shukla (ASVM, ARD Kernels) – LASA
- Stephane Magnenat (ESMLR) – website
- Chih-Chung Chang と Chih-Jen Lin (libSVM) – website
- David Mount と Sunik Arya (ANN library) – website
- Davis E. King (DLIB) – website
- Stefan Klanke と Sethu Vijayakumar (LWPR) – website
- Robert Davies (Newmat) – website
- JF Cardoso (ICA) – website
- Steven G. Johnson (NLOpt) – website
- The WillowGarage crowd (OpenCV) – website
- Trolltech/Nokia/Digia (Qt) – website
- 一部のアイコンの作者 – website
- スイス連邦工科大学ローザンヌ校の2012年MLクラスの博士課程の学生達(Julien Eberle, Pierre-Antoine Sondag, Guillaume deChambrier, Klas Kronander, Renaud Richardet, Raphael Ullman)
また、LASAのサポート・開発チーム:Christophe Paccolat, Nicolas Sommer, Otpal Vittozの協力無しではこれほどのパフォーマンスのプログラムにはならなかったでしょう。
関連記事
GeoGebra:無料で使える数学アプリ
Pylearn2:ディープラーニングに対応したPythonの...
U-Net:ディープラーニングによるSemantic Seg...
bpy-renderer:レンダリング用Pythonパッケー...
Manim:Pythonで使える数学アニメーションライブラリ
フィクションに登場するUIデザインのまとめサイト
OpenMVSのサンプルを動かしてみる
DCGAN (Deep Convolutional GAN)...
ManimML:機械学習の概念を視覚的に説明するためのライブ...
ニューラルネットワークで画像分類
DUSt3R:3Dコンピュータービジョンの基盤モデル
UnityからROSを利用できる『ROS#』
Raspberry Pi 2のGPIOピン配置
viser:Pythonで使える3D可視化ライブラリ
Mitsuba 3:オープンソースの研究向けレンダラ
SONY製のニューラルネットワークライブラリ『NNabla』
SSD (Single Shot Multibox Dete...
CGAN (Conditional GAN):条件付き敵対的...
Microsoft Mathematics:数学の学習支援ツ...
PeopleSansPeople:機械学習用の人物データをU...
成果を待てない長学歴化の時代
ArUco:OpenCVベースのコンパクトなARライブラリ
書籍『イラストで学ぶ ディープラーニング』
ドットインストールのWordPress入門レッスン
Kaolin:3Dディープラーニング用のPyTorchライブ...
NeuralNetwork.NET:.NETで使えるTens...
SVM (Support Vector Machine)
OpenCVのfindEssentialMat関数を使ったサ...
trimesh:PythonでポリゴンMeshを扱うライブラ...
PGGAN:段階的に解像度を上げて学習を進めるGAN
畳み込みニューラルネットワーク (CNN: Convolut...
OpenGVの用語
Zibra Liquids:Unity向け流体シミュレーショ...
BGSLibrary:OpenCVベースの背景差分ライブラリ
Kubric:機械学習用アノテーション付き動画生成パイプライ...
書籍『伝わる イラスト思考』読了
libigl:軽量なジオメトリ処理ライブラリ
pythonの機械学習ライブラリ『scikit-learn』
Caffe:読みやすくて高速なディープラーニングのフレームワ...
Math.NET Numerics:Unityで使える数値計...
Virtual Network Computing
Immersive Math:線形代数をインタラクティブに学...
コメント