Open main menu

Wikipedia β

Comparison of deep learning software

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


Contents

Deep learning software by nameEdit

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)
Caffe Berkeley Vision and Learning Center BSD license Yes Linux, macOS, Windows[2] C++ Python, MATLAB Yes Under development[3] Yes Yes Yes[4] Yes Yes No ?
Caffe2 Facebook Apache 2.0 Yes Linux, macOS, Windows[5] C++, Python Python, MATLAB Yes Under development[6] Yes Yes Yes[7] Yes Yes No Yes
Deeplearning4j Skymind engineering team; Deeplearning4j community; originally Adam Gibson Apache 2.0 Yes Linux, macOS, Windows, Android (Cross-platform) C++, Java Java, Scala, Clojure, Python (Keras), Kotlin Yes On roadmap[8] Yes[9][10] Computational Graph Yes[11] Yes Yes Yes Yes[12]
Dlib Davis King Boost Software License Yes Cross-Platform C++ C++ Yes No Yes Yes Yes No Yes Yes Yes
Intel Data Analytics Acceleration Library Intel Apache License 2.0 Yes Linux, macOS, Windows on Intel CPU[13] C++, Python, Java C++, Python, Java[13] Yes No No Yes No Yes Yes
Intel Math Kernel Library Intel Proprietary No Linux, macOS, Windows on Intel CPU[14] C[15] Yes[16] No No Yes No Yes[17] Yes[17] No
Keras François Chollet MIT license Yes Linux, macOS, Windows Python Python, R Only if using Theano as backend Under development for the Theano backend (and on roadmap for the TensorFlow backend) Yes Yes Yes[18] Yes Yes Yes Yes[19]
MatConvNet Andrea Vedaldi, Karel Lenc BSD license Yes Windows, Linux[20] (macOS via Docker on roadmap) C++ MATLAB, C++, No No Yes Yes Yes Yes Yes No Yes
MATLAB + Neural Network Toolbox MathWorks Proprietary No Linux, macOS, Windows C, C++, Java, MATLAB MATLAB No No Train with Parallel Computing Toolbox and generate CUDA code with GPU Coder[21] No Yes[22][23] Yes[22] Yes[22] No With Parallel Computing Toolbox[24]
Microsoft Cognitive Toolkit Microsoft Research MIT license[25] Yes Windows, Linux[20] (macOS via Docker on roadmap) C++ Python (Keras), C++, Command line,[26] BrainScript[27] (.NET on roadmap[28]) Yes[29] No Yes Yes Yes[30] Yes[31] Yes[31] No[32] Yes[33]
Apache MXNet Apache Software Foundation Apache 2.0 Yes Linux, macOS, Windows,[34][35] AWS, Android,[36] iOS, JavaScript[37] Small C++ core library C++, Python, Julia, Matlab, JavaScript, Go, R, Scala, Perl Yes On roadmap[38] Yes Yes[39] Yes[40] Yes Yes Yes Yes[41]
Neural Designer Artelnics Proprietary No Linux, macOS, Windows C++ Graphical user interface Yes No No ? ? No No No ?
OpenNN Artelnics GNU LGPL Yes Cross-platform C++ C++ Yes No Yes ? ? No No No ?
PaddlePaddle Baidu PaddlePaddle team Apache 2.0 Yes Linux, macOS, Android,[42] Raspberry Pi[43] C++, Go C/C++, Python Yes No Yes Yes Yes[44] Yes Yes No Yes
PyTorch Adam Paszke, Sam Gross, Soumith Chintala, Gregory Chanan BSD license Yes Linux, macOS, Windows,[45] Python, C, CUDA Python
Apache SINGA Apache Incubator Apache 2.0 Yes Linux, macOS, Windows C++ Python, C++, Java No No Yes ? Yes Yes Yes Yes Yes
TensorFlow Google Brain team Apache 2.0 Yes Linux, macOS, Windows[46] C++, Python Python (Keras), C/C++, Java, Go, R[47] No On roadmap[48] but already with SYCL[49] support Yes Yes[50] Yes[51] Yes Yes Yes Yes
Theano Université de Montréal BSD license Yes Cross-platform Python Python (Keras) Yes Under development[52] Yes Yes[53][54] Through Lasagne's model zoo[55] Yes Yes Yes Yes[56]
Torch Ronan Collobert, Koray Kavukcuoglu, Clement Farabet BSD license Yes Linux, macOS, Windows,[57] Android,[58] iOS C, Lua Lua, LuaJIT,[59] C, utility library for C++/OpenCL[60] Yes Third party implementations[61][62] Yes[63][64] Through Twitter's Autograd[65] Yes[66] Yes Yes Yes Yes[67]
Wolfram Mathematica Wolfram Research Proprietary No Windows, macOS, Linux, Cloud computing C++ Wolfram Language No No Yes Yes Yes[68] Yes Yes Yes Yes
LaonSill Laonbud Apache 2.0 Yes Linux, Cloud computing C++ Python No No Yes No Yes[69] No Yes No 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

Related softwareEdit

See alsoEdit

