Safe Haskell | Safe-Inferred |
---|---|
Language | Haskell2010 |
Synopsis
- data Array n a
- class Vector v
- type ShapeL = [Int]
- fromList :: forall n a. KnownNat n => ShapeL -> [a] -> Array n a
- toList :: Array n a -> [a]
- generate :: forall n a. KnownNat n => ShapeL -> ([Int] -> a) -> Array n a
- index :: HasCallStack => Array (1 + n) a -> Int -> Array n a
- transpose :: KnownNat n => [Int] -> Array n a -> Array n a
- reduce :: (a -> a -> a) -> a -> Array n a -> Array 0 a
- rotate :: forall d p a. (KnownNat p, KnownNat d, (d + (p + 1)) ~ ((p + d) + 1), (d + p) ~ (p + d), 1 <= (p + 1), KnownNat ((p + d) + 1), KnownNat (p + 1), KnownNat (1 + (p + 1))) => Int -> Array (p + d) a -> Array ((p + d) + 1) a
- append :: KnownNat n => Array n a -> Array n a -> Array n a
- size :: Array n a -> Int
- iterateN :: forall a. Int -> (a -> a) -> a -> Array 1 a
- slice :: [(Int, Int)] -> Array n a -> Array n a
- shapeL :: Array n a -> ShapeL
- rank :: KnownNat n => Array n a -> Int
- toVector :: Array n a -> Vector a
- fromVector :: forall n a. KnownNat n => ShapeL -> Vector a -> Array n a
- normalize :: KnownNat n => Array n a -> Array n a
- scalar :: a -> Array 0 a
- unScalar :: Array 0 a -> a
- constant :: forall n a. KnownNat n => ShapeL -> a -> Array n a
- reshape :: forall n' n a. (KnownNat n, KnownNat n') => ShapeL -> Array n a -> Array n' a
- stretch :: ShapeL -> Array n a -> Array n a
- stretchOuter :: (HasCallStack, 1 <= n) => Int -> Array n a -> Array n a
- pad :: KnownNat n => [(Int, Int)] -> a -> Array n a -> Array n a
- mapA :: (a -> b) -> Array n a -> Array n b
- zipWithA :: (a -> b -> c) -> Array n a -> Array n b -> Array n c
- zipWith3A :: (a -> b -> c -> d) -> Array n a -> Array n b -> Array n c -> Array n d
- concatOuter :: KnownNat n => [Array n a] -> Array n a
- ravel :: KnownNat (1 + n) => Array 1 (Array n a) -> Array (1 + n) a
- unravel :: Array (1 + n) a -> Array 1 (Array n a)
- window :: (KnownNat n, KnownNat n') => [Int] -> Array n a -> Array n' a
- stride :: [Int] -> Array n a -> Array n a
- rerank :: forall n i o a b. (KnownNat n, KnownNat o, KnownNat (n + o), KnownNat (1 + o)) => (Array i a -> Array o b) -> Array (n + i) a -> Array (n + o) b
- rerank2 :: forall n i o a b c. (KnownNat n, KnownNat o, KnownNat (n + o), KnownNat (1 + o)) => (Array i a -> Array i b -> Array o c) -> Array (n + i) a -> Array (n + i) b -> Array (n + o) c
- rev :: [Int] -> Array n a -> Array n a
- foldrA :: (a -> b -> b) -> b -> Array n a -> b
- traverseA :: Applicative f => (a -> f b) -> Array n a -> f (Array n b)
- allSameA :: Eq a => Array r a -> Bool
- sumA :: Num a => Array r a -> a
- productA :: Num a => Array r a -> a
- maximumA :: Ord a => Array r a -> a
- minimumA :: Ord a => Array r a -> a
- anyA :: (a -> Bool) -> Array r a -> Bool
- allA :: (a -> Bool) -> Array r a -> Bool
- broadcast :: forall r' r a. (HasCallStack, KnownNat r, KnownNat r') => [Int] -> ShapeL -> Array r a -> Array r' a
- iota :: (Enum a, Num a) => Int -> Array 1 a
Documentation
Instances
Foldable (Array n) Source # | |
Defined in Data.Array.Internal.Ranked fold :: Monoid m => Array n m -> m # foldMap :: Monoid m => (a -> m) -> Array n a -> m # foldMap' :: Monoid m => (a -> m) -> Array n a -> m # foldr :: (a -> b -> b) -> b -> Array n a -> b # foldr' :: (a -> b -> b) -> b -> Array n a -> b # foldl :: (b -> a -> b) -> b -> Array n a -> b # foldl' :: (b -> a -> b) -> b -> Array n a -> b # foldr1 :: (a -> a -> a) -> Array n a -> a # foldl1 :: (a -> a -> a) -> Array n a -> a # elem :: Eq a => a -> Array n a -> Bool # maximum :: Ord a => Array n a -> a # minimum :: Ord a => Array n a -> a # | |
Traversable (Array n) Source # | |
Functor (Array n) Source # | |
(a ~ b, KnownNat n) => Convert (Array a) (Array n b) Source # | |
(KnownNat r, Arbitrary a) => Arbitrary (Array r a) Source # | |
(KnownNat n, Data a) => Data (Array n a) Source # | |
Defined in Data.Array.Internal.Ranked gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> Array n a -> c (Array n a) # gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c (Array n a) # toConstr :: Array n a -> Constr # dataTypeOf :: Array n a -> DataType # dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c (Array n a)) # dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c (Array n a)) # gmapT :: (forall b. Data b => b -> b) -> Array n a -> Array n a # gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Array n a -> r # gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Array n a -> r # gmapQ :: (forall d. Data d => d -> u) -> Array n a -> [u] # gmapQi :: Int -> (forall d. Data d => d -> u) -> Array n a -> u # gmapM :: Monad m => (forall d. Data d => d -> m d) -> Array n a -> m (Array n a) # gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> Array n a -> m (Array n a) # gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> Array n a -> m (Array n a) # | |
Generic (Array n a) Source # | |
(KnownNat n, Read a) => Read (Array n a) Source # | |
Show a => Show (Array n a) Source # | |
NFData a => NFData (Array n a) Source # | |
Defined in Data.Array.Internal.Ranked | |
Eq (Array n Vector a) => Eq (Array n a) Source # | |
Ord (Array n Vector a) => Ord (Array n a) Source # | |
Defined in Data.Array.Internal.Ranked | |
Pretty a => Pretty (Array n a) Source # | |
Defined in Data.Array.Internal.Ranked pPrintPrec :: PrettyLevel -> Rational -> Array n a -> Doc # pPrintList :: PrettyLevel -> [Array n a] -> Doc # | |
a ~ b => Convert (Array n a) (Array b) Source # | |
(a ~ b, n ~ m, Unbox a) => Convert (Array n a) (Array m b) Source # | |
(a ~ b, n ~ m, Unbox a) => Convert (Array n a) (Array m b) Source # | |
(a ~ b, Rank sh ~ n, Shape sh) => Convert (Array n a) (Array sh b) Source # | |
(a ~ b, n ~ m, Unbox a) => Convert (Array n a) (Array m b) Source # | |
(a ~ b, n ~ m, Unbox a) => Convert (Array n a) (Array m b) Source # | |
(a ~ b, Rank sh ~ n, Shape sh) => Convert (Array sh a) (Array n b) Source # | |
(a ~ b, n ~ m) => Convert (Array n a) (Array m Vector b) Source # | |
type Rep (Array n a) Source # | |
Defined in Data.Array.Internal.Ranked |
The Vector
class is the interface to the underlying storage for the arrays.
The operations map straight to operations for Vector
.
vIndex, vLength, vToList, vFromList, vSingleton, vReplicate, vMap, vZipWith, vZipWith3, vZipWith4, vZipWith5, vAppend, vConcat, vFold, vSlice, vSum, vProduct, vMaximum, vMinimum, vUpdate, vGenerate, vAll, vAny
Instances
Vector Vector Source # | |
Defined in Data.Array.Internal.Dynamic type VecElem Vector :: Type -> Constraint Source # vIndex :: VecElem Vector a => Vector a -> Int -> a Source # vLength :: VecElem Vector a => Vector a -> Int Source # vToList :: VecElem Vector a => Vector a -> [a] Source # vFromList :: VecElem Vector a => [a] -> Vector a Source # vSingleton :: VecElem Vector a => a -> Vector a Source # vReplicate :: VecElem Vector a => Int -> a -> Vector a Source # vMap :: (VecElem Vector a, VecElem Vector b) => (a -> b) -> Vector a -> Vector b Source # vZipWith :: (VecElem Vector a, VecElem Vector b, VecElem Vector c) => (a -> b -> c) -> Vector a -> Vector b -> Vector c Source # vZipWith3 :: (VecElem Vector a, VecElem Vector b, VecElem Vector c, VecElem Vector d) => (a -> b -> c -> d) -> Vector a -> Vector b -> Vector c -> Vector d Source # vZipWith4 :: (VecElem Vector a, VecElem Vector b, VecElem Vector c, VecElem Vector d, VecElem Vector e) => (a -> b -> c -> d -> e) -> Vector a -> Vector b -> Vector c -> Vector d -> Vector e Source # vZipWith5 :: (VecElem Vector a, VecElem Vector b, VecElem Vector c, VecElem Vector d, VecElem Vector e, VecElem Vector f) => (a -> b -> c -> d -> e -> f) -> Vector a -> Vector b -> Vector c -> Vector d -> Vector e -> Vector f Source # vAppend :: VecElem Vector a => Vector a -> Vector a -> Vector a Source # vConcat :: VecElem Vector a => [Vector a] -> Vector a Source # vFold :: VecElem Vector a => (a -> a -> a) -> a -> Vector a -> a Source # vSlice :: VecElem Vector a => Int -> Int -> Vector a -> Vector a Source # vSum :: (VecElem Vector a, Num a) => Vector a -> a Source # vProduct :: (VecElem Vector a, Num a) => Vector a -> a Source # vMaximum :: (VecElem Vector a, Ord a) => Vector a -> a Source # vMinimum :: (VecElem Vector a, Ord a) => Vector a -> a Source # vUpdate :: VecElem Vector a => Vector a -> [(Int, a)] -> Vector a Source # vGenerate :: VecElem Vector a => Int -> (Int -> a) -> Vector a Source # vAll :: VecElem Vector a => (a -> Bool) -> Vector a -> Bool Source # vAny :: VecElem Vector a => (a -> Bool) -> Vector a -> Bool Source # | |
Vector Vector Source # | |
Defined in Data.Array.Internal.DynamicS type VecElem Vector :: Type -> Constraint Source # vIndex :: VecElem Vector a => Vector a -> Int -> a Source # vLength :: VecElem Vector a => Vector a -> Int Source # vToList :: VecElem Vector a => Vector a -> [a] Source # vFromList :: VecElem Vector a => [a] -> Vector a Source # vSingleton :: VecElem Vector a => a -> Vector a Source # vReplicate :: VecElem Vector a => Int -> a -> Vector a Source # vMap :: (VecElem Vector a, VecElem Vector b) => (a -> b) -> Vector a -> Vector b Source # vZipWith :: (VecElem Vector a, VecElem Vector b, VecElem Vector c) => (a -> b -> c) -> Vector a -> Vector b -> Vector c Source # vZipWith3 :: (VecElem Vector a, VecElem Vector b, VecElem Vector c, VecElem Vector d) => (a -> b -> c -> d) -> Vector a -> Vector b -> Vector c -> Vector d Source # vZipWith4 :: (VecElem Vector a, VecElem Vector b, VecElem Vector c, VecElem Vector d, VecElem Vector e) => (a -> b -> c -> d -> e) -> Vector a -> Vector b -> Vector c -> Vector d -> Vector e Source # vZipWith5 :: (VecElem Vector a, VecElem Vector b, VecElem Vector c, VecElem Vector d, VecElem Vector e, VecElem Vector f) => (a -> b -> c -> d -> e -> f) -> Vector a -> Vector b -> Vector c -> Vector d -> Vector e -> Vector f Source # vAppend :: VecElem Vector a => Vector a -> Vector a -> Vector a Source # vConcat :: VecElem Vector a => [Vector a] -> Vector a Source # vFold :: VecElem Vector a => (a -> a -> a) -> a -> Vector a -> a Source # vSlice :: VecElem Vector a => Int -> Int -> Vector a -> Vector a Source # vSum :: (VecElem Vector a, Num a) => Vector a -> a Source # vProduct :: (VecElem Vector a, Num a) => Vector a -> a Source # vMaximum :: (VecElem Vector a, Ord a) => Vector a -> a Source # vMinimum :: (VecElem Vector a, Ord a) => Vector a -> a Source # vUpdate :: VecElem Vector a => Vector a -> [(Int, a)] -> Vector a Source # vGenerate :: VecElem Vector a => Int -> (Int -> a) -> Vector a Source # vAll :: VecElem Vector a => (a -> Bool) -> Vector a -> Bool Source # vAny :: VecElem Vector a => (a -> Bool) -> Vector a -> Bool Source # | |
Vector Vector Source # | |
Defined in Data.Array.Internal.DynamicU type VecElem Vector :: Type -> Constraint Source # vIndex :: VecElem Vector a => Vector a -> Int -> a Source # vLength :: VecElem Vector a => Vector a -> Int Source # vToList :: VecElem Vector a => Vector a -> [a] Source # vFromList :: VecElem Vector a => [a] -> Vector a Source # vSingleton :: VecElem Vector a => a -> Vector a Source # vReplicate :: VecElem Vector a => Int -> a -> Vector a Source # vMap :: (VecElem Vector a, VecElem Vector b) => (a -> b) -> Vector a -> Vector b Source # vZipWith :: (VecElem Vector a, VecElem Vector b, VecElem Vector c) => (a -> b -> c) -> Vector a -> Vector b -> Vector c Source # vZipWith3 :: (VecElem Vector a, VecElem Vector b, VecElem Vector c, VecElem Vector d) => (a -> b -> c -> d) -> Vector a -> Vector b -> Vector c -> Vector d Source # vZipWith4 :: (VecElem Vector a, VecElem Vector b, VecElem Vector c, VecElem Vector d, VecElem Vector e) => (a -> b -> c -> d -> e) -> Vector a -> Vector b -> Vector c -> Vector d -> Vector e Source # vZipWith5 :: (VecElem Vector a, VecElem Vector b, VecElem Vector c, VecElem Vector d, VecElem Vector e, VecElem Vector f) => (a -> b -> c -> d -> e -> f) -> Vector a -> Vector b -> Vector c -> Vector d -> Vector e -> Vector f Source # vAppend :: VecElem Vector a => Vector a -> Vector a -> Vector a Source # vConcat :: VecElem Vector a => [Vector a] -> Vector a Source # vFold :: VecElem Vector a => (a -> a -> a) -> a -> Vector a -> a Source # vSlice :: VecElem Vector a => Int -> Int -> Vector a -> Vector a Source # vSum :: (VecElem Vector a, Num a) => Vector a -> a Source # vProduct :: (VecElem Vector a, Num a) => Vector a -> a Source # vMaximum :: (VecElem Vector a, Ord a) => Vector a -> a Source # vMinimum :: (VecElem Vector a, Ord a) => Vector a -> a Source # vUpdate :: VecElem Vector a => Vector a -> [(Int, a)] -> Vector a Source # vGenerate :: VecElem Vector a => Int -> (Int -> a) -> Vector a Source # vAll :: VecElem Vector a => (a -> Bool) -> Vector a -> Bool Source # vAny :: VecElem Vector a => (a -> Bool) -> Vector a -> Bool Source # | |
Vector List Source # | |
Defined in Data.Array.Internal vIndex :: VecElem List a => [a] -> Int -> a Source # vLength :: VecElem List a => [a] -> Int Source # vToList :: VecElem List a => [a] -> [a] Source # vFromList :: VecElem List a => [a] -> [a] Source # vSingleton :: VecElem List a => a -> [a] Source # vReplicate :: VecElem List a => Int -> a -> [a] Source # vMap :: (VecElem List a, VecElem List b) => (a -> b) -> [a] -> [b] Source # vZipWith :: (VecElem List a, VecElem List b, VecElem List c) => (a -> b -> c) -> [a] -> [b] -> [c] Source # vZipWith3 :: (VecElem List a, VecElem List b, VecElem List c, VecElem List d) => (a -> b -> c -> d) -> [a] -> [b] -> [c] -> [d] Source # vZipWith4 :: (VecElem List a, VecElem List b, VecElem List c, VecElem List d, VecElem List e) => (a -> b -> c -> d -> e) -> [a] -> [b] -> [c] -> [d] -> [e] Source # vZipWith5 :: (VecElem List a, VecElem List b, VecElem List c, VecElem List d, VecElem List e, VecElem List f) => (a -> b -> c -> d -> e -> f) -> [a] -> [b] -> [c] -> [d] -> [e] -> [f] Source # vAppend :: VecElem List a => [a] -> [a] -> [a] Source # vConcat :: VecElem List a => [[a]] -> [a] Source # vFold :: VecElem List a => (a -> a -> a) -> a -> [a] -> a Source # vSlice :: VecElem List a => Int -> Int -> [a] -> [a] Source # vSum :: (VecElem List a, Num a) => [a] -> a Source # vProduct :: (VecElem List a, Num a) => [a] -> a Source # vMaximum :: (VecElem List a, Ord a) => [a] -> a Source # vMinimum :: (VecElem List a, Ord a) => [a] -> a Source # vUpdate :: VecElem List a => [a] -> [(Int, a)] -> [a] Source # vGenerate :: VecElem List a => Int -> (Int -> a) -> [a] Source # vAll :: VecElem List a => (a -> Bool) -> [a] -> Bool Source # vAny :: VecElem List a => (a -> Bool) -> [a] -> Bool Source # |
fromList :: forall n a. KnownNat n => ShapeL -> [a] -> Array n a Source #
Convert from a list with the elements given in the linearization order. Fails if the given shape does not have the same number of elements as the list. O(n) time.
toList :: Array n a -> [a] Source #
Convert to a list with the elements in the linearization order. O(n) time.
generate :: forall n a. KnownNat n => ShapeL -> ([Int] -> a) -> Array n a Source #
Generate an array with a function that computes the value for each index.
index :: HasCallStack => Array (1 + n) a -> Int -> Array n a Source #
Index into an array. Fails if the index is out of bounds. O(1) time.
transpose :: KnownNat n => [Int] -> Array n a -> Array n a Source #
Do an arbitrary array transposition. Fails if the transposition argument is not a permutation of the numbers [0..r-1], where r is the rank of the array. O(1) time.
rotate :: forall d p a. (KnownNat p, KnownNat d, (d + (p + 1)) ~ ((p + d) + 1), (d + p) ~ (p + d), 1 <= (p + 1), KnownNat ((p + d) + 1), KnownNat (p + 1), KnownNat (1 + (p + 1))) => Int -> Array (p + d) a -> Array ((p + d) + 1) a Source #
Rotate the array k times along the d'th dimension.
E.g., if the array shape is [2, 3, 2]
, d is 1, and k is 4,
the resulting shape will be [2, 4, 3, 2]
.
append :: KnownNat n => Array n a -> Array n a -> Array n a Source #
Append two arrays along the outermost dimension. All dimensions, except the outermost, must be the same. O(n) time.
slice :: [(Int, Int)] -> Array n a -> Array n a Source #
Extract a slice of an array.
The first argument is a list of (offset, length) pairs.
The length of the slicing argument must not exceed the rank of the array.
The extracted slice must fall within the array dimensions.
E.g. slice [1,2] (fromList [4] [1,2,3,4]) == [2,3]
.
O(1) time.
shapeL :: Array n a -> ShapeL Source #
The shape of an array, i.e., a list of the sizes of its dimensions. In the linearization of the array the outermost (i.e. first list element) varies most slowly. O(1) time.
rank :: KnownNat n => Array n a -> Int Source #
The rank of an array, i.e., the number of dimensions it has,
which is the n
in Array n a
.
O(1) time.
toVector :: Array n a -> Vector a Source #
Convert to a vector with the elements in the linearization order. O(n) or O(1) time (the latter if the vector is already in the linearization order).
fromVector :: forall n a. KnownNat n => ShapeL -> Vector a -> Array n a Source #
Convert from a vector with the elements given in the linearization order. Fails if the given shape does not have the same number of elements as the list. O(1) time.
normalize :: KnownNat n => Array n a -> Array n a Source #
Make sure the underlying vector is in the linearization order. This is semantically an identity function, but can have big performance implications. O(n) or O(1) time.
constant :: forall n a. KnownNat n => ShapeL -> a -> Array n a Source #
Make an array with all elements having the same value. O(1) time
reshape :: forall n' n a. (KnownNat n, KnownNat n') => ShapeL -> Array n a -> Array n' a Source #
Change the shape of an array. Fails if the arrays have different number of elements. O(n) or O(1) time.
stretch :: ShapeL -> Array n a -> Array n a Source #
Change the size of dimensions with size 1. These dimension can be changed to any size. All other dimensions must remain the same. O(1) time.
stretchOuter :: (HasCallStack, 1 <= n) => Int -> Array n a -> Array n a Source #
Change the size of the outermost dimension by replication.
pad :: KnownNat n => [(Int, Int)] -> a -> Array n a -> Array n a Source #
Pad each dimension on the low and high side with the given value. O(n) time.
zipWithA :: (a -> b -> c) -> Array n a -> Array n b -> Array n c Source #
Map over the array elements. O(n) time.
zipWith3A :: (a -> b -> c -> d) -> Array n a -> Array n b -> Array n c -> Array n d Source #
Map over the array elements. O(n) time.
concatOuter :: KnownNat n => [Array n a] -> Array n a Source #
Concatenate a number of arrays into a single array. Fails if any, but the outer, dimensions differ. O(n) time.
ravel :: KnownNat (1 + n) => Array 1 (Array n a) -> Array (1 + n) a Source #
Turn a rank-1 array of arrays into a single array by making the outer array into the outermost dimension of the result array. All the arrays must have the same shape. O(n) time.
unravel :: Array (1 + n) a -> Array 1 (Array n a) Source #
Turn an array into a nested array, this is the inverse of ravel
.
I.e., ravel . unravel == id
.
window :: (KnownNat n, KnownNat n') => [Int] -> Array n a -> Array n' a Source #
Make a window of the outermost dimensions.
The rank increases with the length of the window list.
E.g., if the shape of the array is [10,12,8]
and
the window size is [3,3]
then the resulting array will have shape
[8,10,3,3,8]
.
O(1) time.
stride :: [Int] -> Array n a -> Array n a Source #
Stride the outermost dimensions.
E.g., if the array shape is [10,12,8]
and the strides are
[2,2]
then the resulting shape will be [5,6,8]
.
O(1) time.
rerank :: forall n i o a b. (KnownNat n, KnownNat o, KnownNat (n + o), KnownNat (1 + o)) => (Array i a -> Array o b) -> Array (n + i) a -> Array (n + o) b Source #
Apply a function to the subarrays n levels down and make the results into an array with the same n outermost dimensions. The n must not exceed the rank of the array. O(n) time.
rerank2 :: forall n i o a b c. (KnownNat n, KnownNat o, KnownNat (n + o), KnownNat (1 + o)) => (Array i a -> Array i b -> Array o c) -> Array (n + i) a -> Array (n + i) b -> Array (n + o) c Source #
Apply a two-argument function to the subarrays n levels down and make the results into an array with the same n outermost dimensions. The n must not exceed the rank of the array. O(n) time.
rev :: [Int] -> Array n a -> Array n a Source #
Reverse the given dimensions, with the outermost being dimension 0. O(1) time.
foldrA :: (a -> b -> b) -> b -> Array n a -> b Source #
Constrained version of foldr
for Arrays.
Note that this Array
actually has Traversable
anyway.
traverseA :: Applicative f => (a -> f b) -> Array n a -> f (Array n b) Source #
Constrained version of traverse
for Arrays.
Note that this Array
actually has Traversable
anyway.
broadcast :: forall r' r a. (HasCallStack, KnownNat r, KnownNat r') => [Int] -> ShapeL -> Array r a -> Array r' a Source #
Put the dimensions of the argument into the specified dimensions, and just replicate the data along all other dimensions. The list of dimensions indicies must have the same rank as the argument array and it must be strictly ascending.