All Downloads are FREE. Search and download functionalities are using the official Maven repository.

z3-z3-4.13.0.src.nlsat.nlsat_evaluator.h Maven / Gradle / Ivy

The newest version!
/*++
Copyright (c) 2012 Microsoft Corporation

Module Name:

    nlsat_evaluator.h

Abstract:

    Helper class for computing the infeasible intervals of an
    arithmetic literal.

Author:

    Leonardo de Moura (leonardo) 2012-01-12.

Revision History:

--*/
#pragma once

#include "nlsat/nlsat_types.h"
#include "nlsat/nlsat_assignment.h"
#include "nlsat/nlsat_interval_set.h"

namespace nlsat {

    class solver;

    class evaluator {
        struct imp;
        imp *  m_imp;
    public:
        evaluator(solver& s, assignment const & x2v, pmanager & pm, small_object_allocator & allocator);
        ~evaluator();

        interval_set_manager & ism() const;

        /**
           \brief Evaluate the given literal in the current model.
           All variables in the atom must be assigned.
           
           The result is true if the literal is satisfied, and false otherwise.
        */
        bool eval(atom * a, bool neg);
        
        /**
           \brief Return the infeasible interval set for the given literal.
           All but the a->max_var() must be assigned in the current model.

           Let x be a->max_var(). Then, the resultant set specifies which
           values of x falsify the given literal.
        */
        interval_set_ref infeasible_intervals(atom * a, bool neg, clause const* cls);

        void push();
        void pop(unsigned num_scopes);
    };
    
};





© 2015 - 2024 Weber Informatics LLC | Privacy Policy