{-# LANGUAGE BangPatterns #-}
{-# LANGUAGE FlexibleContexts #-}
{-# LANGUAGE MultiParamTypeClasses #-}
{-# LANGUAGE ScopedTypeVariables #-}
{-# LANGUAGE TypeFamilies #-}
{-# LANGUAGE UndecidableInstances #-}
module Data.Massiv.Array.Ops.Fold.Internal (
foldlS,
foldrS,
ifoldlS,
ifoldrS,
foldlM,
foldrM,
foldlM_,
foldrM_,
ifoldlM,
ifoldrM,
ifoldlM_,
ifoldrM_,
fold,
foldMono,
foldlInternal,
ifoldlInternal,
foldrFB,
lazyFoldlS,
lazyFoldrS,
foldlP,
foldrP,
ifoldlP,
ifoldrP,
foldlIO,
ifoldlIO,
ifoldrIO,
splitReduce,
any,
anySu,
anyPu,
) where
import Control.Monad (void, when)
import Control.Monad.Primitive
import Control.Scheduler
import qualified Data.Foldable as F
import Data.Functor.Identity (runIdentity)
import Data.Massiv.Core.Common
import System.IO.Unsafe (unsafePerformIO)
import Prelude hiding (any, foldl, foldr)
fold
:: (Monoid e, Index ix, Source r e)
=> Array r ix e
-> e
fold :: forall e ix r.
(Monoid e, Index ix, Source r e) =>
Array r ix e -> e
fold = (e -> e -> e) -> e -> (e -> e -> e) -> e -> Array r ix e -> e
forall ix r e a b.
(Index ix, Source r e) =>
(a -> e -> a) -> a -> (b -> a -> b) -> b -> Array r ix e -> b
foldlInternal e -> e -> e
forall a. Monoid a => a -> a -> a
mappend e
forall a. Monoid a => a
mempty e -> e -> e
forall a. Monoid a => a -> a -> a
mappend e
forall a. Monoid a => a
mempty
{-# INLINE fold #-}
foldMono
:: (Index ix, Source r e, Monoid m)
=> (e -> m)
-> Array r ix e
-> m
foldMono :: forall ix r e m.
(Index ix, Source r e, Monoid m) =>
(e -> m) -> Array r ix e -> m
foldMono e -> m
f = (m -> e -> m) -> m -> (m -> m -> m) -> m -> Array r ix e -> m
forall ix r e a b.
(Index ix, Source r e) =>
(a -> e -> a) -> a -> (b -> a -> b) -> b -> Array r ix e -> b
foldlInternal (\m
a e
e -> m
a m -> m -> m
forall a. Monoid a => a -> a -> a
`mappend` e -> m
f e
e) m
forall a. Monoid a => a
mempty m -> m -> m
forall a. Monoid a => a -> a -> a
mappend m
forall a. Monoid a => a
mempty
{-# INLINE foldMono #-}
foldlM :: (Index ix, Source r e, Monad m) => (a -> e -> m a) -> a -> Array r ix e -> m a
foldlM :: forall ix r e (m :: * -> *) a.
(Index ix, Source r e, Monad m) =>
(a -> e -> m a) -> a -> Array r ix e -> m a
foldlM a -> e -> m a
f a
acc Array r ix e
arr =
case Array r ix e -> PrefIndex ix e
forall ix. Index ix => Array r ix e -> PrefIndex ix e
forall r e ix.
(Source r e, Index ix) =>
Array r ix e -> PrefIndex ix e
unsafePrefIndex Array r ix e
arr of
PrefIndex ix -> e
gix ->
ix
-> ix -> ix -> (Int -> Int -> Bool) -> a -> (ix -> a -> m a) -> m a
forall ix (m :: * -> *) a.
(Index ix, Monad m) =>
ix
-> ix -> ix -> (Int -> Int -> Bool) -> a -> (ix -> a -> m a) -> m a
forall (m :: * -> *) a.
Monad m =>
ix
-> ix -> ix -> (Int -> Int -> Bool) -> a -> (ix -> a -> m a) -> m a
iterM ix
forall ix. Index ix => ix
zeroIndex (Sz ix -> ix
forall ix. Sz ix -> ix
unSz Sz ix
sz) (Int -> ix
forall ix. Index ix => Int -> ix
pureIndex Int
1) Int -> Int -> Bool
forall a. Ord a => a -> a -> Bool
(<) a
acc ((ix -> a -> m a) -> m a) -> (ix -> a -> m a) -> m a
forall a b. (a -> b) -> a -> b
$ \ !ix
ix !a
a -> a -> e -> m a
f a
a (ix -> e
gix ix
ix)
PrefIndexLinear Int -> e
gi ->
Int
-> (Int -> Bool) -> (Int -> Int) -> a -> (Int -> a -> m a) -> m a
forall (m :: * -> *) a.
Monad m =>
Int
-> (Int -> Bool) -> (Int -> Int) -> a -> (Int -> a -> m a) -> m a
loopM Int
0 (Int -> Int -> Bool
forall a. Ord a => a -> a -> Bool
< Sz ix -> Int
forall ix. Index ix => Sz ix -> Int
totalElem Sz ix
sz) (Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Int
1) a
acc ((Int -> a -> m a) -> m a) -> (Int -> a -> m a) -> m a
forall a b. (a -> b) -> a -> b
$ \ !Int
i !a
a -> a -> e -> m a
f a
a (Int -> e
gi Int
i)
where
sz :: Sz ix
sz = Array r ix e -> Sz ix
forall r ix e. Size r => Array r ix e -> Sz ix
forall ix e. Array r ix e -> Sz ix
size Array r ix e
arr
{-# INLINE foldlM #-}
foldlM_ :: (Index ix, Source r e, Monad m) => (a -> e -> m a) -> a -> Array r ix e -> m ()
foldlM_ :: forall ix r e (m :: * -> *) a.
(Index ix, Source r e, Monad m) =>
(a -> e -> m a) -> a -> Array r ix e -> m ()
foldlM_ a -> e -> m a
f a
acc = m a -> m ()
forall (f :: * -> *) a. Functor f => f a -> f ()
void (m a -> m ()) -> (Array r ix e -> m a) -> Array r ix e -> m ()
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (a -> e -> m a) -> a -> Array r ix e -> m a
forall ix r e (m :: * -> *) a.
(Index ix, Source r e, Monad m) =>
(a -> e -> m a) -> a -> Array r ix e -> m a
foldlM a -> e -> m a
f a
acc
{-# INLINE foldlM_ #-}
ifoldlM :: (Index ix, Source r e, Monad m) => (a -> ix -> e -> m a) -> a -> Array r ix e -> m a
ifoldlM :: forall ix r e (m :: * -> *) a.
(Index ix, Source r e, Monad m) =>
(a -> ix -> e -> m a) -> a -> Array r ix e -> m a
ifoldlM a -> ix -> e -> m a
f !a
acc !Array r ix e
arr =
case Array r ix e -> PrefIndex ix e
forall ix. Index ix => Array r ix e -> PrefIndex ix e
forall r e ix.
(Source r e, Index ix) =>
Array r ix e -> PrefIndex ix e
unsafePrefIndex Array r ix e
arr of
PrefIndex ix -> e
gix ->
ix
-> ix -> ix -> (Int -> Int -> Bool) -> a -> (ix -> a -> m a) -> m a
forall ix (m :: * -> *) a.
(Index ix, Monad m) =>
ix
-> ix -> ix -> (Int -> Int -> Bool) -> a -> (ix -> a -> m a) -> m a
forall (m :: * -> *) a.
Monad m =>
ix
-> ix -> ix -> (Int -> Int -> Bool) -> a -> (ix -> a -> m a) -> m a
iterM ix
forall ix. Index ix => ix
zeroIndex (Sz ix -> ix
forall ix. Sz ix -> ix
unSz (Array r ix e -> Sz ix
forall r ix e. Size r => Array r ix e -> Sz ix
forall ix e. Array r ix e -> Sz ix
size Array r ix e
arr)) (Int -> ix
forall ix. Index ix => Int -> ix
pureIndex Int
1) Int -> Int -> Bool
forall a. Ord a => a -> a -> Bool
(<) a
acc ((ix -> a -> m a) -> m a) -> (ix -> a -> m a) -> m a
forall a b. (a -> b) -> a -> b
$ \ !ix
ix !a
a -> a -> ix -> e -> m a
f a
a ix
ix (ix -> e
gix ix
ix)
PrefIndexLinear Int -> e
gi ->
RowMajor
-> Int
-> Sz ix
-> ix
-> Stride ix
-> a
-> (Int -> ix -> a -> m a)
-> m a
forall it ix (m :: * -> *) a.
(Iterator it, Index ix, Monad m) =>
it
-> Int
-> Sz ix
-> ix
-> Stride ix
-> a
-> (Int -> ix -> a -> m a)
-> m a
forall ix (m :: * -> *) a.
(Index ix, Monad m) =>
RowMajor
-> Int
-> Sz ix
-> ix
-> Stride ix
-> a
-> (Int -> ix -> a -> m a)
-> m a
iterTargetM RowMajor
defRowMajor Int
0 (Array r ix e -> Sz ix
forall r ix e. Size r => Array r ix e -> Sz ix
forall ix e. Array r ix e -> Sz ix
size Array r ix e
arr) ix
forall ix. Index ix => ix
zeroIndex Stride ix
forall ix. Index ix => Stride ix
oneStride a
acc ((Int -> ix -> a -> m a) -> m a) -> (Int -> ix -> a -> m a) -> m a
forall a b. (a -> b) -> a -> b
$ \Int
i ix
ix !a
a -> a -> ix -> e -> m a
f a
a ix
ix (Int -> e
gi Int
i)
{-# INLINE ifoldlM #-}
ifoldlM_ :: (Index ix, Source r e, Monad m) => (a -> ix -> e -> m a) -> a -> Array r ix e -> m ()
ifoldlM_ :: forall ix r e (m :: * -> *) a.
(Index ix, Source r e, Monad m) =>
(a -> ix -> e -> m a) -> a -> Array r ix e -> m ()
ifoldlM_ a -> ix -> e -> m a
f a
acc = m a -> m ()
forall (f :: * -> *) a. Functor f => f a -> f ()
void (m a -> m ()) -> (Array r ix e -> m a) -> Array r ix e -> m ()
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (a -> ix -> e -> m a) -> a -> Array r ix e -> m a
forall ix r e (m :: * -> *) a.
(Index ix, Source r e, Monad m) =>
(a -> ix -> e -> m a) -> a -> Array r ix e -> m a
ifoldlM a -> ix -> e -> m a
f a
acc
{-# INLINE ifoldlM_ #-}
foldrM :: (Index ix, Source r e, Monad m) => (e -> a -> m a) -> a -> Array r ix e -> m a
foldrM :: forall ix r e (m :: * -> *) a.
(Index ix, Source r e, Monad m) =>
(e -> a -> m a) -> a -> Array r ix e -> m a
foldrM e -> a -> m a
f a
acc Array r ix e
arr =
case Array r ix e -> PrefIndex ix e
forall ix. Index ix => Array r ix e -> PrefIndex ix e
forall r e ix.
(Source r e, Index ix) =>
Array r ix e -> PrefIndex ix e
unsafePrefIndex Array r ix e
arr of
PrefIndex ix -> e
gix ->
ix
-> ix -> ix -> (Int -> Int -> Bool) -> a -> (ix -> a -> m a) -> m a
forall ix (m :: * -> *) a.
(Index ix, Monad m) =>
ix
-> ix -> ix -> (Int -> Int -> Bool) -> a -> (ix -> a -> m a) -> m a
forall (m :: * -> *) a.
Monad m =>
ix
-> ix -> ix -> (Int -> Int -> Bool) -> a -> (ix -> a -> m a) -> m a
iterM ((Int -> Int) -> ix -> ix
forall ix. Index ix => (Int -> Int) -> ix -> ix
liftIndex (Int -> Int -> Int
forall a. Num a => a -> a -> a
subtract Int
1) (Sz ix -> ix
forall ix. Sz ix -> ix
unSz Sz ix
sz)) ix
forall ix. Index ix => ix
zeroIndex (Int -> ix
forall ix. Index ix => Int -> ix
pureIndex (-Int
1)) Int -> Int -> Bool
forall a. Ord a => a -> a -> Bool
(>=) a
acc (e -> a -> m a
f (e -> a -> m a) -> (ix -> e) -> ix -> a -> m a
forall b c a. (b -> c) -> (a -> b) -> a -> c
. ix -> e
gix)
PrefIndexLinear Int -> e
gi ->
Int
-> (Int -> Bool) -> (Int -> Int) -> a -> (Int -> a -> m a) -> m a
forall (m :: * -> *) a.
Monad m =>
Int
-> (Int -> Bool) -> (Int -> Int) -> a -> (Int -> a -> m a) -> m a
loopM (Sz ix -> Int
forall ix. Index ix => Sz ix -> Int
totalElem Sz ix
sz Int -> Int -> Int
forall a. Num a => a -> a -> a
- Int
1) (Int -> Int -> Bool
forall a. Ord a => a -> a -> Bool
>= Int
0) (Int -> Int -> Int
forall a. Num a => a -> a -> a
subtract Int
1) a
acc (e -> a -> m a
f (e -> a -> m a) -> (Int -> e) -> Int -> a -> m a
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Int -> e
gi)
where
!sz :: Sz ix
sz = Array r ix e -> Sz ix
forall r ix e. Size r => Array r ix e -> Sz ix
forall ix e. Array r ix e -> Sz ix
size Array r ix e
arr
{-# INLINE foldrM #-}
foldrM_ :: (Index ix, Source r e, Monad m) => (e -> a -> m a) -> a -> Array r ix e -> m ()
foldrM_ :: forall ix r e (m :: * -> *) a.
(Index ix, Source r e, Monad m) =>
(e -> a -> m a) -> a -> Array r ix e -> m ()
foldrM_ e -> a -> m a
f = (ix -> e -> a -> m a) -> a -> Array r ix e -> m ()
forall ix r e (m :: * -> *) a.
(Index ix, Source r e, Monad m) =>
(ix -> e -> a -> m a) -> a -> Array r ix e -> m ()
ifoldrM_ (\ix
_ e
e a
a -> e -> a -> m a
f e
e a
a)
{-# INLINE foldrM_ #-}
ifoldrM :: (Index ix, Source r e, Monad m) => (ix -> e -> a -> m a) -> a -> Array r ix e -> m a
ifoldrM :: forall ix r e (m :: * -> *) a.
(Index ix, Source r e, Monad m) =>
(ix -> e -> a -> m a) -> a -> Array r ix e -> m a
ifoldrM ix -> e -> a -> m a
f !a
acc !Array r ix e
arr =
ix
-> ix -> ix -> (Int -> Int -> Bool) -> a -> (ix -> a -> m a) -> m a
forall ix (m :: * -> *) a.
(Index ix, Monad m) =>
ix
-> ix -> ix -> (Int -> Int -> Bool) -> a -> (ix -> a -> m a) -> m a
forall (m :: * -> *) a.
Monad m =>
ix
-> ix -> ix -> (Int -> Int -> Bool) -> a -> (ix -> a -> m a) -> m a
iterM ((Int -> Int) -> ix -> ix
forall ix. Index ix => (Int -> Int) -> ix -> ix
liftIndex (Int -> Int -> Int
forall a. Num a => a -> a -> a
subtract Int
1) (Sz ix -> ix
forall ix. Sz ix -> ix
unSz (Array r ix e -> Sz ix
forall r ix e. Size r => Array r ix e -> Sz ix
forall ix e. Array r ix e -> Sz ix
size Array r ix e
arr))) ix
forall ix. Index ix => ix
zeroIndex (Int -> ix
forall ix. Index ix => Int -> ix
pureIndex (-Int
1)) Int -> Int -> Bool
forall a. Ord a => a -> a -> Bool
(>=) a
acc ((ix -> a -> m a) -> m a) -> (ix -> a -> m a) -> m a
forall a b. (a -> b) -> a -> b
$ \ !ix
ix ->
ix -> e -> a -> m a
f ix
ix (Array r ix e -> ix -> e
forall ix. Index ix => Array r ix e -> ix -> e
forall r e ix. (Source r e, Index ix) => Array r ix e -> ix -> e
unsafeIndex Array r ix e
arr ix
ix)
{-# INLINE ifoldrM #-}
ifoldrM_ :: (Index ix, Source r e, Monad m) => (ix -> e -> a -> m a) -> a -> Array r ix e -> m ()
ifoldrM_ :: forall ix r e (m :: * -> *) a.
(Index ix, Source r e, Monad m) =>
(ix -> e -> a -> m a) -> a -> Array r ix e -> m ()
ifoldrM_ ix -> e -> a -> m a
f !a
acc !Array r ix e
arr = m a -> m ()
forall (f :: * -> *) a. Functor f => f a -> f ()
void (m a -> m ()) -> m a -> m ()
forall a b. (a -> b) -> a -> b
$ (ix -> e -> a -> m a) -> a -> Array r ix e -> m a
forall ix r e (m :: * -> *) a.
(Index ix, Source r e, Monad m) =>
(ix -> e -> a -> m a) -> a -> Array r ix e -> m a
ifoldrM ix -> e -> a -> m a
f a
acc Array r ix e
arr
{-# INLINE ifoldrM_ #-}
lazyFoldlS :: (Index ix, Source r e) => (a -> e -> a) -> a -> Array r ix e -> a
lazyFoldlS :: forall ix r e a.
(Index ix, Source r e) =>
(a -> e -> a) -> a -> Array r ix e -> a
lazyFoldlS a -> e -> a
f a
initAcc Array r ix e
arr = a -> Int -> a
go a
initAcc Int
0
where
len :: Int
len = Sz ix -> Int
forall ix. Index ix => Sz ix -> Int
totalElem (Array r ix e -> Sz ix
forall r ix e. Size r => Array r ix e -> Sz ix
forall ix e. Array r ix e -> Sz ix
size Array r ix e
arr)
go :: a -> Int -> a
go a
acc !Int
k
| Int
k Int -> Int -> Bool
forall a. Ord a => a -> a -> Bool
< Int
len = a -> Int -> a
go (a -> e -> a
f a
acc (Array r ix e -> Int -> e
forall ix. Index ix => Array r ix e -> Int -> e
forall r e ix. (Source r e, Index ix) => Array r ix e -> Int -> e
unsafeLinearIndex Array r ix e
arr Int
k)) (Int
k Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Int
1)
| Bool
otherwise = a
acc
{-# INLINE lazyFoldlS #-}
lazyFoldrS :: (Index ix, Source r e) => (e -> a -> a) -> a -> Array r ix e -> a
lazyFoldrS :: forall ix r e a.
(Index ix, Source r e) =>
(e -> a -> a) -> a -> Array r ix e -> a
lazyFoldrS = (e -> a -> a) -> a -> Array r ix e -> a
forall ix r e a.
(Index ix, Source r e) =>
(e -> a -> a) -> a -> Array r ix e -> a
foldrFB
{-# INLINE lazyFoldrS #-}
foldlS :: (Index ix, Source r e) => (a -> e -> a) -> a -> Array r ix e -> a
foldlS :: forall ix r e a.
(Index ix, Source r e) =>
(a -> e -> a) -> a -> Array r ix e -> a
foldlS a -> e -> a
f a
acc = Identity a -> a
forall a. Identity a -> a
runIdentity (Identity a -> a)
-> (Array r ix e -> Identity a) -> Array r ix e -> a
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (a -> e -> Identity a) -> a -> Array r ix e -> Identity a
forall ix r e (m :: * -> *) a.
(Index ix, Source r e, Monad m) =>
(a -> e -> m a) -> a -> Array r ix e -> m a
foldlM (\a
a e
e -> a -> Identity a
forall a. a -> Identity a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (a -> Identity a) -> a -> Identity a
forall a b. (a -> b) -> a -> b
$! a -> e -> a
f a
a e
e) a
acc
{-# INLINE foldlS #-}
ifoldlS
:: (Index ix, Source r e)
=> (a -> ix -> e -> a)
-> a
-> Array r ix e
-> a
ifoldlS :: forall ix r e a.
(Index ix, Source r e) =>
(a -> ix -> e -> a) -> a -> Array r ix e -> a
ifoldlS a -> ix -> e -> a
f a
acc = Identity a -> a
forall a. Identity a -> a
runIdentity (Identity a -> a)
-> (Array r ix e -> Identity a) -> Array r ix e -> a
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (a -> ix -> e -> Identity a) -> a -> Array r ix e -> Identity a
forall ix r e (m :: * -> *) a.
(Index ix, Source r e, Monad m) =>
(a -> ix -> e -> m a) -> a -> Array r ix e -> m a
ifoldlM (\a
a ix
ix e
e -> a -> Identity a
forall a. a -> Identity a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (a -> Identity a) -> a -> Identity a
forall a b. (a -> b) -> a -> b
$! a -> ix -> e -> a
f a
a ix
ix e
e) a
acc
{-# INLINE ifoldlS #-}
foldrS :: (Index ix, Source r e) => (e -> a -> a) -> a -> Array r ix e -> a
foldrS :: forall ix r e a.
(Index ix, Source r e) =>
(e -> a -> a) -> a -> Array r ix e -> a
foldrS e -> a -> a
f a
acc = Identity a -> a
forall a. Identity a -> a
runIdentity (Identity a -> a)
-> (Array r ix e -> Identity a) -> Array r ix e -> a
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (e -> a -> Identity a) -> a -> Array r ix e -> Identity a
forall ix r e (m :: * -> *) a.
(Index ix, Source r e, Monad m) =>
(e -> a -> m a) -> a -> Array r ix e -> m a
foldrM (\e
e a
a -> a -> Identity a
forall a. a -> Identity a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (a -> Identity a) -> a -> Identity a
forall a b. (a -> b) -> a -> b
$! e -> a -> a
f e
e a
a) a
acc
{-# INLINE foldrS #-}
ifoldrS :: (Index ix, Source r e) => (ix -> e -> a -> a) -> a -> Array r ix e -> a
ifoldrS :: forall ix r e a.
(Index ix, Source r e) =>
(ix -> e -> a -> a) -> a -> Array r ix e -> a
ifoldrS ix -> e -> a -> a
f a
acc = Identity a -> a
forall a. Identity a -> a
runIdentity (Identity a -> a)
-> (Array r ix e -> Identity a) -> Array r ix e -> a
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (ix -> e -> a -> Identity a) -> a -> Array r ix e -> Identity a
forall ix r e (m :: * -> *) a.
(Index ix, Source r e, Monad m) =>
(ix -> e -> a -> m a) -> a -> Array r ix e -> m a
ifoldrM (\ix
ix e
e a
a -> a -> Identity a
forall a. a -> Identity a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (a -> Identity a) -> a -> Identity a
forall a b. (a -> b) -> a -> b
$! ix -> e -> a -> a
f ix
ix e
e a
a) a
acc
{-# INLINE ifoldrS #-}
foldrFB :: (Index ix, Source r e) => (e -> b -> b) -> b -> Array r ix e -> b
foldrFB :: forall ix r e a.
(Index ix, Source r e) =>
(e -> a -> a) -> a -> Array r ix e -> a
foldrFB e -> b -> b
c b
n Array r ix e
arr = Int -> b
go Int
0
where
!k :: Int
k = Sz ix -> Int
forall ix. Index ix => Sz ix -> Int
totalElem (Array r ix e -> Sz ix
forall r ix e. Size r => Array r ix e -> Sz ix
forall ix e. Array r ix e -> Sz ix
size Array r ix e
arr)
go :: Int -> b
go !Int
i
| Int
i Int -> Int -> Bool
forall a. Eq a => a -> a -> Bool
== Int
k = b
n
| Bool
otherwise = let v :: e
v = Array r ix e -> Int -> e
forall ix. Index ix => Array r ix e -> Int -> e
forall r e ix. (Source r e, Index ix) => Array r ix e -> Int -> e
unsafeLinearIndex Array r ix e
arr Int
i in e
v e -> b -> b
`c` Int -> b
go (Int
i Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Int
1)
{-# INLINE [0] foldrFB #-}
foldlP
:: (MonadIO m, Index ix, Source r e)
=> (a -> e -> a)
-> a
-> (b -> a -> b)
-> b
-> Array r ix e
-> m b
foldlP :: forall (m :: * -> *) ix r e a b.
(MonadIO m, Index ix, Source r e) =>
(a -> e -> a) -> a -> (b -> a -> b) -> b -> Array r ix e -> m b
foldlP a -> e -> a
f a
fAcc b -> a -> b
g b
gAcc =
IO b -> m b
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO b -> m b) -> (Array r ix e -> IO b) -> Array r ix e -> m b
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (a -> e -> IO a)
-> a -> (b -> a -> IO b) -> b -> Array r ix e -> IO b
forall (m :: * -> *) ix r e a b.
(MonadUnliftIO m, Index ix, Source r e) =>
(a -> e -> m a) -> a -> (b -> a -> m b) -> b -> Array r ix e -> m b
foldlIO (\a
acc -> a -> IO a
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (a -> IO a) -> (e -> a) -> e -> IO a
forall b c a. (b -> c) -> (a -> b) -> a -> c
. a -> e -> a
f a
acc) a
fAcc (\b
acc -> b -> IO b
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (b -> IO b) -> (a -> b) -> a -> IO b
forall b c a. (b -> c) -> (a -> b) -> a -> c
. b -> a -> b
g b
acc) b
gAcc
{-# INLINE foldlP #-}
ifoldlP
:: (MonadIO m, Index ix, Source r e)
=> (a -> ix -> e -> a)
-> a
-> (b -> a -> b)
-> b
-> Array r ix e
-> m b
ifoldlP :: forall (m :: * -> *) ix r e a b.
(MonadIO m, Index ix, Source r e) =>
(a -> ix -> e -> a)
-> a -> (b -> a -> b) -> b -> Array r ix e -> m b
ifoldlP a -> ix -> e -> a
f a
fAcc b -> a -> b
g b
gAcc =
IO b -> m b
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO b -> m b) -> (Array r ix e -> IO b) -> Array r ix e -> m b
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (a -> ix -> e -> IO a)
-> a -> (b -> a -> IO b) -> b -> Array r ix e -> IO b
forall (m :: * -> *) ix r e a b.
(MonadUnliftIO m, Index ix, Source r e) =>
(a -> ix -> e -> m a)
-> a -> (b -> a -> m b) -> b -> Array r ix e -> m b
ifoldlIO (\a
acc ix
ix -> a -> IO a
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (a -> IO a) -> (e -> a) -> e -> IO a
forall b c a. (b -> c) -> (a -> b) -> a -> c
. a -> ix -> e -> a
f a
acc ix
ix) a
fAcc (\b
acc -> b -> IO b
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (b -> IO b) -> (a -> b) -> a -> IO b
forall b c a. (b -> c) -> (a -> b) -> a -> c
. b -> a -> b
g b
acc) b
gAcc
{-# INLINE ifoldlP #-}
foldrP
:: (MonadIO m, Index ix, Source r e)
=> (e -> a -> a)
-> a
-> (a -> b -> b)
-> b
-> Array r ix e
-> m b
foldrP :: forall (m :: * -> *) ix r e a b.
(MonadIO m, Index ix, Source r e) =>
(e -> a -> a) -> a -> (a -> b -> b) -> b -> Array r ix e -> m b
foldrP e -> a -> a
f a
fAcc a -> b -> b
g b
gAcc = IO b -> m b
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO b -> m b) -> (Array r ix e -> IO b) -> Array r ix e -> m b
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (ix -> e -> a -> a)
-> a -> (a -> b -> b) -> b -> Array r ix e -> IO b
forall (m :: * -> *) ix r e a b.
(MonadIO m, Index ix, Source r e) =>
(ix -> e -> a -> a)
-> a -> (a -> b -> b) -> b -> Array r ix e -> m b
ifoldrP ((e -> a -> a) -> ix -> e -> a -> a
forall a b. a -> b -> a
const e -> a -> a
f) a
fAcc a -> b -> b
g b
gAcc
{-# INLINE foldrP #-}
ifoldrP
:: (MonadIO m, Index ix, Source r e)
=> (ix -> e -> a -> a)
-> a
-> (a -> b -> b)
-> b
-> Array r ix e
-> m b
ifoldrP :: forall (m :: * -> *) ix r e a b.
(MonadIO m, Index ix, Source r e) =>
(ix -> e -> a -> a)
-> a -> (a -> b -> b) -> b -> Array r ix e -> m b
ifoldrP ix -> e -> a -> a
f a
fAcc a -> b -> b
g b
gAcc = IO b -> m b
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO b -> m b) -> (Array r ix e -> IO b) -> Array r ix e -> m b
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (ix -> e -> a -> IO a)
-> a -> (a -> b -> IO b) -> b -> Array r ix e -> IO b
forall (m :: * -> *) ix r e a b.
(MonadUnliftIO m, Index ix, Source r e) =>
(ix -> e -> a -> m a)
-> a -> (a -> b -> m b) -> b -> Array r ix e -> m b
ifoldrIO (\ix
ix e
e -> a -> IO a
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (a -> IO a) -> (a -> a) -> a -> IO a
forall b c a. (b -> c) -> (a -> b) -> a -> c
. ix -> e -> a -> a
f ix
ix e
e) a
fAcc (\a
e -> b -> IO b
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (b -> IO b) -> (b -> b) -> b -> IO b
forall b c a. (b -> c) -> (a -> b) -> a -> c
. a -> b -> b
g a
e) b
gAcc
{-# INLINE ifoldrP #-}
foldlInternal
:: (Index ix, Source r e) => (a -> e -> a) -> a -> (b -> a -> b) -> b -> Array r ix e -> b
foldlInternal :: forall ix r e a b.
(Index ix, Source r e) =>
(a -> e -> a) -> a -> (b -> a -> b) -> b -> Array r ix e -> b
foldlInternal a -> e -> a
g a
initAcc b -> a -> b
f b
resAcc = IO b -> b
forall a. IO a -> a
unsafePerformIO (IO b -> b) -> (Array r ix e -> IO b) -> Array r ix e -> b
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (a -> e -> a) -> a -> (b -> a -> b) -> b -> Array r ix e -> IO b
forall (m :: * -> *) ix r e a b.
(MonadIO m, Index ix, Source r e) =>
(a -> e -> a) -> a -> (b -> a -> b) -> b -> Array r ix e -> m b
foldlP a -> e -> a
g a
initAcc b -> a -> b
f b
resAcc
{-# INLINE foldlInternal #-}
ifoldlInternal
:: (Index ix, Source r e) => (a -> ix -> e -> a) -> a -> (b -> a -> b) -> b -> Array r ix e -> b
ifoldlInternal :: forall ix r e a b.
(Index ix, Source r e) =>
(a -> ix -> e -> a) -> a -> (b -> a -> b) -> b -> Array r ix e -> b
ifoldlInternal a -> ix -> e -> a
g a
initAcc b -> a -> b
f b
resAcc = IO b -> b
forall a. IO a -> a
unsafePerformIO (IO b -> b) -> (Array r ix e -> IO b) -> Array r ix e -> b
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (a -> ix -> e -> a)
-> a -> (b -> a -> b) -> b -> Array r ix e -> IO b
forall (m :: * -> *) ix r e a b.
(MonadIO m, Index ix, Source r e) =>
(a -> ix -> e -> a)
-> a -> (b -> a -> b) -> b -> Array r ix e -> m b
ifoldlP a -> ix -> e -> a
g a
initAcc b -> a -> b
f b
resAcc
{-# INLINE ifoldlInternal #-}
foldlIO
:: (MonadUnliftIO m, Index ix, Source r e)
=> (a -> e -> m a)
-> a
-> (b -> a -> m b)
-> b
-> Array r ix e
-> m b
foldlIO :: forall (m :: * -> *) ix r e a b.
(MonadUnliftIO m, Index ix, Source r e) =>
(a -> e -> m a) -> a -> (b -> a -> m b) -> b -> Array r ix e -> m b
foldlIO a -> e -> m a
f !a
initAcc b -> a -> m b
g !b
tAcc !Array r ix e
arr
| Array r ix e -> Comp
forall r ix e. Strategy r => Array r ix e -> Comp
forall ix e. Array r ix e -> Comp
getComp Array r ix e
arr Comp -> Comp -> Bool
forall a. Eq a => a -> a -> Bool
== Comp
Seq = (a -> e -> m a) -> a -> Array r ix e -> m a
forall ix r e (m :: * -> *) a.
(Index ix, Source r e, Monad m) =>
(a -> e -> m a) -> a -> Array r ix e -> m a
foldlM a -> e -> m a
f a
initAcc Array r ix e
arr m a -> (a -> m b) -> m b
forall a b. m a -> (a -> m b) -> m b
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= b -> a -> m b
g b
tAcc
| Bool
otherwise = do
let splitAcc :: a -> ST RealWorld (a, a)
splitAcc a
_ = (a, a) -> ST RealWorld (a, a)
forall a. a -> ST RealWorld a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (a
initAcc, a
initAcc)
!sz :: Sz ix
sz = Array r ix e -> Sz ix
forall r ix e. Size r => Array r ix e -> Sz ix
forall ix e. Array r ix e -> Sz ix
size Array r ix e
arr
[a]
results <-
Comp -> (Scheduler RealWorld a -> m a) -> m [a]
forall (m :: * -> *) a b.
MonadUnliftIO m =>
Comp -> (Scheduler RealWorld a -> m b) -> m [a]
withScheduler (Array r ix e -> Comp
forall r ix e. Strategy r => Array r ix e -> Comp
forall ix e. Array r ix e -> Comp
getComp Array r ix e
arr) ((Scheduler RealWorld a -> m a) -> m [a])
-> (Scheduler RealWorld a -> m a) -> m [a]
forall a b. (a -> b) -> a -> b
$ \Scheduler RealWorld a
scheduler ->
((forall a. m a -> IO a) -> IO a) -> m a
forall b. ((forall a. m a -> IO a) -> IO b) -> m b
forall (m :: * -> *) b.
MonadUnliftIO m =>
((forall a. m a -> IO a) -> IO b) -> m b
withRunInIO (((forall a. m a -> IO a) -> IO a) -> m a)
-> ((forall a. m a -> IO a) -> IO a) -> m a
forall a b. (a -> b) -> a -> b
$ \forall a. m a -> IO a
run ->
ST (PrimState IO) a -> IO a
forall (m :: * -> *) a. PrimMonad m => ST (PrimState m) a -> m a
stToPrim (ST (PrimState IO) a -> IO a) -> ST (PrimState IO) a -> IO a
forall a b. (a -> b) -> a -> b
$
case Array r ix e -> PrefIndex ix e
forall ix. Index ix => Array r ix e -> PrefIndex ix e
forall r e ix.
(Source r e, Index ix) =>
Array r ix e -> PrefIndex ix e
unsafePrefIndex Array r ix e
arr of
PrefIndex ix -> e
gix ->
RowMajor
-> Scheduler (PrimState IO) a
-> ix
-> Sz ix
-> a
-> (a -> ST (PrimState IO) (a, a))
-> (ix -> a -> ST (PrimState IO) a)
-> ST (PrimState IO) a
forall it ix s a.
(Iterator it, Index ix) =>
it
-> Scheduler s a
-> ix
-> Sz ix
-> a
-> (a -> ST s (a, a))
-> (ix -> a -> ST s a)
-> ST s a
forall ix s a.
Index ix =>
RowMajor
-> Scheduler s a
-> ix
-> Sz ix
-> a
-> (a -> ST s (a, a))
-> (ix -> a -> ST s a)
-> ST s a
iterFullAccST RowMajor
defRowMajor Scheduler RealWorld a
Scheduler (PrimState IO) a
scheduler ix
forall ix. Index ix => ix
zeroIndex Sz ix
sz a
initAcc a -> ST RealWorld (a, a)
a -> ST (PrimState IO) (a, a)
splitAcc ((ix -> a -> ST (PrimState IO) a) -> ST (PrimState IO) a)
-> (ix -> a -> ST (PrimState IO) a) -> ST (PrimState IO) a
forall a b. (a -> b) -> a -> b
$ \ !ix
ix !a
acc ->
IO a -> ST RealWorld a
forall (m :: * -> *) a.
(PrimMonad m, PrimState m ~ RealWorld) =>
IO a -> m a
ioToPrim (m a -> IO a
forall a. m a -> IO a
run (a -> e -> m a
f a
acc (ix -> e
gix ix
ix)))
PrefIndexLinear Int -> e
gi ->
RowMajor
-> Scheduler (PrimState IO) a
-> Int
-> Sz Int
-> a
-> (a -> ST (PrimState IO) (a, a))
-> (Int -> a -> ST (PrimState IO) a)
-> ST (PrimState IO) a
forall it ix s a.
(Iterator it, Index ix) =>
it
-> Scheduler s a
-> ix
-> Sz ix
-> a
-> (a -> ST s (a, a))
-> (ix -> a -> ST s a)
-> ST s a
forall ix s a.
Index ix =>
RowMajor
-> Scheduler s a
-> ix
-> Sz ix
-> a
-> (a -> ST s (a, a))
-> (ix -> a -> ST s a)
-> ST s a
iterFullAccST RowMajor
defRowMajor Scheduler RealWorld a
Scheduler (PrimState IO) a
scheduler Int
0 (Sz ix -> Sz Int
forall ix. Index ix => Sz ix -> Sz Int
toLinearSz Sz ix
sz) a
initAcc a -> ST RealWorld (a, a)
a -> ST (PrimState IO) (a, a)
splitAcc ((Int -> a -> ST (PrimState IO) a) -> ST (PrimState IO) a)
-> (Int -> a -> ST (PrimState IO) a) -> ST (PrimState IO) a
forall a b. (a -> b) -> a -> b
$ \ !Int
i !a
acc ->
IO a -> ST RealWorld a
forall (m :: * -> *) a.
(PrimMonad m, PrimState m ~ RealWorld) =>
IO a -> m a
ioToPrim (m a -> IO a
forall a. m a -> IO a
run (a -> e -> m a
f a
acc (Int -> e
gi Int
i)))
(b -> a -> m b) -> b -> [a] -> m b
forall (t :: * -> *) (m :: * -> *) b a.
(Foldable t, Monad m) =>
(b -> a -> m b) -> b -> t a -> m b
F.foldlM b -> a -> m b
g b
tAcc [a]
results
{-# INLINE foldlIO #-}
ifoldlIO
:: (MonadUnliftIO m, Index ix, Source r e)
=> (a -> ix -> e -> m a)
-> a
-> (b -> a -> m b)
-> b
-> Array r ix e
-> m b
ifoldlIO :: forall (m :: * -> *) ix r e a b.
(MonadUnliftIO m, Index ix, Source r e) =>
(a -> ix -> e -> m a)
-> a -> (b -> a -> m b) -> b -> Array r ix e -> m b
ifoldlIO a -> ix -> e -> m a
f !a
initAcc b -> a -> m b
g !b
tAcc !Array r ix e
arr
| Array r ix e -> Comp
forall r ix e. Strategy r => Array r ix e -> Comp
forall ix e. Array r ix e -> Comp
getComp Array r ix e
arr Comp -> Comp -> Bool
forall a. Eq a => a -> a -> Bool
== Comp
Seq = (a -> ix -> e -> m a) -> a -> Array r ix e -> m a
forall ix r e (m :: * -> *) a.
(Index ix, Source r e, Monad m) =>
(a -> ix -> e -> m a) -> a -> Array r ix e -> m a
ifoldlM a -> ix -> e -> m a
f a
initAcc Array r ix e
arr m a -> (a -> m b) -> m b
forall a b. m a -> (a -> m b) -> m b
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= b -> a -> m b
g b
tAcc
| Bool
otherwise = do
let !sz :: Sz ix
sz = Array r ix e -> Sz ix
forall r ix e. Size r => Array r ix e -> Sz ix
forall ix e. Array r ix e -> Sz ix
size Array r ix e
arr
splitAcc :: a -> ST RealWorld (a, a)
splitAcc a
_ = (a, a) -> ST RealWorld (a, a)
forall a. a -> ST RealWorld a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (a
initAcc, a
initAcc)
[a]
results <-
Comp -> (Scheduler RealWorld a -> m a) -> m [a]
forall (m :: * -> *) a b.
MonadUnliftIO m =>
Comp -> (Scheduler RealWorld a -> m b) -> m [a]
withScheduler (Array r ix e -> Comp
forall r ix e. Strategy r => Array r ix e -> Comp
forall ix e. Array r ix e -> Comp
getComp Array r ix e
arr) ((Scheduler RealWorld a -> m a) -> m [a])
-> (Scheduler RealWorld a -> m a) -> m [a]
forall a b. (a -> b) -> a -> b
$ \Scheduler RealWorld a
scheduler ->
((forall a. m a -> IO a) -> IO a) -> m a
forall b. ((forall a. m a -> IO a) -> IO b) -> m b
forall (m :: * -> *) b.
MonadUnliftIO m =>
((forall a. m a -> IO a) -> IO b) -> m b
withRunInIO (((forall a. m a -> IO a) -> IO a) -> m a)
-> ((forall a. m a -> IO a) -> IO a) -> m a
forall a b. (a -> b) -> a -> b
$ \forall a. m a -> IO a
run ->
ST (PrimState IO) a -> IO a
forall (m :: * -> *) a. PrimMonad m => ST (PrimState m) a -> m a
stToPrim (ST (PrimState IO) a -> IO a) -> ST (PrimState IO) a -> IO a
forall a b. (a -> b) -> a -> b
$
case Array r ix e -> PrefIndex ix e
forall ix. Index ix => Array r ix e -> PrefIndex ix e
forall r e ix.
(Source r e, Index ix) =>
Array r ix e -> PrefIndex ix e
unsafePrefIndex Array r ix e
arr of
PrefIndex ix -> e
gix ->
RowMajor
-> Scheduler (PrimState IO) a
-> ix
-> Sz ix
-> a
-> (a -> ST (PrimState IO) (a, a))
-> (ix -> a -> ST (PrimState IO) a)
-> ST (PrimState IO) a
forall it ix s a.
(Iterator it, Index ix) =>
it
-> Scheduler s a
-> ix
-> Sz ix
-> a
-> (a -> ST s (a, a))
-> (ix -> a -> ST s a)
-> ST s a
forall ix s a.
Index ix =>
RowMajor
-> Scheduler s a
-> ix
-> Sz ix
-> a
-> (a -> ST s (a, a))
-> (ix -> a -> ST s a)
-> ST s a
iterFullAccST RowMajor
defRowMajor Scheduler RealWorld a
Scheduler (PrimState IO) a
scheduler ix
forall ix. Index ix => ix
zeroIndex Sz ix
sz a
initAcc a -> ST RealWorld (a, a)
a -> ST (PrimState IO) (a, a)
splitAcc ((ix -> a -> ST (PrimState IO) a) -> ST (PrimState IO) a)
-> (ix -> a -> ST (PrimState IO) a) -> ST (PrimState IO) a
forall a b. (a -> b) -> a -> b
$ \ !ix
ix !a
acc ->
IO a -> ST RealWorld a
forall (m :: * -> *) a.
(PrimMonad m, PrimState m ~ RealWorld) =>
IO a -> m a
ioToPrim (m a -> IO a
forall a. m a -> IO a
run (a -> ix -> e -> m a
f a
acc ix
ix (ix -> e
gix ix
ix)))
PrefIndexLinear Int -> e
gi ->
RowMajor
-> Scheduler (PrimState IO) a
-> Int
-> Sz ix
-> a
-> (a -> ST (PrimState IO) (a, a))
-> (Int -> ix -> a -> ST (PrimState IO) a)
-> ST (PrimState IO) a
forall it ix s a.
(Iterator it, Index ix) =>
it
-> Scheduler s a
-> Int
-> Sz ix
-> a
-> (a -> ST s (a, a))
-> (Int -> ix -> a -> ST s a)
-> ST s a
forall ix s a.
Index ix =>
RowMajor
-> Scheduler s a
-> Int
-> Sz ix
-> a
-> (a -> ST s (a, a))
-> (Int -> ix -> a -> ST s a)
-> ST s a
iterTargetFullAccST RowMajor
defRowMajor Scheduler RealWorld a
Scheduler (PrimState IO) a
scheduler Int
0 Sz ix
sz a
initAcc a -> ST RealWorld (a, a)
a -> ST (PrimState IO) (a, a)
splitAcc ((Int -> ix -> a -> ST (PrimState IO) a) -> ST (PrimState IO) a)
-> (Int -> ix -> a -> ST (PrimState IO) a) -> ST (PrimState IO) a
forall a b. (a -> b) -> a -> b
$ \ !Int
i !ix
ix !a
acc ->
IO a -> ST RealWorld a
forall (m :: * -> *) a.
(PrimMonad m, PrimState m ~ RealWorld) =>
IO a -> m a
ioToPrim (m a -> IO a
forall a. m a -> IO a
run (a -> ix -> e -> m a
f a
acc ix
ix (Int -> e
gi Int
i)))
(b -> a -> m b) -> b -> [a] -> m b
forall (t :: * -> *) (m :: * -> *) b a.
(Foldable t, Monad m) =>
(b -> a -> m b) -> b -> t a -> m b
F.foldlM b -> a -> m b
g b
tAcc [a]
results
{-# INLINE ifoldlIO #-}
splitReduce
:: (MonadUnliftIO m, Index ix, Source r e)
=> (Scheduler RealWorld a -> Vector r e -> m a)
-> (b -> a -> m b)
-> b
-> Array r ix e
-> m b
splitReduce :: forall (m :: * -> *) ix r e a b.
(MonadUnliftIO m, Index ix, Source r e) =>
(Scheduler RealWorld a -> Vector r e -> m a)
-> (b -> a -> m b) -> b -> Array r ix e -> m b
splitReduce Scheduler RealWorld a -> Vector r e -> m a
f b -> a -> m b
g !b
tAcc !Array r ix e
arr = do
let !sz :: Sz ix
sz = Array r ix e -> Sz ix
forall r ix e. Size r => Array r ix e -> Sz ix
forall ix e. Array r ix e -> Sz ix
size Array r ix e
arr
!totalLength :: Int
totalLength = Sz ix -> Int
forall ix. Index ix => Sz ix -> Int
totalElem Sz ix
sz
[a]
results <-
Comp -> (Scheduler RealWorld a -> m ()) -> m [a]
forall (m :: * -> *) a b.
MonadUnliftIO m =>
Comp -> (Scheduler RealWorld a -> m b) -> m [a]
withScheduler (Array r ix e -> Comp
forall r ix e. Strategy r => Array r ix e -> Comp
forall ix e. Array r ix e -> Comp
getComp Array r ix e
arr) ((Scheduler RealWorld a -> m ()) -> m [a])
-> (Scheduler RealWorld a -> m ()) -> m [a]
forall a b. (a -> b) -> a -> b
$ \Scheduler RealWorld a
scheduler -> do
((forall a. m a -> IO a) -> IO ()) -> m ()
forall b. ((forall a. m a -> IO a) -> IO b) -> m b
forall (m :: * -> *) b.
MonadUnliftIO m =>
((forall a. m a -> IO a) -> IO b) -> m b
withRunInIO (((forall a. m a -> IO a) -> IO ()) -> m ())
-> ((forall a. m a -> IO a) -> IO ()) -> m ()
forall a b. (a -> b) -> a -> b
$ \forall a. m a -> IO a
run -> do
Int -> Int -> (Int -> Int -> IO ()) -> IO ()
forall a. Int -> Int -> (Int -> Int -> a) -> a
splitLinearly (Scheduler RealWorld a -> Int
forall s a. Scheduler s a -> Int
numWorkers Scheduler RealWorld a
scheduler) Int
totalLength ((Int -> Int -> IO ()) -> IO ()) -> (Int -> Int -> IO ()) -> IO ()
forall a b. (a -> b) -> a -> b
$ \Int
chunkLength Int
slackStart -> do
Int -> (Int -> Bool) -> (Int -> Int) -> (Int -> IO ()) -> IO ()
forall (f :: * -> *) a.
Applicative f =>
Int -> (Int -> Bool) -> (Int -> Int) -> (Int -> f a) -> f ()
loopA_ Int
0 (Int -> Int -> Bool
forall a. Ord a => a -> a -> Bool
< Int
slackStart) (Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Int
chunkLength) ((Int -> IO ()) -> IO ()) -> (Int -> IO ()) -> IO ()
forall a b. (a -> b) -> a -> b
$ \ !Int
start ->
Scheduler RealWorld a -> IO a -> IO ()
forall s (m :: * -> *) a.
MonadPrimBase s m =>
Scheduler s a -> m a -> m ()
scheduleWork Scheduler RealWorld a
scheduler (IO a -> IO ()) -> IO a -> IO ()
forall a b. (a -> b) -> a -> b
$
m a -> IO a
forall a. m a -> IO a
run (m a -> IO a) -> m a -> IO a
forall a b. (a -> b) -> a -> b
$
Scheduler RealWorld a -> Vector r e -> m a
f Scheduler RealWorld a
scheduler (Vector r e -> m a) -> Vector r e -> m a
forall a b. (a -> b) -> a -> b
$
Int -> Sz Int -> Array r ix e -> Vector r e
forall ix. Index ix => Int -> Sz Int -> Array r ix e -> Vector r e
forall r e ix.
(Source r e, Index ix) =>
Int -> Sz Int -> Array r ix e -> Array r Int e
unsafeLinearSlice Int
start (Int -> Sz Int
forall ix. ix -> Sz ix
SafeSz Int
chunkLength) Array r ix e
arr
Bool -> IO () -> IO ()
forall (f :: * -> *). Applicative f => Bool -> f () -> f ()
when (Int
slackStart Int -> Int -> Bool
forall a. Ord a => a -> a -> Bool
< Int
totalLength) (IO () -> IO ()) -> IO () -> IO ()
forall a b. (a -> b) -> a -> b
$
Scheduler RealWorld a -> IO a -> IO ()
forall s (m :: * -> *) a.
MonadPrimBase s m =>
Scheduler s a -> m a -> m ()
scheduleWork Scheduler RealWorld a
scheduler (IO a -> IO ()) -> IO a -> IO ()
forall a b. (a -> b) -> a -> b
$
m a -> IO a
forall a. m a -> IO a
run (m a -> IO a) -> m a -> IO a
forall a b. (a -> b) -> a -> b
$
Scheduler RealWorld a -> Vector r e -> m a
f Scheduler RealWorld a
scheduler (Vector r e -> m a) -> Vector r e -> m a
forall a b. (a -> b) -> a -> b
$
Int -> Sz Int -> Array r ix e -> Vector r e
forall ix. Index ix => Int -> Sz Int -> Array r ix e -> Vector r e
forall r e ix.
(Source r e, Index ix) =>
Int -> Sz Int -> Array r ix e -> Array r Int e
unsafeLinearSlice Int
slackStart (Int -> Sz Int
forall ix. ix -> Sz ix
SafeSz (Int
totalLength Int -> Int -> Int
forall a. Num a => a -> a -> a
- Int
slackStart)) Array r ix e
arr
(b -> a -> m b) -> b -> [a] -> m b
forall (t :: * -> *) (m :: * -> *) b a.
(Foldable t, Monad m) =>
(b -> a -> m b) -> b -> t a -> m b
F.foldlM b -> a -> m b
g b
tAcc [a]
results
{-# INLINE splitReduce #-}
ifoldrIO
:: (MonadUnliftIO m, Index ix, Source r e)
=> (ix -> e -> a -> m a)
-> a
-> (a -> b -> m b)
-> b
-> Array r ix e
-> m b
ifoldrIO :: forall (m :: * -> *) ix r e a b.
(MonadUnliftIO m, Index ix, Source r e) =>
(ix -> e -> a -> m a)
-> a -> (a -> b -> m b) -> b -> Array r ix e -> m b
ifoldrIO ix -> e -> a -> m a
f !a
initAcc a -> b -> m b
g !b
tAcc !Array r ix e
arr
| Array r ix e -> Comp
forall r ix e. Strategy r => Array r ix e -> Comp
forall ix e. Array r ix e -> Comp
getComp Array r ix e
arr Comp -> Comp -> Bool
forall a. Eq a => a -> a -> Bool
== Comp
Seq = (ix -> e -> a -> m a) -> a -> Array r ix e -> m a
forall ix r e (m :: * -> *) a.
(Index ix, Source r e, Monad m) =>
(ix -> e -> a -> m a) -> a -> Array r ix e -> m a
ifoldrM ix -> e -> a -> m a
f a
initAcc Array r ix e
arr m a -> (a -> m b) -> m b
forall a b. m a -> (a -> m b) -> m b
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= (a -> b -> m b
`g` b
tAcc)
| Bool
otherwise = do
let !sz :: Sz ix
sz = Array r ix e -> Sz ix
forall r ix e. Size r => Array r ix e -> Sz ix
forall ix e. Array r ix e -> Sz ix
size Array r ix e
arr
!totalLength :: Int
totalLength = Sz ix -> Int
forall ix. Index ix => Sz ix -> Int
totalElem Sz ix
sz
[a]
results <-
((forall a. m a -> IO a) -> IO [a]) -> m [a]
forall b. ((forall a. m a -> IO a) -> IO b) -> m b
forall (m :: * -> *) b.
MonadUnliftIO m =>
((forall a. m a -> IO a) -> IO b) -> m b
withRunInIO (((forall a. m a -> IO a) -> IO [a]) -> m [a])
-> ((forall a. m a -> IO a) -> IO [a]) -> m [a]
forall a b. (a -> b) -> a -> b
$ \forall a. m a -> IO a
run -> do
Comp -> (Scheduler RealWorld a -> IO ()) -> IO [a]
forall (m :: * -> *) a b.
MonadUnliftIO m =>
Comp -> (Scheduler RealWorld a -> m b) -> m [a]
withScheduler (Array r ix e -> Comp
forall r ix e. Strategy r => Array r ix e -> Comp
forall ix e. Array r ix e -> Comp
getComp Array r ix e
arr) ((Scheduler RealWorld a -> IO ()) -> IO [a])
-> (Scheduler RealWorld a -> IO ()) -> IO [a]
forall a b. (a -> b) -> a -> b
$ \Scheduler RealWorld a
scheduler ->
Int -> Int -> (Int -> Int -> IO ()) -> IO ()
forall a. Int -> Int -> (Int -> Int -> a) -> a
splitLinearly (Scheduler RealWorld a -> Int
forall s a. Scheduler s a -> Int
numWorkers Scheduler RealWorld a
scheduler) Int
totalLength ((Int -> Int -> IO ()) -> IO ()) -> (Int -> Int -> IO ()) -> IO ()
forall a b. (a -> b) -> a -> b
$ \Int
chunkLength Int
slackStart -> do
Bool -> IO () -> IO ()
forall (f :: * -> *). Applicative f => Bool -> f () -> f ()
when (Int
slackStart Int -> Int -> Bool
forall a. Ord a => a -> a -> Bool
< Int
totalLength) (IO () -> IO ()) -> IO () -> IO ()
forall a b. (a -> b) -> a -> b
$
Scheduler RealWorld a -> IO a -> IO ()
forall s (m :: * -> *) a.
MonadPrimBase s m =>
Scheduler s a -> m a -> m ()
scheduleWork Scheduler RealWorld a
scheduler (IO a -> IO ()) -> IO a -> IO ()
forall a b. (a -> b) -> a -> b
$
m a -> IO a
forall a. m a -> IO a
run (m a -> IO a) -> m a -> IO a
forall a b. (a -> b) -> a -> b
$
Sz ix
-> Int
-> Int
-> Int
-> (Int -> Int -> Bool)
-> a
-> (Int -> ix -> a -> m a)
-> m a
forall ix (m :: * -> *) a.
(Index ix, Monad m) =>
Sz ix
-> Int
-> Int
-> Int
-> (Int -> Int -> Bool)
-> a
-> (Int -> ix -> a -> m a)
-> m a
iterLinearM Sz ix
sz (Int
totalLength Int -> Int -> Int
forall a. Num a => a -> a -> a
- Int
1) Int
slackStart (-Int
1) Int -> Int -> Bool
forall a. Ord a => a -> a -> Bool
(>=) a
initAcc ((Int -> ix -> a -> m a) -> m a) -> (Int -> ix -> a -> m a) -> m a
forall a b. (a -> b) -> a -> b
$ \ !Int
i ix
ix ->
ix -> e -> a -> m a
f ix
ix (Array r ix e -> Int -> e
forall ix. Index ix => Array r ix e -> Int -> e
forall r e ix. (Source r e, Index ix) => Array r ix e -> Int -> e
unsafeLinearIndex Array r ix e
arr Int
i)
Int -> (Int -> Bool) -> (Int -> Int) -> (Int -> IO ()) -> IO ()
forall (f :: * -> *) a.
Applicative f =>
Int -> (Int -> Bool) -> (Int -> Int) -> (Int -> f a) -> f ()
loopA_ Int
slackStart (Int -> Int -> Bool
forall a. Ord a => a -> a -> Bool
> Int
0) (Int -> Int -> Int
forall a. Num a => a -> a -> a
subtract Int
chunkLength) ((Int -> IO ()) -> IO ()) -> (Int -> IO ()) -> IO ()
forall a b. (a -> b) -> a -> b
$ \ !Int
start ->
Scheduler RealWorld a -> IO a -> IO ()
forall s (m :: * -> *) a.
MonadPrimBase s m =>
Scheduler s a -> m a -> m ()
scheduleWork Scheduler RealWorld a
scheduler (IO a -> IO ()) -> IO a -> IO ()
forall a b. (a -> b) -> a -> b
$
m a -> IO a
forall a. m a -> IO a
run (m a -> IO a) -> m a -> IO a
forall a b. (a -> b) -> a -> b
$
Sz ix
-> Int
-> Int
-> Int
-> (Int -> Int -> Bool)
-> a
-> (Int -> ix -> a -> m a)
-> m a
forall ix (m :: * -> *) a.
(Index ix, Monad m) =>
Sz ix
-> Int
-> Int
-> Int
-> (Int -> Int -> Bool)
-> a
-> (Int -> ix -> a -> m a)
-> m a
iterLinearM Sz ix
sz (Int
start Int -> Int -> Int
forall a. Num a => a -> a -> a
- Int
1) (Int
start Int -> Int -> Int
forall a. Num a => a -> a -> a
- Int
chunkLength) (-Int
1) Int -> Int -> Bool
forall a. Ord a => a -> a -> Bool
(>=) a
initAcc ((Int -> ix -> a -> m a) -> m a) -> (Int -> ix -> a -> m a) -> m a
forall a b. (a -> b) -> a -> b
$ \ !Int
i ix
ix ->
ix -> e -> a -> m a
f ix
ix (Array r ix e -> Int -> e
forall ix. Index ix => Array r ix e -> Int -> e
forall r e ix. (Source r e, Index ix) => Array r ix e -> Int -> e
unsafeLinearIndex Array r ix e
arr Int
i)
(b -> a -> m b) -> b -> [a] -> m b
forall (t :: * -> *) (m :: * -> *) b a.
(Foldable t, Monad m) =>
(b -> a -> m b) -> b -> t a -> m b
F.foldlM ((a -> b -> m b) -> b -> a -> m b
forall a b c. (a -> b -> c) -> b -> a -> c
flip a -> b -> m b
g) b
tAcc [a]
results
{-# INLINE ifoldrIO #-}
anySu :: (Index ix, Source r e) => (e -> Bool) -> Array r ix e -> Bool
anySu :: forall ix r e.
(Index ix, Source r e) =>
(e -> Bool) -> Array r ix e -> Bool
anySu e -> Bool
f Array r ix e
arr = Int -> Bool
go Int
0
where
!k :: Int
k = Array r ix e -> Int
forall ix r e. (Index ix, Size r) => Array r ix e -> Int
elemsCount Array r ix e
arr
!k4 :: Int
k4 = Int
k Int -> Int -> Int
forall a. Num a => a -> a -> a
- (Int
k Int -> Int -> Int
forall a. Integral a => a -> a -> a
`rem` Int
4)
go :: Int -> Bool
go !Int
i
| Int
i Int -> Int -> Bool
forall a. Ord a => a -> a -> Bool
< Int
k4 =
e -> Bool
f (Array r ix e -> Int -> e
forall ix. Index ix => Array r ix e -> Int -> e
forall r e ix. (Source r e, Index ix) => Array r ix e -> Int -> e
unsafeLinearIndex Array r ix e
arr Int
i)
Bool -> Bool -> Bool
|| e -> Bool
f (Array r ix e -> Int -> e
forall ix. Index ix => Array r ix e -> Int -> e
forall r e ix. (Source r e, Index ix) => Array r ix e -> Int -> e
unsafeLinearIndex Array r ix e
arr (Int
i Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Int
1))
Bool -> Bool -> Bool
|| e -> Bool
f (Array r ix e -> Int -> e
forall ix. Index ix => Array r ix e -> Int -> e
forall r e ix. (Source r e, Index ix) => Array r ix e -> Int -> e
unsafeLinearIndex Array r ix e
arr (Int
i Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Int
2))
Bool -> Bool -> Bool
|| e -> Bool
f (Array r ix e -> Int -> e
forall ix. Index ix => Array r ix e -> Int -> e
forall r e ix. (Source r e, Index ix) => Array r ix e -> Int -> e
unsafeLinearIndex Array r ix e
arr (Int
i Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Int
3))
Bool -> Bool -> Bool
|| Int -> Bool
go (Int
i Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Int
4)
| Int
i Int -> Int -> Bool
forall a. Ord a => a -> a -> Bool
< Int
k = e -> Bool
f (Array r ix e -> Int -> e
forall ix. Index ix => Array r ix e -> Int -> e
forall r e ix. (Source r e, Index ix) => Array r ix e -> Int -> e
unsafeLinearIndex Array r ix e
arr Int
i) Bool -> Bool -> Bool
|| Int -> Bool
go (Int
i Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Int
1)
| Bool
otherwise = Bool
False
{-# INLINE anySu #-}
anySliceSuM
:: (Index ix, Source r e)
=> Batch RealWorld Bool
-> Ix1
-> Sz1
-> (e -> Bool)
-> Array r ix e
-> IO Bool
anySliceSuM :: forall ix r e.
(Index ix, Source r e) =>
Batch RealWorld Bool
-> Int -> Sz Int -> (e -> Bool) -> Array r ix e -> IO Bool
anySliceSuM Batch RealWorld Bool
batch Int
ix0 (Sz1 Int
k) e -> Bool
f Array r ix e
arr = Int -> IO Bool
go Int
ix0
where
!k' :: Int
k' = Int
k Int -> Int -> Int
forall a. Num a => a -> a -> a
- Int
ix0
!k4 :: Int
k4 = Int
ix0 Int -> Int -> Int
forall a. Num a => a -> a -> a
+ (Int
k' Int -> Int -> Int
forall a. Num a => a -> a -> a
- (Int
k' Int -> Int -> Int
forall a. Integral a => a -> a -> a
`rem` Int
4))
go :: Int -> IO Bool
go !Int
i
| Int
i Int -> Int -> Bool
forall a. Ord a => a -> a -> Bool
< Int
k4 = do
let r :: Bool
r =
e -> Bool
f (Array r ix e -> Int -> e
forall ix. Index ix => Array r ix e -> Int -> e
forall r e ix. (Source r e, Index ix) => Array r ix e -> Int -> e
unsafeLinearIndex Array r ix e
arr Int
i)
Bool -> Bool -> Bool
|| e -> Bool
f (Array r ix e -> Int -> e
forall ix. Index ix => Array r ix e -> Int -> e
forall r e ix. (Source r e, Index ix) => Array r ix e -> Int -> e
unsafeLinearIndex Array r ix e
arr (Int
i Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Int
1))
Bool -> Bool -> Bool
|| e -> Bool
f (Array r ix e -> Int -> e
forall ix. Index ix => Array r ix e -> Int -> e
forall r e ix. (Source r e, Index ix) => Array r ix e -> Int -> e
unsafeLinearIndex Array r ix e
arr (Int
i Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Int
2))
Bool -> Bool -> Bool
|| e -> Bool
f (Array r ix e -> Int -> e
forall ix. Index ix => Array r ix e -> Int -> e
forall r e ix. (Source r e, Index ix) => Array r ix e -> Int -> e
unsafeLinearIndex Array r ix e
arr (Int
i Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Int
3))
in if Bool
r
then Batch RealWorld Bool -> Bool -> IO Bool
forall s (m :: * -> *) a. MonadPrim s m => Batch s a -> a -> m Bool
cancelBatchWith Batch RealWorld Bool
batch Bool
True
else do
Bool
done <- Batch RealWorld Bool -> IO Bool
forall s (m :: * -> *) a. MonadPrim s m => Batch s a -> m Bool
hasBatchFinished Batch RealWorld Bool
batch
if Bool
done
then Bool -> IO Bool
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure Bool
True
else Int -> IO Bool
go (Int
i Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Int
4)
| Int
i Int -> Int -> Bool
forall a. Ord a => a -> a -> Bool
< Int
k =
if e -> Bool
f (Array r ix e -> Int -> e
forall ix. Index ix => Array r ix e -> Int -> e
forall r e ix. (Source r e, Index ix) => Array r ix e -> Int -> e
unsafeLinearIndex Array r ix e
arr Int
i)
then Batch RealWorld Bool -> Bool -> IO Bool
forall s (m :: * -> *) a. MonadPrim s m => Batch s a -> a -> m Bool
cancelBatchWith Batch RealWorld Bool
batch Bool
True
else Int -> IO Bool
go (Int
i Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Int
1)
| Bool
otherwise = Bool -> IO Bool
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure Bool
False
{-# INLINE anySliceSuM #-}
anyPu :: (Index ix, Source r e) => (e -> Bool) -> Array r ix e -> IO Bool
anyPu :: forall ix r e.
(Index ix, Source r e) =>
(e -> Bool) -> Array r ix e -> IO Bool
anyPu e -> Bool
f Array r ix e
arr = do
let !sz :: Sz ix
sz = Array r ix e -> Sz ix
forall r ix e. Size r => Array r ix e -> Sz ix
forall ix e. Array r ix e -> Sz ix
size Array r ix e
arr
!totalLength :: Int
totalLength = Sz ix -> Int
forall ix. Index ix => Sz ix -> Int
totalElem Sz ix
sz
[Bool]
results <-
Comp -> (Scheduler RealWorld Bool -> IO ()) -> IO [Bool]
forall (m :: * -> *) a b.
MonadUnliftIO m =>
Comp -> (Scheduler RealWorld a -> m b) -> m [a]
withScheduler (Array r ix e -> Comp
forall r ix e. Strategy r => Array r ix e -> Comp
forall ix e. Array r ix e -> Comp
getComp Array r ix e
arr) ((Scheduler RealWorld Bool -> IO ()) -> IO [Bool])
-> (Scheduler RealWorld Bool -> IO ()) -> IO [Bool]
forall a b. (a -> b) -> a -> b
$ \Scheduler RealWorld Bool
scheduler -> do
Batch RealWorld Bool
batch <- Scheduler RealWorld Bool -> IO (Batch RealWorld Bool)
forall s (m :: * -> *) a.
MonadPrim s m =>
Scheduler s a -> m (Batch s a)
getCurrentBatch Scheduler RealWorld Bool
scheduler
Int -> Int -> (Int -> Int -> IO ()) -> IO ()
forall a. Int -> Int -> (Int -> Int -> a) -> a
splitLinearly (Scheduler RealWorld Bool -> Int
forall s a. Scheduler s a -> Int
numWorkers Scheduler RealWorld Bool
scheduler) Int
totalLength ((Int -> Int -> IO ()) -> IO ()) -> (Int -> Int -> IO ()) -> IO ()
forall a b. (a -> b) -> a -> b
$ \Int
chunkLength Int
slackStart -> do
Int -> (Int -> Bool) -> (Int -> Int) -> (Int -> IO ()) -> IO ()
forall (f :: * -> *) a.
Applicative f =>
Int -> (Int -> Bool) -> (Int -> Int) -> (Int -> f a) -> f ()
loopA_ Int
0 (Int -> Int -> Bool
forall a. Ord a => a -> a -> Bool
< Int
slackStart) (Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Int
chunkLength) ((Int -> IO ()) -> IO ()) -> (Int -> IO ()) -> IO ()
forall a b. (a -> b) -> a -> b
$ \ !Int
start ->
Scheduler RealWorld Bool -> IO Bool -> IO ()
forall s (m :: * -> *) a.
MonadPrimBase s m =>
Scheduler s a -> m a -> m ()
scheduleWork Scheduler RealWorld Bool
scheduler (IO Bool -> IO ()) -> IO Bool -> IO ()
forall a b. (a -> b) -> a -> b
$ Batch RealWorld Bool
-> Int -> Sz Int -> (e -> Bool) -> Array r ix e -> IO Bool
forall ix r e.
(Index ix, Source r e) =>
Batch RealWorld Bool
-> Int -> Sz Int -> (e -> Bool) -> Array r ix e -> IO Bool
anySliceSuM Batch RealWorld Bool
batch Int
start (Int -> Sz Int
forall ix. Index ix => ix -> Sz ix
Sz (Int
start Int -> Int -> Int
forall a. Num a => a -> a -> a
+ Int
chunkLength)) e -> Bool
f Array r ix e
arr
Bool -> IO () -> IO ()
forall (f :: * -> *). Applicative f => Bool -> f () -> f ()
when (Int
slackStart Int -> Int -> Bool
forall a. Ord a => a -> a -> Bool
< Int
totalLength) (IO () -> IO ()) -> IO () -> IO ()
forall a b. (a -> b) -> a -> b
$
Scheduler RealWorld Bool -> IO Bool -> IO ()
forall s (m :: * -> *) a.
MonadPrimBase s m =>
Scheduler s a -> m a -> m ()
scheduleWork Scheduler RealWorld Bool
scheduler (IO Bool -> IO ()) -> IO Bool -> IO ()
forall a b. (a -> b) -> a -> b
$
Batch RealWorld Bool
-> Int -> Sz Int -> (e -> Bool) -> Array r ix e -> IO Bool
forall ix r e.
(Index ix, Source r e) =>
Batch RealWorld Bool
-> Int -> Sz Int -> (e -> Bool) -> Array r ix e -> IO Bool
anySliceSuM Batch RealWorld Bool
batch Int
slackStart (Int -> Sz Int
forall ix. Index ix => ix -> Sz ix
Sz Int
totalLength) e -> Bool
f Array r ix e
arr
Bool -> IO Bool
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (Bool -> IO Bool) -> Bool -> IO Bool
forall a b. (a -> b) -> a -> b
$ (Bool -> Bool -> Bool) -> Bool -> [Bool] -> Bool
forall b a. (b -> a -> b) -> b -> [a] -> b
forall (t :: * -> *) b a.
Foldable t =>
(b -> a -> b) -> b -> t a -> b
F.foldl' Bool -> Bool -> Bool
(||) Bool
False [Bool]
results
{-# INLINE anyPu #-}
any :: (Index ix, Source r e) => (e -> Bool) -> Array r ix e -> Bool
any :: forall ix r e.
(Index ix, Source r e) =>
(e -> Bool) -> Array r ix e -> Bool
any e -> Bool
f Array r ix e
arr =
case Array r ix e -> Comp
forall r ix e. Strategy r => Array r ix e -> Comp
forall ix e. Array r ix e -> Comp
getComp Array r ix e
arr of
Comp
Seq -> (e -> Bool) -> Array r ix e -> Bool
forall ix r e.
(Index ix, Source r e) =>
(e -> Bool) -> Array r ix e -> Bool
anySu e -> Bool
f Array r ix e
arr
Comp
_ -> IO Bool -> Bool
forall a. IO a -> a
unsafePerformIO (IO Bool -> Bool) -> IO Bool -> Bool
forall a b. (a -> b) -> a -> b
$ (e -> Bool) -> Array r ix e -> IO Bool
forall ix r e.
(Index ix, Source r e) =>
(e -> Bool) -> Array r ix e -> IO Bool
anyPu e -> Bool
f Array r ix e
arr
{-# INLINE any #-}