Software:PyTorch

From HandWiki
Jump to: navigation, search
PyTorch
PyTorch logo black.svg
Original author(s)
  • Adam Paszke
  • Sam Gross
  • Soumith Chintala
  • Gregory Chanan
Developer(s)Facebook's AI Research lab (FAIR)
Initial releaseSeptember 2016; 4 years ago (2016-09)[1]
Written in
Operating system
PlatformIA-32, x86-64
Available inEnglish
TypeLibrary for machine learning and deep learning
LicenseBSD
Websitepytorch.org

PyTorch is an open source machine learning library based on the Torch library,[2][3][4] used for applications such as computer vision and natural language processing,[5] primarily developed by Facebook's AI Research lab (FAIR).[6][7][8] It is free and open-source software released under the Modified BSD license. Although the Python interface is more polished and the primary focus of development, PyTorch also has a C++ interface.[9]

A number of pieces of deep learning software are built on top of PyTorch, including Tesla Autopilot,[10] Uber's Pyro,[11] HuggingFace's Transformers,[12] PyTorch Lightning,[13][14] and Catalyst.[15][16]

PyTorch provides two high-level features:[17]

History

Facebook operates both PyTorch and Convolutional Architecture for Fast Feature Embedding (Caffe2), but models defined by the two frameworks were mutually incompatible. The Open Neural Network Exchange (ONNX) project was created by Facebook and Microsoft in September 2017 for converting models between frameworks. Caffe2 was merged into PyTorch at the end of March 2018.[18]

PyTorch tensors

PyTorch defines a class called Tensor (torch.Tensor) to store and operate on homogeneous multidimensional rectangular arrays of numbers. PyTorch Tensors are similar to NumPy Arrays, but can also be operated on a CUDA-capable Nvidia GPU. PyTorch supports various sub-types of Tensors.[19]

Modules

Autograd module

PyTorch uses a method called automatic differentiation. A recorder records what operations have performed, and then it replays it backward to compute the gradients. This method is especially powerful when building neural networks to save time on one epoch by calculating differentiation of the parameters at the forward pass.

Optim module

torch.optim is a module that implements various optimization algorithms used for building neural networks. Most of the commonly used methods are already supported, so there is no need to build them from scratch.

nn module

PyTorch autograd makes it easy to define computational graphs and take gradients, but raw autograd can be a bit too low-level for defining complex neural networks. This is where the nn module can help.

See also

References

  1. Chintala, Soumith (1 September 2016). "PyTorch Alpha-1 release". https://github.com/pytorch/pytorch/releases/tag/v0.1.1. 
  2. Yegulalp, Serdar (19 January 2017). "Facebook brings GPU-powered machine learning to Python". InfoWorld. https://www.infoworld.com/article/3159120/artificial-intelligence/facebook-brings-gpu-powered-machine-learning-to-python.html. 
  3. Lorica, Ben (3 August 2017). "Why AI and machine learning researchers are beginning to embrace PyTorch". O'Reilly Media. https://www.oreilly.com/ideas/why-ai-and-machine-learning-researchers-are-beginning-to-embrace-pytorch. 
  4. Ketkar, Nikhil (2017). "Introduction to PyTorch" (in en). Deep Learning with Python. Apress, Berkeley, CA. pp. 195–208. doi:10.1007/978-1-4842-2766-4_12. ISBN 9781484227657. 
  5. "Natural Language Processing (NLP) with PyTorch – NLP with PyTorch documentation" (in en). http://dl4nlp.info/en/latest/. 
  6. Patel, Mo (2017-12-07). "When two trends fuse: PyTorch and recommender systems" (in en). O'Reilly Media. https://www.oreilly.com/ideas/when-two-trends-fuse-pytorch-and-recommender-systems. 
  7. Mannes, John. "Facebook and Microsoft collaborate to simplify conversions from PyTorch to Caffe2" (in en). TechCrunch. https://techcrunch.com/2017/09/07/facebook-and-microsoft-collaborate-to-simplify-conversions-from-pytorch-to-caffe2/. "FAIR is accustomed to working with PyTorch – a deep learning framework optimized for achieving state of the art results in research, regardless of resource constraints. Unfortunately in the real world, most of us are limited by the computational capabilities of our smartphones and computers." 
  8. Arakelyan, Sophia (2017-11-29). "Tech giants are using open source frameworks to dominate the AI community" (in en-US). https://venturebeat.com/2017/11/29/tech-giants-are-using-open-source-frameworks-to-dominate-the-ai-community/. 
  9. "The C++ Frontend". https://pytorch.org/cppdocs/frontend.html. 
  10. Karpathy, Andrej. "PyTorch at Tesla - Andrej Karpathy, Tesla". https://www.youtube.com/watch?v=oBklltKXtDE. 
  11. "Uber AI Labs Open Sources Pyro, a Deep Probabilistic Programming Language" (in en-US). Uber Engineering Blog. 2017-11-03. https://eng.uber.com/pyro/. 
  12. PYTORCH-TRANSFORMERS: PyTorch implementations of popular NLP Transformers, PyTorch Hub, 2019-12-01, https://pytorch.org/hub/huggingface_pytorch-transformers/, retrieved 2019-12-01 
  13. PYTORCH-Lightning: The lightweight PyTorch wrapper for ML researchers. Scale your models. Write less boilerplate, Lightning-Team, 2020-06-18, https://github.com/PyTorchLightning/pytorch-lightning/, retrieved 2020-06-18 
  14. "Ecosystem Tools" (in en). https://pytorch.org/ecosystem/. 
  15. GitHub - catalyst-team/catalyst: Accelerated DL & RL, Catalyst-Team, 2019-12-05, https://github.com/catalyst-team/catalyst, retrieved 2019-12-05 
  16. "Ecosystem Tools" (in en). https://pytorch.org/ecosystem/. 
  17. "PyTorch – About". https://pytorch.org/about/. 
  18. "Caffe2 Merges With PyTorch". 2018-04-02. https://medium.com/@Synced/caffe2-merges-with-pytorch-a89c70ad9eb7. 
  19. "An Introduction to PyTorch – A Simple yet Powerful Deep Learning Library". 2018-02-22. https://www.analyticsvidhya.com/blog/2018/02/pytorch-tutorial/. 

External links