サイトアイコン NegativeMindException

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

もう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: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だそうです。 NumSharp NumSharpは.NET StandardをターゲットとしたNumPyのC#ポートです。NumSharpはC#で科学計算を...


スポンサーリンク

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

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



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


スポンサーリンク

関連記事

  • BGSLibrary:OpenCVベースの背景差分ライブラリ
  • AfterEffectsプラグイン開発
  • AR (Augmented Reality)とDR (Diminished Reality)
  • Point Cloud Consortiumのセミナー「3D点群の未来」に行ってきたよ
  • Unreal Engine 5の情報が公開された!
  • PeopleSansPeople:機械学習用の人物データをUnityで生成する
  • Super Resolution:OpenCVの超解像処理モジュール
  • libigl:軽量なジオメトリ処理ライブラリ
  • ブログをGoogle App EngineからAmazon EC2へ移行
  • オープンソースの物理ベースGIレンダラ『appleseed』
  • Python拡張モジュールのWindows用インストーラー配布サイト
  • 写真から3Dメッシュの生成・編集ができる無料ツール『Autodesk Memento』
  • html5のcanvasの可能性
  • オープンソースの人体モデリングツール『MakeHuman』のAPI開発プロジェクトがスタート
  • 小説『仮面ライダーエグゼイド ~マイティノベルX~』読了
  • マルコフ連鎖モンテカルロ法
  • SSII 2014 デモンストレーションセッションのダイジェスト動画
  • 画像生成AI Stable Diffusionで遊ぶ
  • Unreal Engineの薄い本
  • Unite 2014の動画
  • バージョン管理の履歴を可視化するツール『Gource』
  • Kaolin:3Dディープラーニング用のPyTorchライブラリ
  • TensorFlowでCGを微分できる『TensorFlow Graphics』
  • python-twitterで自分のお気に入りを取得する
  • 第1回 3D勉強会@関東『SLAMチュートリアル大会』
  • Seleniumを使ったFXや株の自動取引
  • Immersive Math:線形代数をインタラクティブに学べるWebサイト
  • Pythonのソースコードに特化した検索エンジン『Nullege』
  • UnityのGameObjectの向きをScriptで制御する
  • Unityで強化学習できる『Unity ML-Agents』
  • プログラミングスキルとは何か?
  • Google製オープンソース機械学習ライブラリ『TensorFlow』のWindows版が公開された
  • R-CNN (Regions with CNN features):ディープラーニングによる一般物体...
  • Amazon Web ServicesでWordPress
  • OpenGV:画像からカメラの3次元位置・姿勢を推定するライブラリ
  • 今年もSSII
  • OpenCV 3.1とopencv_contribモジュールをVisual Studio 2015で...
  • Pix2Pix:CGANによる画像変換
  • 2D→3D復元技術で使われる用語まとめ
  • Russian3DScannerのトポロジー転送ツール『WrapX』
  • Iterator
  • スクレイピング
  • モバイルバージョンを終了