From 592d5953c20fc9749033ca0e0a7b0f47e4a3f928 Mon Sep 17 00:00:00 2001 From: Levent Erkok Date: Sun, 12 Nov 2023 12:46:43 -0800 Subject: [PATCH] Add extra instances for SMTDefinable to support upto 12 arguments Fixes #670 --- Data/SBV/Core/Model.hs | 235 +++++++++++++++++++++++++++++++++++++ Data/SBV/Provers/Prover.hs | 67 ++++++++--- 2 files changed, 286 insertions(+), 16 deletions(-) diff --git a/Data/SBV/Core/Model.hs b/Data/SBV/Core/Model.hs index 68746c6c1..be8f41e04 100644 --- a/Data/SBV/Core/Model.hs +++ b/Data/SBV/Core/Model.hs @@ -2582,6 +2582,201 @@ instance (SymVal h, SymVal g, SymVal f, SymVal e, SymVal d, SymVal c, SymVal b, mapM_ forceSVArg [sw0, sw1, sw2, sw3, sw4, sw5, sw6] newExpr st ka $ SBVApp (Uninterpreted nm) [sw0, sw1, sw2, sw3, sw4, sw5, sw6] +-- Functions of eight arguments +instance (SymVal i, SymVal h, SymVal g, SymVal f, SymVal e, SymVal d, SymVal c, SymVal b, HasKind a) + => SMTDefinable (SBV i -> SBV h -> SBV g -> SBV f -> SBV e -> SBV d -> SBV c -> SBV b -> SBV a) where + sbv2smt fn = defs2smt $ \i h g f e d c b -> fn i h g f e d c b .== fn i h g f e d c b + + sbvDefineValue nm uiKind = f + where f arg0 arg1 arg2 arg3 arg4 arg5 arg6 arg7 + | Just v <- retrieveConstCode uiKind, isConcrete arg0, isConcrete arg1, isConcrete arg2, isConcrete arg3, isConcrete arg4, isConcrete arg5, isConcrete arg6, isConcrete arg7 + = v arg0 arg1 arg2 arg3 arg4 arg5 arg6 arg7 + | True + = SBV $ SVal ka $ Right $ cache result + where ka = kindOf (Proxy @a) + kb = kindOf (Proxy @b) + kc = kindOf (Proxy @c) + kd = kindOf (Proxy @d) + ke = kindOf (Proxy @e) + kf = kindOf (Proxy @f) + kg = kindOf (Proxy @g) + kh = kindOf (Proxy @h) + ki = kindOf (Proxy @i) + result st = do isSMT <- inSMTMode st + case (isSMT, uiKind) of + (True, UICodeC (v, _)) -> sbvToSV st (v arg0 arg1 arg2 arg3 arg4 arg5 arg6 arg7) + _ -> do newUninterpreted st (nm, Nothing) (SBVType [kh, kg, kf, ke, kd, kc, kb, ka, ki]) =<< retrieveUICode nm st ka uiKind + sw0 <- sbvToSV st arg0 + sw1 <- sbvToSV st arg1 + sw2 <- sbvToSV st arg2 + sw3 <- sbvToSV st arg3 + sw4 <- sbvToSV st arg4 + sw5 <- sbvToSV st arg5 + sw6 <- sbvToSV st arg6 + sw7 <- sbvToSV st arg7 + mapM_ forceSVArg [sw0, sw1, sw2, sw3, sw4, sw5, sw6, sw7] + newExpr st ka $ SBVApp (Uninterpreted nm) [sw0, sw1, sw2, sw3, sw4, sw5, sw6, sw7] + +-- Functions of nine arguments +instance (SymVal j, SymVal i, SymVal h, SymVal g, SymVal f, SymVal e, SymVal d, SymVal c, SymVal b, HasKind a) + => SMTDefinable (SBV j -> SBV i -> SBV h -> SBV g -> SBV f -> SBV e -> SBV d -> SBV c -> SBV b -> SBV a) where + sbv2smt fn = defs2smt $ \j i h g f e d c b -> fn j i h g f e d c b .== fn j i h g f e d c b + + sbvDefineValue nm uiKind = f + where f arg0 arg1 arg2 arg3 arg4 arg5 arg6 arg7 arg8 + | Just v <- retrieveConstCode uiKind, isConcrete arg0, isConcrete arg1, isConcrete arg2, isConcrete arg3, isConcrete arg4, isConcrete arg5, isConcrete arg6, isConcrete arg7, isConcrete arg8 + = v arg0 arg1 arg2 arg3 arg4 arg5 arg6 arg7 arg8 + | True + = SBV $ SVal ka $ Right $ cache result + where ka = kindOf (Proxy @a) + kb = kindOf (Proxy @b) + kc = kindOf (Proxy @c) + kd = kindOf (Proxy @d) + ke = kindOf (Proxy @e) + kf = kindOf (Proxy @f) + kg = kindOf (Proxy @g) + kh = kindOf (Proxy @h) + ki = kindOf (Proxy @i) + kj = kindOf (Proxy @j) + result st = do isSMT <- inSMTMode st + case (isSMT, uiKind) of + (True, UICodeC (v, _)) -> sbvToSV st (v arg0 arg1 arg2 arg3 arg4 arg5 arg6 arg7 arg8) + _ -> do newUninterpreted st (nm, Nothing) (SBVType [kh, kg, kf, ke, kd, kc, kb, ka, ki, kj]) =<< retrieveUICode nm st ka uiKind + sw0 <- sbvToSV st arg0 + sw1 <- sbvToSV st arg1 + sw2 <- sbvToSV st arg2 + sw3 <- sbvToSV st arg3 + sw4 <- sbvToSV st arg4 + sw5 <- sbvToSV st arg5 + sw6 <- sbvToSV st arg6 + sw7 <- sbvToSV st arg7 + sw8 <- sbvToSV st arg8 + mapM_ forceSVArg [sw0, sw1, sw2, sw3, sw4, sw5, sw6, sw7, sw8] + newExpr st ka $ SBVApp (Uninterpreted nm) [sw0, sw1, sw2, sw3, sw4, sw5, sw6, sw7, sw8] + +-- Functions of ten arguments +instance (SymVal k, SymVal j, SymVal i, SymVal h, SymVal g, SymVal f, SymVal e, SymVal d, SymVal c, SymVal b, HasKind a) + => SMTDefinable (SBV k -> SBV j -> SBV i -> SBV h -> SBV g -> SBV f -> SBV e -> SBV d -> SBV c -> SBV b -> SBV a) where + sbv2smt fn = defs2smt $ \k j i h g f e d c b -> fn k j i h g f e d c b .== fn k j i h g f e d c b + + sbvDefineValue nm uiKind = f + where f arg0 arg1 arg2 arg3 arg4 arg5 arg6 arg7 arg8 arg9 + | Just v <- retrieveConstCode uiKind, isConcrete arg0, isConcrete arg1, isConcrete arg2, isConcrete arg3, isConcrete arg4, isConcrete arg5, isConcrete arg6, isConcrete arg7, isConcrete arg8, isConcrete arg9 + = v arg0 arg1 arg2 arg3 arg4 arg5 arg6 arg7 arg8 arg9 + | True + = SBV $ SVal ka $ Right $ cache result + where ka = kindOf (Proxy @a) + kb = kindOf (Proxy @b) + kc = kindOf (Proxy @c) + kd = kindOf (Proxy @d) + ke = kindOf (Proxy @e) + kf = kindOf (Proxy @f) + kg = kindOf (Proxy @g) + kh = kindOf (Proxy @h) + ki = kindOf (Proxy @i) + kj = kindOf (Proxy @j) + kk = kindOf (Proxy @k) + result st = do isSMT <- inSMTMode st + case (isSMT, uiKind) of + (True, UICodeC (v, _)) -> sbvToSV st (v arg0 arg1 arg2 arg3 arg4 arg5 arg6 arg7 arg8 arg9) + _ -> do newUninterpreted st (nm, Nothing) (SBVType [kh, kg, kf, ke, kd, kc, kb, ka, ki, kj, kk]) =<< retrieveUICode nm st ka uiKind + sw0 <- sbvToSV st arg0 + sw1 <- sbvToSV st arg1 + sw2 <- sbvToSV st arg2 + sw3 <- sbvToSV st arg3 + sw4 <- sbvToSV st arg4 + sw5 <- sbvToSV st arg5 + sw6 <- sbvToSV st arg6 + sw7 <- sbvToSV st arg7 + sw8 <- sbvToSV st arg8 + sw9 <- sbvToSV st arg9 + mapM_ forceSVArg [sw0, sw1, sw2, sw3, sw4, sw5, sw6, sw7, sw8, sw9] + newExpr st ka $ SBVApp (Uninterpreted nm) [sw0, sw1, sw2, sw3, sw4, sw5, sw6, sw7, sw8, sw9] + +-- Functions of eleven arguments +instance (SymVal l, SymVal k, SymVal j, SymVal i, SymVal h, SymVal g, SymVal f, SymVal e, SymVal d, SymVal c, SymVal b, HasKind a) + => SMTDefinable (SBV l -> SBV k -> SBV j -> SBV i -> SBV h -> SBV g -> SBV f -> SBV e -> SBV d -> SBV c -> SBV b -> SBV a) where + sbv2smt fn = defs2smt $ \l k j i h g f e d c b -> fn l k j i h g f e d c b .== fn l k j i h g f e d c b + + sbvDefineValue nm uiKind = f + where f arg0 arg1 arg2 arg3 arg4 arg5 arg6 arg7 arg8 arg9 arg10 + | Just v <- retrieveConstCode uiKind, isConcrete arg0, isConcrete arg1, isConcrete arg2, isConcrete arg3, isConcrete arg4, isConcrete arg5, isConcrete arg6, isConcrete arg7, isConcrete arg8, isConcrete arg9, isConcrete arg10 + = v arg0 arg1 arg2 arg3 arg4 arg5 arg6 arg7 arg8 arg9 arg10 + | True + = SBV $ SVal ka $ Right $ cache result + where ka = kindOf (Proxy @a) + kb = kindOf (Proxy @b) + kc = kindOf (Proxy @c) + kd = kindOf (Proxy @d) + ke = kindOf (Proxy @e) + kf = kindOf (Proxy @f) + kg = kindOf (Proxy @g) + kh = kindOf (Proxy @h) + ki = kindOf (Proxy @i) + kj = kindOf (Proxy @j) + kk = kindOf (Proxy @k) + kl = kindOf (Proxy @l) + result st = do isSMT <- inSMTMode st + case (isSMT, uiKind) of + (True, UICodeC (v, _)) -> sbvToSV st (v arg0 arg1 arg2 arg3 arg4 arg5 arg6 arg7 arg8 arg9 arg10) + _ -> do newUninterpreted st (nm, Nothing) (SBVType [kh, kg, kf, ke, kd, kc, kb, ka, ki, kj, kk, kl]) =<< retrieveUICode nm st ka uiKind + sw0 <- sbvToSV st arg0 + sw1 <- sbvToSV st arg1 + sw2 <- sbvToSV st arg2 + sw3 <- sbvToSV st arg3 + sw4 <- sbvToSV st arg4 + sw5 <- sbvToSV st arg5 + sw6 <- sbvToSV st arg6 + sw7 <- sbvToSV st arg7 + sw8 <- sbvToSV st arg8 + sw9 <- sbvToSV st arg9 + sw10 <- sbvToSV st arg10 + mapM_ forceSVArg [sw0, sw1, sw2, sw3, sw4, sw5, sw6, sw7, sw8, sw9, sw10] + newExpr st ka $ SBVApp (Uninterpreted nm) [sw0, sw1, sw2, sw3, sw4, sw5, sw6, sw7, sw8, sw9, sw10] + +-- Functions of twelve arguments +instance (SymVal m, SymVal l, SymVal k, SymVal j, SymVal i, SymVal h, SymVal g, SymVal f, SymVal e, SymVal d, SymVal c, SymVal b, HasKind a) + => SMTDefinable (SBV m -> SBV l -> SBV k -> SBV j -> SBV i -> SBV h -> SBV g -> SBV f -> SBV e -> SBV d -> SBV c -> SBV b -> SBV a) where + sbv2smt fn = defs2smt $ \m l k j i h g f e d c b -> fn m l k j i h g f e d c b .== fn m l k j i h g f e d c b + + sbvDefineValue nm uiKind = f + where f arg0 arg1 arg2 arg3 arg4 arg5 arg6 arg7 arg8 arg9 arg10 arg11 + | Just v <- retrieveConstCode uiKind, isConcrete arg0, isConcrete arg1, isConcrete arg2, isConcrete arg3, isConcrete arg4, isConcrete arg5, isConcrete arg6, isConcrete arg7, isConcrete arg8, isConcrete arg9, isConcrete arg10, isConcrete arg11 + = v arg0 arg1 arg2 arg3 arg4 arg5 arg6 arg7 arg8 arg9 arg10 arg11 + | True + = SBV $ SVal ka $ Right $ cache result + where ka = kindOf (Proxy @a) + kb = kindOf (Proxy @b) + kc = kindOf (Proxy @c) + kd = kindOf (Proxy @d) + ke = kindOf (Proxy @e) + kf = kindOf (Proxy @f) + kg = kindOf (Proxy @g) + kh = kindOf (Proxy @h) + ki = kindOf (Proxy @i) + kj = kindOf (Proxy @j) + kk = kindOf (Proxy @k) + kl = kindOf (Proxy @l) + km = kindOf (Proxy @m) + result st = do isSMT <- inSMTMode st + case (isSMT, uiKind) of + (True, UICodeC (v, _)) -> sbvToSV st (v arg0 arg1 arg2 arg3 arg4 arg5 arg6 arg7 arg8 arg9 arg10 arg11) + _ -> do newUninterpreted st (nm, Nothing) (SBVType [kh, kg, kf, ke, kd, kc, kb, ka, ki, kj, kk, kl, km]) =<< retrieveUICode nm st ka uiKind + sw0 <- sbvToSV st arg0 + sw1 <- sbvToSV st arg1 + sw2 <- sbvToSV st arg2 + sw3 <- sbvToSV st arg3 + sw4 <- sbvToSV st arg4 + sw5 <- sbvToSV st arg5 + sw6 <- sbvToSV st arg6 + sw7 <- sbvToSV st arg7 + sw8 <- sbvToSV st arg8 + sw9 <- sbvToSV st arg9 + sw10 <- sbvToSV st arg10 + sw11 <- sbvToSV st arg11 + mapM_ forceSVArg [sw0, sw1, sw2, sw3, sw4, sw5, sw6, sw7, sw8, sw9, sw10, sw11] + newExpr st ka $ SBVApp (Uninterpreted nm) [sw0, sw1, sw2, sw3, sw4, sw5, sw6, sw7, sw8, sw9, sw10, sw11] + -- Uncurried functions of two arguments instance (SymVal c, SymVal b, HasKind a) => SMTDefinable ((SBV c, SBV b) -> SBV a) where sbv2smt fn = defs2smt $ \p -> fn p .== fn p @@ -2627,6 +2822,46 @@ instance (SymVal h, SymVal g, SymVal f, SymVal e, SymVal d, SymVal c, SymVal b, sbvDefineValue nm uiKind = let f = sbvDefineValue nm (uc7 <$> uiKind) in \(arg0, arg1, arg2, arg3, arg4, arg5, arg6) -> f arg0 arg1 arg2 arg3 arg4 arg5 arg6 where uc7 fn a b c d e f g = fn (a, b, c, d, e, f, g) +-- Uncurried functions of eight arguments +instance (SymVal i, SymVal h, SymVal g, SymVal f, SymVal e, SymVal d, SymVal c, SymVal b, HasKind a) + => SMTDefinable ((SBV i, SBV h, SBV g, SBV f, SBV e, SBV d, SBV c, SBV b) -> SBV a) where + sbv2smt fn = defs2smt $ \p -> fn p .== fn p + + sbvDefineValue nm uiKind = let f = sbvDefineValue nm (uc8 <$> uiKind) in \(arg0, arg1, arg2, arg3, arg4, arg5, arg6, arg7) -> f arg0 arg1 arg2 arg3 arg4 arg5 arg6 arg7 + where uc8 fn a b c d e f g h = fn (a, b, c, d, e, f, g, h) + +-- Uncurried functions of nine arguments +instance (SymVal j, SymVal i, SymVal h, SymVal g, SymVal f, SymVal e, SymVal d, SymVal c, SymVal b, HasKind a) + => SMTDefinable ((SBV j, SBV i, SBV h, SBV g, SBV f, SBV e, SBV d, SBV c, SBV b) -> SBV a) where + sbv2smt fn = defs2smt $ \p -> fn p .== fn p + + sbvDefineValue nm uiKind = let f = sbvDefineValue nm (uc9 <$> uiKind) in \(arg0, arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8) -> f arg0 arg1 arg2 arg3 arg4 arg5 arg6 arg7 arg8 + where uc9 fn a b c d e f g h i = fn (a, b, c, d, e, f, g, h, i) + +-- Uncurried functions of ten arguments +instance (SymVal k, SymVal j, SymVal i, SymVal h, SymVal g, SymVal f, SymVal e, SymVal d, SymVal c, SymVal b, HasKind a) + => SMTDefinable ((SBV k, SBV j, SBV i, SBV h, SBV g, SBV f, SBV e, SBV d, SBV c, SBV b) -> SBV a) where + sbv2smt fn = defs2smt $ \p -> fn p .== fn p + + sbvDefineValue nm uiKind = let f = sbvDefineValue nm (uc10 <$> uiKind) in \(arg0, arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8, arg9) -> f arg0 arg1 arg2 arg3 arg4 arg5 arg6 arg7 arg8 arg9 + where uc10 fn a b c d e f g h i j = fn (a, b, c, d, e, f, g, h, i, j) + +-- Uncurried functions of eleven arguments +instance (SymVal l, SymVal k, SymVal j, SymVal i, SymVal h, SymVal g, SymVal f, SymVal e, SymVal d, SymVal c, SymVal b, HasKind a) + => SMTDefinable ((SBV l, SBV k, SBV j, SBV i, SBV h, SBV g, SBV f, SBV e, SBV d, SBV c, SBV b) -> SBV a) where + sbv2smt fn = defs2smt $ \p -> fn p .== fn p + + sbvDefineValue nm uiKind = let f = sbvDefineValue nm (uc11 <$> uiKind) in \(arg0, arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8, arg9, arg10) -> f arg0 arg1 arg2 arg3 arg4 arg5 arg6 arg7 arg8 arg9 arg10 + where uc11 fn a b c d e f g h i j k = fn (a, b, c, d, e, f, g, h, i, j, k) + +-- Uncurried functions of twelve arguments +instance (SymVal m, SymVal l, SymVal k, SymVal j, SymVal i, SymVal h, SymVal g, SymVal f, SymVal e, SymVal d, SymVal c, SymVal b, HasKind a) + => SMTDefinable ((SBV m, SBV l, SBV k, SBV j, SBV i, SBV h, SBV g, SBV f, SBV e, SBV d, SBV c, SBV b) -> SBV a) where + sbv2smt fn = defs2smt $ \p -> fn p .== fn p + + sbvDefineValue nm uiKind = let f = sbvDefineValue nm (uc12 <$> uiKind) in \(arg0, arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8, arg9, arg10, arg11) -> f arg0 arg1 arg2 arg3 arg4 arg5 arg6 arg7 arg8 arg9 arg10 arg11 + where uc12 fn a b c d e f g h i j k l = fn (a, b, c, d, e, f, g, h, i, j, k, l) + -- | Symbolic computations provide a context for writing symbolic programs. instance MonadIO m => SolverContext (SymbolicT m) where constrain = imposeConstraint False [] . unSBV . quantifiedBool diff --git a/Data/SBV/Provers/Prover.hs b/Data/SBV/Provers/Prover.hs index 20c027ba0..3b1c5beb7 100644 --- a/Data/SBV/Provers/Prover.hs +++ b/Data/SBV/Provers/Prover.hs @@ -659,59 +659,94 @@ mkArg = mkSymVal (NonQueryVar Nothing) Nothing -- Functions instance (SymVal a, SatisfiableM m p) => SatisfiableM m (SBV a -> p) where - satArgReduce k = mkArg >>= \a -> satArgReduce $ k a + satArgReduce fn = mkArg >>= \a -> satArgReduce $ fn a instance (SymVal a, ProvableM m p) => ProvableM m (SBV a -> p) where - proofArgReduce k = mkArg >>= \a -> proofArgReduce $ k a + proofArgReduce fn = mkArg >>= \a -> proofArgReduce $ fn a -- Arrays instance (HasKind a, HasKind b, SatisfiableM m p) => SatisfiableM m (SArray a b -> p) where - satArgReduce k = newArray_ Nothing >>= \a -> satArgReduce $ k a + satArgReduce fn = newArray_ Nothing >>= \a -> satArgReduce $ fn a instance (HasKind a, HasKind b, ProvableM m p) => ProvableM m (SArray a b -> p) where - proofArgReduce k = newArray_ Nothing >>= \a -> proofArgReduce $ k a + proofArgReduce fn = newArray_ Nothing >>= \a -> proofArgReduce $ fn a -- 2 Tuple instance (SymVal a, SymVal b, SatisfiableM m p) => SatisfiableM m ((SBV a, SBV b) -> p) where - satArgReduce k = mkArg >>= \a -> satArgReduce $ \b -> k (a, b) + satArgReduce fn = mkArg >>= \a -> satArgReduce $ \b -> fn (a, b) instance (SymVal a, SymVal b, ProvableM m p) => ProvableM m ((SBV a, SBV b) -> p) where - proofArgReduce k = mkArg >>= \a -> proofArgReduce $ \b -> k (a, b) + proofArgReduce fn = mkArg >>= \a -> proofArgReduce $ \b -> fn (a, b) -- 3 Tuple instance (SymVal a, SymVal b, SymVal c, SatisfiableM m p) => SatisfiableM m ((SBV a, SBV b, SBV c) -> p) where - satArgReduce k = mkArg >>= \a -> satArgReduce $ \b c -> k (a, b, c) + satArgReduce fn = mkArg >>= \a -> satArgReduce $ \b c -> fn (a, b, c) instance (SymVal a, SymVal b, SymVal c, ProvableM m p) => ProvableM m ((SBV a, SBV b, SBV c) -> p) where - proofArgReduce k = mkArg >>= \a -> proofArgReduce $ \b c -> k (a, b, c) + proofArgReduce fn = mkArg >>= \a -> proofArgReduce $ \b c -> fn (a, b, c) -- 4 Tuple instance (SymVal a, SymVal b, SymVal c, SymVal d, SatisfiableM m p) => SatisfiableM m ((SBV a, SBV b, SBV c, SBV d) -> p) where - satArgReduce k = mkArg >>= \a -> satArgReduce $ \b c d -> k (a, b, c, d) + satArgReduce fn = mkArg >>= \a -> satArgReduce $ \b c d -> fn (a, b, c, d) instance (SymVal a, SymVal b, SymVal c, SymVal d, ProvableM m p) => ProvableM m ((SBV a, SBV b, SBV c, SBV d) -> p) where - proofArgReduce k = mkArg >>= \a -> proofArgReduce $ \b c d -> k (a, b, c, d) + proofArgReduce fn = mkArg >>= \a -> proofArgReduce $ \b c d -> fn (a, b, c, d) -- 5 Tuple instance (SymVal a, SymVal b, SymVal c, SymVal d, SymVal e, SatisfiableM m p) => SatisfiableM m ((SBV a, SBV b, SBV c, SBV d, SBV e) -> p) where - satArgReduce k = mkArg >>= \a -> satArgReduce $ \b c d e -> k (a, b, c, d, e) + satArgReduce fn = mkArg >>= \a -> satArgReduce $ \b c d e -> fn (a, b, c, d, e) instance (SymVal a, SymVal b, SymVal c, SymVal d, SymVal e, ProvableM m p) => ProvableM m ((SBV a, SBV b, SBV c, SBV d, SBV e) -> p) where - proofArgReduce k = mkArg >>= \a -> proofArgReduce $ \b c d e -> k (a, b, c, d, e) + proofArgReduce fn = mkArg >>= \a -> proofArgReduce $ \b c d e -> fn (a, b, c, d, e) -- 6 Tuple instance (SymVal a, SymVal b, SymVal c, SymVal d, SymVal e, SymVal f, SatisfiableM m p) => SatisfiableM m ((SBV a, SBV b, SBV c, SBV d, SBV e, SBV f) -> p) where - satArgReduce k = mkArg >>= \a -> satArgReduce $ \b c d e f -> k (a, b, c, d, e, f) + satArgReduce fn = mkArg >>= \a -> satArgReduce $ \b c d e f -> fn (a, b, c, d, e, f) instance (SymVal a, SymVal b, SymVal c, SymVal d, SymVal e, SymVal f, ProvableM m p) => ProvableM m ((SBV a, SBV b, SBV c, SBV d, SBV e, SBV f) -> p) where - proofArgReduce k = mkArg >>= \a -> proofArgReduce $ \b c d e f -> k (a, b, c, d, e, f) + proofArgReduce fn = mkArg >>= \a -> proofArgReduce $ \b c d e f -> fn (a, b, c, d, e, f) -- 7 Tuple instance (SymVal a, SymVal b, SymVal c, SymVal d, SymVal e, SymVal f, SymVal g, SatisfiableM m p) => SatisfiableM m ((SBV a, SBV b, SBV c, SBV d, SBV e, SBV f, SBV g) -> p) where - satArgReduce k = mkArg >>= \a -> satArgReduce $ \b c d e f g -> k (a, b, c, d, e, f, g) + satArgReduce fn = mkArg >>= \a -> satArgReduce $ \b c d e f g -> fn (a, b, c, d, e, f, g) instance (SymVal a, SymVal b, SymVal c, SymVal d, SymVal e, SymVal f, SymVal g, ProvableM m p) => ProvableM m ((SBV a, SBV b, SBV c, SBV d, SBV e, SBV f, SBV g) -> p) where - proofArgReduce k = mkArg >>= \a -> proofArgReduce $ \b c d e f g -> k (a, b, c, d, e, f, g) + proofArgReduce fn = mkArg >>= \a -> proofArgReduce $ \b c d e f g -> fn (a, b, c, d, e, f, g) + +-- 8 Tuple +instance (SymVal a, SymVal b, SymVal c, SymVal d, SymVal e, SymVal f, SymVal g, SymVal h, SatisfiableM m p) => SatisfiableM m ((SBV a, SBV b, SBV c, SBV d, SBV e, SBV f, SBV g, SBV h) -> p) where + satArgReduce fn = mkArg >>= \a -> satArgReduce $ \b c d e f g h -> fn (a, b, c, d, e, f, g, h) + +instance (SymVal a, SymVal b, SymVal c, SymVal d, SymVal e, SymVal f, SymVal g, SymVal h, ProvableM m p) => ProvableM m ((SBV a, SBV b, SBV c, SBV d, SBV e, SBV f, SBV g, SBV h) -> p) where + proofArgReduce fn = mkArg >>= \a -> proofArgReduce $ \b c d e f g h -> fn (a, b, c, d, e, f, g, h) + +-- 9 Tuple +instance (SymVal a, SymVal b, SymVal c, SymVal d, SymVal e, SymVal f, SymVal g, SymVal h, SymVal i, SatisfiableM m p) => SatisfiableM m ((SBV a, SBV b, SBV c, SBV d, SBV e, SBV f, SBV g, SBV h, SBV i) -> p) where + satArgReduce fn = mkArg >>= \a -> satArgReduce $ \b c d e f g h i -> fn (a, b, c, d, e, f, g, h, i) + +instance (SymVal a, SymVal b, SymVal c, SymVal d, SymVal e, SymVal f, SymVal g, SymVal h, SymVal i, ProvableM m p) => ProvableM m ((SBV a, SBV b, SBV c, SBV d, SBV e, SBV f, SBV g, SBV h, SBV i) -> p) where + proofArgReduce fn = mkArg >>= \a -> proofArgReduce $ \b c d e f g h i -> fn (a, b, c, d, e, f, g, h, i) + +-- 10 Tuple +instance (SymVal a, SymVal b, SymVal c, SymVal d, SymVal e, SymVal f, SymVal g, SymVal h, SymVal i, SymVal j, SatisfiableM m p) => SatisfiableM m ((SBV a, SBV b, SBV c, SBV d, SBV e, SBV f, SBV g, SBV h, SBV i, SBV j) -> p) where + satArgReduce fn = mkArg >>= \a -> satArgReduce $ \b c d e f g h i j -> fn (a, b, c, d, e, f, g, h, i, j) + +instance (SymVal a, SymVal b, SymVal c, SymVal d, SymVal e, SymVal f, SymVal g, SymVal h, SymVal i, SymVal j, ProvableM m p) => ProvableM m ((SBV a, SBV b, SBV c, SBV d, SBV e, SBV f, SBV g, SBV h, SBV i, SBV j) -> p) where + proofArgReduce fn = mkArg >>= \a -> proofArgReduce $ \b c d e f g h i j -> fn (a, b, c, d, e, f, g, h, i, j) + +-- 11 Tuple +instance (SymVal a, SymVal b, SymVal c, SymVal d, SymVal e, SymVal f, SymVal g, SymVal h, SymVal i, SymVal j, SymVal k, SatisfiableM m p) => SatisfiableM m ((SBV a, SBV b, SBV c, SBV d, SBV e, SBV f, SBV g, SBV h, SBV i, SBV j, SBV k) -> p) where + satArgReduce fn = mkArg >>= \a -> satArgReduce $ \b c d e f g h i j k -> fn (a, b, c, d, e, f, g, h, i, j, k) + +instance (SymVal a, SymVal b, SymVal c, SymVal d, SymVal e, SymVal f, SymVal g, SymVal h, SymVal i, SymVal j, SymVal k, ProvableM m p) => ProvableM m ((SBV a, SBV b, SBV c, SBV d, SBV e, SBV f, SBV g, SBV h, SBV i, SBV j, SBV k) -> p) where + proofArgReduce fn = mkArg >>= \a -> proofArgReduce $ \b c d e f g h i j k -> fn (a, b, c, d, e, f, g, h, i, j, k) + +-- 12 Tuple +instance (SymVal a, SymVal b, SymVal c, SymVal d, SymVal e, SymVal f, SymVal g, SymVal h, SymVal i, SymVal j, SymVal k, SymVal l, SatisfiableM m p) => SatisfiableM m ((SBV a, SBV b, SBV c, SBV d, SBV e, SBV f, SBV g, SBV h, SBV i, SBV j, SBV k, SBV l) -> p) where + satArgReduce fn = mkArg >>= \a -> satArgReduce $ \b c d e f g h i j k l -> fn (a, b, c, d, e, f, g, h, i, j, k, l) + +instance (SymVal a, SymVal b, SymVal c, SymVal d, SymVal e, SymVal f, SymVal g, SymVal h, SymVal i, SymVal j, SymVal k, SymVal l, ProvableM m p) => ProvableM m ((SBV a, SBV b, SBV c, SBV d, SBV e, SBV f, SBV g, SBV h, SBV i, SBV j, SBV k, SBV l) -> p) where + proofArgReduce fn = mkArg >>= \a -> proofArgReduce $ \b c d e f g h i j k l -> fn (a, b, c, d, e, f, g, h, i, j, k, l) -- | Generalization of 'Data.SBV.runSMT' runSMT :: MonadIO m => SymbolicT m a -> m a