Jblas: Linear Algebra for Java
||The topic of this article may not meet Wikipedia's notability guidelines for products and services. (September 2013) (Learn how and when to remove this template message)|
|Original author(s)||Mikio L. Braun|
1.2.4 / May 12, 2015
jblas is a linear algebra library, created by Mikio Braun, for the Java programming language built upon BLAS and LAPACK. Unlike most other Java linear algebra libraries, jblas is designed to be used with native code through the Java Native Interface (JNI) and comes with precompiled binaries. When used on one of the targeted architectures, it will automatically select the correct binary to use and load it. This allows it to be used out of the box and avoid a potentially tedious compilation process. jblas provides an easier to use high level API on top of the archaic API provided by BLAS and LAPACK, removing much of the tediousness.
Since its initial release, jblas has been gaining popularity in scientific computing. With applications in a range of applications, such as text classification, network analysis, and stationary subspace analysis. It is part of software packages, such as JLabGroovy, Universal Java Matrix Library (UJMP)., and DataMelt scientific computational environment. In a recent performance study of Java matrix libraries, jblas is the highest performing library, when libraries with native code are considered.
The following is an overview of jblas's capabilities, as listed on the project's website:
- Eigen – eigendecomposition
- Solve – solving linear equations
- Singular – singular value decomposition
- Decompose – LU, Cholesky, ...
- Geometry – centering, normalizing, ...
Example of Eigenvalue Decomposition:
DoubleMatrix evd = Eigen.symmetricEigenvectors(matA); DoubleMatrix V = evd; DoubleMatrix D = evd;
Example of matrix multiplication:
DoubleMatrix result = matA.mmul(matB);
- C. Dharmadhikar, Shweta; Maya Ingle; Parag Kulkarn (July 2012). "A Novel Multi label Text Classification Model using Semi supervised learning". International Journal of Data Mining & Knowledge Ma nagement Process (IJDKP). 2 (4).
- Davis, Nicholas; Ahwan Pandey; B. A. McKinney (2011). "Real-world comparison of CPU and GPU implementations of SNPrank: a network analysis tool for GWAS". Bioinformatics. 27 (2): 284–285. doi:10.1093/bioinformatics/btq638. PMC . PMID 21115438.
- Muller, Jan Saputra; Paul von Bunau; Frank C. Meinecke; Franz J. Kiraly; Klaus-Robert Muller (2011). SSA Toolbox 1.3 Manual (PDF). Retrieved September 25, 2013.
- Papadimitriou, Stergios. "JLabGroovy". Retrieved September 23, 2013.
- Arndt, Holger. "Universal Java Matrix Package". Retrieved September 25, 2013.
- Abeles, Peter. "Java Matrix Benchmark". Retrieved September 23, 2013.