размером. Чтобы в сигнатурах функций проверялось что все аргументы-векторы одной длины. https://wiki.haskell.org/The_Monad.Reader/Issue5/Number_Param_Types тут нашел как подобное сделать, н оне понятно как обявить функцию конкатенации - чтоб на входе вуктора длин x и y, а на выходе x+y. Как такую функцию объявить с типом вектора из примера в ссылке?
https://www.parsonsmatt.org/2017/04/26/basic_type_level_programming_in_haskell.html
Спасибо, то что нужно. Как такие вектора будут работать под капотом? Будет односвязный список или ghci додумается в сплошную оласть памяти элементы вектора положить?
Не пойму как из типа такого вектора доставать длину. import Data.Number.Peano newtype SizedArray (size :: Nat) i a = SizedArray (Array i a) deriving (Eq, Show) repeat_arr :: SizedArray s i2 a2 -> a -> SizedArray s Int a repeat_arr _ x = let ln = (fromPeano s)::Int in SizedArray $ listArray (0, pred ln) (replicate ln x) вот пытаюсь написать функцию которая создаст массив с размером из типа, но не получается посчитать ln: Variable not in scope: s
1) ScopedTypeVariables 2) forall size i a. ... 3) KnownNat size
значение, зависящее от типа — это тайпкласс
2) что значит forall? то что я пока нагуглил говорит что это объявляет что любые типы подойдут, но тоже самое будет значить и сигнатура без forall 3) KnownNat это что?
2. в контексте ScopedTypeVariables у квантора forall появляется ещё один смысл
Как без экземпляра тип в функцию передать?
Ещё через Proxy делают, хотя с TypeApplications проще
Обсуждают сегодня