3
0
Fork 0
mirror of https://github.com/Z3Prover/z3 synced 2025-04-05 17:14:07 +00:00

added stubs for theory_fpa

Signed-off-by: Christoph M. Wintersteiger <cwinter@microsoft.com>
This commit is contained in:
Christoph M. Wintersteiger 2014-04-23 20:10:53 +01:00
parent af0b823bf5
commit a8b65ebb36
6 changed files with 80 additions and 10 deletions

View file

@ -2595,6 +2595,42 @@ void substitute_vars_example() {
Z3_del_context(ctx); Z3_del_context(ctx);
} }
void fpa_example() {
Z3_config cfg;
Z3_context ctx;
Z3_sort double_sort, rm_sort;
Z3_symbol symbol_rm, symbol_x, symbol_y;
Z3_ast rm, x, y, n, c;
printf("\nFPA-example\n");
LOG_MSG("FPA-example");
enable_trace("fpa");
cfg = Z3_mk_config();
ctx = Z3_mk_context(cfg);
Z3_del_config(cfg);
double_sort = Z3_mk_fpa_sort(ctx, 11, 53);
rm_sort = Z3_mk_fpa_rounding_mode_sort(ctx);
symbol_rm = Z3_mk_string_symbol(ctx, "rm");
rm = Z3_mk_const(ctx, symbol_rm, rm_sort);
symbol_x = Z3_mk_string_symbol(ctx, "x");
symbol_y = Z3_mk_string_symbol(ctx, "y");
x = Z3_mk_const(ctx, symbol_x, double_sort);
y = Z3_mk_const(ctx, symbol_y, double_sort);
n = Z3_mk_double(ctx, 42.0, double_sort);
c = Z3_mk_eq(ctx, Z3_mk_fpa_add(ctx, rm, x, y), n);
Z3_assert_cnstr(ctx, c);
if (Z3_check(ctx) != Z3_L_TRUE)
printf("FPA-example not satisfied!\n");
Z3_del_context(ctx);
}
/*@}*/ /*@}*/
/*@}*/ /*@}*/

View file

@ -64,9 +64,7 @@ struct fpa2bv_rewriter_cfg : public default_rewriter_cfg {
} }
bool max_steps_exceeded(unsigned num_steps) const { bool max_steps_exceeded(unsigned num_steps) const {
cooperate("fpa2bv"); cooperate("fpa2bv");
if (memory::get_allocation_size() > m_max_memory)
throw tactic_exception(TACTIC_MAX_MEMORY_MSG);
return num_steps > m_max_steps; return num_steps > m_max_steps;
} }
@ -147,7 +145,7 @@ struct fpa2bv_rewriter_cfg : public default_rewriter_cfg {
default: default:
TRACE("fpa2bv", tout << "unsupported operator: " << f->get_name() << "\n"; TRACE("fpa2bv", tout << "unsupported operator: " << f->get_name() << "\n";
for (unsigned i = 0; i < num; i++) tout << mk_ismt2_pp(args[i], m()) << std::endl;); for (unsigned i = 0; i < num; i++) tout << mk_ismt2_pp(args[i], m()) << std::endl;);
throw tactic_exception("NYI"); NOT_IMPLEMENTED_YET();
} }
} }

View file

