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

z3-z3-4.13.0.src.test.value_generator.cpp Maven / Gradle / Ivy

The newest version!
#include "ast/value_generator.h"
#include "ast/reg_decl_plugins.h"
#include "ast/ast_pp.h"
#include "ast/datatype_decl_plugin.h"
#include "ast/seq_decl_plugin.h"
#include "ast/array_decl_plugin.h"
#include 

static void list(unsigned bound, ast_manager& m, sort* s) {
    value_generator gen(m);
    for (unsigned i = 0; i < bound; ++i) {
        std::cout << gen.get_value(s, i) << "\n";
    }
}

static void tst1_vg() {
    ast_manager m;
    reg_decl_plugins(m);
    datatype_util dt(m);
    arith_util a(m);
    array_util ar(m);
    seq_util seq(m);
    sort_ref int_sort(a.mk_int(), m);
    func_decl_ref cons(m), is_cons(m), head(m), tail(m), nil(m), is_nil(m);

    sort_ref bool_seq(seq.str.mk_seq(m.mk_bool_sort()), m);
    list(16, m, bool_seq);
    return;

    sort_ref ilist = dt.mk_list_datatype(int_sort, symbol("ilist"), 
                                     cons, is_cons, head, tail, nil, is_nil);
    list(100, m, ilist);

    sort_ref blist = dt.mk_list_datatype(m.mk_bool_sort(), symbol("blist"), 
                                     cons, is_cons, head, tail, nil, is_nil);
    list(100, m, blist);
    
    sort_ref rlist = dt.mk_list_datatype(a.mk_real(), symbol("rlist"), 
                                     cons, is_cons, head, tail, nil, is_nil);
    list(100, m, rlist);

    list(100, m, a.mk_real());
    list(100, m, a.mk_int());

    sort_ref int_seq(seq.str.mk_seq(a.mk_int()), m);
    list(100, m, int_seq);

    sort_ref as(m);
    as = ar.mk_array_sort(a.mk_int(), a.mk_int());
    list(100, m, as);
    as = ar.mk_array_sort(m.mk_bool_sort(), a.mk_int());
    list(100, m, as);
    as = ar.mk_array_sort(m.mk_bool_sort(), m.mk_bool_sort());
    list(10, m, as);

}

void tst_value_generator() {
    tst1_vg();
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy