diff options
author | anwu1219 <haozewu@stanford.edu> | 2018-09-25 10:38:50 -0700 |
---|---|---|
committer | anwu1219 <haozewu@stanford.edu> | 2018-09-25 10:38:50 -0700 |
commit | 35353be470c5b73b7c19d9aea27d09695d9b4dfc (patch) | |
tree | 9d1ebe00b9e1fdb3af024a699f2e0eb8d2b09871 /cryptominisat5/cryptominisat-5.6.3/tests/probe_test.cpp | |
parent | 43e3983647365e36ec616b4ee92a223537bf4616 (diff) |
revert space
Diffstat (limited to 'cryptominisat5/cryptominisat-5.6.3/tests/probe_test.cpp')
-rw-r--r-- | cryptominisat5/cryptominisat-5.6.3/tests/probe_test.cpp | 365 |
1 files changed, 365 insertions, 0 deletions
diff --git a/cryptominisat5/cryptominisat-5.6.3/tests/probe_test.cpp b/cryptominisat5/cryptominisat-5.6.3/tests/probe_test.cpp new file mode 100644 index 000000000..aae779a6a --- /dev/null +++ b/cryptominisat5/cryptominisat-5.6.3/tests/probe_test.cpp @@ -0,0 +1,365 @@ +/****************************************** +Copyright (c) 2016, Mate Soos + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. +***********************************************/ + +#include "gtest/gtest.h" + +#include <set> +using std::set; + +#include "src/solver.h" +#include "src/prober.h" +#include "src/solverconf.h" +using namespace CMSat; +#include "test_helper.h" + +struct probe : public ::testing::Test { + probe() + { + must_inter.store(false, std::memory_order_relaxed); + SolverConf conf; + conf.doProbe = true; + conf.otfHyperbin = true; + conf.doStamp = true; + conf.doCache = true; + //conf.verbosity = 20; + s = new Solver(&conf, &must_inter); + s->new_vars(30); + p = s->prober; + } + ~probe() + { + delete s; + } + + Solver* s; + Prober* p; + std::vector<uint32_t> vars; + std::atomic<bool> must_inter; +}; + +//Regular, 1UIP fails + +TEST_F(probe, uip_fail_1) +{ + //s->conf.verbosity = 20; + s->add_clause_outer(str_to_cl(" 1, 2")); + s->add_clause_outer(str_to_cl("-2, 3")); + s->add_clause_outer(str_to_cl("-2, -3")); + + s->conf.doBothProp = false; + s->conf.doStamp = false; + s->conf.otfHyperbin = false; + vars = str_to_vars("1"); + p->probe(&vars); + + //1UIP is -2 + check_zero_assigned_lits_contains(s, "-2"); +} + +TEST_F(probe, uip_fail_2) +{ + //s->conf.verbosity = 20; + s->add_clause_outer(str_to_cl("1, -2")); + s->add_clause_outer(str_to_cl("1, -3")); + s->add_clause_outer(str_to_cl("1, -4")); + s->add_clause_outer(str_to_cl("1, -5")); + s->add_clause_outer(str_to_cl("2, 3, 4, 5, 6")); + s->add_clause_outer(str_to_cl("2, 3, 4, 5, -6")); + + s->conf.doBothProp = false; + s->conf.doStamp = false; + s->conf.otfHyperbin = false; + vars = str_to_vars("1"); + p->probe(&vars); + + //First UIP is 1 + check_zero_assigned_lits_eq(s, "1"); +} + +//BFS, DFS fails + +TEST_F(probe, fail_dfs) +{ + //s->conf.verbosity = 20; + s->add_clause_outer(str_to_cl("1, -2")); + s->add_clause_outer(str_to_cl("1, -3")); + s->add_clause_outer(str_to_cl("1, -4")); + s->add_clause_outer(str_to_cl("1, -5")); + s->add_clause_outer(str_to_cl("2, 3, 4, 5, 6")); + s->add_clause_outer(str_to_cl("2, 3, 4, 5, -6")); + + s->conf.doBothProp = false; + s->conf.doStamp = false; + s->conf.otfHyperbin = true; + p->force_stamp = 1; + vars = str_to_vars("1"); + p->probe(&vars); + + //deepest common ancestor + check_zero_assigned_lits_eq(s, "1"); +} + +TEST_F(probe, fail_bfs) +{ + //s->conf.verbosity = 10; + s->add_clause_outer(str_to_cl("1, -2")); + s->add_clause_outer(str_to_cl("1, -3")); + s->add_clause_outer(str_to_cl("1, -4")); + s->add_clause_outer(str_to_cl("1, -5")); + s->add_clause_outer(str_to_cl("2, 3, 4, 5, 6")); + s->add_clause_outer(str_to_cl("2, 3, 4, 5, -6")); + + s->conf.doBothProp = false; + s->conf.doStamp = false; + s->conf.otfHyperbin = true; + p->force_stamp = 0; + vars = str_to_vars("1"); + p->probe(&vars); + + //deepest common ancestor + check_zero_assigned_lits_eq(s, "1"); +} + +//Stamp correctness + +TEST_F(probe, stamp) +{ + //s->conf.verbosity = 20; + s->add_clause_outer(str_to_cl("1, -2")); + + s->conf.doBothProp = false; + s->conf.doStamp = true; + s->conf.otfHyperbin = true; + p->force_stamp = 2; + vars = str_to_vars("1"); + p->probe(&vars); + + check_stamp_contains(s, "1, -2", STAMP_IRRED); +} + +TEST_F(probe, stamp_2) +{ + //s->conf.verbosity = 20; + s->add_clause_outer(str_to_cl("1, -2")); + s->add_clause_outer(str_to_cl("2, 3")); + + s->conf.doBothProp = false; + s->conf.doStamp = true; + s->conf.otfHyperbin = true; + p->force_stamp = 2; + vars = str_to_vars("1"); + p->probe(&vars); + + check_stamp_contains(s, "1, 3", STAMP_IRRED); +} + +TEST_F(probe, stamp_3) +{ + //s->conf.verbosity = 20; + s->add_clause_outer(str_to_cl("1, -2")); + s->add_clause_outer(str_to_cl("2, 3")); + + s->conf.doBothProp = false; + s->conf.doStamp = true; + s->conf.otfHyperbin = true; + p->force_stamp = 1; + vars = str_to_vars("1"); + p->probe(&vars); + + check_stamp_contains(s, "1, 3", STAMP_RED); +} + + +TEST_F(probe, stamp_4) +{ + //s->conf.verbosity = 20; + s->add_clause_outer(str_to_cl("1, -2")); + s->add_clause_outer(str_to_cl("2, 3")); + s->add_clause_outer(str_to_cl("2, 4")); + + s->add_clause_outer(str_to_cl("-3, 5")); + s->add_clause_outer(str_to_cl("-4, 6")); + + s->add_clause_outer(str_to_cl("-5, 7")); + s->add_clause_outer(str_to_cl("-6, 7")); + + s->conf.doBothProp = false; + s->conf.doStamp = true; + s->conf.otfHyperbin = true; + p->force_stamp = 2; + vars = str_to_vars("1"); + p->probe(&vars); + + check_stamp_contains(s, "1, 7", STAMP_IRRED); + check_stamp_contains(s, "2, 7", STAMP_IRRED); +} + +//transitive reduction + +TEST_F(probe, trans_red1) +{ + s->add_clause_outer(str_to_cl("1, 2")); + s->add_clause_outer(str_to_cl("-2, 3")); + s->add_clause_outer(str_to_cl("-3, 4")); + s->add_clause_outer(str_to_cl("1, 4")); + + vars = str_to_vars("1"); + s->conf.doBothProp = false; + s->conf.doStamp = false; + s->conf.otfHyperbin = true; + p->probe(&vars); + check_irred_cls_doesnt_contain(s, "1, 4"); +} + +TEST_F(probe, trans_red2) +{ + s->add_clause_outer(str_to_cl("1, 2")); + s->add_clause_outer(str_to_cl("-2, 3")); + s->add_clause_outer(str_to_cl("-3, 4")); + s->add_clause_outer(str_to_cl("-4, 5")); + s->add_clause_outer(str_to_cl("-3, 5")); + s->add_clause_outer(str_to_cl("1, 5")); + + vars = str_to_vars("1"); + s->conf.doBothProp = false; + s->conf.doStamp = false; + s->conf.otfHyperbin = true; + p->probe(&vars); + check_irred_cls_doesnt_contain(s, "-3, 5"); + check_irred_cls_doesnt_contain(s, "1, 5"); +} + +//Hyper-binary resolution + +TEST_F(probe, hyper_bin) +{ + s->add_clause_outer(str_to_cl("1, 2")); + s->add_clause_outer(str_to_cl("1, 3")); + s->add_clause_outer(str_to_cl("-2, -3, 4")); + + vars = str_to_vars("1"); + s->conf.doBothProp = false; + s->conf.doStamp = false; + s->conf.otfHyperbin = true; + p->probe(&vars); + check_red_cls_contains(s, "1, 4"); +} + +TEST_F(probe, hyper_bin2) +{ + s->add_clause_outer(str_to_cl("1, 2")); + s->add_clause_outer(str_to_cl("1, 3")); + s->add_clause_outer(str_to_cl("1, -4")); + s->add_clause_outer(str_to_cl("-2, -3, 4, 5")); + + vars = str_to_vars("1"); + s->conf.doBothProp = false; + s->conf.doStamp = false; + s->conf.otfHyperbin = true; + p->probe(&vars); + check_red_cls_contains(s, "1, 5"); +} + +TEST_F(probe, hyper_bin3) +{ + s->add_clause_outer(str_to_cl("1, 2")); + s->add_clause_outer(str_to_cl("1, 3")); + s->add_clause_outer(str_to_cl("1, -4")); + s->add_clause_outer(str_to_cl("-2, -3, 4, 5")); + s->add_clause_outer(str_to_cl("-5, 6")); + s->add_clause_outer(str_to_cl("-5, 7")); + s->add_clause_outer(str_to_cl("-5, 8")); + s->add_clause_outer(str_to_cl("-6, -7, -8, 9")); + + vars = str_to_vars("1"); + s->conf.doBothProp = false; + s->conf.doStamp = false; + s->conf.otfHyperbin = true; + p->probe(&vars); + check_red_cls_contains(s, "1, 5"); + check_red_cls_contains(s, "-5, 9"); +} + + +//hyper-binary resolution and transitive reduction + +TEST_F(probe, hyper_bin_and_trans_red1) +{ + s->add_clause_outer(str_to_cl("1, 2")); + s->add_clause_outer(str_to_cl("1, 3")); + s->add_clause_outer(str_to_cl("1, -4")); + s->add_clause_outer(str_to_cl("-2, -3, 4, 5")); + s->add_clause_outer(str_to_cl("-5, 6")); + s->add_clause_outer(str_to_cl("1, 6"), true); + s->add_clause_outer(str_to_cl("-5, 7")); + s->add_clause_outer(str_to_cl("-5, 8")); + s->add_clause_outer(str_to_cl("-6, -7, -8, 9")); + + vars = str_to_vars("1"); + s->conf.doBothProp = false; + s->conf.doStamp = false; + s->conf.otfHyperbin = true; + p->probe(&vars); + check_red_cls_contains(s, "1, 5"); + check_red_cls_contains(s, "-5, 9"); + check_red_cls_doesnt_contain(s, "1, 6"); +} + + +//Implication cache + +TEST_F(probe, imp_cache) +{ + s->add_clause_outer(str_to_cl("1, 2")); + s->add_clause_outer(str_to_cl("-2, 3")); + + vars = str_to_vars("1, 2, 3"); + p->probe(&vars); + check_impl_cache_contains(s, "1, 3"); +} + +TEST_F(probe, imp_cache_2) +{ + s->add_clause_outer(str_to_cl("1, 2")); + s->add_clause_outer(str_to_cl("-2, 3")); + + vars = str_to_vars("3, 2, 1"); + p->probe(&vars); + check_impl_cache_contains(s, "3, 1"); +} + +TEST_F(probe, imp_cache_longer) +{ + s->add_clause_outer(str_to_cl("1, 2")); + s->add_clause_outer(str_to_cl("-2, 3")); + s->add_clause_outer(str_to_cl("-3, 4")); + s->add_clause_outer(str_to_cl("-4, 5")); + + vars = str_to_vars("5, 4, 3, 2, 1"); + p->probe(&vars); + check_impl_cache_contains(s, "5, 1"); +} + +int main(int argc, char **argv) { + ::testing::InitGoogleTest(&argc, argv); + return RUN_ALL_TESTS(); +} |