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

関連記事

OpenCVでiPhone6sのカメラをキャリブレーションする

Geogram:C++の3D幾何アルゴリズムライブラリ

ブラウザ操作自動化ツール『Selenium』を試す

AndroidもopenGLも初心者さ (でもJavaは知ってるよ)

HerokuでMEAN stack

PyDataTokyo主催のDeep Learning勉強会

Twitter APIのPythonラッパー『python-twitter』

UnityからROSを利用できる『ROS#』

ドットインストールのWordPress入門レッスン

Structure from Motion (多視点画像からの3次元形状復元)

BlenderのPython環境にPyTorchをインストールする

JavaScriptとかWebGLとかCanvasとか

PGGAN:段階的に解像度を上げて学習を進めるGAN

AnacondaとTensorFlowをインストールしてVisual Studio 2015で使う

WordPress on Google App Engineを1週間運用してみて

Unity Scriptコーディング→Unreal Engine Scriptコーディング

機械学習手法『Random Forest』

Googleが画像解析旅行ガイドアプリのJetpac社を買収

ManimML:機械学習の概念を視覚的に説明するためのライブラリ

Facebookの顔認証技術『DeepFace』

C#で使える遺伝的アルゴリズムライブラリ『GeneticSharp』

OpenCV3.3.0でsfmモジュールのビルドに成功!

Pix2Pix:CGANによる画像変換

WebGL開発に関する情報が充実してきている

科学技術計算向けスクリプト言語『Julia』

BlenderProc:Blenderで機械学習用の画像データを生成するPythonツール

OpenCV 3.1から追加されたSfMモジュール

Google XML Sitemap Generatorプラグインを3.4.1へダウングレード

OpenCVのfindEssentialMat関数を使ったサンプルを読んでみる

OpenMesh:オープンソースの3Dメッシュデータライブラリ

Unityで360度ステレオVR動画を作る

trimesh:PythonでポリゴンMeshを扱うライブラリ

DensePose:画像中の人物表面のUV座標を推定する

ポリゴンジオメトリ処理ライブラリ『pmp-library (Polygon Mesh Process...

iPhone・iPod touchで動作する知育ロボット『ROMO』

WordPressの表示を高速化する

WinSCP

スクラッチで既存のキャラクターを立体化したい

Runway ML:クリエイターのための機械学習ツール

Google製オープンソース機械学習ライブラリ『TensorFlow』のWindows版が公開された

LLM Visualization:大規模言語モデルの可視化

プログラムによる景観の自動生成

コメント