Skip to content

Commit

Permalink
More fusion across slices.
Browse files Browse the repository at this point in the history
  • Loading branch information
athas committed Dec 21, 2023
1 parent 6993123 commit 2b54144
Show file tree
Hide file tree
Showing 5 changed files with 18 additions and 18 deletions.
2 changes: 2 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,8 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0.
used in all public interfaces. The OpenCL names are still supported
for backwards compatibility.

* More fusion across array slicing.

### Removed

### Changed
Expand Down
24 changes: 10 additions & 14 deletions src/Futhark/IR/SOACS/SOAC.hs
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,6 @@ module Futhark.IR.SOACS.SOAC
isScanSOAC,
isReduceSOAC,
isMapSOAC,
scremaLambda,
ppScrema,
ppHist,
ppStream,
Expand Down Expand Up @@ -143,11 +142,16 @@ data HistOp rep = HistOp

-- | The essential parts of a 'Screma' factored out (everything
-- except the input arrays).
data ScremaForm rep
= ScremaForm
[Scan rep]
[Reduce rep]
(Lambda rep)
data ScremaForm rep = ScremaForm
{ scremaScans :: [Scan rep],
scremaReduces :: [Reduce rep],
-- | The "main" lambda of the Screma. For a map, this is
-- equivalent to 'isMapSOAC'. Note that the meaning of the return
-- value of this lambda depends crucially on exactly which Screma
-- this is. The parameters will correspond exactly to elements of
-- the input arrays, however.
scremaLambda :: Lambda rep
}
deriving (Eq, Ord, Show)

singleBinOp :: (Buildable rep) => [Lambda rep] -> Lambda rep
Expand Down Expand Up @@ -316,14 +320,6 @@ isMapSOAC (ScremaForm scans reds map_lam) = do
guard $ null reds
pure map_lam

-- | Return the "main" lambda of the Screma. For a map, this is
-- equivalent to 'isMapSOAC'. Note that the meaning of the return
-- value of this lambda depends crucially on exactly which Screma this
-- is. The parameters will correspond exactly to elements of the
-- input arrays, however.
scremaLambda :: ScremaForm rep -> Lambda rep
scremaLambda (ScremaForm _ _ map_lam) = map_lam

-- | @groupScatterResults <output specification> <results>@
--
-- Blocks the index values and result values of <results> according to the
Expand Down
3 changes: 1 addition & 2 deletions src/Futhark/Optimise/Fusion.hs
Original file line number Diff line number Diff line change
Expand Up @@ -279,10 +279,9 @@ vFuseNodeT
vFuseNodeT
_
infusible
(SoacNode ots1 pat1 (H.Screma w form inps) aux1, _, _)
(SoacNode ots1 pat1 (H.Screma _ form inps) aux1, _, _)
(TransNode stm2_out (H.Index cs slice@(Slice (ds@(DimSlice _ w' _) : ds_rest))) _, _)
| null infusible,
w /= w',
ots1 == mempty,
Just _ <- isMapSOAC form,
[pe] <- patElems pat1 = do
Expand Down
3 changes: 1 addition & 2 deletions src/Futhark/Optimise/Fusion/TryFusion.hs
Original file line number Diff line number Diff line change
Expand Up @@ -673,11 +673,10 @@ pullIndex ::
SOAC ->
SOAC.ArrayTransforms ->
TryFusion (SOAC, SOAC.ArrayTransforms)
pullIndex (SOAC.Screma w form inps) ots
pullIndex (SOAC.Screma _ form inps) ots
| SOAC.Index cs slice@(Slice (ds@(DimSlice _ w' _) : inner_ds))
SOAC.:< ots' <-
SOAC.viewf ots,
w /= w',
Just lam <- isMapSOAC form = do
let sliceInput inp =
SOAC.addTransform
Expand Down
4 changes: 4 additions & 0 deletions tests/fusion/slicemap4.fut
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
-- ==
-- structure { Screma 1 }

def main (xs: []i32) = xs |> map (+2) |> reverse |> map (*3)

0 comments on commit 2b54144

Please sign in to comment.