ReferencesEdit

  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. ^ "Caffe2 Github Repo". 
  6. ^ "OpenCL Caffe". 
  7. ^ "Caffe Model Zoo". 
  8. ^ "Support for Open CL · Issue #27 · deeplearning4j/nd4j". GitHub. 
  9. ^ "N-Dimensional Scientific Computing for Java". 
  10. ^ "Comparing Top Deep Learning Frameworks". Deeplearning4j. 
  11. ^ Chris Nicholson; Adam Gibson. "Deeplearning4j Models". 
  12. ^ Deeplearning4j. "Deeplearning4j on Spark". Deeplearning4j. 
  13. ^ a b Intel® Data Analytics Acceleration Library (Intel® DAAL) | Intel® Software
  14. ^ Intel® Math Kernel Library (Intel® MKL) | Intel® Software
  15. ^ Deep Neural Network Functions
  16. ^ Using Intel® MKL with Threaded Applications | Intel® Software
  17. ^ a b Intel® Xeon Phi™ Delivers Competitive Performance For Deep Learning—And Getting Better Fast | Intel® Software
  18. ^ https://keras.io/applications/
  19. ^ Does Keras support using multiple GPUs? · Issue #2436 · fchollet/keras
  20. ^ a b "Setup CNTK on your machine". GitHub. 
  21. ^ "GPU Coder - MATLAB & Simulink". MathWorks. Retrieved 13 November 2017. 
  22. ^ a b c "Neural Network Toolbox - MATLAB". MathWorks. Retrieved 13 November 2017. 
  23. ^ "Deep Learning Models - MATLAB & Simulink". MathWorks. Retrieved 13 November 2017. 
  24. ^ "Parallel Computing Toolbox - MATLAB". MathWorks. Retrieved 13 November 2017. 
  25. ^ "CNTK/LICENSE.md at master · Microsoft/CNTK · GitHub". GitHub. 
  26. ^ "CNTK usage overview". GitHub. 
  27. ^ "BrainScript Network Builder". GitHub. 
  28. ^ ".NET Support · Issue #960 · Microsoft/CNTK". GitHub. 
  29. ^ "How to train a model using multiple machines? · Issue #59 · Microsoft/CNTK". GitHub. 
  30. ^ https://github.com/Microsoft/CNTK/issues/140#issuecomment-186466820
  31. ^ a b "CNTK - Computational Network Toolkit". Microsoft Corporation. 
  32. ^ url=https://github.com/Microsoft/CNTK/issues/534
  33. ^ "Multiple GPUs and machines". Microsoft Corporation. 
  34. ^ "Releases · dmlc/mxnet". Github. 
  35. ^ "Installation Guide — mxnet documentation". Readthdocs. 
  36. ^ "MXNet Smart Device". ReadTheDocs. 
  37. ^ "MXNet.js". Github. 
  38. ^ "Support for other Device Types, OpenCL AMD GPU · Issue #621 · dmlc/mxnet". GitHub. 
  39. ^ https://mxnet.readthedocs.io/
  40. ^ "Model Gallery". GitHub. 
  41. ^ "Run MXNet on Multiple CPU/GPUs with Data Parallel". GitHub. 
  42. ^ http://www.paddlepaddle.org/docs/develop/documentation/en/mobile/cross_compiling_for_android_en.html
  43. ^ http://www.paddlepaddle.org/docs/develop/documentation/en/mobile/cross_compiling_for_raspberry_en.html
  44. ^ http://www.paddlepaddle.org/docs/develop/models/README.html
  45. ^ https://github.com/pytorch/pytorch/issues/494
  46. ^ https://developers.googleblog.com/2016/11/tensorflow-0-12-adds-support-for-windows.html
  47. ^ interface), JJ Allaire (R; RStudio; Eddelbuettel, Dirk; Golding, Nick; Tang, Yuan; Tutorials), Google Inc (Examples and (2017-05-26), tensorflow: R Interface to TensorFlow, retrieved 2017-06-14 
  48. ^ "tensorflow/roadmap.md at master · tensorflow/tensorflow · GitHub". GitHub. January 23, 2017. Retrieved May 21, 2017. 
  49. ^ "OpenCL support · Issue #22 · tensorflow/tensorflow". GitHub. 
  50. ^ https://www.tensorflow.org/
  51. ^ https://github.com/tensorflow/models
  52. ^ "Using the GPU — Theano 0.8.2 documentation". 
  53. ^ http://deeplearning.net/software/theano/library/gradient.html
  54. ^ https://groups.google.com/d/msg/theano-users/mln5g2IuBSU/gespG36Lf_QJ
  55. ^ "Recipes/modelzoo at master · Lasagne/Recipes · GitHub". GitHub. 
  56. ^ Using multiple GPUs — Theano 0.8.2 documentation
  57. ^ https://github.com/torch/torch7/wiki/Windows
  58. ^ "GitHub - soumith/torch-android: Torch-7 for Android". GitHub. 
  59. ^ "Torch7: A Matlab-like Environment for Machine Learning" (PDF). 
  60. ^ "GitHub - jonathantompson/jtorch: An OpenCL Torch Utility Library". GitHub. 
  61. ^ "Cheatsheet". GitHub. 
  62. ^ "cltorch". GitHub. 
  63. ^ "Torch CUDA backend". GitHub. 
  64. ^ "Torch CUDA backend for nn". GitHub. 
  65. ^ https://github.com/twitter/torch-autograd
  66. ^ "ModelZoo". GitHub. 
  67. ^ https://github.com/torch/torch7/wiki/Cheatsheet#distributed-computing--parallel-processing
  68. ^ http://blog.stephenwolfram.com/2017/03/the-rd-pipeline-continues-launching-version-11-1/
  69. ^ http://blog.stephenwolfram.com/2017/03/the-rd-pipeline-continues-launching-version-11-1/