blob: d29e4d5b79d2a40a645aee3ee6dad3a98fb96ec4 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
|
{-# LANGUAGE DataKinds #-}
{-# LANGUAGE GADTs #-}
{-# LANGUAGE TypeApplications #-}
module Main where
import Data.Array.Nested
arr :: Ranked I2 (Shaped [2, 3] (Double, Int))
arr = rgenerate (3 ::: 4 ::: IZR) $ \(i ::: j ::: IZR) ->
sgenerate @[2, 3] $ \(k ::$ l ::$ IZS) ->
let s = 24*i + 6*j + 3*k + l
in (fromIntegral s, s)
foo :: (Double, Int)
foo = arr `rindex` (2 ::: 1 ::: IZR) `sindex` (1 ::$ 1 ::$ IZS)
bad :: Ranked I2 (Ranked I1 Double)
bad = rgenerate (3 ::: 4 ::: IZR) $ \(i ::: j ::: IZR) ->
rgenerate (i ::: IZR) $ \(k ::: IZR) ->
let s = 24*i + 6*j + 3*k
in fromIntegral s
main :: IO ()
main = do
print arr
print foo
print (rtranspose [1,0] arr)
-- print bad
|