| Copyright | (c) 2019 Composewell Technologies (c) 2013 Gabriel Gonzalez | 
|---|---|
| License | BSD3 | 
| Maintainer | streamly@composewell.com | 
| Stability | experimental | 
| Portability | GHC | 
| Safe Haskell | Safe-Inferred | 
| Language | Haskell2010 | 
Streamly.Internal.Data.Tuple.Strict
Description
| Strict data types to be used as accumulator for strict left folds and scans. For more comprehensive strict data types see https://hackage.haskell.org/package/strict-base-types . The names have been suffixed by a prime so that programmers can easily distinguish the strict versions from the lazy ones.
One major advantage of strict data structures as accumulators in folds and scans is that it helps the compiler optimize the code much better by unboxing. In a big tight loop the difference could be huge.
Synopsis
- data Tuple' a b = Tuple' !a !b
- data Tuple3' a b c = Tuple3' !a !b !c
- data Tuple3Fused' a b c = Tuple3Fused' !a !b !c
- data Tuple4' a b c d = Tuple4' !a !b !c !d
Documentation
A strict (,)
Constructors
| Tuple' !a !b | 
A strict (,,)
Constructors
| Tuple3' !a !b !c | 
data Tuple3Fused' a b c Source #
A strict (,,)
Constructors
| Tuple3Fused' !a !b !c | 
Instances
| (Show a, Show b, Show c) => Show (Tuple3Fused' a b c) Source # | |
| Defined in Streamly.Internal.Data.Tuple.Strict | |
A strict (,,,)
Constructors
| Tuple4' !a !b !c !d |