KelpNet:C#で使える可読性重視のディープラーニングライブラリ

ここ最近、ディープラーニングというか、ニューラルネットワークのお勉強をしてみて、その処理コストが高いため、実装では行列演算として扱われていることを知った。


畳み込みニューラルネットワーク (CNN:Convolutional Neural Network)
例の書籍「ゼロから作るDeep Learning ―Pythonで学ぶディープラーニングの理論と実装」を一通り読み終わりました。「あえてPythonを使わずにUnity C#で実装しながら勉強する」とか言っておきながら、結局途中で...


行列演算に最適化されたライブラリを使うことで処理の高速化を図っているらしい。(GPUも行列演算得意だしね)

そういうわけで、巷のオープンソースコードからアルゴリズムを勉強するのは、数学(というか行列)に疎いとちょっとしんどかったりする。


スポンサーリンク


そんな数学の苦手な人でもコードを読んで勉強できるよう、春条氏が行列演算を使わずにディープラーニングを実装したライブラリKelpNetを公開している。

KelpNet

KelpNetはC#で実装された深層学習のライブラリです。

特徴

  • 行列演算をライブラリに頼らないため全ソースが可読になっており、どこで何をしているかを全て観測できます
  • KerasやChainerが採用している、関数を積み重ねるように記述するコーディングスタイルを採用しています
  • 並列演算にOpenCLを採用しているため、GPUだけでなくCPUやFPGA等の様々な演算装置で処理を並列化できます

C#で作られているメリット

  • 開発環境の構築が容易で、プログラミング初学者にも学びやすい言語です
  • WindowsFormやUnity等、処理結果を視覚的に表示するための選択肢が豊富です
  • PCや携帯、組み込み機器等、様々なプラットフォームに向けたアプリケーションの開発ができます

このライブラリについて

このライブラリの基幹部分はChainerを参考に実装されています。 その為ほとんどの関数パラメータがChainerと同じになっており、Chainer向けのサンプルを参考に開発することが可能になっています。


スポンサーリンク

License



Unityでの利用も想定されているようなので、ちょっと試してみたいな。

2018年8月 追記:じんべえざめさんがKelpNetを使った学習記事を公開している↓
https://jinbeizame.hateblo.jp/entry/kelpnet_intro
https://jinbeizame.hateblo.jp/entry/kelpnet_xor
https://jinbeizame.hateblo.jp/entry/kelpnet_opencl_gpu
https://jinbeizame.hateblo.jp/entry/kelpnet_cnn
https://jinbeizame.hateblo.jp/entry/kelpnet_vgg
https://jinbeizame.hateblo.jp/entry/kelpnet_transfer

2019年3月 追記:KelpNetをUnityで使うQiita記事↓
https://qiita.com/yanosen_jp/items/4ca7d16908f0956ef7d8


スポンサーリンク

関連記事

AMIMOTO(PVM版)で作成したインスタンスをAMIMOTO (HVM版)へ移行する
Blenderの人体モデリングアドオン『MB-Lab』
ドットインストールのWordPress入門レッスン
OpenSfM:PythonのStructure from Motionライブラリ
libigl:軽量なジオメトリ処理ライブラリ
Google Colaboratoryで遊ぶ準備
Russian3DScannerのトポロジー転送ツール『WrapX』
WordPressプラグインの作り方
Mean Stack開発の最初の一歩
Raspberry Piでセンサーの常時稼働を検討する
C#で使える遺伝的アルゴリズムライブラリ『GeneticSharp』
UnrealCV:コンピュータビジョン研究のためのUnreal Engineプラグイン
GoogleのDeep Learning論文
RefineNet (Multi-Path Refinement Network):ディープラーニン...
プログラムによる景観の自動生成
BlenderでPhotogrammetryできるアドオン
Raspberry Pi
MLDemos:機械学習について理解するための可視化ツール
PGGAN:段階的に解像度を上げて学習を進めるGAN
画像からカメラの3次元位置・姿勢を推定するライブラリ『OpenGV』
バージョン管理の履歴を可視化するツール『Gource』
OpenCVで平均顔を作るチュートリアル
CycleGAN:ドメイン関係を学習した画像変換
hloc:SuperGlueで精度を向上させたSfM実装
機械学習で流体シミュレーションを近似する『Physics Forests』
3Dスキャンしたテクスチャから照明を除去するUnityツール『De Lighting tool』
konashiのサンプルコードを動かしてみた
WinSCP
HerokuでMEAN stack
株式会社ヘキサドライブの研究室ページ
pythonの機械学習ライブラリ『scikit-learn』
OpenCV 3.1から追加されたSfMモジュール
複数画像から3次元形状を再構築するライブラリ『Multi-View Environment』
Google Chromecast
畳み込みニューラルネットワーク (CNN:Convolutional Neural Network)
OANDAのfxTrade API
YOLO (You Only Look Once):ディープラーニングによる一般物体検出手法
チャットツール用bot開発フレームワーク『Hubot』
サンプルコードにも間違いはある?
OpenCVの顔検出過程を可視化した動画
OpenCVの三角測量関数『cv::triangulatepoints』
機械学習で遊ぶ

コメント