Ejemplo n.º 1
0
 // See mk_split_strict_comp and mk_split_nonstrict_comp
 void split_even_odd(bool strict, polynomial::factors const & fs, expr_ref_buffer & even_eqs, expr_ref_buffer & odd_factors) {
     expr_ref arg(m);
     for (unsigned i = 0; i < fs.distinct_factors(); i++) {
         m_expr2poly.to_expr(fs[i], true, arg);
         if (fs.get_degree(i) % 2 == 0) {
             expr * eq = m.mk_eq(arg, mk_zero_for(arg));
             if (strict)
                 even_eqs.push_back(m.mk_not(eq));
             else
                 even_eqs.push_back(eq);
         }
         else {
             odd_factors.push_back(arg);
         }
     }
 }
Ejemplo n.º 2
0
 void mk_new_rule_tail(ast_manager & m, app * pred, var_idx_set const & non_local_vars, unsigned & next_idx, varidx2var_map & varidx2var, 
                       sort_ref_buffer & new_rule_domain, expr_ref_buffer & new_rule_args, app_ref & new_pred) {
     expr_ref_buffer new_args(m);
     unsigned n  = pred->get_num_args();
     for (unsigned i = 0; i < n; i++) {
         expr * arg = pred->get_arg(i);
         if (m.is_value(arg)) {
             new_args.push_back(arg);
         }
         else {
             SASSERT(is_var(arg));
             int vidx      = to_var(arg)->get_idx();
             var * new_var = 0;
             if (!varidx2var.find(vidx, new_var)) {
                 new_var = m.mk_var(next_idx, to_var(arg)->get_sort());
                 next_idx++;
                 varidx2var.insert(vidx, new_var);
                 if (non_local_vars.contains(vidx)) {
                     // other predicates used this variable... so it should be in the domain of the filter
                     new_rule_domain.push_back(to_var(arg)->get_sort());
                     new_rule_args.push_back(new_var);
                 }
             }
             SASSERT(new_var != 0);
             new_args.push_back(new_var);
         }
     }
     new_pred = m.mk_app(pred->get_decl(), new_args.size(), new_args.c_ptr());
 }