Jump to content

Comparison of deep learning software

From Wikipedia, the free encyclopedia

This is an old revision of this page, as edited by Vahid83 (talk | contribs) at 21:09, 17 April 2017 (Deep learning software by name). The present address (URL) is a permanent link to this revision, which may differ significantly from the current revision.

The following table compares some of the most popular software frameworks, libraries and computer programs for deep learning.


Deep learning software by name

Software Creator Software license[a] Open source Platform Written in Interface OpenMP support OpenCL support CUDA support Automatic differentiation[1] Has pretrained models Recurrent nets Convolutional nets RBM/DBNs Parallel execution (multi node)
Apache Singa Apache Incubator Apache 2.0 Yes Linux, Mac OS X, Windows C++ Python, C++, Java No Yes Yes ? Yes Yes Yes Yes Yes
Caffe Berkeley Vision and Learning Center BSD license Yes Linux, Mac OS X, Windows[2] C++ Python, MATLAB Yes Under development[3] Yes Yes Yes[4] Yes Yes No ?
Deeplearning4j Skymind engineering team; Deeplearning4j community; originally Adam Gibson Apache 2.0 Yes Linux, Mac OS X, Windows, Android (Cross-platform) java Java, Scala, Clojure, Python (Keras) Yes On roadmap[5] Yes[6] Computational Graph Yes[7] Yes Yes Yes Yes[8]
Dlib Davis King Boost Software License Yes Cross-Platform C++ C++ Yes No Yes Yes Yes No Yes Yes Yes
Keras François Chollet MIT license Yes Linux, Mac OS X, Windows Python Python Only if using Theano as backend Under development for the Theano backend (and on roadmap for the TensorFlow backend) Yes Yes Yes[9] Yes Yes Yes Yes[10]
Microsoft Cognitive Toolkit Microsoft Research MIT license[11] Yes Windows, Linux[12] (OSX via Docker on roadmap) C++ Python, C++, Command line,[13] BrainScript[14] (.NET on roadmap[15]) Yes[16] No Yes Yes Yes[17] Yes[18] Yes[18] No[19] Yes[20]
MXNet Distributed (Deep) Machine Learning Community Apache 2.0 Yes Linux, Mac OS X, Windows,[21][22] AWS, Android,[23] iOS, JavaScript[24] Small C++ core library C++, Python, Julia, Matlab, JavaScript, Go, R, Scala, Perl Yes On roadmap[25] Yes Yes[26] Yes[27] Yes Yes Yes Yes[28]
Neural Designer Artelnics Proprietary No Linux, Mac OS X, Windows C++ Graphical user interface Yes No No ? ? No No No ?
OpenNN Artelnics GNU LGPL Yes Cross-platform C++ C++ Yes No No ? ? No No No ?
TensorFlow Google Brain team Apache 2.0 Yes Linux, Mac OS X, Windows[29] C++, Python Python, C/C++, Java, Go No On roadmap[30][31] Yes Yes[32] Yes[33] Yes Yes Yes Yes
Theano Université de Montréal BSD license Yes Cross-platform Python Python Yes Under development[34] Yes Yes[35][36] Through Lasagne's model zoo[37] Yes Yes Yes Yes[38]
Torch Ronan Collobert, Koray Kavukcuoglu, Clement Farabet BSD license Yes Linux, Mac OS X, Windows,[39] Android,[40] iOS C, Lua Lua, LuaJIT,[41] C, utility library for C++/OpenCL[42] Yes Third party implementations[43][44] Yes[45][46] Through Twitter's Autograd[47] Yes[48] Yes Yes Yes Yes[49]
Wolfram Mathematica Wolfram Research Proprietary No Windows, Mac OS X, Linux, Cloud computing C++ Command line, Java, C++ No Yes Yes Yes Yes[50] Yes Yes Yes Yes
  1. ^ Licenses here are a summary, and are not taken to be complete statements of the licenses. Some libraries may use other libraries internally under different licenses

See also

