-
Notifications
You must be signed in to change notification settings - Fork 120
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
WIP: SIMD and other goodies #534
Draft
tmcdonell
wants to merge
89
commits into
AccelerateHS:master
Choose a base branch
from
tmcdonell:wip/type-hierarchy
base: master
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
Draft
Conversation
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
…/accelerate into wip/vector-operations # Conflicts: # src/Data/Array/Accelerate/Trafo/Algebra.hs
Previously we could represent SIMD types (e.g. for complex numbers) but calculations directly in this representation were not possible. User defined (sum and product) types can also be stored in SIMD format through the (generic derivable) SIMD class. Nested SIMD types are not supported. New type classes VOrd and VEq which provide operations from Eq and Ord that compute their result per-lane. Types of member functions of several (otherwise standard H98) classes are changed in order to support SIMD types, in particular Bits.
[ 99 of 112] Compiling Data.Array.Accelerate.Lift ghc: panic! (the 'impossible' happened) (GHC version 8.6.5 for x86_64-unknown-linux): expectJust mkOneConFull CallStack (from HasCallStack): error, called at compiler/utils/Maybes.hs:55:27 in ghc:Maybes expectJust, called at compiler/deSugar/Check.hs:1312:37 in ghc:Check
This should now match the behaviour of the tuple instances
# Conflicts: # .github/workflows/ci-linux.yml # accelerate.cabal # src/Data/Array/Accelerate/AST/Idx.hs # src/Data/Array/Accelerate/Array/Data.hs # src/Data/Array/Accelerate/Classes/RealFrac.hs # src/Data/Array/Accelerate/Classes/RealFrac.hs-boot # src/Data/Array/Accelerate/Data/Complex.hs # src/Data/Array/Accelerate/Language.hs # src/Data/Array/Accelerate/Prelude.hs # src/Data/Array/Accelerate/Sugar/Vec.hs # stack-8.10.yaml # stack-9.2.yaml # stack.yaml
ghc-iserv: munmapForLinker: m32_release_page: Failed to unmap 4096 bytes at ...: Attempt to access invalid address.
- VNum class for horizontal sum/product of a vector - vminimum/vmaximum for horizontal vector min/max reduction - bitreverse - byteswap
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Motivation and context
A while ago @HugoPeters1024 asked something along the lines of "how do I make a SIMD vector of this data type". The answer was "you can't", and so he made a workaround instead that didn't require it.
This patch fixes that infelicity. Now you can:
and then:
will create a 2-wide SIMD-vector-like thing, where internally the usual struct-of-array type of thing is happening to store the ints and floats in their own vector registers.
Of course, just being able to represent SIMD vector data in the language isn't enough, you need to be able to compute with that data as well. Now you can write something like this SIMD-vectorised Mandelbrot computation (adapted from here), where the SIMD width is altered by changing the type:
Description
Since we are making fundamental changes to the internal representation of types, we might as well tick off a bunch of TODOs at the same time. Here is a rough list of changes in this patch, but this has been in progress for a while so I've probably forgotten some stuff.
Int
andWord
nonsense; that gets stripped out at the surface level now-ffloat128
since that needs thequadmath
library installed (gcc/linux x86_64 will have it, other platforms may or may not).bfloat16
or 8-bit floats (which one?) but I'll leave that for nowVEq
,VOrd
,VNum
Ord
instance will do it in the same way as ordering on tuples, whereasVOrd
will do it lane-wise. Similarly,min
will do the tuple-style minimum whereasvmin
will do it lane-wise andvminimum
will give you the minimum element in that vector (i.e. horizontal reduction across the vector) etc. etc.pack
,unpack
,insert
,extract
)FromBool
to convert Bools to and from integral typesVector Float
andVector (Vec 2 Float)
, orVector Bool
(bit vector) andVector Word64
, etc. Works for structured types (pairs, etc.) as well.V2
to construct a 2-wide SIMD vector at both the Haskell value level as well as the Accelerate expression level. I find it useful, but otoh it does hide a bit what is going on, so the type errors can be worse (as usual).There are still TODOs in the code and to an extent the design depends on what code we can eventually generate from it (in progress), but I'm just throwing this up for now to start getting eyes on it.
How has this been tested?
>_>
Types of changes
Checklist