| Copyright | (c) 2019 Composewell Technologies (c) 2013 Gabriel Gonzalez | 
|---|---|
| License | BSD3 | 
| Maintainer | streamly@composewell.com | 
| Stability | experimental | 
| Portability | GHC | 
| Safe Haskell | None | 
| Language | Haskell2010 | 
Streamly.Internal.Data.Fold
Contents
Description
See Streamly.Data.Fold for an overview and Streamly.Internal.Data.Fold.Type for design notes.
Synopsis
- foldr :: forall (m :: Type -> Type) a b. Monad m => (a -> b -> b) -> b -> Fold m a b
- genericLength :: forall (m :: Type -> Type) b a. (Monad m, Num b) => Fold m a b
- length :: forall (m :: Type -> Type) a. Monad m => Fold m a Int
- foldl' :: forall (m :: Type -> Type) b a. Monad m => (b -> a -> b) -> b -> Fold m a b
- filter :: forall (m :: Type -> Type) a r. Monad m => (a -> Bool) -> Fold m a r -> Fold m a r
- toList :: forall (m :: Type -> Type) a. Monad m => Fold m a [a]
- many :: forall (m :: Type -> Type) a b c. Monad m => Fold m a b -> Fold m b c -> Fold m a c
- catMaybes :: forall (m :: Type -> Type) a b. Monad m => Fold m a b -> Fold m (Maybe a) b
- last :: forall (m :: Type -> Type) a. Monad m => Fold m a (Maybe a)
- foldl1' :: forall (m :: Type -> Type) a. Monad m => (a -> a -> a) -> Fold m a (Maybe a)
- scanl :: forall (m :: Type -> Type) a b c. Monad m => Scanl m a b -> Fold m b c -> Fold m a c
- foldr' :: forall (m :: Type -> Type) a b. Monad m => (a -> b -> b) -> b -> Fold m a b
- take :: forall (m :: Type -> Type) a b. Monad m => Int -> Fold m a b -> Fold m a b
- concatMap :: forall (m :: Type -> Type) b a c. Monad m => (b -> Fold m a c) -> Fold m a b -> Fold m a c
- reduce :: Monad m => Fold m a b -> m (Fold m a b)
- close :: forall (m :: Type -> Type) a b. Monad m => Fold m a b -> Fold m a b
- filterM :: Monad m => (a -> m Bool) -> Fold m a r -> Fold m a r
- duplicate :: forall (m :: Type -> Type) a b. Monad m => Fold m a b -> Fold m a (Fold m a b)
- snoc :: Monad m => Fold m a b -> a -> m (Fold m a b)
- splitWith :: forall (m :: Type -> Type) a b c x. Monad m => (a -> b -> c) -> Fold m x a -> Fold m x b -> Fold m x c
- data Step s b
- lmapM :: Monad m => (a -> m b) -> Fold m b r -> Fold m a r
- rmapM :: Monad m => (b -> m c) -> Fold m a b -> Fold m a c
- mapMStep :: Applicative m => (a -> m b) -> Step s a -> m (Step s b)
- fromPure :: forall (m :: Type -> Type) b a. Applicative m => b -> Fold m a b
- data Fold (m :: Type -> Type) a b = Fold (s -> a -> m (Step s b)) (m (Step s b)) (s -> m b) (s -> m b)
- toStreamK :: forall (m :: Type -> Type) a (n :: Type -> Type). Monad m => Fold m a (StreamK n a)
- morphInner :: (forall x. m x -> n x) -> Fold m a b -> Fold n a b
- postscan :: forall (m :: Type -> Type) a b c. Monad m => Fold m a b -> Fold m b c -> Fold m a c
- scanlMany :: forall (m :: Type -> Type) a b c. Monad m => Scanl m a b -> Fold m b c -> Fold m a c
- scan :: forall (m :: Type -> Type) a b c. Monad m => Fold m a b -> Fold m b c -> Fold m a c
- scanMany :: forall (m :: Type -> Type) a b c. Monad m => Fold m a b -> Fold m b c -> Fold m a c
- takeEndBy :: forall (m :: Type -> Type) a b. Monad m => (a -> Bool) -> Fold m a b -> Fold m a b
- takeEndBy_ :: forall (m :: Type -> Type) a b. Monad m => (a -> Bool) -> Fold m a b -> Fold m a b
- teeWith :: forall (m :: Type -> Type) a b c x. Monad m => (a -> b -> c) -> Fold m x a -> Fold m x b -> Fold m x c
- lmap :: forall a b (m :: Type -> Type) r. (a -> b) -> Fold m b r -> Fold m a r
- refoldMany :: forall (m :: Type -> Type) a b x c. Monad m => Fold m a b -> Refold m x b c -> Refold m x a c
- groupsOf :: forall (m :: Type -> Type) a b c. Monad m => Int -> Fold m a b -> Fold m b c -> Fold m a c
- drain :: forall (m :: Type -> Type) a. Monad m => Fold m a ()
- foldlM' :: Monad m => (b -> a -> m b) -> m b -> Fold m a b
- addOne :: Monad m => a -> Fold m a b -> m (Fold m a b)
- foldl1M' :: Monad m => (a -> a -> m a) -> Fold m a (Maybe a)
- foldtM' :: (s -> a -> m (Step s b)) -> m (Step s b) -> (s -> m b) -> Fold m a b
- toListRev :: forall (m :: Type -> Type) a. Monad m => Fold m a [a]
- latest :: forall (m :: Type -> Type) a. Monad m => Fold m a (Maybe a)
- catLefts :: forall (m :: Type -> Type) a c b. Monad m => Fold m a c -> Fold m (Either a b) c
- catRights :: forall (m :: Type -> Type) b c a. Monad m => Fold m b c -> Fold m (Either a b) c
- catEithers :: forall (m :: Type -> Type) a b. Fold m a b -> Fold m (Either a a) b
- postscanl :: forall (m :: Type -> Type) a b c. Monad m => Scanl m a b -> Fold m b c -> Fold m a c
- foldlM1' :: Monad m => (a -> a -> m a) -> Fold m a (Maybe a)
- serialWith :: forall (m :: Type -> Type) a b c x. Monad m => (a -> b -> c) -> Fold m x a -> Fold m x b -> Fold m x c
- scanMaybe :: forall (m :: Type -> Type) a b c. Monad m => Fold m a (Maybe b) -> Fold m b c -> Fold m a c
- fromEffect :: Applicative m => m b -> Fold m a b
- postscanlMaybe :: forall (m :: Type -> Type) a b c. Monad m => Scanl m a (Maybe b) -> Fold m b c -> Fold m a c
- chainStepM :: Applicative m => (s1 -> m s2) -> (a -> m (Step s2 b)) -> Step s1 a -> m (Step s2 b)
- foldt' :: forall (m :: Type -> Type) s a b. Monad m => (s -> a -> Step s b) -> Step s b -> (s -> b) -> Fold m a b
- foldrM' :: Monad m => (a -> b -> m b) -> m b -> Fold m a b
- fromRefold :: forall (m :: Type -> Type) c a b. Refold m c a b -> c -> Fold m a b
- fromScanl :: forall (m :: Type -> Type) a b. Scanl m a b -> Fold m a b
- toStreamKRev :: forall (m :: Type -> Type) a (n :: Type -> Type). Monad m => Fold m a (StreamK n a)
- filtering :: forall (m :: Type -> Type) a. Monad m => (a -> Bool) -> Fold m a (Maybe a)
- taking :: forall (m :: Type -> Type) a. Monad m => Int -> Fold m a (Maybe a)
- dropping :: forall (m :: Type -> Type) a. Monad m => Int -> Fold m a (Maybe a)
- ifThen :: Monad m => m Bool -> Fold m a b -> Fold m a b -> Fold m a b
- split_ :: forall (m :: Type -> Type) x a b. Monad m => Fold m x a -> Fold m x b -> Fold m x b
- data ManyState s1 s2
- manyPost :: forall (m :: Type -> Type) a b c. Monad m => Fold m a b -> Fold m b c -> Fold m a c
- refoldMany1 :: forall (m :: Type -> Type) x a b c. Monad m => Refold m x a b -> Fold m b c -> Refold m x a c
- refold :: forall (m :: Type -> Type) b a c. Monad m => Refold m b a c -> Fold m a b -> Fold m a c
- teeWithFst :: forall (m :: Type -> Type) b c d a. Monad m => (b -> c -> d) -> Fold m a b -> Fold m a c -> Fold m a d
- teeWithMin :: forall (m :: Type -> Type) b c d a. Monad m => (b -> c -> d) -> Fold m a b -> Fold m a c -> Fold m a d
- shortest :: forall (m :: Type -> Type) x a b. Monad m => Fold m x a -> Fold m x b -> Fold m x (Either a b)
- longest :: forall (m :: Type -> Type) x a b. Monad m => Fold m x a -> Fold m x b -> Fold m x (Either a b)
- snocM :: Monad m => Fold m a b -> m a -> m (Fold m a b)
- snocl :: forall (m :: Type -> Type) a b. Monad m => Fold m a b -> a -> Fold m a b
- snoclM :: Monad m => Fold m a b -> m a -> Fold m a b
- finalM :: Monad m => Fold m a b -> m b
- isClosed :: Monad m => Fold m a b -> m Bool
- generalizeInner :: forall (m :: Type -> Type) a b. Monad m => Fold Identity a b -> Fold m a b
- extractM :: Monad m => Fold m a b -> m b
- toFold :: forall (m :: Type -> Type) a b. Tee m a b -> Fold m a b
- newtype Tee (m :: Type -> Type) a b = Tee {}
- index :: forall (m :: Type -> Type) a. Monad m => Int -> Fold m a (Maybe a)
- range :: forall (m :: Type -> Type) a. (Monad m, Ord a) => Fold m a (Maybe (a, a))
- mapMaybe :: forall (m :: Type -> Type) a b r. Monad m => (a -> Maybe b) -> Fold m b r -> Fold m a r
- unzip :: forall (m :: Type -> Type) a x b y. Monad m => Fold m a x -> Fold m b y -> Fold m (a, b) (x, y)
- maximumBy :: forall (m :: Type -> Type) a. Monad m => (a -> a -> Ordering) -> Fold m a (Maybe a)
- minimumBy :: forall (m :: Type -> Type) a. Monad m => (a -> a -> Ordering) -> Fold m a (Maybe a)
- genericIndex :: forall i (m :: Type -> Type) a. (Integral i, Monad m) => i -> Fold m a (Maybe a)
- head :: forall (m :: Type -> Type) a. Monad m => Fold m a (Maybe a)
- mapM :: Monad m => (b -> m c) -> Fold m a b -> Fold m a c
- sequence :: Monad m => Fold m a (m b) -> Fold m a b
- with :: forall (m :: Type -> Type) s a b c. (Fold m (s, a) b -> Fold m a b) -> (((s, a) -> c) -> Fold m (s, a) b -> Fold m (s, a) b) -> ((s, a) -> c) -> Fold m a b -> Fold m a b
- foldMap :: forall (m :: Type -> Type) b a. (Monad m, Monoid b) => (a -> b) -> Fold m a b
- trace :: Monad m => (a -> m b) -> Fold m a r -> Fold m a r
- mconcat :: forall (m :: Type -> Type) a. (Monad m, Monoid a) => Fold m a a
- sconcat :: forall (m :: Type -> Type) a. (Monad m, Semigroup a) => a -> Fold m a a
- maybe :: forall (m :: Type -> Type) a b. Monad m => (a -> Maybe b) -> Fold m a (Maybe b)
- null :: forall (m :: Type -> Type) a. Monad m => Fold m a Bool
- sum :: forall (m :: Type -> Type) a. (Monad m, Num a) => Fold m a a
- product :: forall (m :: Type -> Type) a. (Monad m, Num a, Eq a) => Fold m a a
- maximum :: forall (m :: Type -> Type) a. (Monad m, Ord a) => Fold m a (Maybe a)
- minimum :: forall (m :: Type -> Type) a. (Monad m, Ord a) => Fold m a (Maybe a)
- splitAt :: forall (m :: Type -> Type) a b c. Monad m => Int -> Fold m a b -> Fold m a c -> Fold m a (b, c)
- and :: forall (m :: Type -> Type). Monad m => Fold m Bool Bool
- or :: forall (m :: Type -> Type). Monad m => Fold m Bool Bool
- any :: forall (m :: Type -> Type) a. Monad m => (a -> Bool) -> Fold m a Bool
- all :: forall (m :: Type -> Type) a. Monad m => (a -> Bool) -> Fold m a Bool
- elem :: forall a (m :: Type -> Type). (Eq a, Monad m) => a -> Fold m a Bool
- notElem :: forall a (m :: Type -> Type). (Eq a, Monad m) => a -> Fold m a Bool
- lookup :: forall a (m :: Type -> Type) b. (Eq a, Monad m) => a -> Fold m (a, b) (Maybe b)
- satisfy :: forall (m :: Type -> Type) a. Monad m => (a -> Bool) -> Fold m a (Maybe a)
- find :: forall (m :: Type -> Type) a. Monad m => (a -> Bool) -> Fold m a (Maybe a)
- elemIndex :: forall a (m :: Type -> Type). (Eq a, Monad m) => a -> Fold m a (Maybe Int)
- elemIndices :: forall (m :: Type -> Type) a. (Monad m, Eq a) => a -> Fold m a (Maybe Int)
- findIndex :: forall (m :: Type -> Type) a. Monad m => (a -> Bool) -> Fold m a (Maybe Int)
- findIndices :: forall (m :: Type -> Type) a. Monad m => (a -> Bool) -> Fold m a (Maybe Int)
- deleteBy :: forall (m :: Type -> Type) a. Monad m => (a -> a -> Bool) -> a -> Fold m a (Maybe a)
- partition :: forall (m :: Type -> Type) b x c y. Monad m => Fold m b x -> Fold m c y -> Fold m (Either b c) (x, y)
- tracing :: Monad m => (a -> m b) -> a -> m a
- the :: forall (m :: Type -> Type) a. (Monad m, Eq a) => Fold m a (Maybe a)
- unzipWith :: forall (m :: Type -> Type) a b c x y. Monad m => (a -> (b, c)) -> Fold m b x -> Fold m c y -> Fold m a (x, y)
- drainBy :: Monad m => (a -> m b) -> Fold m a ()
- findM :: Monad m => (a -> m Bool) -> Fold m a (Maybe a)
- toStream :: forall (m :: Type -> Type) (n :: Type -> Type) a. (Monad m, Monad n) => Fold m a (Stream n a)
- one :: forall (m :: Type -> Type) a. Monad m => Fold m a (Maybe a)
- indexed :: forall (m :: Type -> Type) a b. Monad m => Fold m (Int, a) b -> Fold m a b
- sampleFromthen :: forall (m :: Type -> Type) a b. Monad m => Int -> Int -> Fold m a b -> Fold m a b
- tee :: forall (m :: Type -> Type) a b c. Monad m => Fold m a b -> Fold m a c -> Fold m a (b, c)
- drive :: Monad m => Stream m a -> Fold m a b -> m b
- addStream :: Monad m => Stream m a -> Fold m a b -> m (Fold m a b)
- foldMapM :: (Monad m, Monoid b) => (a -> m b) -> Fold m a b
- drainMapM :: Monad m => (a -> m b) -> Fold m a ()
- mean :: forall (m :: Type -> Type) a. (Monad m, Fractional a) => Fold m a a
- rollingHash :: forall (m :: Type -> Type) a. (Monad m, Enum a) => Fold m a Int64
- rollingHashWithSalt :: forall (m :: Type -> Type) a. (Monad m, Enum a) => Int64 -> Fold m a Int64
- topBy :: forall (m :: Type -> Type) a. (MonadIO m, Unbox a) => (a -> a -> Ordering) -> Int -> Fold m a (MutArray a)
- uniqBy :: forall (m :: Type -> Type) a. Monad m => (a -> a -> Bool) -> Fold m a (Maybe a)
- takeEndBySeq :: forall (m :: Type -> Type) a b. (MonadIO m, Unbox a, Enum a, Eq a) => Array a -> Fold m a b -> Fold m a b
- takeEndBySeq_ :: forall (m :: Type -> Type) a b. (MonadIO m, Unbox a, Enum a, Eq a) => Array a -> Fold m a b -> Fold m a b
- distribute :: forall (m :: Type -> Type) a b. Monad m => [Fold m a b] -> Fold m a [b]
- variance :: forall (m :: Type -> Type) a. (Monad m, Fractional a) => Fold m a a
- stdDev :: forall (m :: Type -> Type) a. (Monad m, Floating a) => Fold m a a
- mapMaybeM :: Monad m => (a -> m (Maybe b)) -> Fold m b r -> Fold m a r
- unfoldMany :: forall (m :: Type -> Type) a b c. Monad m => Unfold m a b -> Fold m b c -> Fold m a c
- rollingHashFirstN :: forall (m :: Type -> Type) a. (Monad m, Enum a) => Int -> Fold m a Int64
- rangeBy :: forall (m :: Type -> Type) a. Monad m => (a -> a -> Ordering) -> Fold m a (Maybe (a, a))
- toStreamRev :: forall (m :: Type -> Type) (n :: Type -> Type) a. (Monad m, Monad n) => Fold m a (Stream n a)
- top :: forall (m :: Type -> Type) a. (MonadIO m, Unbox a, Ord a) => Int -> Fold m a (MutArray a)
- bottomBy :: forall (m :: Type -> Type) a. (MonadIO m, Unbox a) => (a -> a -> Ordering) -> Int -> Fold m a (MutArray a)
- bottom :: forall (m :: Type -> Type) a. (MonadIO m, Unbox a, Ord a) => Int -> Fold m a (MutArray a)
- rollingMap :: forall (m :: Type -> Type) a b. Monad m => (Maybe a -> a -> b) -> Fold m a b
- rollingMapM :: Monad m => (Maybe a -> a -> m b) -> Fold m a b
- uniq :: forall (m :: Type -> Type) a. (Monad m, Eq a) => Fold m a (Maybe a)
- repeated :: forall (m :: Type -> Type) a. Fold m a (Maybe a)
- drainN :: forall (m :: Type -> Type) a. Monad m => Int -> Fold m a ()
- takingEndByM :: Monad m => (a -> m Bool) -> Fold m a (Maybe a)
- takingEndBy :: forall (m :: Type -> Type) a. Monad m => (a -> Bool) -> Fold m a (Maybe a)
- takingEndByM_ :: Monad m => (a -> m Bool) -> Fold m a (Maybe a)
- takingEndBy_ :: forall (m :: Type -> Type) a. Monad m => (a -> Bool) -> Fold m a (Maybe a)
- droppingWhileM :: Monad m => (a -> m Bool) -> Fold m a (Maybe a)
- droppingWhile :: forall (m :: Type -> Type) a. Monad m => (a -> Bool) -> Fold m a (Maybe a)
- prune :: forall a (m :: Type -> Type). (a -> Bool) -> Fold m a (Maybe a)
- slide2 :: forall (m :: Type -> Type) a b. Monad m => Fold m (a, Maybe a) b -> Fold m a b
- pipe :: forall (m :: Type -> Type) a b c. Monad m => Pipe m a b -> Fold m b c -> Fold m a c
- zipStreamWithM :: (a -> b -> m c) -> Stream m a -> Fold m c x -> Fold m b x
- zipStream :: forall (m :: Type -> Type) a b x. Monad m => Stream m a -> Fold m (a, b) x -> Fold m b x
- distributeScan :: Monad m => m [Fold m a b] -> Scanl m a [b]
- unzipWithM :: Monad m => (a -> m (b, c)) -> Fold m b x -> Fold m c y -> Fold m a (x, y)
- unzipWithFstM :: Monad m => (a -> m (b, c)) -> Fold m b x -> Fold m c y -> Fold m a (x, y)
- unzipWithMinM :: Monad m => (a -> m (b, c)) -> Fold m b x -> Fold m c y -> Fold m a (x, y)
- partitionByM :: Monad m => (a -> m (Either b c)) -> Fold m b x -> Fold m c y -> Fold m a (x, y)
- partitionByFstM :: Monad m => (a -> m (Either b c)) -> Fold m b x -> Fold m c y -> Fold m a (x, y)
- partitionByMinM :: Monad m => (a -> m (Either b c)) -> Fold m b x -> Fold m c y -> Fold m a (x, y)
- partitionBy :: forall (m :: Type -> Type) a b c x y. Monad m => (a -> Either b c) -> Fold m b x -> Fold m c y -> Fold m a (x, y)
- chunksBetween :: forall (m :: Type -> Type) a b c. Int -> Int -> Fold m a b -> Fold m b c -> Fold m a c
- intersperseWithQuotes :: forall (m :: Type -> Type) a b c. (Monad m, Eq a) => a -> a -> a -> Fold m a b -> Fold m b c -> Fold m a c
- concatSequence :: forall (m :: Type -> Type) b c t a. Fold m b c -> t (Fold m a b) -> Fold m a c
- indexingWith :: forall (m :: Type -> Type) a. Monad m => Int -> (Int -> Int) -> Fold m a (Maybe (Int, a))
- indexing :: forall (m :: Type -> Type) a. Monad m => Fold m a (Maybe (Int, a))
- indexingRev :: forall (m :: Type -> Type) a. Monad m => Int -> Fold m a (Maybe (Int, a))
- defaultSalt :: Int64
- nub :: forall (m :: Type -> Type) a. (Monad m, Ord a) => Fold m a (Maybe a)
- nubInt :: forall (m :: Type -> Type). Monad m => Fold m Int (Maybe Int)
- countDistinct :: forall (m :: Type -> Type) a. (Monad m, Ord a) => Fold m a Int
- countDistinctInt :: forall (m :: Type -> Type). Monad m => Fold m Int Int
- frequency :: forall (m :: Type -> Type) a. (Monad m, Ord a) => Fold m a (Map a Int)
- toSet :: forall (m :: Type -> Type) a. (Monad m, Ord a) => Fold m a (Set a)
- toIntSet :: forall (m :: Type -> Type). Monad m => Fold m Int IntSet
- toMap :: forall (m :: Type -> Type) k a b. (Monad m, Ord k) => (a -> k) -> Fold m a b -> Fold m a (Map k b)
- toMapIO :: forall (m :: Type -> Type) k a b. (MonadIO m, Ord k) => (a -> k) -> Fold m a b -> Fold m a (Map k b)
- demuxerToMap :: (Monad m, Ord k) => (a -> k) -> (k -> m (Maybe (Fold m a b))) -> Fold m a (Map k b)
- demuxerToMapIO :: (MonadIO m, Ord k) => (a -> k) -> (k -> m (Maybe (Fold m a b))) -> Fold m a (Map k b)
- classify :: (Monad m, Ord k) => (a -> k) -> Fold m a b -> Fold m a (m (Map k b), Maybe (k, b))
- classifyIO :: (MonadIO m, Ord k) => (a -> k) -> Fold m a b -> Fold m a (m (Map k b), Maybe (k, b))
- demux :: (Monad m, Ord k) => (a -> k) -> (a -> m (Fold m a b)) -> Fold m a (m (Map k b), Maybe (k, b))
- demuxIO :: (MonadIO m, Ord k) => (a -> k) -> (a -> m (Fold m a b)) -> Fold m a (m (Map k b), Maybe (k, b))
- demuxToMap :: (Monad m, Ord k) => (a -> k) -> (a -> m (Fold m a b)) -> Fold m a (Map k b)
- demuxToMapIO :: (MonadIO m, Ord k) => (a -> k) -> (a -> m (Fold m a b)) -> Fold m a (Map k b)
- demuxerToContainer :: (Monad m, IsMap f, Traversable f) => (a -> Key f) -> (Key f -> m (Maybe (Fold m a b))) -> Fold m a (f b)
- demuxerToContainerIO :: (MonadIO m, IsMap f, Traversable f) => (a -> Key f) -> (Key f -> m (Maybe (Fold m a b))) -> Fold m a (f b)
- demuxKvToContainer :: (Monad m, IsMap f, Traversable f) => (Key f -> m (Maybe (Fold m a b))) -> Fold m (Key f, a) (f b)
- demuxKvToMap :: (Monad m, Ord k) => (k -> m (Maybe (Fold m a b))) -> Fold m (k, a) (Map k b)
- demuxScanGeneric :: (Monad m, IsMap f, Traversable f) => (a -> Key f) -> (Key f -> m (Maybe (Fold m a b))) -> Scanl m a (m (f b), Maybe (Key f, b))
- demuxScan :: (Monad m, Ord k) => (a -> k) -> (k -> m (Maybe (Fold m a b))) -> Scanl m a (Maybe (k, b))
- demuxScanGenericIO :: (MonadIO m, IsMap f, Traversable f) => (a -> Key f) -> (Key f -> m (Maybe (Fold m a b))) -> Scanl m a (m (f b), Maybe (Key f, b))
- demuxScanIO :: (MonadIO m, Ord k) => (a -> k) -> (k -> m (Maybe (Fold m a b))) -> Scanl m a (Maybe (k, b))
- kvToMap :: forall (m :: Type -> Type) k a b. (Monad m, Ord k) => Fold m a b -> Fold m (k, a) (Map k b)
- toContainer :: forall (m :: Type -> Type) f a b. (Monad m, IsMap f, Traversable f) => (a -> Key f) -> Fold m a b -> Fold m a (f b)
- toContainerIO :: forall (m :: Type -> Type) f a b. (MonadIO m, IsMap f, Traversable f) => (a -> Key f) -> Fold m a b -> Fold m a (f b)
- classifyScanGeneric :: (Monad m, IsMap f, Traversable f, Ord (Key f)) => (a -> Key f) -> Fold m a b -> Scanl m a (m (f b), Maybe (Key f, b))
- classifyScan :: forall (m :: Type -> Type) k a b. (MonadIO m, Ord k) => (a -> k) -> Fold m a b -> Scanl m a (Maybe (k, b))
- classifyScanGenericIO :: (MonadIO m, IsMap f, Traversable f, Ord (Key f)) => (a -> Key f) -> Fold m a b -> Scanl m a (m (f b), Maybe (Key f, b))
- classifyScanIO :: forall (m :: Type -> Type) k a b. (MonadIO m, Ord k) => (a -> k) -> Fold m a b -> Scanl m a (Maybe (k, b))
- demuxGeneric :: (Monad m, IsMap f, Traversable f) => (a -> Key f) -> (a -> m (Fold m a b)) -> Fold m a (m (f b), Maybe (Key f, b))
- demuxGenericIO :: (MonadIO m, IsMap f, Traversable f) => (a -> Key f) -> (a -> m (Fold m a b)) -> Fold m a (m (f b), Maybe (Key f, b))
- demuxToContainer :: (Monad m, IsMap f, Traversable f) => (a -> Key f) -> (a -> m (Fold m a b)) -> Fold m a (f b)
- demuxToContainerIO :: (MonadIO m, IsMap f, Traversable f) => (a -> Key f) -> (a -> m (Fold m a b)) -> Fold m a (f b)
- classifyGeneric :: (Monad m, IsMap f, Traversable f, Ord (Key f)) => (a -> Key f) -> Fold m a b -> Fold m a (m (f b), Maybe (Key f, b))
- classifyGenericIO :: (MonadIO m, IsMap f, Traversable f, Ord (Key f)) => (a -> Key f) -> Fold m a b -> Fold m a (m (f b), Maybe (Key f, b))
- windowLmap :: forall c a (m :: Type -> Type) b. (c -> a) -> Fold m (a, Maybe a) b -> Fold m (c, Maybe c) b
- cumulative :: forall (m :: Type -> Type) a b. Fold m (a, Maybe a) b -> Fold m a b
- windowRollingMap :: forall (m :: Type -> Type) a b. Monad m => (Maybe a -> a -> Maybe b) -> Fold m (a, Maybe a) (Maybe b)
- windowRollingMapM :: Monad m => (Maybe a -> a -> m (Maybe b)) -> Fold m (a, Maybe a) (Maybe b)
- windowLength :: forall (m :: Type -> Type) b a. (Monad m, Num b) => Fold m (a, Maybe a) b
- windowSum :: forall (m :: Type -> Type) a. (Monad m, Num a) => Fold m (a, Maybe a) a
- windowSumInt :: forall (m :: Type -> Type) a. (Monad m, Integral a) => Fold m (a, Maybe a) a
- windowPowerSum :: forall (m :: Type -> Type) a. (Monad m, Num a) => Int -> Fold m (a, Maybe a) a
- windowPowerSumFrac :: forall (m :: Type -> Type) a. (Monad m, Floating a) => a -> Fold m (a, Maybe a) a
- windowMinimum :: forall (m :: Type -> Type) a. (MonadIO m, Unbox a, Ord a) => Int -> Fold m a (Maybe a)
- windowMaximum :: forall (m :: Type -> Type) a. (MonadIO m, Unbox a, Ord a) => Int -> Fold m a (Maybe a)
- windowRange :: forall (m :: Type -> Type) a. (MonadIO m, Unbox a, Ord a) => Int -> Fold m a (Maybe (a, a))
- windowMean :: forall (m :: Type -> Type) a. (Monad m, Fractional a) => Fold m (a, Maybe a) a
- onException :: MonadCatch m => m x -> Fold m a b -> Fold m a b
- bracketIO :: forall (m :: Type -> Type) x c a b. (MonadIO m, MonadCatch m) => IO x -> (x -> IO c) -> (x -> Fold m a b) -> Fold m a b
- before :: Monad m => m x -> Fold m a b -> Fold m a b
- finallyIO :: forall (m :: Type -> Type) b a. (MonadIO m, MonadCatch m) => IO b -> Fold m a b -> Fold m a b
Imports
>>>:m>>>:set -XFlexibleContexts>>>import Control.Monad (void)>>>import qualified Data.Foldable as Foldable>>>import Data.Bifunctor(bimap)>>>import Data.Function ((&))>>>import Data.Functor.Identity (Identity, runIdentity)>>>import Data.IORef (newIORef, readIORef, writeIORef)>>>import Data.Maybe (fromJust, isJust)>>>import Data.Monoid (Endo(..), Last(..), Sum(..))
>>>import Streamly.Data.Array (Array)>>>import Streamly.Data.Fold (Fold, Tee(..))>>>import Streamly.Data.Stream (Stream)
>>>import qualified Data.Map as Map>>>import qualified Data.Set as Set>>>import qualified Data.IntSet as IntSet>>>import qualified Streamly.Data.Array as Array>>>import qualified Streamly.Data.Fold as Fold>>>import qualified Streamly.Data.MutArray as MutArray>>>import qualified Streamly.Data.Parser as Parser>>>import qualified Streamly.Data.Stream as Stream>>>import qualified Streamly.Data.StreamK as StreamK>>>import qualified Streamly.Data.Unfold as Unfold
For APIs that have not been released yet.
>>>import qualified Streamly.Internal.Data.Fold as Fold>>>import qualified Streamly.Internal.Data.Scanl as Scanl>>>import qualified Streamly.Internal.Data.Stream as Stream
foldr :: forall (m :: Type -> Type) a b. Monad m => (a -> b -> b) -> b -> Fold m a b Source #
Deprecated: Please use foldr' instead.
length :: forall (m :: Type -> Type) a. Monad m => Fold m a Int Source #
Determine the length of the input stream.
Definition:
>>>length = Fold.genericLength>>>length = fmap getSum $ Fold.foldMap (Sum . const 1)
foldl' :: forall (m :: Type -> Type) b a. Monad m => (b -> a -> b) -> b -> Fold m a b Source #
Make a fold from a left fold style pure step function and initial value of the accumulator.
If your Fold returns only Partial (i.e. never returns a Done) then you
 can use foldl'* constructors.