References

  1. ^ Atilim Gunes Baydin; Barak A. Pearlmutter; Alexey Andreyevich Radul; Jeffrey Mark Siskind (20 February 2015). "Automatic differentiation in machine learning: a survey". arXiv:1502.05767 [cs.LG].
  2. ^ "Microsoft/caffe". GitHub.
  3. ^ "OpenCL Caffe".
  4. ^ "Caffe Model Zoo".
  5. ^ "Support for Open CL · Issue #27 · deeplearning4j/nd4j". GitHub.
  6. ^ "N-Dimensional Scientific Computing for Java".
  7. ^ Chris Nicholson; Adam Gibson. "Deeplearning4j Models".
  8. ^ Deeplearning4j. "Deeplearning4j on Spark". Deeplearning4j.{{cite web}}: CS1 maint: numeric names: authors list (link)
  9. ^ https://keras.io/applications/
  10. ^ Does Keras support using multiple GPUs? · Issue #2436 · fchollet/keras
  11. ^ "CNTK/LICENSE.md at master · Microsoft/CNTK · GitHub". GitHub.
  12. ^ "Setup CNTK on your machine". GitHub.
  13. ^ "CNTK usage overview". GitHub.
  14. ^ "BrainScript Network Builder". GitHub.
  15. ^ ".NET Support · Issue #960 · Microsoft/CNTK". GitHub.
  16. ^ "How to train a model using multiple machines? · Issue #59 · Microsoft/CNTK". GitHub.
  17. ^ https://github.com/Microsoft/CNTK/issues/140#issuecomment-186466820
  18. ^ a b "CNTK - Computational Network Toolkit". Microsoft Corporation.
  19. ^ url=https://github.com/Microsoft/CNTK/issues/534
  20. ^ "Multiple GPUs and machines". Microsoft Corporation.
  21. ^ "Releases · dmlc/mxnet". Github.
  22. ^ "Installation Guide — mxnet documentation". Readthdocs.
  23. ^ "MXNet Smart Device". ReadTheDocs.
  24. ^ "MXNet.js". Github.
  25. ^ "Support for other Device Types, OpenCL AMD GPU · Issue #621 · dmlc/mxnet". GitHub.
  26. ^ http://mxnet.readthedocs.io/
  27. ^ "Model Gallery". GitHub.
  28. ^ "Run MXNet on Multiple CPU/GPUs with Data Parallel". GitHub.
  29. ^ https://developers.googleblog.com/2016/11/tensorflow-0-12-adds-support-for-windows.html
  30. ^ "tensorflow/roadmap.md at master · tensorflow/tensorflow · GitHub". GitHub.
  31. ^ "OpenCL support · Issue #22 · tensorflow/tensorflow". GitHub.
  32. ^ https://www.tensorflow.org/
  33. ^ https://github.com/tensorflow/models
  34. ^ "Using the GPU — Theano 0.8.2 documentation".
  35. ^ http://deeplearning.net/software/theano/library/gradient.html
  36. ^ https://groups.google.com/d/msg/theano-users/mln5g2IuBSU/gespG36Lf_QJ
  37. ^ "Recipes/modelzoo at master · Lasagne/Recipes · GitHub". GitHub.
  38. ^ Using multiple GPUs — Theano 0.8.2 documentation
  39. ^ https://github.com/torch/torch7/wiki/Windows
  40. ^ "GitHub - soumith/torch-android: Torch-7 for Android". GitHub.
  41. ^ "Torch7: A Matlab-like Environment for Machine Learning" (PDF).
  42. ^ "GitHub - jonathantompson/jtorch: An OpenCL Torch Utility Library". GitHub.
  43. ^ "Cheatsheet". GitHub.
  44. ^ "cltorch". GitHub.
  45. ^ "Torch CUDA backend". GitHub.
  46. ^ "Torch CUDA backend for nn". GitHub.
  47. ^ https://github.com/twitter/torch-autograd
  48. ^ "ModelZoo". GitHub.
  49. ^ https://github.com/torch/torch7/wiki/Cheatsheet#distributed-computing--parallel-processing
  50. ^ http://blog.stephenwolfram.com/2017/03/the-rd-pipeline-continues-launching-version-11-1/