The primitive-simd package

[Tags:benchmark, bsd3, library]

This package provides a lifted version of the SIMD data types and instructions from ghc-prim.

The implementation is based on type families to provide a uniform interface to all different vector types. Instances for numeric operations, Prim, Storable and unboxed vector instances are provided.

Although not all processors support 256 or 512-bit vectors this package provides a uniform interface. Vectors which are bigger than supported are modeled by combining smaller vectors. If the same code is compiled on a computer supporting larger vectors the smaller vectors are replaced by larger vectors.

Note: This package needs to be compiled with LLVM as the NCG does not know how to deal with SIMD-instructions. If LLVM is not available, use -f no-vec to disable the use of SIMD instructions. While this will give you no speedup, it will work with plain Haskell (and should even work with GHCJS).


Dependencies base (>=4.7 && <5), ghc-prim (>=0.3.1), primitive (>=0.5), vector (>=0.10) [details]
License BSD3
Copyright (c) 2015 Anselm Jonas Scholl
Author Anselm Jonas Scholl
Category Data
Source repository head: git clone git://
Uploaded Mon Feb 1 22:37:38 UTC 2016 by JonasScholl
Distributions NixOS:
Downloads 88 total (4 in the last 30 days)
0 []
Status Docs uploaded by user
Build status unknown [no reports yet]
Hackage Matrix CI




no-vecDisable all vector hardware instructions. Your code will run on all hardware but also be a lot slower.DisabledManual
vec256Enable 256-bit vector hardware instructions. Your code will only run if your CPU supports 256-bit vector instructions.DisabledManual
vec512Enable 512-bit vector hardware instructions. Your code will only run if your CPU supports 512-bit vector instructions.DisabledManual

Use -f <flag> to enable a flag, or -f -<flag> to disable that flag. More info


Maintainer's Corner

For package maintainers and hackage trustees