{-# LANGUAGE CPP #-}
{-# LANGUAGE ScopedTypeVariables #-}
{-# OPTIONS_GHC -Wall -Werror #-}
module Documentation.SBV.Examples.Uninterpreted.AUF where
import Data.SBV
#ifndef HADDOCK
#endif
f :: SWord32 -> SWord64
f :: SWord32 -> SWord64
f = String -> SWord32 -> SWord64
forall a. SMTDefinable a => String -> a
uninterpret String
"f"
thm :: SWord32 -> SWord32 -> SArray Word32 Word32 -> SBool
thm :: SWord32 -> SWord32 -> SArray Word32 Word32 -> SBool
thm SWord32
x SWord32
y SArray Word32 Word32
a = SBool
lhs SBool -> SBool -> SBool
.=> SBool
rhs
where lhs :: SBool
lhs = SWord32
x SWord32 -> SWord32 -> SWord32
forall a. Num a => a -> a -> a
+ SWord32
2 SWord32 -> SWord32 -> SBool
forall a. EqSymbolic a => a -> a -> SBool
.== SWord32
y
rhs :: SBool
rhs = SWord32 -> SWord64
f (SArray Word32 Word32 -> SWord32 -> SWord32
forall key val.
(Eq key, SymVal key, SymVal val, HasKind val) =>
SArray key val -> SBV key -> SBV val
readArray (SArray Word32 Word32 -> SWord32 -> SWord32 -> SArray Word32 Word32
forall key val.
(HasKind key, SymVal key, SymVal val, HasKind val) =>
SArray key val -> SBV key -> SBV val -> SArray key val
writeArray SArray Word32 Word32
a SWord32
x SWord32
3) (SWord32
y SWord32 -> SWord32 -> SWord32
forall a. Num a => a -> a -> a
- SWord32
2))
SWord64 -> SWord64 -> SBool
forall a. EqSymbolic a => a -> a -> SBool
.== SWord32 -> SWord64
f (SWord32
y SWord32 -> SWord32 -> SWord32
forall a. Num a => a -> a -> a
- SWord32
x SWord32 -> SWord32 -> SWord32
forall a. Num a => a -> a -> a
+ SWord32
1)