1
0
mirror of https://github.com/andre-wojtowicz/blas-benchmarks synced 2025-01-05 19:25:28 +01:00
Timing results for BLAS (Basic Linear Algebra Subprograms) libraries in R
Go to file
Andrzej Wójtowicz e0c075fcea Added print to benchmark sample;
Updated results R markdown for next host and gpu
2016-05-29 17:45:39 +02:00
gen updated readme (first results) 2016-05-26 19:30:19 +02:00
.gitignore updated readme (first results) 2016-05-26 19:30:19 +02:00
benchmark-gcbd.R added gcbd benchmark; 2016-05-20 12:54:32 +02:00
benchmark-revolution.R added saving host info; 2016-05-19 19:11:33 +02:00
benchmark-sample.R Added print to benchmark sample; 2016-05-29 17:45:39 +02:00
benchmark-urbanek.R added saving host info; 2016-05-19 19:11:33 +02:00
master-ctrl-slaves.sh added gcbd benchmark; 2016-05-20 12:54:32 +02:00
README.md fixed typo in ToC 2016-05-26 19:39:26 +02:00
results.Rmd Added print to benchmark sample; 2016-05-29 17:45:39 +02:00
slave-cmds.sh fixed gotoblas2 threading issue 2016-05-27 00:07:49 +02:00

BLAS libraries benchmarks

Andrzej Wójtowicz

Document generation date: 2016-05-26 19:23:05

Table of Contents

  1. Configuration
  2. Results per host
  3. Results per library

Configuration

R software: Microsoft R Open.

Libraries:

CPU (single-threaded) CPU (multi-threaded) GPU
Netlib (debian package) OpenBLAS (debian package) NVIDIA cuBLAS (NVBLAS + Intel MKL)
ATLAS (debian package) ATLAS (dev branch)
GotoBLAS2 (Survive fork)
Intel MKL (part of Microsoft R Open)
BLIS

Hosts:

No. CPU GPU
1. Intel Core i5-4590 NVIDIA GeForce GT 430
2. Intel Core i5-3570 -
3. Intel Core i3-2120 -
4. Intel Core i3-3120M -

Benchmarks: Urbanek, Revolution, Gcbd.

Results per host

Intel Core i5-4590 + NVIDIA GeForce GT 430

Urbanek benchmark

2800x2800 cross-product matrix

Time in seconds - 10 runs - lower is better

Linear regr. over a 3000x3000 matrix

Time in seconds - 10 runs - lower is better

Eigenvalues of a 640x640 random matrix

Time in seconds - 10 runs - lower is better

Determinant of a 2500x2500 random matrix

Time in seconds - 10 runs - lower is better

Cholesky decomposition of a 3000x3000 matrix

Time in seconds - 10 runs - lower is better

Inverse of a 1600x1600 random matrix

Time in seconds - 10 runs - lower is better

Escoufier's method on a 45x45 matrix

Time in seconds - 10 runs - lower is better

Revolution benchmark

Matrix Multiply

Time in seconds - 10 runs - lower is better

Cholesky Factorization

Time in seconds - 10 runs - lower is better

Singular Value Deomposition

Time in seconds - 10 runs - lower is better

Principal Components Analysis

Time in seconds - 10 runs - lower is better

Linear Discriminant Analysis

Time in seconds - 10 runs - lower is better

Gcbd benchmark

Matrix Multiply

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

QR Decomposition

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

Singular Value Deomposition

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

Triangular Decomposition

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

Intel Core i5-3570

Urbanek benchmark

2800x2800 cross-product matrix

Time in seconds - 10 runs - lower is better

Linear regr. over a 3000x3000 matrix

Time in seconds - 10 runs - lower is better

Eigenvalues of a 640x640 random matrix

Time in seconds - 10 runs - lower is better

Determinant of a 2500x2500 random matrix

Time in seconds - 10 runs - lower is better

Cholesky decomposition of a 3000x3000 matrix

Time in seconds - 10 runs - lower is better

Inverse of a 1600x1600 random matrix

Time in seconds - 10 runs - lower is better

Escoufier's method on a 45x45 matrix

Time in seconds - 10 runs - lower is better

Revolution benchmark

Matrix Multiply

