/********************* */ /*! \file bv_to_bool.h ** \verbatim ** Original author: Liana Hadarean ** Major contributors: none ** Minor contributors (to current version): none ** This file is part of the CVC4 project. ** Copyright (c) 2009-2014 New York University and The University of Iowa ** See the file COPYING in the top-level source directory for licensing ** information.\endverbatim ** ** \brief Preprocessing pass that lifts bit-vectors of size 1 to booleans. ** ** Preprocessing pass that lifts bit-vectors of size 1 to booleans. **/ #include "cvc4_private.h" #ifndef __CVC4__THEORY__BV__BV_TO_BOOL_H #define __CVC4__THEORY__BV__BV_TO_BOOL_H #include "expr/statistics_registry.h" #include "theory/bv/theory_bv_utils.h" namespace CVC4 { namespace theory { namespace bv { typedef __gnu_cxx::hash_map NodeNodeMap; class BvToBoolPreprocessor { struct Statistics { IntStat d_numTermsLifted; IntStat d_numAtomsLifted; IntStat d_numTermsForcedLifted; Statistics(); ~Statistics(); }; NodeNodeMap d_liftCache; NodeNodeMap d_boolCache; Node d_one; Node d_zero; void addToBoolCache(TNode term, Node new_term); Node getBoolCache(TNode term) const; bool hasBoolCache(TNode term) const; void addToLiftCache(TNode term, Node new_term); Node getLiftCache(TNode term) const; bool hasLiftCache(TNode term) const; bool isConvertibleBvTerm(TNode node); bool isConvertibleBvAtom(TNode node); Node convertBvAtom(TNode node); Node convertBvTerm(TNode node); Node liftNode(TNode current); Statistics d_statistics; public: BvToBoolPreprocessor(); void liftBvToBool(const std::vector& assertions, std::vector& new_assertions); }; }/* CVC4::theory::bv namespace */ }/* CVC4::theory namespace */ }/* CVC4 namespace */ #endif /* __CVC4__THEORY__BV__BV_TO_BOOL_H */