//===-- TimingSolver.h ------------------------------------------*- C++ -*-===// // // The KLEE Symbolic Virtual Machine // // This file is distributed under the University of Illinois Open Source // License. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// #ifndef KLEE_TIMINGSOLVER_H #define KLEE_TIMINGSOLVER_H #include "klee/Expr/Constraints.h" #include "klee/Expr/Expr.h" #include "klee/Solver/Solver.h" #include "klee/System/Time.h" #include #include namespace klee { class ConstraintSet; class Solver; /// TimingSolver - A simple class which wraps a solver and handles /// tracking the statistics that we care about. class TimingSolver { public: std::unique_ptr solver; bool simplifyExprs; public: /// TimingSolver - Construct a new timing solver. /// /// \param _simplifyExprs - Whether expressions should be /// simplified (via the constraint manager interface) prior to /// querying. TimingSolver(Solver *_solver, bool _simplifyExprs = true) : solver(_solver), simplifyExprs(_simplifyExprs) {} void setTimeout(time::Span t) { solver->setCoreSolverTimeout(t); } char *getConstraintLog(const Query &query) { return solver->getConstraintLog(query); } bool evaluate(const ConstraintSet &, ref, Solver::Validity &result, SolverQueryMetaData &metaData); bool mustBeTrue(const ConstraintSet &, ref, bool &result, SolverQueryMetaData &metaData); bool mustBeFalse(const ConstraintSet &, ref, bool &result, SolverQueryMetaData &metaData); bool mayBeTrue(const ConstraintSet &, ref, bool &result, SolverQueryMetaData &metaData); bool mayBeFalse(const ConstraintSet &, ref, bool &result, SolverQueryMetaData &metaData); bool getValue(const ConstraintSet &, ref expr, ref &result, SolverQueryMetaData &metaData); bool getInitialValues(const ConstraintSet &, const std::vector &objects, std::vector> &result, SolverQueryMetaData &metaData); std::pair, ref> getRange(const ConstraintSet &, ref query, SolverQueryMetaData &metaData); }; } #endif /* KLEE_TIMINGSOLVER_H */