Time in seconds - 10 runs - lower is better

Cholesky Factorization

Time in seconds - 10 runs - lower is better

Singular Value Deomposition

Time in seconds - 10 runs - lower is better

Principal Components Analysis

Time in seconds - 10 runs - lower is better

Linear Discriminant Analysis

Time in seconds - 10 runs - lower is better

Gcbd benchmark

Matrix Multiply

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

QR Decomposition

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

Singular Value Deomposition

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

Triangular Decomposition

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

Intel Core i3-2120

Urbanek benchmark

2800x2800 cross-product matrix

Time in seconds - 10 runs - lower is better

Linear regr. over a 3000x3000 matrix

Time in seconds - 10 runs - lower is better

Eigenvalues of a 640x640 random matrix

Time in seconds - 10 runs - lower is better

Determinant of a 2500x2500 random matrix

Time in seconds - 10 runs - lower is better

Cholesky decomposition of a 3000x3000 matrix

Time in seconds - 10 runs - lower is better

Inverse of a 1600x1600 random matrix

Time in seconds - 10 runs - lower is better

Escoufier's method on a 45x45 matrix

Time in seconds - 10 runs - lower is better

Revolution benchmark

Matrix Multiply

Time in seconds - 10 runs - lower is better

Cholesky Factorization

Time in seconds - 10 runs - lower is better

Singular Value Deomposition

Time in seconds - 10 runs - lower is better

Principal Components Analysis

Time in seconds - 10 runs - lower is better

Linear Discriminant Analysis

Time in seconds - 10 runs - lower is better

Gcbd benchmark

Matrix Multiply

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

QR Decomposition

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

Singular Value Deomposition

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

Triangular Decomposition

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

Intel Core i3-3120M

Urbanek benchmark

2800x2800 cross-product matrix

Time in seconds - 10 runs - lower is better

Linear regr. over a 3000x3000 matrix

Time in seconds - 10 runs - lower is better

Eigenvalues of a 640x640 random matrix

Time in seconds - 10 runs - lower is better

Determinant of a 2500x2500 random matrix

Time in seconds - 10 runs - lower is better

Cholesky decomposition of a 3000x3000 matrix

Time in seconds - 10 runs - lower is better

Inverse of a 1600x1600 random matrix

Time in seconds - 10 runs - lower is better

Escoufier's method on a 45x45 matrix

Time in seconds - 10 runs - lower is better

Revolution benchmark

Matrix Multiply

Time in seconds - 10 runs - lower is better

Cholesky Factorization

Time in seconds - 10 runs - lower is better

Singular Value Deomposition

Time in seconds - 10 runs - lower is better

Principal Components Analysis

Time in seconds - 10 runs - lower is better

Linear Discriminant Analysis

Time in seconds - 10 runs - lower is better

Gcbd benchmark

Matrix Multiply

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

QR Decomposition

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

Singular Value Deomposition

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

Triangular Decomposition

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

Results per library

Netlib

Urbanek benchmark

2800x2800 cross-product matrix

Time in seconds - 10 runs - lower is better

Linear regr. over a 3000x3000 matrix

Time in seconds - 10 runs - lower is better

Eigenvalues of a 640x640 random matrix

Time in seconds - 10 runs - lower is better

Determinant of a 2500x2500 random matrix

Time in seconds - 10 runs - lower is better

Cholesky decomposition of a 3000x3000 matrix

Time in seconds - 10 runs - lower is better

Inverse of a 1600x1600 random matrix

Time in seconds - 10 runs - lower is better

Escoufier's method on a 45x45 matrix

Time in seconds - 10 runs - lower is better

Revolution benchmark

Matrix Multiply

Time in seconds - 10 runs - lower is better

Cholesky Factorization

Time in seconds - 10 runs - lower is better

Singular Value Deomposition

Time in seconds - 10 runs - lower is better

Principal Components Analysis

Time in seconds - 10 runs - lower is better

Linear Discriminant Analysis

Time in seconds - 10 runs - lower is better

Gcbd benchmark

Matrix Multiply

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

QR Decomposition

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

Singular Value Deomposition

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

Triangular Decomposition

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

ATLAS (st)

Urbanek benchmark

2800x2800 cross-product matrix

Time in seconds - 10 runs - lower is better

