/********************* */ /*! \file bounded_integers.h ** \verbatim ** Original author: Andrew Reynolds ** Major contributors: Morgan Deters ** 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 ** ** [[ Add lengthier description here ]] ** \todo document this file **/ #include "cvc4_private.h" #ifndef __CVC4__BOUNDED_INTEGERS_H #define __CVC4__BOUNDED_INTEGERS_H #include "theory/quantifiers_engine.h" #include "context/context.h" #include "context/context_mm.h" #include "context/cdchunk_list.h" namespace CVC4 { namespace theory { class RepSetIterator; namespace quantifiers { class BoundedIntegers : public QuantifiersModule { typedef context::CDHashMap NodeBoolMap; typedef context::CDHashMap NodeIntMap; typedef context::CDHashMap NodeNodeMap; typedef context::CDHashMap IntBoolMap; private: //for determining bounds bool isBound( Node f, Node v ); bool hasNonBoundVar( Node f, Node b ); std::map< Node, std::map< Node, Node > > d_bounds[2]; std::map< Node, std::vector< Node > > d_set; std::map< Node, std::vector< int > > d_set_nums; std::map< Node, std::map< Node, Node > > d_range; std::map< Node, std::map< Node, Node > > d_nground_range; void hasFreeVar( Node f, Node n ); void process( Node f, Node n, bool pol, std::map< int, std::map< Node, Node > >& bound_lit_map, std::map< int, std::map< Node, bool > >& bound_lit_pol_map ); void processLiteral( Node f, Node lit, bool pol, std::map< int, std::map< Node, Node > >& bound_lit_map, std::map< int, std::map< Node, bool > >& bound_lit_pol_map ); std::vector< Node > d_bound_quants; private: class RangeModel { private: BoundedIntegers * d_bi; void allocateRange(); Node d_proxy_range; public: RangeModel(BoundedIntegers * bi, Node r, context::Context* c, context::Context* u, bool isProxy); Node d_range; int d_curr_max; std::map< int, Node > d_range_literal; std::map< Node, bool > d_lit_to_pol; NodeIntMap d_lit_to_range; NodeBoolMap d_range_assertions; context::CDO< bool > d_has_range; context::CDO< int > d_curr_range; IntBoolMap d_ranges_proxied; void initialize(); void assertNode(Node n); Node getNextDecisionRequest(); bool proxyCurrentRange(); }; private: //information for minimizing ranges std::vector< Node > d_ranges; //map to range model objects std::map< Node, RangeModel * > d_rms; //literal to range std::map< Node, std::vector< Node > > d_lit_to_ranges; //list of currently asserted arithmetic literals NodeBoolMap d_assertions; private: //class to store whether bounding lemmas have been added class BoundInstTrie { public: std::map< Node, BoundInstTrie > d_children; bool hasInstantiated( std::vector< Node > & vals, int index = 0, bool madeNew = false ){ if( index>=(int)vals.size() ){ return !madeNew; }else{ Node n = vals[index]; if( d_children.find(n)==d_children.end() ){ madeNew = true; } return d_children[n].hasInstantiated(vals,index+1,madeNew); } } }; std::map< Node, std::map< Node, BoundInstTrie > > d_bnd_it; private: void addLiteralFromRange( Node lit, Node r ); public: BoundedIntegers( context::Context* c, QuantifiersEngine* qe ); ~BoundedIntegers() throw() {} bool needsCheck( Theory::Effort e ); void check( Theory::Effort e, unsigned quant_e ); void registerQuantifier( Node f ); void assertNode( Node n ); Node getNextDecisionRequest(); bool isBoundVar( Node f, Node v ) { return std::find( d_set[f].begin(), d_set[f].end(), v )!=d_set[f].end(); } unsigned getNumBoundVars( Node f ) { return d_set[f].size(); } Node getBoundVar( Node f, int i ) { return d_set[f][i]; } int getBoundVarNum( Node f, int i ) { return d_set_nums[f][i]; } Node getLowerBound( Node f, Node v ){ return d_bounds[0][f][v]; } Node getUpperBound( Node f, Node v ){ return d_bounds[1][f][v]; } void getBounds( Node f, Node v, RepSetIterator * rsi, Node & l, Node & u ); void getBoundValues( Node f, Node v, RepSetIterator * rsi, Node & l, Node & u ); bool isGroundRange(Node f, Node v); /** Identify this module */ std::string identify() const { return "BoundedIntegers"; } }; } } } #endif