3
0
Fork 0
mirror of https://github.com/Z3Prover/z3 synced 2025-08-07 19:51:22 +00:00
z3/src/ast/simplifiers/solve_context_eqs.h
2022-11-08 12:23:36 -08:00

57 lines
1.5 KiB
C++

/*++
Copyright (c) 2022 Microsoft Corporation
Module Name:
solve_context_eqs.h
Abstract:
simplifier for solving equations within a context
Author:
Nikolaj Bjorner (nbjorner) 2022-11-2.
--*/
#pragma once
#include "ast/simplifiers/dependent_expr_state.h"
#include "ast/simplifiers/extract_eqs.h"
namespace euf {
class solve_eqs;
class solve_context_eqs {
ast_manager& m;
dependent_expr_state& m_fmls;
solve_eqs& m_solve_eqs;
expr_mark m_and_pos, m_and_neg, m_or_pos, m_or_neg;
expr_mark m_contains_v;
ptr_vector<expr> m_todo;
typedef svector<std::pair<bool, expr*>> signed_expressions;
bool contains_v(expr* f) const { return m_contains_v.is_marked(f); }
bool is_safe_eq(expr* e);
bool is_safe_eq(unsigned recursion_depth, expr* f, bool sign, expr* e);
bool is_safe_eq(expr* f, expr* e) { return is_safe_eq(0, f, false, e); }
bool is_disjunctively_safe(unsigned recursion_depth, expr* f, bool sign, expr* e);
bool contains_conjunctively(expr* f, bool sign, expr* e, signed_expressions& conjuncts);
bool is_conjunction(bool sign, expr* f) const;
void collect_nested_equalities(dependent_expr const& f, expr_mark& visited, dep_eq_vector& eqs);
public:
solve_context_eqs(solve_eqs& s);
void collect_nested_equalities(dep_eq_vector& eqs);
};
}