Linear regr. over a 3000x3000 matrix

Time in seconds - 10 runs - lower is better

Eigenvalues of a 640x640 random matrix

Time in seconds - 10 runs - lower is better

Determinant of a 2500x2500 random matrix

Time in seconds - 10 runs - lower is better

Cholesky decomposition of a 3000x3000 matrix

Time in seconds - 10 runs - lower is better

Inverse of a 1600x1600 random matrix

Time in seconds - 10 runs - lower is better

Escoufier's method on a 45x45 matrix

Time in seconds - 10 runs - lower is better

Revolution benchmark

Matrix Multiply

Time in seconds - 10 runs - lower is better

Cholesky Factorization

Time in seconds - 10 runs - lower is better

Singular Value Deomposition

Time in seconds - 10 runs - lower is better

Principal Components Analysis

Time in seconds - 10 runs - lower is better

Linear Discriminant Analysis

Time in seconds - 10 runs - lower is better

Gcbd benchmark

Matrix Multiply

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

QR Decomposition

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

Singular Value Deomposition

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

Triangular Decomposition

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

OpenBLAS

Urbanek benchmark

2800x2800 cross-product matrix

Time in seconds - 10 runs - lower is better

Linear regr. over a 3000x3000 matrix

Time in seconds - 10 runs - lower is better

Eigenvalues of a 640x640 random matrix

Time in seconds - 10 runs - lower is better

Determinant of a 2500x2500 random matrix

Time in seconds - 10 runs - lower is better

Cholesky decomposition of a 3000x3000 matrix

Time in seconds - 10 runs - lower is better

Inverse of a 1600x1600 random matrix

Time in seconds - 10 runs - lower is better

Escoufier's method on a 45x45 matrix

Time in seconds - 10 runs - lower is better

Revolution benchmark

Matrix Multiply

Time in seconds - 10 runs - lower is better

Cholesky Factorization

Time in seconds - 10 runs - lower is better

Singular Value Deomposition

Time in seconds - 10 runs - lower is better

Principal Components Analysis

Time in seconds - 10 runs - lower is better

Linear Discriminant Analysis

Time in seconds - 10 runs - lower is better

Gcbd benchmark

Matrix Multiply

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

QR Decomposition

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

Singular Value Deomposition

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

Triangular Decomposition

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

ATLAS (mt)

Urbanek benchmark

2800x2800 cross-product matrix

Time in seconds - 10 runs - lower is better

Linear regr. over a 3000x3000 matrix

Time in seconds - 10 runs - lower is better

Eigenvalues of a 640x640 random matrix

Time in seconds - 10 runs - lower is better

Determinant of a 2500x2500 random matrix

Time in seconds - 10 runs - lower is better

Cholesky decomposition of a 3000x3000 matrix

Time in seconds - 10 runs - lower is better

Inverse of a 1600x1600 random matrix

Time in seconds - 10 runs - lower is better

Escoufier's method on a 45x45 matrix

Time in seconds - 10 runs - lower is better

Revolution benchmark

Matrix Multiply

Time in seconds - 10 runs - lower is better

Cholesky Factorization

Time in seconds - 10 runs - lower is better

Singular Value Deomposition

Time in seconds - 10 runs - lower is better

Principal Components Analysis

Time in seconds - 10 runs - lower is better

Linear Discriminant Analysis

Time in seconds - 10 runs - lower is better

Gcbd benchmark

Matrix Multiply

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

QR Decomposition

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

Singular Value Deomposition

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

Triangular Decomposition

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

GotoBLAS2

Urbanek benchmark

2800x2800 cross-product matrix

Time in seconds - 10 runs - lower is better

Linear regr. over a 3000x3000 matrix

Time in seconds - 10 runs - lower is better

Eigenvalues of a 640x640 random matrix

Time in seconds - 10 runs - lower is better

Determinant of a 2500x2500 random matrix

Time in seconds - 10 runs - lower is better

Cholesky decomposition of a 3000x3000 matrix

Time in seconds - 10 runs - lower is better

Inverse of a 1600x1600 random matrix

Time in seconds - 10 runs - lower is better

Escoufier's method on a 45x45 matrix

Time in seconds - 10 runs - lower is better

