もう1年以上前になりますが、書籍「イラストで学ぶ ディープラーニング」を購入して少しずつ読み進めていたのです。↓

ところが、読み進めている途中で壁にぶち当たりました。この書籍、途中からどんどん数式率が上がって行き、あんまりイラストで教えてくれなくなるんですよ(笑)
数式が苦手だから「イラストで学ぶ」に期待していたのですが、考えが甘かったようです。
載っているサンプルコードは各種Deep Learningライブラリの使い方なので、肝心の仕組みは当然隠蔽されていて、そこから仕組みを理解するのは難しい。(ライブラリの使い方を覚えられる分実践的なんだけどね)
なので、実装しながら仕組みを理解していく方針に切り替えることにした。
ということで、こちらの書籍に頼ることにしました↓ (すぐ書籍買っちゃう)

Pythonのサンプルコードと、書籍の正誤表はGitHubにある↓
https://github.com/oreilly-japan/deep-learning-from-scratch
https://github.com/oreilly-japan/deep-learning-from-scratch/wiki/errata
これでディープラーニングを作れる(笑)
書籍のサンプルコードはPythonですが、そこは慣れたUnity(というかC#)環境に置き換えて学ぼうと思い、PythonのNumPyに代わる数値計算ライブラリを探していたのでした。

で、Math.NET Numerics導入後に少し調べたら、似た発想の人がいた↓
http://tnakamura.hatenablog.com/entry/2016/12/05/perceptron
http://tnakamura.hatenablog.com/entry/2016/12/08/sigmoid-relu-softmax
http://tnakamura.hatenablog.com/entry/2016/12/15/mnist
http://tnakamura.hatenablog.com/entry/2016/12/16/three-layer-neural-network
http://tnakamura.hatenablog.com/entry/2017/01/30/loss-function
http://tnakamura.hatenablog.com/entry/2017/02/08/numerical-differentiation
http://tnakamura.hatenablog.com/entry/2017/02/10/numeric-gradient
http://tnakamura.hatenablog.com/entry/2017/02/15/gradient-descent
http://tnakamura.hatenablog.com/entry/2017/02/20/gradient-simplenet
https://github.com/snaga/DeepLearning_C_Sharp
せっかくなので実装の参考にさせていただこう。Math.NET Numericsの使い方を知るのに良いサンプルだ。
Unity上で動作の仕組みを可視化できたら最高なんだが、そこまで行けるだろうか。
2019年 追記:今ならMath.NET Numericsじゃなくて、このNumSharpを使った方が良いと思う↓

パーセプトロン、ニューラルネットワークのイメージ
書籍とは関係ないけど、パーセプトロン、ニューラルネットワークの働きをビジュアル化するとこんなイメージらしい↓
色んなアルゴリズムをこんな感じで可視化できると理解が捗るだろうなぁ。
関連記事
OpenCVで動画の手ぶれ補正
書籍『仕事ではじめる機械学習』を読みました
SVM (Support Vector Machine)
書籍『転職の思考法』読了
書籍『ピクサー流 創造するちから』読了
SSD (Single Shot Multibox Dete...
Verilog HDL
書籍『グラビアアイドルの仕事論』読了
PCA (主成分分析)
R-CNN (Regions with CNN featur...
Boost オープンソースライブラリ
OpenSfM:PythonのStructure from ...
Faceshiftで表情をキャプチャしてBlender上でM...
adskShaderSDK
Adobe MAX 2015
オープンソースの取引プラットフォーム
機械学習手法『Random Forest』
OpenCVの超解像(SuperResolution)モジュ...
読書は趣味か?
深海魚
OpenCV 3.1のsfmモジュールを試す
SegNet:ディープラーニングによるSemantic Se...
OpenCVで顔のモーフィングを実装する
WebGL開発に関する情報が充実してきている
Active Appearance Models(AAM)
Kinect for Windows v2の日本価格決定
OpenGVのライブラリ構成
書籍『「あなた」という商品を高く売る方法』読了
写真から3Dメッシュの生成・編集ができる無料ツール『Auto...
OANDAのfxTrade API
UnityからROSを利用できる『ROS#』
畳み込みニューラルネットワーク (CNN: Convolut...
MVStudio:オープンソースのPhotogrammetr...
AnacondaとTensorFlowをインストールしてVi...
仮想関数
Mean Stack開発の最初の一歩
Kornia:微分可能なコンピュータービジョンライブラリ
Unity ARKitプラグインサンプルのドキュメントを読む
iOSで使えるJetpac社の物体認識SDK『DeepBel...
Pythonの自然言語処理ライブラリ『NLTK(Natura...
pythonの機械学習ライブラリ『scikit-learn』
FCN (Fully Convolutional Netwo...


コメント