3
0
Fork 0
mirror of https://github.com/Z3Prover/z3 synced 2025-04-28 11:25:51 +00:00

separate out gcd test

Signed-off-by: Nikolaj Bjorner <nbjorner@microsoft.com>
This commit is contained in:
Nikolaj Bjorner 2020-02-08 16:44:25 -08:00
parent e964973f19
commit 5dc8c93897
6 changed files with 298 additions and 254 deletions

View file

@ -0,0 +1,42 @@
/*++
Copyright (c) 2020 Microsoft Corporation
Module Name:
int_gcd_test.h
Abstract:
Gcd_Test heuristic
Author:
Nikolaj Bjorner (nbjorner)
Lev Nachmanson (levnach)
Revision History:
--*/
#pragma once
#include "math/lp/lia_move.h"
namespace lp {
class int_solver;
class lar_solver;
class int_gcd_test {
class int_solver& lia;
class lar_solver& lra;
bool gcd_test();
bool gcd_test_for_row(static_matrix<mpq, numeric_pair<mpq>> & A, unsigned i);
bool ext_gcd_test(const row_strip<mpq> & row,
mpq const & least_coeff,
mpq const & lcm_den,
mpq const & consts);
void fill_explanation_from_fixed_columns(const row_strip<mpq> & row);
public:
int_gcd_test(int_solver& lia);
~int_gcd_test() {}
lia_move operator()();
};
}