module Data.Array.Comfort.Check where

import qualified Data.Array.Comfort.Shape as Shape

import Text.Printf (printf)


{-# INLINE reshape #-}
reshape ::
   (Shape.C sh0, Shape.C sh1) =>
   String ->
   (array0 -> sh0) ->
   (sh1 -> array0 -> array1) ->
   sh1 -> array0 -> array1
reshape :: forall sh0 sh1 array0 array1.
(C sh0, C sh1) =>
String
-> (array0 -> sh0)
-> (sh1 -> array0 -> array1)
-> sh1
-> array0
-> array1
reshape String
name array0 -> sh0
shape sh1 -> array0 -> array1
uncheckedReshape sh1
sh1 array0
arr =
   let n0 :: Int
n0 = sh0 -> Int
forall sh. C sh => sh -> Int
Shape.size (sh0 -> Int) -> sh0 -> Int
forall a b. (a -> b) -> a -> b
$ array0 -> sh0
shape array0
arr
       n1 :: Int
n1 = sh1 -> Int
forall sh. C sh => sh -> Int
Shape.size sh1
sh1
   in if Int
n0 Int -> Int -> Bool
forall a. Eq a => a -> a -> Bool
== Int
n1
         then sh1 -> array0 -> array1
uncheckedReshape sh1
sh1 array0
arr
         else String -> array1
forall a. HasCallStack => String -> a
error (String -> array1) -> String -> array1
forall a b. (a -> b) -> a -> b
$
              String -> String -> Int -> Int -> String
forall r. PrintfType r => String -> r
printf
                 (String
"Array.Comfort.%s.reshape: " String -> String -> String
forall a. [a] -> [a] -> [a]
++
                  String
"different sizes of old (%d) and new (%d) shape")
                 String
name Int
n0 Int
n1