ND4J backends for GPUs and CPUs

You can choose GPUs or native CPUs for your backend linear algebra operations by changing the dependencies in ND4J’s POM.xml file. Your selection will affect both ND4J and DL4J being used in your application.

If you have CUDA v9.2+ installed and NVIDIA-compatible hardware, then your dependency declaration will look like:

  1. <dependency>
  2. <groupId>org.nd4j</groupId>
  3. <artifactId>nd4j-cuda-10.1</artifactId>
  4. <version>1.0.0-beta4</version>
  5. </dependency>

As of now, the artifactId for the CUDA versions can be one of nd4j-cuda-9.0, nd4j-cuda-9.2 or nd4j-cuda-10.0.

You can also find the available CUDA versions via Maven Central search or in the Release Notes.

Otherwise you will need to use the native implementation of ND4J as a CPU backend:

  1. <dependency>
  2. <groupId>org.nd4j</groupId>
  3. <artifactId>nd4j-native</artifactId>
  4. <version>1.0.0-beta4</version>
  5. </dependency>

System architectures

If you are developing your project on multiple operating systems/system architectures, you can add -platform to the end of your artifactId which will download binaries for most major systems.

  1. <dependency>
  2. ...
  3. <artifactId>nd4j-native-platform</artifactId>
  4. ...
  5. </dependency>

Multiple GPUs

If you have several GPUs, but your system is forcing you to use just one, you can use the helper CudaEnvironment.getInstance().getConfiguration().allowMultiGPU(true); as first line of your main() method.

CuDNN

See our page on CuDNN.

CUDA Installation

Check the NVIDIA guides for instructions on setting up CUDA on the NVIDIA website.