This package implements a general framework for utilizing R to harness the power of NVIDIA GPU's. The "gmatrix" and "gvector" classes allow for easy management of the separate device and host memory spaces. Numerous numerical operations are implemented for these objects on the GPU. These operations include matrix multiplication, addition, subtraction, the kronecker product, the outer product, comparison operators, logical operators, trigonometric functions, indexing, sorting, random number generation and many more. The "gmatrix" package has only been tested and compiled for linux machines. It would certainly be nice of someone to get it working in Windows. Until then, Windows is not supported. In addition we assume that the divice is at least of NVIDIA(R) compute capibility 2.0, so this package may not work with older devices.
- Install the the CUDA Toolkit. The current version of 'gmatix' has been tested for CUDA Toolkit 5.0 and 7.0.
- Install R. The current version of 'gmatrix' has been tested under R 3.0.2 and 3.2.2.
- Start R and then install the 'gmatrix' package with the following commands. Package compilation may take 5-10 minutes.
install.packages("gmatrix")
Alternatively, if you would like to install the developmental version, the following from the linux command line may be used:
git clone https://github.com/njm18/gmatrix.git
rm ./gmatrix/.git -rf
MAKE="make -j7" #note this make the compile process use 7 threads
R CMD INSTALL gmatrix
By default, when compiling, the build process assumes that
- The nvcc compiler is in the PATH, and that the the CUDA library files may be located based on the location of nvcc.
- R is located in the PATH, and:
- The R home directory may be located using the command: R RHOME
- The R include director may be located using the command: R --slave --no-save -e "cat(R.home('include'))".
- The compute capability of the target device is 2.0.
If these are incorrect assumptions, the user may set these values and install using the following R command as an example.
install.packages("gmatrix" ,
configure.args = "
--with-arch=sm_30
--with-cuda-home=/opt/cuda
--with-r-home=/opt/R
--with-r-include=/opt/R/include/x64"
)
Alternatively, from the command line, use a cammand such as:
R CMD INSTALL gmatrix --configure-args="--with-arch=sm_35"
We recomend that the user test the installation using the following commands:
library(gmatrix)
gtest()
Please report any errors to the package maintainer.
- Load the library for each sessesion using: library(gmatrix)
- To list available gpu devices use: listDevices()
- To set the device use: setDevice()
- To move object to the device use: g()
- To move object to the host use: h()
- Object on the device can be manipulated in much the same way other R objects can.
- A list of help topics may be optained using: help(package="gmatrix")