@ -30,6 +30,7 @@ Revision History:
#include"theory_dummy.h" #include"theory_dummy.h"
#include"theory_dl.h" #include"theory_dl.h"
#include"theory_seq_empty.h" #include"theory_seq_empty.h"
#include"theory_fpa.h"
namespace smt { namespace smt {
@ -679,6 +680,15 @@ namespace smt {
setup_mi_arith(); setup_mi_arith();
} }
void setup::setup_QF_FPA() {
m_context.register_plugin(alloc(smt::theory_fpa, m_manager));
}
void setup::setup_QF_FPABV() {
setup_QF_BV();
m_context.register_plugin(alloc(smt::theory_fpa, m_manager));
}
bool is_arith(static_features const & st) { bool is_arith(static_features const & st) {
return st.m_num_arith_ineqs > 0 || st.m_num_arith_terms > 0 || st.m_num_arith_eqs > 0; return st.m_num_arith_ineqs > 0 || st.m_num_arith_terms > 0 || st.m_num_arith_eqs > 0;
} }
@ -780,6 +790,10 @@ namespace smt {
m_context.register_plugin(alloc(theory_seq_empty, m_manager)); m_context.register_plugin(alloc(theory_seq_empty, m_manager));
} }
void setup::setup_fpa() {
m_context.register_plugin(alloc(theory_fpa, m_manager));
}
void setup::setup_unknown() { void setup::setup_unknown() {
setup_arith(); setup_arith();
setup_arrays(); setup_arrays();
@ -787,6 +801,7 @@ namespace smt {
setup_datatypes(); setup_datatypes();
setup_dl(); setup_dl();
setup_seq(); setup_seq();
setup_fpa();
} }
void setup::setup_unknown(static_features & st) { void setup::setup_unknown(static_features & st) {

View file

@ -75,6 +75,8 @@ namespace smt {
void setup_QF_AX(static_features const & st); void setup_QF_AX(static_features const & st);
void setup_QF_AUFLIA(); void setup_QF_AUFLIA();
void setup_QF_AUFLIA(static_features const & st); void setup_QF_AUFLIA(static_features const & st);
void setup_QF_FPA();
void setup_QF_FPABV();
void setup_LRA(); void setup_LRA();
void setup_AUFLIA(bool simple_array = true); void setup_AUFLIA(bool simple_array = true);
void setup_AUFLIA(static_features const & st); void setup_AUFLIA(static_features const & st);
@ -91,10 +93,12 @@ namespace smt {
void setup_bv(); void setup_bv();
void setup_arith(); void setup_arith();
void setup_dl(); void setup_dl();
void setup_seq(); void setup_seq();
void setup_instgen(); void setup_instgen();
void setup_i_arith(); void setup_i_arith();
void setup_mi_arith(); void setup_mi_arith();
void setup_fpa();
public: public:
setup(context & c, smt_params & params); setup(context & c, smt_params & params);
void mark_already_configured() { m_already_configured = true; } void mark_already_configured() { m_already_configured = true; }

View file

@ -17,14 +17,29 @@ Revision History:
--*/ --*/
#include"ast_smt2_pp.h" #include"ast_smt2_pp.h"
#include"smt_context.h"
#include"theory_fpa.h" #include"theory_fpa.h"
namespace smt { namespace smt {
theory_fpa::theory_fpa(ast_manager & m) :
theory(m.mk_family_id("float")),
m_converter(m),
m_rw(m, m_converter, params_ref())
{
}
bool theory_fpa::internalize_atom(app * atom, bool gate_ctx) { bool theory_fpa::internalize_atom(app * atom, bool gate_ctx) {
TRACE("bv", tout << "internalizing atom: " << mk_ismt2_pp(atom, get_manager()) << "\n";); TRACE("fpa", tout << "internalizing atom: " << mk_ismt2_pp(atom, get_manager()) << "\n";);
SASSERT(atom->get_family_id() == get_family_id()); SASSERT(atom->get_family_id() == get_family_id());
NOT_IMPLEMENTED_YET();
ast_manager & m = get_manager();
context & ctx = get_context();
expr_ref res(m);
m_rw(atom, res);
SASSERT(res.get() != atom);
ctx.internalize(res, gate_ctx);
return true; return true;
} }

View file

@ -21,14 +21,16 @@ Revision History:
#include"smt_theory.h" #include"smt_theory.h"
#include"fpa2bv_converter.h" #include"fpa2bv_converter.h"
#include"fpa2bv_rewriter.h"
namespace smt { namespace smt {
class theory_fpa : public theory { class theory_fpa : public theory {
fpa2bv_converter m_converter; fpa2bv_converter m_converter;
fpa2bv_rewriter m_rw;
virtual final_check_status final_check_eh() { return FC_DONE; } virtual final_check_status final_check_eh() { return FC_DONE; }
virtual bool internalize_atom(app*, bool); virtual bool internalize_atom(app * a, bool);
virtual bool internalize_term(app*) { return internalize_atom(0, false); } virtual bool internalize_term(app * a) { return internalize_atom(a, false); }
virtual void new_eq_eh(theory_var, theory_var); virtual void new_eq_eh(theory_var, theory_var);
virtual void new_diseq_eh(theory_var, theory_var); virtual void new_diseq_eh(theory_var, theory_var);
virtual void push_scope_eh(); virtual void push_scope_eh();
@ -36,7 +38,7 @@ namespace smt {
virtual theory* mk_fresh(context*) { return alloc(theory_fpa, get_manager()); } virtual theory* mk_fresh(context*) { return alloc(theory_fpa, get_manager()); }
virtual char const * get_name() const { return "fpa"; } virtual char const * get_name() const { return "fpa"; }
public: public:
theory_fpa(ast_manager& m) : theory(m.mk_family_id("fpa")), m_converter(m) {} theory_fpa(ast_manager& m);
}; };
}; };