Revolution benchmark

Matrix Multiply

Time in seconds - 10 runs - lower is better

Cholesky Factorization

Time in seconds - 10 runs - lower is better

Singular Value Deomposition

Time in seconds - 10 runs - lower is better

Principal Components Analysis

Time in seconds - 10 runs - lower is better

Linear Discriminant Analysis

Time in seconds - 10 runs - lower is better

Gcbd benchmark

Matrix Multiply

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

QR Decomposition

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

Singular Value Deomposition

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

Triangular Decomposition

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

MKL

Urbanek benchmark

2800x2800 cross-product matrix

Time in seconds - 10 runs - lower is better

Linear regr. over a 3000x3000 matrix

Time in seconds - 10 runs - lower is better

Eigenvalues of a 640x640 random matrix

Time in seconds - 10 runs - lower is better

Determinant of a 2500x2500 random matrix

Time in seconds - 10 runs - lower is better

Cholesky decomposition of a 3000x3000 matrix

Time in seconds - 10 runs - lower is better

Inverse of a 1600x1600 random matrix

Time in seconds - 10 runs - lower is better

Escoufier's method on a 45x45 matrix

Time in seconds - 10 runs - lower is better

Revolution benchmark

Matrix Multiply

Time in seconds - 10 runs - lower is better

Cholesky Factorization

Time in seconds - 10 runs - lower is better

Singular Value Deomposition

Time in seconds - 10 runs - lower is better

Principal Components Analysis

Time in seconds - 10 runs - lower is better

Linear Discriminant Analysis

Time in seconds - 10 runs - lower is better

Gcbd benchmark

Matrix Multiply

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

QR Decomposition

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

Singular Value Deomposition

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

Triangular Decomposition

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

BLIS

Urbanek benchmark

2800x2800 cross-product matrix

Time in seconds - 10 runs - lower is better

Linear regr. over a 3000x3000 matrix

Time in seconds - 10 runs - lower is better

Eigenvalues of a 640x640 random matrix

Time in seconds - 10 runs - lower is better

Determinant of a 2500x2500 random matrix

Time in seconds - 10 runs - lower is better

Cholesky decomposition of a 3000x3000 matrix

Time in seconds - 10 runs - lower is better

Inverse of a 1600x1600 random matrix

Time in seconds - 10 runs - lower is better

Escoufier's method on a 45x45 matrix

Time in seconds - 10 runs - lower is better

Revolution benchmark

Matrix Multiply

Time in seconds - 10 runs - lower is better

Cholesky Factorization

Time in seconds - 10 runs - lower is better

Singular Value Deomposition

Time in seconds - 10 runs - lower is better

Principal Components Analysis

Time in seconds - 10 runs - lower is better

Linear Discriminant Analysis

Time in seconds - 10 runs - lower is better

Gcbd benchmark

Matrix Multiply

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

QR Decomposition

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

Singular Value Deomposition

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

Triangular Decomposition

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

cuBLAS

Urbanek benchmark

2800x2800 cross-product matrix

Time in seconds - 10 runs - lower is better

Linear regr. over a 3000x3000 matrix

Time in seconds - 10 runs - lower is better

Eigenvalues of a 640x640 random matrix

Time in seconds - 10 runs - lower is better

Determinant of a 2500x2500 random matrix

Time in seconds - 10 runs - lower is better

Cholesky decomposition of a 3000x3000 matrix

Time in seconds - 10 runs - lower is better

Inverse of a 1600x1600 random matrix

Time in seconds - 10 runs - lower is better

Escoufier's method on a 45x45 matrix

Time in seconds - 10 runs - lower is better

Revolution benchmark

Matrix Multiply

Time in seconds - 10 runs - lower is better

Cholesky Factorization

Time in seconds - 10 runs - lower is better

Singular Value Deomposition

Time in seconds - 10 runs - lower is better

Principal Components Analysis

Time in seconds - 10 runs - lower is better

Linear Discriminant Analysis

Time in seconds - 10 runs - lower is better

Gcbd benchmark

Matrix Multiply

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

QR Decomposition

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

Singular Value Deomposition

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better

Triangular Decomposition

Time in seconds regarding matrix size - right panel on log scale - from 50 to 5 runs - lower is better