Я новичок в Irdis. Можно ли перевернуть HVect
? Если я назову реверс на HVect [String, Int]
, он должен вернуть HVect [Int, String]
, и если я вызову реверс на HVect [String, Int, Day]
, он должен вернуть HVect [Day, Int, String]
.Как отменить HVect в Идрисе?
Я попытался повторно Data.Vect.reverse
(Gist)
module reverse_hvect
import Data.HVect
reverse : HVect ts -> HVect (reverse ts)
reverse [] = []
reverse (x::xs) = (reverse xs) ++ [x]
, но я получаю
Type checking .\reverse_hvect.idr
reverse_hvect.idr:7:9:When checking right hand side of reverse_hvect.reverse with expected type
HVect (reverse (t :: ts))
Type mismatch between
HVect (Data.Vect.reverse, go Type k ts [] ts ++ [t]) (Type of reverse xs ++ [x])
and
HVect (Data.Vect.reverse, go Type (S k) (t :: ts) [t] ts) (Expected type)
Specifically:
Type mismatch between
Data.Vect.reverse, go Type k ts [] ts ++ [t]
and
Data.Vect.reverse, go Type (S k) (t :: ts) [t] ts
Holes: reverse_hvect.reverse
Поскольку Data.Vect.reverse
использует внутреннюю функцию go
с аккумулятором, я написал свой собственный Vect.reverse
с той же структурой, мой HVect.reverse
(Gist)
module reverse_hvect
import Data.Vect
import Data.HVect
myReverse : Vect n a -> Vect n a
myReverse [] = []
myReverse {n = S k} (x::xs) = rewrite plusCommutative 1 k in (myReverse xs) ++ [x]
reverse : HVect ts -> HVect (myReverse ts)
reverse [] = []
reverse (x::xs) = (reverse xs) ++ [x]
, но я получаю другую ошибку
Type checking .\reverse_hvect.idr
reverse_hvect.idr:12:9:When checking right hand side of reverse_hvect.reverse with expected type
HVect (myReverse (t :: ts))
Type mismatch between
HVect (myReverse ts ++ [t]) (Type of reverse xs ++ [x])
and
HVect (replace (sym (replace (sym (replace (sym (plusZeroRightNeutral k)) Refl)) (replace (sym (plusSuccRightSucc k 0)) Refl))) (myReverse ts ++ [t])) (Expected type)
Specifically:
Type mismatch between
myReverse ts ++ [t]
and
replace (sym (replace (sym (replace (sym (plusZeroRightNeutral k)) Refl)) (replace (sym (plusSuccRightSucc k 0)) Refl))) (myReverse ts ++ [t])
Holes: reverse_hvect.reverse
Я не знаком с Агда. Я действительно был бы признателен за перевод в Идрис. – maiermic
Что вы подразумеваете под сломанным? Он не использует foldl, но это потому, что foldl в интерфейсе Foldable не фиксирует изменение размера. Это по сути тот же алгоритм. –
@ Эдвин Брэди, возможно, «сломан» - это не правильное слово. Я имею в виду, что эти 'plusZeroRightNeutral' и' plusSuccRightSucc' не нужны, когда 'reverse' определяется через' foldl'. – user3237465