- Prioritizes the Java developer's experience
- Makes it easy for new machine learning developers to get started
- Allows developers to write modular, reusable code
- Reduces friction for deploying to a production environment
- Connects model developers with their consumers using the model zoo
- Allows developers to write code once and run it on any deep learning engine
- Allows developers to use engine specific features
While DJL is designed to be engine-agnostic and to run with the any engine, we currently support the following engines:
- Apache MXNet
- PyTorch (Currently only support inference)
- TensorFlow (Experimental - inference only)
- fastText
Yes. DJL does support inference on GPU. If GPUs are available, DJL automatically detects the GPU, and runs inference on a single GPU by default.
Yes. DJL offers multi-GPU support. DJL can automatically detect if GPUs are available. If GPUs are available, it will run on a single GPU by default, unless the user specifies otherwise.
During training, if you wish to train on multiple GPUs or if you wish to limit the number of GPUs to be used (you may want to limit the number of GPU for smaller datasets), you have to configure the TrainingConfig
to do so by
setting the devices. For example, if you have 7 GPUs available, and you want the Trainer
to train on 5 GPUs, you can configure it as follows.
int maxNumberOfGpus = 5;
TrainingConfig config = new DefaultTrainingConfig(initializer, loss)
.setOptimizer(optimizer)
.addEvaluator(accuracy)
.setBatchSize(batchSize)
// Set the devices to run on multi-GPU
.setDevices(Device.getDevices(numberOfGpus));
All of the examples in the example folder can be run on multiple GPUs with the appropriate arguments. Follow the steps in the example to train a ResNet50 model on CIFAR-10 dataset on a GPU.
Yes. DJL offers multi-threaded inference. If using the MXNet engine for a multi-threaded inference case, you need to specify the 'MXNET_ENGINE_TYPE' environment variable to 'NaiveEngine'. For more information, see the inference_performance_optimization.
DJL does not currently support distributed training.
This is not officially supported by DJL, but you can follow the steps outlined in the troubleshooting document to use other versions of MXNet or built your own customized version.
While DJL is designed to be engine-agnostic, here is a list of the DJL engines and the formats they support:
- MXNet
- MXNet symbolic model
- MXNet Gluon model - The model must be hybridized and exported to symbolic model before loading in DJL
- PyTorch
- TorchScript model - You can find more details at (https://pytorch.org/tutorials/beginner/Intro_to_TorchScript_tutorial.html)
- TensorFlow
- .pb format
- Keras model - DJL only supports the SavedModel API. The .h5 format is currently not supported
- ONNX Model
- .onnx format
- fastText
- .bin format
- .ftz format
- SageMaker BlazingText