module Meas9 () where import Data.Set (Set(..)) {-@ myid :: xs:[a] -> {v:[a]| listElts(v) = listElts(xs)} @-} myid [] = [] myid (x:xs) = x : myid xs {-@ myapp :: xs:[a] -> ys:[a] -> {v:[a] | listElts v = Set_cup (listElts xs) (listElts ys)} @-} myapp :: [a] -> [a] -> [a] myapp [] ys = ys myapp (x:xs) ys = x : myapp xs ys {-@ myrev :: xs:[a] -> {v:[a]| listElts v = listElts xs} @-} myrev :: [a] -> [a] myrev = go [] where go acc [] = acc go acc (y:ys) = go (y:acc) ys