3
0
Fork 0
mirror of https://github.com/Z3Prover/z3 synced 2025-04-24 17:45:32 +00:00

new files

Signed-off-by: Nikolaj Bjorner <nbjorner@microsoft.com>
This commit is contained in:
Nikolaj Bjorner 2019-03-28 09:21:34 -07:00
parent e4eca577f6
commit bce1ee6d39
4 changed files with 282 additions and 0 deletions

View file

@ -0,0 +1,72 @@
/*++
Copyright (c) 2019 Microsoft Corporation
Module Name:
special_relations_tactic.cpp
Abstract:
Detect special relations in an axiomatization,
rewrite goal using special relations.
Author:
Nikolaj Bjorner (nbjorner) 2019-03-28
Notes:
--*/
#include "tactic/core/special_relations.h"
void special_relations_tactic::collect_feature(goal const& g, unsigned idx,
obj_map<func_decl, sp_axioms>& goal_features) {
expr* f = g.form(idx);
func_decl_ref p(m);
if (is_transitivity(f, p)) {
insert(goal_features, p, idx, sr_transitive);
}
}
void specia_relations_tactic::insert(obj_map<func_decl, sp_axioms>& goal_features, func_decl* p, unsigned idx, sr_property p) {
}
bool special_relations_tactic::is_transitivity(expr* fml, func_decl_ref& p) {
return false;
}
bool special_relations_tactic::is_anti_symmetry(expr* fml, func_decl_ref& p) {
return false;
}
bool special_relations_tactic::is_left_tree(expr* fml, func_decl_ref& p) {
return false;
}
bool special_relations_tactic::is_right_tree(expr* fml, func_decl_ref& p) {
return false;
}
bool special_relations_tactic::is_reflexivity(expr* fml, func_decl_ref& p) {
return false;
}
bool special_relations_tactic::is_total(expr* fml, func_decl_ref& p) {
return false;
}
bool special_relations_tactic::is_symmetric(expr* fml, func_decl_ref& p) {
return false;
}
void special_relations_tactic::operator()(goal_ref const & g, goal_ref_buffer & result) {
tactic_report report("special_relations", g);
obj_map<func_decl, sp_axioms> goal_features;
unsigned size = g.size();
for (unsigned idx = 0; idx < size; idx++) {
collect_feature(g, idx, goal_features);
}
if (!goal_features.empty()) {
}
g->inc_depth();
result.push_back(g.get());
}

View file

@ -0,0 +1,69 @@
/*++
Copyright (c) 2019 Microsoft Corporation
Module Name:
special_relations_tactic.h
Abstract:
Detect special relations in an axiomatization,
rewrite goal using special relations.
Author:
Nikolaj Bjorner (nbjorner) 2019-03-28
Notes:
--*/
#ifndef SPECIAL_RELATIONS_TACTIC_H_
#define SPECIAL_RELATIONS_TACTIC_H_
#include "tactic/tactic.h"
#include "tactic/tactical.h"
class special_relations_tactic : public tactic {
params_ref m_params;
struct sp_axioms {
unsigned_vector m_goal_indices;
unsigned m_sp_features;
};
void collect_feature(goal const& g, unsigned idx, obj_map<func_decl, sp_axioms>& goal_features);
void insert(obj_map<func_decl, sp_axioms>& goal_features, func_decl* p, unsigned idx, sr_property p);
bool is_transitivity(expr* fml, func_decl_ref& p);
bool is_anti_symmetry(expr* fml, func_decl_ref& p);
bool is_left_tree(expr* fml, func_decl_ref& p);
bool is_right_tree(expr* fml, func_decl_ref& p);
bool is_reflexivity(expr* fml, func_decl_ref& p);
bool is_total(expr* fml, func_decl_ref& p);
bool is_symmetric(expr* fml, func_decl_ref& p);
public:
special_relations_tactic(ast_manager & m, params_ref const & ref = params_ref()) {}
~special_relations_tactic() override {}
void updt_params(params_ref const & p) override { m_params = p; }
void collect_param_descrs(param_descrs & r) override { }
void operator()(goal_ref const & in, goal_ref_buffer & result) override;
void cleanup() override {}
tactic * translate(ast_manager & m) override { return alloc(special_relations_tactic, m, m_params); }
};
tactic * mk_special_relations_tactic(ast_manager & m, params_ref const & p = params_ref());
/*
ADD_TACTIC("special_relations", "detect and replace by special relations.", "mk_special_relations_tactic(m, p)")
*/
#endif