A fold with an extract function can be expressed using fmap:
mkfoldlx :: Monad m => (s -> a -> s) -> s -> (s -> b) -> Fold m a b mkfoldlx step initial extract = fmap extract (foldl' step initial)
filter :: forall (m :: Type -> Type) a r. Monad m => (a -> Bool) -> Fold m a r -> Fold m a r Source #
Include only those elements that pass a predicate.
>>>Stream.fold (Fold.filter (> 5) Fold.sum) $ Stream.fromList [1..10]40
>>>filter p = Fold.filterM (return . p)>>>filter p = Fold.mapMaybe (\x -> if p x then Just x else Nothing)
toList :: forall (m :: Type -> Type) a. Monad m => Fold m a [a] Source #
Folds the input stream to a list.
Warning! working on large lists accumulated as buffers in memory could be very inefficient, consider using Streamly.Data.Array instead.
>>>toList = Fold.foldr' (:) []
many :: forall (m :: Type -> Type) a b c. Monad m => Fold m a b -> Fold m b c -> Fold m a c Source #
Collect zero or more applications of a fold.  many first second applies
 the first fold repeatedly on the input stream and accumulates it's results
 using the second fold.
>>>two = Fold.take 2 Fold.toList>>>twos = Fold.many two Fold.toList>>>Stream.fold twos $ Stream.fromList [1..10][[1,2],[3,4],[5,6],[7,8],[9,10]]
Stops when second fold stops.
last :: forall (m :: Type -> Type) a. Monad m => Fold m a (Maybe a) Source #
Deprecated: Please use latest instead.
foldl1' :: forall (m :: Type -> Type) a. Monad m => (a -> a -> a) -> Fold m a (Maybe a) Source #
Make a strict left fold, for non-empty streams, using first element as the starting value. Returns Nothing if the stream is empty.
Pre-release
scanl :: forall (m :: Type -> Type) a b c. Monad m => Scanl m a b -> Fold m b c -> Fold m a c Source #
foldr' :: forall (m :: Type -> Type) a b. Monad m => (a -> b -> b) -> b -> Fold m a b Source #
Make a fold using a right fold style step function and a terminal value. It performs a strict right fold via a left fold using function composition. Note that a strict right fold can only be useful for constructing strict structures in memory. For reductions this will be very inefficient.
Definitions:
>>>foldr' f z = fmap (flip appEndo z) $ Fold.foldMap (Endo . f)>>>foldr' f z = fmap ($ z) $ Fold.foldl' (\g x -> g . f x) id
Example:
>>>Stream.fold (Fold.foldr' (:) []) $ Stream.enumerateFromTo 1 5[1,2,3,4,5]
take :: forall (m :: Type -> Type) a b. Monad m => Int -> Fold m a b -> Fold m a b Source #
Take at most n input elements and fold them using the supplied fold. A
 negative count is treated as 0.
>>>Stream.fold (Fold.take 2 Fold.toList) $ Stream.fromList [1..10][1,2]
concatMap :: forall (m :: Type -> Type) b a c. Monad m => (b -> Fold m a c) -> Fold m a b -> Fold m a c Source #
Map a Fold returning function on the result of a Fold and run the
 returned fold. This is akin to an n-ary version of splitWith where the
 next fold for splitting the input is decided dynamically using the previous
 result. This operation can be used to express data dependencies
 between fold operations.
Let's say the first element in the stream is a count of the following elements that we have to add, then:
>>>import Data.Maybe (fromJust)>>>count = fmap fromJust Fold.one>>>total n = Fold.take n Fold.sum>>>Stream.fold (Fold.concatMap total count) $ Stream.fromList [10,9..1]45
This does not fuse completely, see refold for a fusible alternative.
Time: O(n^2) where n is the number of compositions.
See also: foldIterateM, refold
reduce :: Monad m => Fold m a b -> m (Fold m a b) Source #
Evaluate the initialization effect of a fold. If we are building the fold by chaining lazy actions in fold init this would reduce the actions to a strict accumulator value.
Pre-release
close :: forall (m :: Type -> Type) a b. Monad m => Fold m a b -> Fold m a b Source #
Close a fold so that it does not accept any more input.
filterM :: Monad m => (a -> m Bool) -> Fold m a r -> Fold m a r Source #
Like filter but with a monadic predicate.
>>>f p x = p x >>= \r -> return $ if r then Just x else Nothing>>>filterM p = Fold.mapMaybeM (f p)
duplicate :: forall (m :: Type -> Type) a b. Monad m => Fold m a b -> Fold m a (Fold m a b) Source #
duplicate provides the ability to run a fold in parts.  The duplicated
 fold consumes the input and returns the same fold as output instead of
 returning the final result, the returned fold can be run later to consume
 more input.
duplicate essentially appends a stream to the fold without finishing the
 fold.  Compare with snoc which appends a singleton value to the fold.
Pre-release
snoc :: Monad m => Fold m a b -> a -> m (Fold m a b) Source #
Append a singleton value to the fold, in other words run a single step of the fold.
Example:
>>>import qualified Data.Foldable as Foldable>>>Foldable.foldlM Fold.snoc Fold.toList [1..3] >>= Fold.drive Stream.nil[1,2,3]
Pre-release
splitWith :: forall (m :: Type -> Type) a b c x. Monad m => (a -> b -> c) -> Fold m x a -> Fold m x b -> Fold m x c Source #
Sequential fold application. Apply two folds sequentially to an input stream. The input is provided to the first fold, when it is done - the remaining input is provided to the second fold. When the second fold is done or if the input stream is over, the outputs of the two folds are combined using the supplied function.
Example:
>>>header = Fold.take 8 Fold.toList>>>line = Fold.takeEndBy (== '\n') Fold.toList>>>f = Fold.splitWith (,) header line>>>Stream.fold f $ Stream.fromList "header: hello\n"("header: ","hello\n")
Note: This is dual to appending streams using append.
Note: this implementation allows for stream fusion but has quadratic time complexity, because each composition adds a new branch that each subsequent fold's input element has to traverse, therefore, it cannot scale to a large number of compositions. After around 100 compositions the performance starts dipping rapidly compared to a CPS style implementation.
For larger number of compositions you can convert the fold to a parser and use ParserK.
Time: O(n^2) where n is the number of compositions.
Represents the result of the step of a Fold.  Partial returns an
 intermediate state of the fold, the fold step can be called again with the
 state or the driver can use extract on the state to get the result out.
 Done returns the final result and the fold cannot be driven further.
Pre-release
lmapM :: Monad m => (a -> m b) -> Fold m b r -> Fold m a r Source #
lmapM f fold maps the monadic function f on the input of the fold.
rmapM :: Monad m => (b -> m c) -> Fold m a b -> Fold m a c Source #
Map a monadic function on the output of a fold.
mapMStep :: Applicative m => (a -> m b) -> Step s a -> m (Step s b) Source #
Map a monadic function over the result b in Step s b.
Internal
fromPure :: forall (m :: Type -> Type) b a. Applicative m => b -> Fold m a b Source #
Make a fold that yields the supplied value without consuming any further input.
Pre-release
data Fold (m :: Type -> Type) a b Source #
The type Fold m a b represents a consumer of an input stream of values
 of type a and returning a final value of type b in Monad m. The
 constructor of a fold is Fold step initial extract final.
The fold uses an internal state of type s. The initial value of the state
 s is created by initial. This function is called once and only once
 before the fold starts consuming input. Any resource allocation can be done
 in this function.
The step function is called on each input, it consumes an input and
 returns the next intermediate state (see Step) or the final result b if
 the fold terminates.
Folds are no longer used for scanning, please see the Scanl
 module for scanning. The extract operation is no longer used and will be
 removed in future.
Before a fold terminates, final is called once and only once (unless the
 fold terminated in initial itself). Any resources allocated by initial
 can be released in final.
When implementing fold combinators, care should be taken to cleanup any
 state of the argument folds held by the fold by calling the respective
 final at all exit points of the fold. Also, final should not be called
 more than once. Note that if a fold terminates by Done constructor, there
 is no state to cleanup.
NOTE: The constructor is not yet released, smart constructors are provided to create folds.
Constructors
| Fold (s -> a -> m (Step s b)) (m (Step s b)) (s -> m b) (s -> m b) | 
 | 
Instances
| Monad m => Applicative (Fold m a) Source # | 
 | 
| Defined in Streamly.Internal.Data.Fold.Type | |
| Functor m => Functor (Fold m a) Source # | Maps a function on the output of the fold (the type  | 
toStreamK :: forall (m :: Type -> Type) a (n :: Type -> Type). Monad m => Fold m a (StreamK n a) Source #
A fold that buffers its input to a pure stream.
>>>toStreamK = foldr StreamK.cons StreamK.nil>>>toStreamK = fmap StreamK.reverse Fold.toStreamKRev
Internal
morphInner :: (forall x. m x -> n x) -> Fold m a b -> Fold n a b Source #
Change the underlying monad of a fold. Also known as hoist.
Pre-release
postscan :: forall (m :: Type -> Type) a b c. Monad m => Fold m a b -> Fold m b c -> Fold m a c Source #
scanlMany :: forall (m :: Type -> Type) a b c. Monad m => Scanl m a b -> Fold m b c -> Fold m a c Source #
scan :: forall (m :: Type -> Type) a b c. Monad m => Fold m a b -> Fold m b c -> Fold m a c Source #
scanMany :: forall (m :: Type -> Type) a b c. Monad m => Fold m a b -> Fold m b c -> Fold m a c Source #
takeEndBy :: forall (m :: Type -> Type) a b. Monad m => (a -> Bool) -> Fold m a b -> Fold m a b Source #
Take the input, stop when the predicate succeeds taking the succeeding element as well.
Example:
>>>input = Stream.fromList "hello\nthere\n">>>line = Fold.takeEndBy (== '\n') Fold.toList>>>Stream.fold line input"hello\n"
>>>Stream.fold Fold.toList $ Stream.foldMany line input["hello\n","there\n"]
takeEndBy_ :: forall (m :: Type -> Type) a b. Monad m => (a -> Bool) -> Fold m a b -> Fold m a b Source #
Like takeEndBy but drops the element on which the predicate succeeds.
Example:
>>>input = Stream.fromList "hello\nthere\n">>>line = Fold.takeEndBy_ (== '\n') Fold.toList>>>Stream.fold line input"hello"
>>>Stream.fold Fold.toList $ Stream.foldMany line input["hello","there"]
teeWith :: forall (m :: Type -> Type) a b c x. Monad m => (a -> b -> c) -> Fold m x a -> Fold m x b -> Fold m x c Source #
teeWith k f1 f2 distributes its input to both f1 and f2 until both
 of them terminate and combines their output using k.
Definition:
>>>teeWith k f1 f2 = fmap (uncurry k) (Fold.tee f1 f2)
Example:
>>>avg = Fold.teeWith (/) Fold.sum (fmap fromIntegral Fold.length)>>>Stream.fold avg $ Stream.fromList [1.0..100.0]50.5
For applicative composition using this combinator see Streamly.Data.Fold.Tee.
See also: Streamly.Data.Fold.Tee
Note that nested applications of teeWith do not fuse.
lmap :: forall a b (m :: Type -> Type) r. (a -> b) -> Fold m b r -> Fold m a r Source #
lmap f fold maps the function f on the input of the fold.
Definition:
>>>lmap = Fold.lmapM return
Example:
>>>sumSquared = Fold.lmap (\x -> x * x) Fold.sum>>>Stream.fold sumSquared (Stream.enumerateFromTo 1 100)338350
refoldMany :: forall (m :: Type -> Type) a b x c. Monad m => Fold m a b -> Refold m x b c -> Refold m x a c Source #
groupsOf :: forall (m :: Type -> Type) a b c. Monad m => Int -> Fold m a b -> Fold m b c -> Fold m a c Source #
groupsOf n split collect repeatedly applies the split fold to chunks
 of n items in the input stream and supplies the result to the collect
 fold.
Definition:
>>>groupsOf n split = Fold.many (Fold.take n split)
Example:
>>>twos = Fold.groupsOf 2 Fold.toList Fold.toList>>>Stream.fold twos $ Stream.fromList [1..10][[1,2],[3,4],[5,6],[7,8],[9,10]]
Stops when collect stops.
drain :: forall (m :: Type -> Type) a. Monad m => Fold m a () Source #
A fold that drains all its input, running the effects and discarding the results.
>>>drain = Fold.drainMapM (const (return ()))>>>drain = Fold.foldl' (\_ _ -> ()) ()
foldlM' :: Monad m => (b -> a -> m b) -> m b -> Fold m a b Source #
Make a fold from a left fold style monadic step function and initial value of the accumulator.
A fold with an extract function can be expressed using rmapM:
mkFoldlxM :: Functor m => (s -> a -> m s) -> m s -> (s -> m b) -> Fold m a b mkFoldlxM step initial extract = rmapM extract (foldlM' step initial)
addOne :: Monad m => a -> Fold m a b -> m (Fold m a b) Source #
Append a singleton value to the fold.
See examples under addStream.
Pre-release
foldl1M' :: Monad m => (a -> a -> m a) -> Fold m a (Maybe a) Source #
Like 'foldl1'' but with a monadic step function.
Pre-release
foldtM' :: (s -> a -> m (Step s b)) -> m (Step s b) -> (s -> m b) -> Fold m a b Source #
Make a terminating fold with an effectful step function and initial state, and a state extraction function.
>>>foldtM' = Fold.Fold
We can just use Fold but it is provided for completeness.
Pre-release
toListRev :: forall (m :: Type -> Type) a. Monad m => Fold m a [a] Source #
Buffers the input stream to a list in the reverse order of the input.
Definition:
>>>toListRev = Fold.foldl' (flip (:)) []
Warning! working on large lists accumulated as buffers in memory could be very inefficient, consider using Streamly.Array instead.
latest :: forall (m :: Type -> Type) a. Monad m => Fold m a (Maybe a) Source #
Returns the latest element of the input stream, if any.
>>>latest = Fold.foldl1' (\_ x -> x)>>>latest = fmap getLast $ Fold.foldMap (Last . Just)
catLefts :: forall (m :: Type -> Type) a c b. Monad m => Fold m a c -> Fold m (Either a b) c Source #
catRights :: forall (m :: Type -> Type) b c a. Monad m => Fold m b c -> Fold m (Either a b) c Source #
catEithers :: forall (m :: Type -> Type) a b. Fold m a b -> Fold m (Either a a) b Source #
Remove the either wrapper and flatten both lefts and as well as rights in the output stream.
Definition:
>>>catEithers = Fold.lmap (either id id)
Pre-release
postscanl :: forall (m :: Type -> Type) a b c. Monad m => Scanl m a b -> Fold m b c -> Fold m a c Source #
postscanl scanner collector postscans the input of the collector fold
 to change it in a stateful manner using scanner.
Pre-release
foldlM1' :: Monad m => (a -> a -> m a) -> Fold m a (Maybe a) Source #
Deprecated: Please use foldl1M' instead
Like 'foldl1'' but with a monadic step function.
Pre-release
serialWith :: forall (m :: Type -> Type) a b c x. Monad m => (a -> b -> c) -> Fold m x a -> Fold m x b -> Fold m x c Source #
Deprecated: Please use "splitWith" instead
scanMaybe :: forall (m :: Type -> Type) a b c. Monad m => Fold m a (Maybe b) -> Fold m b c -> Fold m a c Source #
Deprecated: Please use postscanlMaybe instead.
Use a Maybe returning fold as a filtering scan.
> scanMaybe p f = Fold.postscan p (Fold.catMaybes f)
Pre-release
fromEffect :: Applicative m => m b -> Fold m a b Source #
Make a fold that yields the result of the supplied effectful action without consuming any further input.
Pre-release
postscanlMaybe :: forall (m :: Type -> Type) a b c. Monad m => Scanl m a (Maybe b) -> Fold m b c -> Fold m a c Source #
Use a Maybe returning left scan for filtering the input of a fold.
>>>scanlMaybe p f = Fold.postscanl p (Fold.catMaybes f)
Pre-release
chainStepM :: Applicative m => (s1 -> m s2) -> (a -> m (Step s2 b)) -> Step s1 a -> m (Step s2 b) Source #
foldt' :: forall (m :: Type -> Type) s a b. Monad m => (s -> a -> Step s b) -> Step s b -> (s -> b) -> Fold m a b Source #
Make a terminating fold using a pure step function, a pure initial state and a pure state extraction function.
Pre-release
foldrM' :: Monad m => (a -> b -> m b) -> m b -> Fold m a b Source #
Like foldr' but with a monadic step function.
Example:
>>>toList = Fold.foldrM' (\a xs -> return $ a : xs) (return [])
See also: foldrM
Pre-release
fromRefold :: forall (m :: Type -> Type) c a b. Refold m c a b -> c -> Fold m a b Source #
Make a fold from a consumer.
Internal
fromScanl :: forall (m :: Type -> Type) a b. Scanl m a b -> Fold m a b Source #
Convert a left scan to a fold.
toStreamKRev :: forall (m :: Type -> Type) a (n :: Type -> Type). Monad m => Fold m a (StreamK n a) Source #
Buffers the input stream to a pure stream in the reverse order of the input.
>>>toStreamKRev = Foldable.foldl' (flip StreamK.cons) StreamK.nil
This is more efficient than toStreamK. toStreamK has exactly the same
 performance as reversing the stream after toStreamKRev.
Pre-release
filtering :: forall (m :: Type -> Type) a. Monad m => (a -> Bool) -> Fold m a (Maybe a) Source #
A scanning fold for filtering elements based on a predicate.
ifThen :: Monad m => m Bool -> Fold m a b -> Fold m a b -> Fold m a b Source #
Evaluate a condition, if True then use the first fold otherwise use the second fold.
split_ :: forall (m :: Type -> Type) x a b. Monad m => Fold m x a -> Fold m x b -> Fold m x b Source #
Same as applicative *>. Run two folds serially one after the other
 discarding the result of the first.
This was written in the hope that it might be faster than implementing it using splitWith, but the current benchmarks show that it has the same performance. So do not expose it unless some benchmark shows benefit.
manyPost :: forall (m :: Type -> Type) a b c. Monad m => Fold m a b -> Fold m b c -> Fold m a c Source #
refoldMany1 :: forall (m :: Type -> Type) x a b c. Monad m => Refold m x a b -> Fold m b c -> Refold m x a c Source #
refold :: forall (m :: Type -> Type) b a c. Monad m => Refold m b a c -> Fold m a b -> Fold m a c Source #
teeWithFst :: forall (m :: Type -> Type) b c d a. Monad m => (b -> c -> d) -> Fold m a b -> Fold m a c -> Fold m a d Source #
Like teeWith but terminates as soon as the first fold terminates.
Pre-release
teeWithMin :: forall (m :: Type -> Type) b c d a. Monad m => (b -> c -> d) -> Fold m a b -> Fold m a c -> Fold m a d Source #
Like teeWith but terminates as soon as any one of the two folds
 terminates.
Pre-release
shortest :: forall (m :: Type -> Type) x a b. Monad m => Fold m x a -> Fold m x b -> Fold m x (Either a b) Source #
Shortest alternative. Apply both folds in parallel but choose the result from the one which consumed least input i.e. take the shortest succeeding fold.
If both the folds finish at the same time or if the result is extracted before any of the folds could finish then the left one is taken.
Pre-release
longest :: forall (m :: Type -> Type) x a b. Monad m => Fold m x a -> Fold m x b -> Fold m x (Either a b) Source #
Longest alternative. Apply both folds in parallel but choose the result from the one which consumed more input i.e. take the longest succeeding fold.
If both the folds finish at the same time or if the result is extracted before any of the folds could finish then the left one is taken.
Pre-release
snocM :: Monad m => Fold m a b -> m a -> m (Fold m a b) Source #
Append a singleton value to the fold in other words run a single step of the fold.
Definition:
>>>snocM f = Fold.reduce . Fold.snoclM f
Pre-release
snocl :: forall (m :: Type -> Type) a b. Monad m => Fold m a b -> a -> Fold m a b Source #
Append a singleton value to the fold lazily, in other words run a single step of the fold.
Definition:
>>>snocl f = Fold.snoclM f . return
Example:
>>>import qualified Data.Foldable as Foldable>>>Fold.finalM $ Foldable.foldl Fold.snocl Fold.toList [1..3][1,2,3]
Pre-release
snoclM :: Monad m => Fold m a b -> m a -> Fold m a b Source #
Append an effect to the fold lazily, in other words run a single step of the fold.
Pre-release
finalM :: Monad m => Fold m a b -> m b Source #
Finalize a fold and extract the accumulated result of the fold.
Definition:
>>>finalM = Fold.drive Stream.nil
Example:
>>>Fold.finalM Fold.toList[]
Pre-release
isClosed :: Monad m => Fold m a b -> m Bool Source #
Check if the fold has terminated and can take no more input.
Pre-release
generalizeInner :: forall (m :: Type -> Type) a b. Monad m => Fold Identity a b -> Fold m a b Source #
Adapt a pure fold to any monad.
>>>generalizeInner = Fold.morphInner (return . runIdentity)
Pre-release
extractM :: Monad m => Fold m a b -> m b Source #
Deprecated: Please use finalM instead
Extract the accumulated result of the fold.
Definition:
>>>extractM = Fold.drive Stream.nil
Pre-release
toFold :: forall (m :: Type -> Type) a b. Tee m a b -> Fold m a b Source #
Deprecated: Please use unTee instead.
newtype Tee (m :: Type -> Type) a b Source #
Tee is a newtype wrapper over the Fold type providing distributing
 Applicative, Semigroup, Monoid, Num, Floating and Fractional
 instances.
The input received by the composed Tee is replicated and distributed to
 the constituent folds of the Tee.
For example, to compute the average of numbers in a stream without going through the stream twice:
>>>avg = (/) <$> (Tee Fold.sum) <*> (Tee $ fmap fromIntegral Fold.length)>>>Stream.fold (unTee avg) $ Stream.fromList [1.0..100.0]50.5
Similarly, the Semigroup and Monoid instances of Tee distribute the
 input to both the folds and combine the outputs using Monoid or Semigroup
 instances of the output types:
>>>import Data.Monoid (Sum(..))>>>t = Tee Fold.one <> Tee Fold.latest>>>Stream.fold (unTee t) (fmap Sum $ Stream.enumerateFromTo 1.0 100.0)Just (Sum {getSum = 101.0})
The Num, Floating, and Fractional instances work in the same way.
Instances
| Monad m => Applicative (Tee m a) Source # | 
 | 
| Functor m => Functor (Tee m a) Source # | |
| (Monoid b, Monad m) => Monoid (Tee m a b) Source # | 
 | 
| (Semigroup b, Monad m) => Semigroup (Tee m a b) Source # | 
 | 
| (Monad m, Floating b) => Floating (Tee m a b) Source # | Binary  | 
| Defined in Streamly.Internal.Data.Fold.Tee Methods exp :: Tee m a b -> Tee m a b # log :: Tee m a b -> Tee m a b # sqrt :: Tee m a b -> Tee m a b # (**) :: Tee m a b -> Tee m a b -> Tee m a b # logBase :: Tee m a b -> Tee m a b -> Tee m a b # sin :: Tee m a b -> Tee m a b # cos :: Tee m a b -> Tee m a b # tan :: Tee m a b -> Tee m a b # asin :: Tee m a b -> Tee m a b # acos :: Tee m a b -> Tee m a b # atan :: Tee m a b -> Tee m a b # sinh :: Tee m a b -> Tee m a b # cosh :: Tee m a b -> Tee m a b # tanh :: Tee m a b -> Tee m a b # asinh :: Tee m a b -> Tee m a b # acosh :: Tee m a b -> Tee m a b # atanh :: Tee m a b -> Tee m a b # log1p :: Tee m a b -> Tee m a b # expm1 :: Tee m a b -> Tee m a b # | |
| (Monad m, Num b) => Num (Tee m a b) Source # | Binary  | 
| Defined in Streamly.Internal.Data.Fold.Tee | |
| (Monad m, Fractional b) => Fractional (Tee m a b) Source # | Binary  | 
index :: forall (m :: Type -> Type) a. Monad m => Int -> Fold m a (Maybe a) Source #
Return the element at the given index.
Definition:
>>>index = Fold.genericIndex
range :: forall (m :: Type -> Type) a. (Monad m, Ord a) => Fold m a (Maybe (a, a)) Source #
Find minimum and maximum elements i.e. (min, max).
mapMaybe :: forall (m :: Type -> Type) a b r. Monad m => (a -> Maybe b) -> Fold m b r -> Fold m a r Source #
mapMaybe f fold maps a Maybe returning function f on the input of
 the fold, filters out Nothing elements, and return the values extracted
 from Just.
>>>mapMaybe f = Fold.lmap f . Fold.catMaybes>>>mapMaybe f = Fold.mapMaybeM (return . f)
>>>f x = if even x then Just x else Nothing>>>fld = Fold.mapMaybe f Fold.toList>>>Stream.fold fld (Stream.enumerateFromTo 1 10)[2,4,6,8,10]
unzip :: forall (m :: Type -> Type) a x b y. Monad m => Fold m a x -> Fold m b y -> Fold m (a, b) (x, y) Source #
Send the elements of tuples in a stream of tuples through two different folds.
                          |-------Fold m a x--------|
---------stream of (a,b)--|                         |----m (x,y)
                          |-------Fold m b y--------|
Definition:
>>>unzip = Fold.unzipWith id
This is the consumer side dual of the producer side zip operation.
maximumBy :: forall (m :: Type -> Type) a. Monad m => (a -> a -> Ordering) -> Fold m a (Maybe a) Source #
Determine the maximum element in a stream using the supplied comparison function.
minimumBy :: forall (m :: Type -> Type) a. Monad m => (a -> a -> Ordering) -> Fold m a (Maybe a) Source #
Computes the minimum element with respect to the given comparison function
genericIndex :: forall i (m :: Type -> Type) a. (Integral i, Monad m) => i -> Fold m a (Maybe a) Source #
head :: forall (m :: Type -> Type) a. Monad m => Fold m a (Maybe a) Source #
Deprecated: Please use "one" instead
Extract the first element of the stream, if any.
>>>head = Fold.one
mapM :: Monad m => (b -> m c) -> Fold m a b -> Fold m a c Source #
Deprecated: Use rmapM instead
Map a monadic function on the output of a fold.
sequence :: Monad m => Fold m a (m b) -> Fold m a b Source #
Deprecated: Use "rmapM id" instead
Flatten the monadic output of a fold to pure output.
with :: forall (m :: Type -> Type) s a b c. (Fold m (s, a) b -> Fold m a b) -> (((s, a) -> c) -> Fold m (s, a) b -> Fold m (s, a) b) -> ((s, a) -> c) -> Fold m a b -> Fold m a b Source #
Change the predicate function of a Fold from a -> b to accept an
 additional state input (s, a) -> b. Convenient to filter with an
 addiitonal index or time input.
>>>filterWithIndex = Fold.with Fold.indexed Fold.filter
filterWithAbsTime = with timestamped filter filterWithRelTime = with timeIndexed filter
Pre-release
trace :: Monad m => (a -> m b) -> Fold m a r -> Fold m a r Source #
Apply a monadic function to each element flowing through and discard the results.
>>>Stream.fold (Fold.trace print Fold.drain) $ (Stream.enumerateFromTo (1 :: Int) 2)1 2
>>>trace f = Fold.lmapM (Fold.tracing f)
Pre-release
sconcat :: forall (m :: Type -> Type) a. (Monad m, Semigroup a) => a -> Fold m a a Source #
Semigroup concat. Append the elements of an input stream to a provided starting value.
Definition:
>>>sconcat = Fold.foldl' (<>)
>>>semigroups = fmap Data.Monoid.Sum $ Stream.enumerateFromTo 1 10>>>Stream.fold (Fold.sconcat 10) semigroupsSum {getSum = 65}
maybe :: forall (m :: Type -> Type) a b. Monad m => (a -> Maybe b) -> Fold m a (Maybe b) Source #
Consume a single input and transform it using the supplied Maybe
 returning function.
Pre-release
sum :: forall (m :: Type -> Type) a. (Monad m, Num a) => Fold m a a Source #
Determine the sum of all elements of a stream of numbers. Returns additive
 identity (0) when the stream is empty. Note that this is not numerically
 stable for floating point numbers.
>>>sum = Fold.fromScanl (Scanl.cumulativeScan Scanl.incrSum)
Same as following but numerically stable:
>>>sum = Fold.foldl' (+) 0>>>sum = fmap Data.Monoid.getSum $ Fold.foldMap Data.Monoid.Sum
product :: forall (m :: Type -> Type) a. (Monad m, Num a, Eq a) => Fold m a a Source #
Determine the product of all elements of a stream of numbers. Returns
 multiplicative identity (1) when the stream is empty. The fold terminates
 when it encounters (0) in its input.
Same as the following but terminates on multiplication by 0:
>>>product = fmap Data.Monoid.getProduct $ Fold.foldMap Data.Monoid.Product
maximum :: forall (m :: Type -> Type) a. (Monad m, Ord a) => Fold m a (Maybe a) Source #
Determine the maximum element in a stream.
Definitions:
>>>maximum = Fold.maximumBy compare>>>maximum = Fold.foldl1' max
Same as the following but without a default maximum. The Max Monoid uses
 the minBound as the default maximum:
>>>maximum = fmap Data.Semigroup.getMax $ Fold.foldMap Data.Semigroup.Max
minimum :: forall (m :: Type -> Type) a. (Monad m, Ord a) => Fold m a (Maybe a) Source #
Determine the minimum element in a stream using the supplied comparison function.
Definitions:
>>>minimum = Fold.minimumBy compare>>>minimum = Fold.foldl1' min
Same as the following but without a default minimum. The Min Monoid uses the
 maxBound as the default maximum:
>>>maximum = fmap Data.Semigroup.getMin $ Fold.foldMap Data.Semigroup.Min
splitAt :: forall (m :: Type -> Type) a b c. Monad m => Int -> Fold m a b -> Fold m a c -> Fold m a (b, c) Source #
splitAt n f1 f2 composes folds f1 and f2 such that first n
 elements of its input are consumed by fold f1 and the rest of the stream
 is consumed by fold f2.
>>>let splitAt_ n xs = Stream.fold (Fold.splitAt n Fold.toList Fold.toList) $ Stream.fromList xs
>>>splitAt_ 6 "Hello World!"("Hello ","World!")
>>>splitAt_ (-1) [1,2,3]([],[1,2,3])
>>>splitAt_ 0 [1,2,3]([],[1,2,3])
>>>splitAt_ 1 [1,2,3]([1],[2,3])
>>>splitAt_ 3 [1,2,3]([1,2,3],[])
>>>splitAt_ 4 [1,2,3]([1,2,3],[])
splitAt n f1 f2 = Fold.splitWith (,) (Fold.take n f1) f2
Internal
any :: forall (m :: Type -> Type) a. Monad m => (a -> Bool) -> Fold m a Bool Source #
Returns True if any element of the input satisfies the predicate.
Definition:
>>>any p = Fold.lmap p Fold.or
Example:
>>>Stream.fold (Fold.any (== 0)) $ Stream.fromList [1,0,1]True
all :: forall (m :: Type -> Type) a. Monad m => (a -> Bool) -> Fold m a Bool Source #
Returns True if all elements of the input satisfy the predicate.
Definition:
>>>all p = Fold.lmap p Fold.and
Example:
>>>Stream.fold (Fold.all (== 0)) $ Stream.fromList [1,0,1]False
notElem :: forall a (m :: Type -> Type). (Eq a, Monad m) => a -> Fold m a Bool Source #
Returns True if the given element is not present in the stream.
Definition:
>>>notElem a = Fold.all (/= a)
lookup :: forall a (m :: Type -> Type) b. (Eq a, Monad m) => a -> Fold m (a, b) (Maybe b) Source #
In a stream of (key-value) pairs (a, b), return the value b of the
 first pair where the key equals the given value a.
Definition:
>>>lookup x = fmap snd <$> Fold.find ((== x) . fst)
satisfy :: forall (m :: Type -> Type) a. Monad m => (a -> Bool) -> Fold m a (Maybe a) Source #
Consume a single element and return it if it passes the predicate else
 return Nothing.
Definition:
>>>satisfy f = Fold.maybe (\a -> if f a then Just a else Nothing)
Pre-release
find :: forall (m :: Type -> Type) a. Monad m => (a -> Bool) -> Fold m a (Maybe a) Source #
Returns the first element that satisfies the given predicate.
elemIndex :: forall a (m :: Type -> Type). (Eq a, Monad m) => a -> Fold m a (Maybe Int) Source #
Returns the first index where a given value is found in the stream.
Definition:
>>>elemIndex a = Fold.findIndex (== a)
elemIndices :: forall (m :: Type -> Type) a. (Monad m, Eq a) => a -> Fold m a (Maybe Int) Source #
Returns the index of the latest element if the element matches the given value.
Definition:
>>>elemIndices a = Fold.findIndices (== a)
findIndex :: forall (m :: Type -> Type) a. Monad m => (a -> Bool) -> Fold m a (Maybe Int) Source #
Returns the first index that satisfies the given predicate.
findIndices :: forall (m :: Type -> Type) a. Monad m => (a -> Bool) -> Fold m a (Maybe Int) Source #
Returns the index of the latest element if the element satisfies the given predicate.
deleteBy :: forall (m :: Type -> Type) a. Monad m => (a -> a -> Bool) -> a -> Fold m a (Maybe a) Source #
Returns the latest element omitting the first occurrence that satisfies the given equality predicate.
Example:
>>>input = Stream.fromList [1,3,3,5]
> Stream.toList $ Stream.scanMaybe (Fold.deleteBy (==) 3) input
- 1,3,5
partition :: forall (m :: Type -> Type) b x c y. Monad m => Fold m b x -> Fold m c y -> Fold m (Either b c) (x, y) Source #
tracing :: Monad m => (a -> m b) -> a -> m a Source #
Apply a monadic function on the input and return the input.
>>>Stream.fold (Fold.lmapM (Fold.tracing print) Fold.drain) $ (Stream.enumerateFromTo (1 :: Int) 2)1 2
Pre-release
unzipWith :: forall (m :: Type -> Type) a b c x y. Monad m => (a -> (b, c)) -> Fold m b x -> Fold m c y -> Fold m a (x, y) Source #
Split elements in the input stream into two parts using a pure splitter function, direct each part to a different fold and zip the results.
Definitions:
>>>unzipWith f = Fold.unzipWithM (return . f)>>>unzipWith f fld1 fld2 = Fold.lmap f (Fold.unzip fld1 fld2)
This fold terminates when both the input folds terminate.
Pre-release
findM :: Monad m => (a -> m Bool) -> Fold m a (Maybe a) Source #
Returns the first element that satisfies the given predicate.
Pre-release
toStream :: forall (m :: Type -> Type) (n :: Type -> Type) a. (Monad m, Monad n) => Fold m a (Stream n a) Source #
A fold that buffers its input to a pure stream.
Warning! working on large streams accumulated as buffers in memory could be very inefficient, consider using Streamly.Data.Array instead.
>>>toStream = fmap Stream.fromList Fold.toList
Pre-release
one :: forall (m :: Type -> Type) a. Monad m => Fold m a (Maybe a) Source #
Take one element from the stream and stop.
Definition:
>>>one = Fold.maybe Just
This is similar to the stream uncons operation.
indexed :: forall (m :: Type -> Type) a b. Monad m => Fold m (Int, a) b -> Fold m a b Source #
Pair each element of a fold input with its index, starting from index 0.
>>>indexed = Fold.postscanlMaybe Scanl.indexing
sampleFromthen :: forall (m :: Type -> Type) a b. Monad m => Int -> Int -> Fold m a b -> Fold m a b Source #
sampleFromthen offset stride samples the element at offset index and
 then every element at strides of stride.
tee :: forall (m :: Type -> Type) a b c. Monad m => Fold m a b -> Fold m a c -> Fold m a (b, c) Source #
Distribute one copy of the stream to each fold and zip the results.
                |-------Fold m a b--------|
---stream m a---|                         |---m (b,c)
                |-------Fold m a c--------|
Definition:
>>>tee = Fold.teeWith (,)
Example:
>>>t = Fold.tee Fold.sum Fold.length>>>Stream.fold t (Stream.enumerateFromTo 1.0 100.0)(5050.0,100)
drive :: Monad m => Stream m a -> Fold m a b -> m b Source #
Drive a fold using the supplied Stream, reducing the resulting
 expression strictly at each step.
Definition:
>>>drive = flip Stream.fold
Example:
>>>Fold.drive (Stream.enumerateFromTo 1 100) Fold.sum5050
addStream :: Monad m => Stream m a -> Fold m a b -> m (Fold m a b) Source #
Append a stream to a fold to build the fold accumulator incrementally. We
 can repeatedly call addStream on the same fold to continue building the
 fold and finally use drive to finish the fold and extract the result. Also
 see the addOne operation which is a singleton version
 of addStream.
Definitions:
>>>addStream stream = Fold.drive stream . Fold.duplicate
Example, build a list incrementally:
>>>:{pure (Fold.toList :: Fold IO Int [Int]) >>= Fold.addOne 1 >>= Fold.addStream (Stream.enumerateFromTo 2 4) >>= Fold.drive Stream.nil >>= print :} [1,2,3,4]
This can be used as an O(n) list append compared to the O(n^2) ++ when
 used for incrementally building a list.
Example, build a stream incrementally:
>>>:{pure (Fold.toStream :: Fold IO Int (Stream Identity Int)) >>= Fold.addOne 1 >>= Fold.addStream (Stream.enumerateFromTo 2 4) >>= Fold.drive Stream.nil >>= print :} fromList [1,2,3,4]
This can be used as an O(n) stream append compared to the O(n^2) <> when
 used for incrementally building a stream.
Example, build an array incrementally:
>>>:{pure (Array.create :: Fold IO Int (Array Int)) >>= Fold.addOne 1 >>= Fold.addStream (Stream.enumerateFromTo 2 4) >>= Fold.drive Stream.nil >>= print :} fromList [1,2,3,4]
Example, build an array stream incrementally:
>>>:{let f :: Fold IO Int (Stream Identity (Array Int)) f = Fold.groupsOf 2 (Array.createOf 3) Fold.toStream in pure f >>= Fold.addOne 1 >>= Fold.addStream (Stream.enumerateFromTo 2 4) >>= Fold.drive Stream.nil >>= print :} fromList [fromList [1,2],fromList [3,4]]
drainMapM :: Monad m => (a -> m b) -> Fold m a () Source #
Definitions:
>>>drainMapM f = Fold.lmapM f Fold.drain>>>drainMapM f = Fold.foldMapM (void . f)
Drain all input after passing it through a monadic function. This is the dual of mapM_ on stream producers.
mean :: forall (m :: Type -> Type) a. (Monad m, Fractional a) => Fold m a a Source #
Compute a numerically stable arithmetic mean of all elements in the input stream.
rollingHash :: forall (m :: Type -> Type) a. (Monad m, Enum a) => Fold m a Int64 Source #
Compute an Int sized polynomial rolling hash of a stream.
>>>rollingHash = Fold.rollingHashWithSalt Fold.defaultSalt
rollingHashWithSalt :: forall (m :: Type -> Type) a. (Monad m, Enum a) => Int64 -> Fold m a Int64 Source #
Compute an Int sized polynomial rolling hash
H = salt * k ^ n + c1 * k ^ (n - 1) + c2 * k ^ (n - 2) + ... + cn * k ^ 0
Where c1, c2, cn are the elements in the input stream and k is a
 constant.
This hash is often used in Rabin-Karp string search algorithm.
topBy :: forall (m :: Type -> Type) a. (MonadIO m, Unbox a) => (a -> a -> Ordering) -> Int -> Fold m a (MutArray a) Source #
Get the top n elements using the supplied comparison function.
To get bottom n elements instead:
>>>bottomBy cmp = Fold.topBy (flip cmp)
Example:
>>>stream = Stream.fromList [2::Int,7,9,3,1,5,6,11,17]>>>Stream.fold (Fold.topBy compare 3) stream >>= MutArray.toList[17,11,9]
Pre-release
uniqBy :: forall (m :: Type -> Type) a. Monad m => (a -> a -> Bool) -> Fold m a (Maybe a) Source #
Return the latest unique element using the supplied comparison function.
 Returns Nothing if the current element is same as the last element
 otherwise returns Just.
Example, strip duplicate path separators:
>>>input = Stream.fromList "//a//b">>>f x y = x == '/' && y == '/'
> Stream.toList $ Stream.scanMaybe (Fold.uniqBy f) input
"ab"
Space: O(1)
Pre-release
takeEndBySeq :: forall (m :: Type -> Type) a b. (MonadIO m, Unbox a, Enum a, Eq a) => Array a -> Fold m a b -> Fold m a b Source #
Continue taking the input until the input sequence matches the supplied sequence, taking the supplied sequence as well. If the pattern is empty this acts as an identity fold.
>>>s = Stream.fromList "Gauss---Euler---Noether">>>f = Fold.takeEndBySeq (Array.fromList "---") Fold.toList>>>Stream.fold f s"Gauss---"
>>>Stream.fold Fold.toList $ Stream.foldMany f s["Gauss---","Euler---","Noether"]
Uses Rabin-Karp algorithm for substring search.
See also: splitOnSeq and
 splitEndBySeq.
Pre-release
takeEndBySeq_ :: forall (m :: Type -> Type) a b. (MonadIO m, Unbox a, Enum a, Eq a) => Array a -> Fold m a b -> Fold m a b Source #
Like takeEndBySeq but discards the matched sequence.
>>>s = Stream.fromList "Gauss---Euler---Noether">>>f = Fold.takeEndBySeq_ (Array.fromList "---") Fold.toList>>>Stream.fold f s"Gauss"
>>>Stream.fold Fold.toList $ Stream.foldMany f s["Gauss","Euler","Noether"]
See also: splitOnSeq and
 splitEndBySeq_.
Pre-release
distribute :: forall (m :: Type -> Type) a b. Monad m => [Fold m a b] -> Fold m a [b] Source #
Distribute one copy of the stream to each fold and collect the results in a container.
                |-------Fold m a b--------|
---stream m a---|                         |---m [b]
                |-------Fold m a b--------|
                |                         |
                           ...
>>>Stream.fold (Fold.distribute [Fold.sum, Fold.length]) (Stream.enumerateFromTo 1 5)[15,5]
>>>distribute = Prelude.foldr (Fold.teeWith (:)) (Fold.fromPure [])
This is the consumer side dual of the producer side sequence operation.
Stops when all the folds stop.
variance :: forall (m :: Type -> Type) a. (Monad m, Fractional a) => Fold m a a Source #
Deprecated: Use the streamly-statistics package instead
Compute a numerically stable (population) variance over all elements in the input stream.
stdDev :: forall (m :: Type -> Type) a. (Monad m, Floating a) => Fold m a a Source #
Deprecated: Use the streamly-statistics package instead
Compute a numerically stable (population) standard deviation over all elements in the input stream.
mapMaybeM :: Monad m => (a -> m (Maybe b)) -> Fold m b r -> Fold m a r Source #
>>>mapMaybeM f = Fold.lmapM f . Fold.catMaybes
unfoldMany :: forall (m :: Type -> Type) a b c. Monad m => Unfold m a b -> Fold m b c -> Fold m a c Source #
Unfold and flatten the input stream of a fold.
Stream.fold (unfoldMany u f) = Stream.fold f . Stream.unfoldMany u
Pre-release
rollingHashFirstN :: forall (m :: Type -> Type) a. (Monad m, Enum a) => Int -> Fold m a Int64 Source #
Compute an Int sized polynomial rolling hash of the first n elements of
 a stream.
>>>rollingHashFirstN n = Fold.take n Fold.rollingHash
Pre-release
rangeBy :: forall (m :: Type -> Type) a. Monad m => (a -> a -> Ordering) -> Fold m a (Maybe (a, a)) Source #
toStreamRev :: forall (m :: Type -> Type) (n :: Type -> Type) a. (Monad m, Monad n) => Fold m a (Stream n a) Source #
Buffers the input stream to a pure stream in the reverse order of the input.
>>>toStreamRev = fmap Stream.fromList Fold.toListRev
Warning! working on large streams accumulated as buffers in memory could be very inefficient, consider using Streamly.Data.Array instead.
Pre-release
top :: forall (m :: Type -> Type) a. (MonadIO m, Unbox a, Ord a) => Int -> Fold m a (MutArray a) Source #
Fold the input stream to top n elements.
Definition:
>>>top = Fold.topBy compare
>>>stream = Stream.fromList [2::Int,7,9,3,1,5,6,11,17]>>>Stream.fold (Fold.top 3) stream >>= MutArray.toList[17,11,9]
Pre-release
bottomBy :: forall (m :: Type -> Type) a. (MonadIO m, Unbox a) => (a -> a -> Ordering) -> Int -> Fold m a (MutArray a) Source #
Get the bottom most n elements using the supplied comparison function.
bottom :: forall (m :: Type -> Type) a. (MonadIO m, Unbox a, Ord a) => Int -> Fold m a (MutArray a) Source #
Fold the input stream to bottom n elements.
Definition:
>>>bottom = Fold.bottomBy compare
>>>stream = Stream.fromList [2::Int,7,9,3,1,5,6,11,17]>>>Stream.fold (Fold.bottom 3) stream >>= MutArray.toList[1,2,3]
Pre-release
rollingMap :: forall (m :: Type -> Type) a b. Monad m => (Maybe a -> a -> b) -> Fold m a b Source #
>>>rollingMap f = Fold.rollingMapM (\x y -> return $ f x y)
rollingMapM :: Monad m => (Maybe a -> a -> m b) -> Fold m a b Source #
Apply a function on every two successive elements of a stream. The first
 argument of the map function is the previous element and the second argument
 is the current element. When processing the very first element in the
 stream, the previous element is Nothing.
Pre-release
repeated :: forall (m :: Type -> Type) a. Fold m a (Maybe a) Source #
Emit only repeated elements, once.
Unimplemented
drainN :: forall (m :: Type -> Type) a. Monad m => Int -> Fold m a () Source #
A fold that drains the first n elements of its input, running the effects and discarding the results.
Definition:
>>>drainN n = Fold.take n Fold.drain
Pre-release
takingEndBy :: forall (m :: Type -> Type) a. Monad m => (a -> Bool) -> Fold m a (Maybe a) Source #
>>>takingEndBy p = Fold.takingEndByM (return . p)
takingEndBy_ :: forall (m :: Type -> Type) a. Monad m => (a -> Bool) -> Fold m a (Maybe a) Source #
>>>takingEndBy_ p = Fold.takingEndByM_ (return . p)
droppingWhile :: forall (m :: Type -> Type) a. Monad m => (a -> Bool) -> Fold m a (Maybe a) Source #
>>>droppingWhile p = Fold.droppingWhileM (return . p)
prune :: forall a (m :: Type -> Type). (a -> Bool) -> Fold m a (Maybe a) Source #
Strip all leading and trailing occurrences of an element passing a predicate and make all other consecutive occurrences uniq.
> prune p = Stream.dropWhileAround p $ Stream.uniqBy (x y -> p x && p y)
> Stream.prune isSpace (Stream.fromList " hello world! ") "hello world!"
Space: O(1)
Unimplemented
slide2 :: forall (m :: Type -> Type) a b. Monad m => Fold m (a, Maybe a) b -> Fold m a b Source #
Provide a sliding window of length 2 elements.
pipe :: forall (m :: Type -> Type) a b c. Monad m => Pipe m a b -> Fold m b c -> Fold m a c Source #
zipStreamWithM :: (a -> b -> m c) -> Stream m a -> Fold m c x -> Fold m b x Source #
Zip a stream with the input of a fold using the supplied function.
Unimplemented
zipStream :: forall (m :: Type -> Type) a b x. Monad m => Stream m a -> Fold m (a, b) x -> Fold m b x Source #
Zip a stream with the input of a fold.
>>>zip = Fold.zipStreamWithM (curry return)
Unimplemented
distributeScan :: Monad m => m [Fold m a b] -> Scanl m a [b] Source #
Distribute the input to the folds returned by an effect. The effect is executed every time an input is processed, and the folds returned by it are added to the distribution list. The scan returns the results of the folds as they complete. To avoid adding the same folds repeatedly, the action must return the folds only once e.g. it can be implemented using modifyIORef replacing the original value by an empty list before returning it.
>>>import Data.IORef>>>ref <- newIORef [Fold.take 2 Fold.sum, Fold.take 2 Fold.length :: Fold IO Int Int]>>>gen = atomicModifyIORef ref (\xs -> ([], xs))>>>Stream.toList $ Stream.scanl (Fold.distributeScan gen) (Stream.enumerateFromTo 1 10)[[],[],[],[2,3],[],[],[],[],[],[],[]]
unzipWithM :: Monad m => (a -> m (b, c)) -> Fold m b x -> Fold m c y -> Fold m a (x, y) Source #
Like unzipWith but with a monadic splitter function.
Definition:
>>>unzipWithM k f1 f2 = Fold.lmapM k (Fold.unzip f1 f2)
Pre-release
unzipWithFstM :: Monad m => (a -> m (b, c)) -> Fold m b x -> Fold m c y -> Fold m a (x, y) Source #
Similar to unzipWithM but terminates when the first fold terminates.
unzipWithMinM :: Monad m => (a -> m (b, c)) -> Fold m b x -> Fold m c y -> Fold m a (x, y) Source #
Similar to unzipWithM but terminates when any fold terminates.
partitionByM :: Monad m => (a -> m (Either b c)) -> Fold m b x -> Fold m c y -> Fold m a (x, y) Source #
Partition the input over two folds using an Either partitioning
 predicate.
                                    |-------Fold b x--------|
-----stream m a --> (Either b c)----|                       |----(x,y)
                                    |-------Fold c y--------|
Example, send input to either fold randomly:
>>>:set -package random>>>import System.Random (randomIO)>>>randomly a = randomIO >>= \x -> return $ if x then Left a else Right a>>>f = Fold.partitionByM randomly Fold.length Fold.length>>>Stream.fold f (Stream.enumerateFromTo 1 100)...
Example, send input to the two folds in a proportion of 2:1:
>>>:set -fno-warn-unrecognised-warning-flags>>>:set -fno-warn-x-partial>>>:{proportionately m n = do ref <- newIORef $ cycle $ concat [replicate m Left, replicate n Right] return $ \a -> do r <- readIORef ref writeIORef ref $ tail r return $ Prelude.head r a :}
>>>:{main = do g <- proportionately 2 1 let f = Fold.partitionByM g Fold.length Fold.length r <- Stream.fold f (Stream.enumerateFromTo (1 :: Int) 100) print r :}
>>>main(67,33)
This is the consumer side dual of the producer side mergeBy operation.
When one fold is done, any input meant for it is ignored until the other fold is also done.
Stops when both the folds stop.
See also: partitionByFstM and partitionByMinM.
Pre-release
partitionByFstM :: Monad m => (a -> m (Either b c)) -> Fold m b x -> Fold m c y -> Fold m a (x, y) Source #
Similar to partitionByM but terminates when the first fold terminates.
partitionByMinM :: Monad m => (a -> m (Either b c)) -> Fold m b x -> Fold m c y -> Fold m a (x, y) Source #
Similar to partitionByM but terminates when any fold terminates.
partitionBy :: forall (m :: Type -> Type) a b c x y. Monad m => (a -> Either b c) -> Fold m b x -> Fold m c y -> Fold m a (x, y) Source #
Same as partitionByM but with a pure partition function.
Example, count even and odd numbers in a stream:
>>>:{let f = Fold.partitionBy (\n -> if even n then Left n else Right n) (fmap (("Even " ++) . show) Fold.length) (fmap (("Odd " ++) . show) Fold.length) in Stream.fold f (Stream.enumerateFromTo 1 100) :} ("Even 50","Odd 50")
Pre-release
chunksBetween :: forall (m :: Type -> Type) a b c. Int -> Int -> Fold m a b -> Fold m b c -> Fold m a c Source #
Group the input stream into groups of elements between low and high.
 Collection starts in chunks of low and then keeps doubling until we reach
 high. Each chunk is folded using the provided fold function.
This could be useful, for example, when we are folding a stream of unknown size to a stream of arrays and we want to minimize the number of allocations.
NOTE: this would be an application of "many" using a terminating fold.
Unimplemented
intersperseWithQuotes :: forall (m :: Type -> Type) a b c. (Monad m, Eq a) => a -> a -> a -> Fold m a b -> Fold m b c -> Fold m a c Source #
concatSequence :: forall (m :: Type -> Type) b c t a. Fold m b c -> t (Fold m a b) -> Fold m a c Source #
concatSequence f t applies folds from stream t sequentially and
 collects the results using the fold f.
Unimplemented
indexingWith :: forall (m :: Type -> Type) a. Monad m => Int -> (Int -> Int) -> Fold m a (Maybe (Int, a)) Source #
Deprecated: Use Scanl.indexingWith instead
Pair each element of a fold input with its index, starting from index 0.
indexing :: forall (m :: Type -> Type) a. Monad m => Fold m a (Maybe (Int, a)) Source #
Deprecated: Use Scanl.indexing instead
> indexing = Fold.indexingWith 0 (+ 1)
indexingRev :: forall (m :: Type -> Type) a. Monad m => Int -> Fold m a (Maybe (Int, a)) Source #
Deprecated: Use Scanl.indexingRev instead
> indexingRev n = Fold.indexingWith n (subtract 1)
defaultSalt :: Int64 Source #
A default salt used in the implementation of rollingHash.
countDistinct :: forall (m :: Type -> Type) a. (Monad m, Ord a) => Fold m a Int Source #
Count non-duplicate elements in the stream.
Definition:
>>>countDistinct = fmap Set.size Fold.toSet>>>countDistinct = Fold.postscanl Scanl.nub $ Fold.catMaybes $ Fold.length
The memory used is proportional to the number of distinct elements in the stream, to guard against using too much memory use it as a scan and terminate if the count reaches more than a threshold.
Space: \(\mathcal{O}(n)\)
Pre-release
countDistinctInt :: forall (m :: Type -> Type). Monad m => Fold m Int Int Source #
Like countDistinct but specialized to a stream of Int, for better
 performance.
Definition:
>>>countDistinctInt = fmap IntSet.size Fold.toIntSet>>>countDistinctInt = Fold.postscanl Scanl.nubInt $ Fold.catMaybes $ Fold.length
Pre-release
frequency :: forall (m :: Type -> Type) a. (Monad m, Ord a) => Fold m a (Map a Int) Source #
Determine the frequency of each element in the stream.
You can just collect the keys of the resulting map to get the unique elements in the stream.
Definition:
>>>frequency = Fold.toMap id Fold.length
toSet :: forall (m :: Type -> Type) a. (Monad m, Ord a) => Fold m a (Set a) Source #
Fold the input to a set.
Definition:
>>>toSet = Fold.foldl' (flip Set.insert) Set.empty
toIntSet :: forall (m :: Type -> Type). Monad m => Fold m Int IntSet Source #
Fold the input to an int set. For integer inputs this performs better than
 toSet.
Definition:
>>>toIntSet = Fold.foldl' (flip IntSet.insert) IntSet.empty
toMap :: forall (m :: Type -> Type) k a b. (Monad m, Ord k) => (a -> k) -> Fold m a b -> Fold m a (Map k b) Source #
Split the input stream based on a key field and fold each split using the given fold. Useful for map/reduce, bucketizing the input in different bins or for generating histograms.
Example:
>>>import Data.Map.Strict (Map)>>>:{let input = Stream.fromList [("ONE",1),("ONE",1.1),("TWO",2), ("TWO",2.2)] classify = Fold.toMap fst (Fold.lmap snd Fold.toList) in Stream.fold classify input :: IO (Map String [Double]) :} fromList [("ONE",[1.0,1.1]),("TWO",[2.0,2.2])]
Once the classifier fold terminates for a particular key any further inputs in that bucket are ignored.
Space used is proportional to the number of keys seen till now and monotonically increases because it stores whether a key has been seen or not.
See demuxToMap for a more powerful version where you can use a different
 fold for each key. A simpler version of toMap retaining only the last
 value for a key can be written as:
>>>toMap = Fold.foldl' (\kv (k, v) -> Map.insert k v kv) Map.empty
Stops: never
Pre-release
toMapIO :: forall (m :: Type -> Type) k a b. (MonadIO m, Ord k) => (a -> k) -> Fold m a b -> Fold m a (Map k b) Source #
Same as toMap but maybe faster because it uses mutable cells as
 fold accumulators in the Map.
demuxerToMap :: (Monad m, Ord k) => (a -> k) -> (k -> m (Maybe (Fold m a b))) -> Fold m a (Map k b) Source #
demuxerToMap getKey getFold: In a key value stream, fold values
 corresponding to each key using a key specific fold. getFold is invoked to
 generate a key specific fold when a key is encountered for the first time in
 the stream.
If a fold terminates, another instance of the fold is started upon receiving
 an input with that key, getFold is invoked again whenever the key is
 encountered again.
This combinator can be used to scan a stream and collect the results from the scan output.
Since the fold generator function is monadic, folds for new keys can be added dynamically or folds for old keys can be deleted or modified. For example, we can maintain a Map of keys to folds in an IORef and lookup the fold from that corresponding to a key. This Map can be changed dynamically.
Note that this fold never terminates. Inputs that do not correspond to a fold in the map are dropped.
Compare with classify, the fold in classify is a static fold.
Pre-release
demuxerToMapIO :: (MonadIO m, Ord k) => (a -> k) -> (k -> m (Maybe (Fold m a b))) -> Fold m a (Map k b) Source #
Same as demuxerToMap but uses mutable cells for better performance.
classify :: (Monad m, Ord k) => (a -> k) -> Fold m a b -> Fold m a (m (Map k b), Maybe (k, b)) Source #
Deprecated: Use classifyScan instead
Folds the values for each key using the supplied fold. When scanning, as soon as the fold is complete, its result is available in the second component of the tuple. The first component of the tuple is a snapshot of the in-progress folds.
Once the fold for a key is done, any future values of the key are ignored.
Definition:
> classify f fld = Fold.demux f (const fld)
classifyIO :: (MonadIO m, Ord k) => (a -> k) -> Fold m a b -> Fold m a (m (Map k b), Maybe (k, b)) Source #
Deprecated: Use classifyScanIO instead
Same as classify except that it uses mutable IORef cells in the Map providing better performance. Be aware that if this is used as a scan, the values in the intermediate Maps would be mutable.
Definitions:
> classifyIO f fld = Fold.demuxIO f (const fld)
demux :: (Monad m, Ord k) => (a -> k) -> (a -> m (Fold m a b)) -> Fold m a (m (Map k b), Maybe (k, b)) Source #
Deprecated: Use demuxScan instead
demux getKey getFold: In a key value stream, fold values corresponding
 to each key using a key specific fold. getFold is invoked to generate a
 key specific fold when a key is encountered for the first time in the
 stream.
The first component of the output tuple is a key-value Map of in-progress folds. The fold returns the fold result as the second component of the output tuple whenever a fold terminates.
If a fold terminates, another instance of the fold is started upon receiving
 an input with that key, getFold is invoked again whenever the key is
 encountered again.
This can be used to scan a stream and collect the results from the scan output.
Since the fold generator function is monadic we can add folds dynamically. For example, we can maintain a Map of keys to folds in an IORef and lookup the fold from that corresponding to a key. This Map can be changed dynamically, folds for new keys can be added or folds for old keys can be deleted or modified.
Compare with classify, the fold in classify is a static fold.
Pre-release
demuxIO :: (MonadIO m, Ord k) => (a -> k) -> (a -> m (Fold m a b)) -> Fold m a (m (Map k b), Maybe (k, b)) Source #
Deprecated: Use demuxScanIO instead
This is specialized version of demux that uses mutable IO cells as
 fold accumulators for better performance.
Keep in mind that the values in the returned Map may be changed by the ongoing fold if you are using those concurrently in another thread.
demuxToMap :: (Monad m, Ord k) => (a -> k) -> (a -> m (Fold m a b)) -> Fold m a (Map k b) Source #
Deprecated: Use demuxerToMap instead
This collects all the results of demux in a Map.
demuxToMapIO :: (MonadIO m, Ord k) => (a -> k) -> (a -> m (Fold m a b)) -> Fold m a (Map k b) Source #
Deprecated: Use demuxerToMapIO instead
Same as demuxToMap but uses demuxIO for better performance.
demuxerToContainer :: (Monad m, IsMap f, Traversable f) => (a -> Key f) -> (Key f -> m (Maybe (Fold m a b))) -> Fold m a (f b) Source #
This is the most general of all demux, classify operations.
See demux for documentation.
demuxerToContainerIO :: (MonadIO m, IsMap f, Traversable f) => (a -> Key f) -> (Key f -> m (Maybe (Fold m a b))) -> Fold m a (f b) Source #
This is a specialized version of demuxToContainer that uses mutable IO cells
 as fold accumulators for better performance.
demuxKvToContainer :: (Monad m, IsMap f, Traversable f) => (Key f -> m (Maybe (Fold m a b))) -> Fold m (Key f, a) (f b) Source #
demuxKvToMap :: (Monad m, Ord k) => (k -> m (Maybe (Fold m a b))) -> Fold m (k, a) (Map k b) Source #
Fold a stream of key value pairs using a function that maps keys to folds.
Definition:
>>>demuxKvToMap f = Fold.demuxerToContainer fst (Fold.lmap snd . f)
Example:
>>>import Data.Map (Map)>>>:{let f "SUM" = return (Just Fold.sum) f _ = return (Just Fold.product) input = Stream.fromList [("SUM",1),("PRODUCT",2),("SUM",3),("PRODUCT",4)] in Stream.fold (Fold.demuxKvToMap f) input :: IO (Map String Int) :} fromList [("PRODUCT",8),("SUM",4)]
Pre-release
demuxScanGeneric :: (Monad m, IsMap f, Traversable f) => (a -> Key f) -> (Key f -> m (Maybe (Fold m a b))) -> Scanl m a (m (f b), Maybe (Key f, b)) Source #
Scanning variant of demuxerToContainer.
demuxScan :: (Monad m, Ord k) => (a -> k) -> (k -> m (Maybe (Fold m a b))) -> Scanl m a (Maybe (k, b)) Source #
Scanning variant of demuxerToMap.
TODO: To drain the final in-progress folds this requires the drain step of Scanl to be streaming.
demuxScanGenericIO :: (MonadIO m, IsMap f, Traversable f) => (a -> Key f) -> (Key f -> m (Maybe (Fold m a b))) -> Scanl m a (m (f b), Maybe (Key f, b)) Source #
This is a specialized version of demux that uses mutable IO cells as
 fold accumulators for better performance.
Keep in mind that the values in the returned Map may be changed by the ongoing fold if you are using those concurrently in another thread.
demuxScanIO :: (MonadIO m, Ord k) => (a -> k) -> (k -> m (Maybe (Fold m a b))) -> Scanl m a (Maybe (k, b)) Source #
This is a specialized version of demuxScan that uses mutable IO cells as
 scan accumulators for better performance.
TODO: To drain the final in-progress folds this requires the drain step of Scanl to be streaming.
kvToMap :: forall (m :: Type -> Type) k a b. (Monad m, Ord k) => Fold m a b -> Fold m (k, a) (Map k b) Source #
Given an input stream of key value pairs and a fold for values, fold all the values belonging to each key. Useful for map/reduce, bucketizing the input in different bins or for generating histograms.
Definition:
>>>kvToMap = Fold.toMap fst . Fold.lmap snd
Example:
>>>:{let input = Stream.fromList [("ONE",1),("ONE",1.1),("TWO",2), ("TWO",2.2)] in Stream.fold (Fold.kvToMap Fold.toList) input :} fromList [("ONE",[1.0,1.1]),("TWO",[2.0,2.2])]
Pre-release
toContainer :: forall (m :: Type -> Type) f a b. (Monad m, IsMap f, Traversable f) => (a -> Key f) -> Fold m a b -> Fold m a (f b) Source #
toContainerIO :: forall (m :: Type -> Type) f a b. (MonadIO m, IsMap f, Traversable f) => (a -> Key f) -> Fold m a b -> Fold m a (f b) Source #
classifyScanGeneric :: (Monad m, IsMap f, Traversable f, Ord (Key f)) => (a -> Key f) -> Fold m a b -> Scanl m a (m (f b), Maybe (Key f, b)) Source #
Scanning variant of toContainer.
classifyScan :: forall (m :: Type -> Type) k a b. (MonadIO m, Ord k) => (a -> k) -> Fold m a b -> Scanl m a (Maybe (k, b)) Source #
Scanning variant of toMap.
classifyScanGenericIO :: (MonadIO m, IsMap f, Traversable f, Ord (Key f)) => (a -> Key f) -> Fold m a b -> Scanl m a (m (f b), Maybe (Key f, b)) Source #
Scanning variant of classifyGenericIO.
classifyScanIO :: forall (m :: Type -> Type) k a b. (MonadIO m, Ord k) => (a -> k) -> Fold m a b -> Scanl m a (Maybe (k, b)) Source #
This is a specialized version of classifyScan that uses mutable IO cells
 as scan accumulators for better performance.
TODO: To drain the final in-progress folds this requires the drain step of Scanl to be streaming.
demuxGeneric :: (Monad m, IsMap f, Traversable f) => (a -> Key f) -> (a -> m (Fold m a b)) -> Fold m a (m (f b), Maybe (Key f, b)) Source #
Deprecated: Use demuxScanGeneric instead
This is the most general of all demux, classify operations.
See demux for documentation.
demuxGenericIO :: (MonadIO m, IsMap f, Traversable f) => (a -> Key f) -> (a -> m (Fold m a b)) -> Fold m a (m (f b), Maybe (Key f, b)) Source #
Deprecated: Use demuxScanGenericIO instead
This is specialized version of demuxGeneric that uses mutable IO cells
 as fold accumulators for better performance.
demuxToContainer :: (Monad m, IsMap f, Traversable f) => (a -> Key f) -> (a -> m (Fold m a b)) -> Fold m a (f b) Source #
Deprecated: Use demuxerToContainer instead
demuxToContainerIO :: (MonadIO m, IsMap f, Traversable f) => (a -> Key f) -> (a -> m (Fold m a b)) -> Fold m a (f b) Source #
Deprecated: Use demuxerToContainerIO instead
classifyGeneric :: (Monad m, IsMap f, Traversable f, Ord (Key f)) => (a -> Key f) -> Fold m a b -> Fold m a (m (f b), Maybe (Key f, b)) Source #
Deprecated: Use classifyScanGeneric instead
classifyGenericIO :: (MonadIO m, IsMap f, Traversable f, Ord (Key f)) => (a -> Key f) -> Fold m a b -> Fold m a (m (f b), Maybe (Key f, b)) Source #
Deprecated: Use classifyGenericIO from Scanl module
windowLmap :: forall c a (m :: Type -> Type) b. (c -> a) -> Fold m (a, Maybe a) b -> Fold m (c, Maybe c) b Source #
Map a function on the incoming as well as outgoing element of a rolling window fold.
>>>:set -fno-warn-deprecations>>>lmap f = Fold.lmap (bimap f (f <$>))
cumulative :: forall (m :: Type -> Type) a b. Fold m (a, Maybe a) b -> Fold m a b Source #
Convert an incremental fold to a cumulative fold using the entire input stream as a single window.
>>>cumulative f = Fold.lmap (\x -> (x, Nothing)) f
windowRollingMap :: forall (m :: Type -> Type) a b. Monad m => (Maybe a -> a -> Maybe b) -> Fold m (a, Maybe a) (Maybe b) Source #
Apply a pure function on the latest and the oldest element of the window.
>>>windowRollingMap f = Fold.windowRollingMapM (\x y -> return $ f x y)
windowRollingMapM :: Monad m => (Maybe a -> a -> m (Maybe b)) -> Fold m (a, Maybe a) (Maybe b) Source #
Apply an effectful function on the latest and the oldest element of the window.
windowLength :: forall (m :: Type -> Type) b a. (Monad m, Num b) => Fold m (a, Maybe a) b Source #
The number of elements in the rolling window.
This is the \(0\)th power sum.
>>>length = Fold.windowPowerSum 0
windowSum :: forall (m :: Type -> Type) a. (Monad m, Num a) => Fold m (a, Maybe a) a Source #
Sum of all the elements in a rolling window:
\(S = \sum_{i=1}^n x_{i}\)
This is the first power sum.
>>>windowSum = Fold.windowPowerSum 1
Uses Kahan-Babuska-Neumaier style summation for numerical stability of floating precision arithmetic.
Space: \(\mathcal{O}(1)\)
Time: \(\mathcal{O}(n)\)
windowSumInt :: forall (m :: Type -> Type) a. (Monad m, Integral a) => Fold m (a, Maybe a) a Source #
The sum of all the elements in a rolling window. The input elements are required to be intergal numbers.
This was written in the hope that it would be a tiny bit faster than sum
 for Integral values. But turns out that sum is 2% faster than this even
 for intergal values!
Internal
windowPowerSum :: forall (m :: Type -> Type) a. (Monad m, Num a) => Int -> Fold m (a, Maybe a) a Source #
Sum of the \(k\)th power of all the elements in a rolling window:
\(S_k = \sum_{i=1}^n x_{i}^k\)
>>>windowPowerSum k = Fold.windowLmap (^ k) Fold.windowSum
Space: \(\mathcal{O}(1)\)
Time: \(\mathcal{O}(n)\)
windowPowerSumFrac :: forall (m :: Type -> Type) a. (Monad m, Floating a) => a -> Fold m (a, Maybe a) a Source #
Like powerSum but powers can be negative or fractional. This is slower
 than powerSum for positive intergal powers.
>>>windowPowerSumFrac p = Fold.windowLmap (** p) Fold.windowSum
windowMinimum :: forall (m :: Type -> Type) a. (MonadIO m, Unbox a, Ord a) => Int -> Fold m a (Maybe a) Source #
Find the minimum element in a rolling window.
This implementation traverses the entire window buffer to compute the
 minimum whenever we demand it.  It performs better than the dequeue based
 implementation in streamly-statistics package when the window size is
 small (< 30).
If you want to compute the minimum of the entire stream
 minimum is much faster.
Time: \(\mathcal{O}(n*w)\) where \(w\) is the window size.
windowMaximum :: forall (m :: Type -> Type) a. (MonadIO m, Unbox a, Ord a) => Int -> Fold m a (Maybe a) Source #
The maximum element in a rolling window.
See the performance related comments in minimum.
If you want to compute the maximum of the entire stream maximum would
 be much faster.
Time: \(\mathcal{O}(n*w)\) where \(w\) is the window size.
windowRange :: forall (m :: Type -> Type) a. (MonadIO m, Unbox a, Ord a) => Int -> Fold m a (Maybe (a, a)) Source #
Determine the maximum and minimum in a rolling window.
If you want to compute the range of the entire stream Fold.teeWith (,)
 Fold.maximum Fold.minimum would be much faster.
Space: \(\mathcal{O}(n)\) where n is the window size.
Time: \(\mathcal{O}(n*w)\) where \(w\) is the window size.
windowMean :: forall (m :: Type -> Type) a. (Monad m, Fractional a) => Fold m (a, Maybe a) a Source #
Arithmetic mean of elements in a sliding window:
\(\mu = \frac{\sum_{i=1}^n x_{i}}{n}\)
This is also known as the Simple Moving Average (SMA) when used in the sliding window and Cumulative Moving Avergae (CMA) when used on the entire stream.
>>>mean = Fold.teeWith (/) Fold.windowSum Fold.windowLength
Space: \(\mathcal{O}(1)\)
Time: \(\mathcal{O}(n)\)
onException :: MonadCatch m => m x -> Fold m a b -> Fold m a b Source #
onException action fold runs action whenever the fold throws an
 exception.  The action is executed on any exception whether it is in
 initial, step or extract action of the fold.
The exception is not caught, simply rethrown. If the action itself
 throws an exception that exception is thrown instead of the original
 exception.
Internal
bracketIO :: forall (m :: Type -> Type) x c a b. (MonadIO m, MonadCatch m) => IO x -> (x -> IO c) -> (x -> Fold m a b) -> Fold m a b Source #
bracketIO before after between runs before and invokes between using
 its output, then runs the fold generated by between.  If the fold ends
 normally, due to an exception or if it is garbage collected prematurely then
 after is run with the output of before as argument.
If before or after throw an exception that exception is thrown.