{-# OPTIONS_GHC -Wall -Werror #-}
module Documentation.SBV.Examples.Queries.UnsatCore where
import Data.SBV
import Data.SBV.Control
p :: Symbolic (Maybe [String])
p :: Symbolic (Maybe [String])
p = do a <- String -> Symbolic SInteger
sInteger String
"a"
b <- sInteger "b"
setOption $ ProduceUnsatCores True
namedConstraint "less than 5" $ a .< 5
namedConstraint "more than 10" $ a .> 10
namedConstraint "irrelevant" $ a .> b
query $ do cs <- checkSat
case cs of
CheckSatResult
Unsat -> [String] -> Maybe [String]
forall a. a -> Maybe a
Just ([String] -> Maybe [String])
-> QueryT IO [String] -> Query (Maybe [String])
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> QueryT IO [String]
getUnsatCore
CheckSatResult
_ -> Maybe [String] -> Query (Maybe [String])
forall a. a -> QueryT IO a
forall (m :: * -> *) a. Monad m => a -> m a
return Maybe [String]
forall a. Maybe a
Nothing
ucCore :: IO ()
ucCore :: IO ()
ucCore = do mbCore <- Symbolic (Maybe [String]) -> IO (Maybe [String])
forall a. Symbolic a -> IO a
runSMT Symbolic (Maybe [String])
p
case mbCore of
Maybe [String]
Nothing -> String -> IO ()
putStrLn String
"Problem is satisfiable."
Just [String]
core -> String -> IO ()
putStrLn (String -> IO ()) -> String -> IO ()
forall a b. (a -> b) -> a -> b
$ String
"Unsat core is: " String -> String -> String
forall a. [a] -> [a] -> [a]
++ [String] -> String
forall a. Show a => a -> String
show [String]
core