Need advice about which tool to choose?Ask the StackShare community!
DMTK vs TensorFlow: What are the differences?
DMTK: Microsoft Distributed Machine Learning Tookit. DMTK provides a parameter server based framework for training machine learning models on big data with numbers of machines. It is currently a standard C++ library and provides a series of friendly programming interfaces; TensorFlow: Open Source Software Library for Machine Intelligence. TensorFlow is an open source software library for numerical computation using data flow graphs. Nodes in the graph represent mathematical operations, while the graph edges represent the multidimensional data arrays (tensors) communicated between them. The flexible architecture allows you to deploy computation to one or more CPUs or GPUs in a desktop, server, or mobile device with a single API.
DMTK and TensorFlow can be primarily classified as "Machine Learning" tools.
DMTK is an open source tool with 2.68K GitHub stars and 596 GitHub forks. Here's a link to DMTK's open source repository on GitHub.
Pytorch is a famous tool in the realm of machine learning and it has already set up its own ecosystem. Tutorial documentation is really detailed on the official website. It can help us to create our deep learning model and allowed us to use GPU as the hardware support.
I have plenty of projects based on Pytorch and I am familiar with building deep learning models with this tool. I have used TensorFlow too but it is not dynamic. Tensorflow works on a static graph concept that means the user first has to define the computation graph of the model and then run the ML model, whereas PyTorch believes in a dynamic graph that allows defining/manipulating the graph on the go. PyTorch offers an advantage with its dynamic nature of creating graphs.
For data analysis, we choose a Python-based framework because of Python's simplicity as well as its large community and available supporting tools. We choose PyTorch over TensorFlow for our machine learning library because it has a flatter learning curve and it is easy to debug, in addition to the fact that our team has some existing experience with PyTorch. Numpy is used for data processing because of its user-friendliness, efficiency, and integration with other tools we have chosen. Finally, we decide to include Anaconda in our dev process because of its simple setup process to provide sufficient data science environment for our purposes. The trained model then gets deployed to the back end as a pickle.
Pros of DMTK
Pros of TensorFlow
- High Performance32
- Connect Research and Production19
- Deep Flexibility16
- Auto-Differentiation12
- True Portability11
- Easy to use6
- High level abstraction5
- Powerful5
Sign up to add or upvote prosMake informed product decisions
Cons of DMTK
Cons of TensorFlow
- Hard9
- Hard to debug6
- Documentation not very helpful2