書籍『ゼロから作るDeep Learning』で自分なりに学ぶ

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



ところが、読み進めている途中で壁にぶち当たりました。この書籍、途中からどんどん数式率が上がって行き、あんまりイラストで教えてくれなくなるんですよ(笑)

数式が苦手だから「イラストで学ぶ」に期待していたのですが、考えが甘かったようです。
載っているサンプルコードは各種Deep Learningライブラリの使い方なので、肝心の仕組みは当然隠蔽されていて、そこから仕組みを理解するのは難しい。(ライブラリの使い方を覚えられる分実践的なんだけどね)

なので、実装しながら仕組みを理解していく方針に切り替えることにした。
ということで、こちらの書籍に頼ることにしました↓ (すぐ書籍買っちゃう)

ゼロから作るDeep Learning ―Pythonで学ぶディープラーニングの理論と実装

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:Unityで使える数値計算ライブラリ
立て続けにUnityの話題ですが。数学的なことをUnityで勉強しようかなという気分になってきた。お勉強用途だと最近はPython、というかPythonのNumPyが手軽で良く使われてるイメージ。Unityでも使える数値計算ライブラ...


で、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を使った方が良いと思う↓
NumSharp:C#で使えるNumPyライクな数値計算ライブラリ
C#で書かれたNumPy風の数値計算ライブラリ。Apache License 2.0だそうです。NumSharpNumSharpは.NET StandardをターゲットとしたNumPyのC#ポートです。NumSharpはC#で...


スポンサーリンク

パーセプトロン、ニューラルネットワークのイメージ

書籍とは関係ないけど、パーセプトロン、ニューラルネットワークの働きをビジュアル化するとこんなイメージらしい↓



色んなアルゴリズムをこんな感じで可視化できると理解が捗るだろうなぁ。


スポンサーリンク

関連記事

機械学習で遊ぶ
Googleが画像解析旅行ガイドアプリのJetpac社を買収
オープンソースの物理ベースGIレンダラ『appleseed』
SSII 2014 デモンストレーションセッションのダイジェスト動画
Python for Unity:UnityEditorでPythonを使えるパッケージ
CGのためのディープラーニング
OpenMesh:オープンソースの3Dメッシュデータライブラリ
Unreal Engine 5の情報が公開された!
libigl:軽量なジオメトリ処理ライブラリ
.NETで使えるTensorFlowライクなニューラルネットワークライブラリ『NeuralNetwo...
書籍『自分の強みを見つけよう』読了
Pythonの自然言語処理ライブラリ『NLTK(Natural Language Toolkit)』
Unityで画面タッチ・ジェスチャ入力を扱う無料Asset『TouchScript』
WordPress on Google App Engineを1週間運用してみて
Unity MonoBehaviourクラスのオーバーライド関数が呼び出される順番
Model View Controller
NumSharp:C#で使えるNumPyライクな数値計算ライブラリ
UnityからROSを利用できる『ROS#』
ブラウザ操作自動化ツール『Selenium』を試す
このブログのデザインに飽きてきた
書籍『データビジュアライゼーションのデザインパターン20』読了
Webサイトのワイヤーフレームが作成できるオンラインツール
読みやすくて高速なディープラーニングのフレームワーク『Caffe』
小説『GODZILLA 怪獣黙示録』読了(ネタバレ無し)
OpenCV 3.1のsfmモジュールを試す
2D→3D復元技術で使われる用語まとめ
円谷プロダクション クリエイティブアワード 金城哲夫賞
Adobe MAX 2015
書籍『「あなた」という商品を高く売る方法』読了
TeleSculptor:空撮動画からPhotogrammetryするツール
第1回 3D勉強会@関東『SLAMチュートリアル大会』
Photogrammetry (写真測量法)
OpenAR:OpenCVベースのマーカーARライブラリ
すてる英語学習本『ずるいえいご』
iPhoneアプリ開発 Xcode 5のお作法
疑似3D写真が撮れるiPhoneアプリ『Seene』がアップデートでついにフル3Dモデルが撮影できる...
Facebookの顔認証技術『DeepFace』
書籍『GODZILLA GRAPHIC COLLECTION ゴジラ造型写真集』が出るぞ
顔画像処理技術の過去の研究
Web経由でRaspberry PiのGPIOを操作したい
それぞれの媒質の屈折率
ディープラーニングに対応したPythonの機械学習ライブラリ『Pylearn2』

コメント