| Copyright | (c) Laurent P. René de Cotret | 
|---|---|
| License | MIT | 
| Maintainer | laurent.decotret@outlook.com | 
| Portability | portable | 
| Safe Haskell | Safe-Inferred | 
| Language | GHC2021 | 
Data.Series.Generic.Internal
Description
WARNING
This module is considered internal. Using the Series constructor
 directly may result in loss or corruption of data if not handled carefully.
The Package Versioning Policy still applies.
Synopsis
Constructor
A Series v k a is a labeled array of type v filled with values of type a,
 indexed by keys of type k.
Like Map, they support efficient:
- random access by key ( \(O(\log n)\) );
- slice by key ( \(O(\log n)\) ).
Like Vector, they support efficient:
- random access by index ( \(O(1)\) );
- slice by index ( \(O(1)\) );
- numerical operations.
Constructors
| MkSeries | |
Instances
| (forall a. Vector v a, Vector v k, Foldable v, Functor v) => FoldableWithIndex k (Series v k) Source # | |
| Defined in Data.Series.Generic.Definition | |
| (forall a. Vector v a, Functor v) => FunctorWithIndex k (Series v k) Source # | |
| Defined in Data.Series.Generic.Definition | |
| (forall a. Vector v a, Functor v, Foldable v, Ord k, Traversable v) => TraversableWithIndex k (Series v k) Source # | |
| Defined in Data.Series.Generic.Definition Methods itraverse :: Applicative f => (k -> a -> f b) -> Series v k a -> f (Series v k b) # | |
| Foldable v => Bifoldable (Series v) Source # | |
| Foldable v => Foldable (Series v k) Source # | |
| Defined in Data.Series.Generic.Definition Methods fold :: Monoid m => Series v k m -> m # foldMap :: Monoid m => (a -> m) -> Series v k a -> m # foldMap' :: Monoid m => (a -> m) -> Series v k a -> m # foldr :: (a -> b -> b) -> b -> Series v k a -> b # foldr' :: (a -> b -> b) -> b -> Series v k a -> b # foldl :: (b -> a -> b) -> b -> Series v k a -> b # foldl' :: (b -> a -> b) -> b -> Series v k a -> b # foldr1 :: (a -> a -> a) -> Series v k a -> a # foldl1 :: (a -> a -> a) -> Series v k a -> a # toList :: Series v k a -> [a] # null :: Series v k a -> Bool # length :: Series v k a -> Int # elem :: Eq a => a -> Series v k a -> Bool # maximum :: Ord a => Series v k a -> a # minimum :: Ord a => Series v k a -> a # | |
| Traversable v => Traversable (Series v k) Source # | |
| Defined in Data.Series.Generic.Definition | |
| Functor v => Functor (Series v k) Source # | |
| (Vector v a, Ord k) => Monoid (Series v k a) Source # | |
| (Vector v a, Ord k) => Semigroup (Series v k a) Source # | |
| (Vector v a, Ord k, Show k, Show a) => Show (Series v k a) Source # | |
| (NFData (v a), NFData k2) => NFData (Series v k2 a) Source # | |
| Defined in Data.Series.Generic.Definition | |
| (Vector v a, Eq k, Eq a) => Eq (Series v k a) Source # | |
| (Vector v a, Ord (v a), Ord k, Ord a) => Ord (Series v k a) Source # | |
| Defined in Data.Series.Generic.Definition | |
Unsafe construction
fromDistinctAscList :: Vector v a => [(k, a)] -> Series v k a Source #
\(O(n)\) Build a Series from a list of pairs, where the first elements of the pairs (the keys)
 are distinct elements in ascending order. The precondition that the keys be unique and sorted is not checked.
fromDistinctAscVector :: (Vector v k, Vector v a, Vector v (k, a)) => v (k, a) -> Series v k a Source #
\(O(n)\) Build a Series from a vector of pairs, where the first elements of the pairs (the keys)
 are distinct elements in ascending order. The precondition that the keys be unique and sorted is not checked.