# GiMMiK **Repository Path**: avicari/GiMMiK ## Basic Information - **Project Name**: GiMMiK - **Description**: No description available - **Primary Language**: Unknown - **License**: BSD-3-Clause - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 0 - **Created**: 2020-05-31 - **Last Updated**: 2020-12-19 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README GiMMiK ====== Generator of Matrix Multiplication Kernels - GiMMiK - is a tool for generation of high performance matrix multiplication kernel code for various accelerator platforms. Currently CUDA and OpenCL are the only supported platforms. What does GiMMiK do? -------------------- Consider matrix multiplication of the form C = α ∙ A ⨉ B + β ∙ C GiMMiK generates fully unrolled kernels, highly specialised to a given operator matrix. The generated code is fully unrolled - each kernel computes a single column of the output matrix. GiMMiK was designed to perform well in a Block by Panel type of matrix multiplication where the operator matrix is small. GiMMiK also removes any sparsity form the operator matrix as well as attempts to reduce common sub-expressions. How do I install GiMMiK? ------------------------ Clone the git repository and use `setup.py` to install the GiMMiK package. You will need the following dependencies: * `mako `_ * `numpy >= 1.7 `_ Once obtained, you can install GiMMiK by running :: python setup.py install to perform a system-wide install. Alternatively, run :: python setup.py install --user to install the package locally. How do I use GiMMiK? -------------------- Once installed, you are ready to use GiMMiK. .. code:: python from gimmik import generate_mm ... # Generate a CUDA kernel for C = 2*mat*B src = generate_mm(mat, np.float32, platform='cuda', alpha=2.0, beta=0.0) ... Who uses GiMMiK? ---------------- GiMMiK was develop to improve performance of the `PyFR `_ framework.