mirror of
				https://github.com/ethereum/solidity
				synced 2023-10-03 13:03:40 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			122 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			122 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
| 	This file is part of solidity.
 | |
| 
 | |
| 	solidity is free software: you can redistribute it and/or modify
 | |
| 	it under the terms of the GNU General Public License as published by
 | |
| 	the Free Software Foundation, either version 3 of the License, or
 | |
| 	(at your option) any later version.
 | |
| 
 | |
| 	solidity is distributed in the hope that it will be useful,
 | |
| 	but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
| 	MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
| 	GNU General Public License for more details.
 | |
| 
 | |
| 	You should have received a copy of the GNU General Public License
 | |
| 	along with solidity.  If not, see <http://www.gnu.org/licenses/>.
 | |
| */
 | |
| // SPDX-License-Identifier: GPL-3.0
 | |
| 
 | |
| #include <libsolutil/CDCL.h>
 | |
| #include <test/Common.h>
 | |
| 
 | |
| #include <boost/test/unit_test.hpp>
 | |
| 
 | |
| using namespace std;
 | |
| using namespace solidity::util;
 | |
| 
 | |
| 
 | |
| namespace solidity::util::test
 | |
| {
 | |
| 
 | |
| class CDCLTestFramework
 | |
| {
 | |
| public:
 | |
| 	Literal variable(string const& _name)
 | |
| 	{
 | |
| 		m_variables.emplace_back(_name);
 | |
| 		return Literal{true, m_variables.size() - 1};
 | |
| 	}
 | |
| 
 | |
| 	void satisfiable(vector<Clause> _clauses)
 | |
| 	{
 | |
| 		auto model = CDCL{m_variables, move(_clauses)}.solve();
 | |
| 		BOOST_REQUIRE(!!model);
 | |
| 	}
 | |
| 
 | |
| 	void unsatisfiable(vector<Clause> _clauses)
 | |
| 	{
 | |
| 		auto model = CDCL{m_variables, move(_clauses)}.solve();
 | |
| 		BOOST_REQUIRE(!model);
 | |
| 	}
 | |
| 
 | |
| protected:
 | |
| 
 | |
| 	vector<string> m_variables;
 | |
| };
 | |
| 
 | |
| 
 | |
| BOOST_FIXTURE_TEST_SUITE(CDCL, CDCLTestFramework, *boost::unit_test::label("nooptions"))
 | |
| 
 | |
| BOOST_AUTO_TEST_CASE(basic)
 | |
| {
 | |
| 	auto x = variable("x");
 | |
| 	Clause c1{x, ~x};
 | |
| 	satisfiable({c1});
 | |
| }
 | |
| 
 | |
| BOOST_AUTO_TEST_CASE(basic_unsat1)
 | |
| {
 | |
| 	auto x = variable("x");
 | |
| 	unsatisfiable({{x}, {~x}});
 | |
| }
 | |
| 
 | |
| BOOST_AUTO_TEST_CASE(basic_unsat2)
 | |
| {
 | |
| 	auto x1 = variable("x1");
 | |
| 	auto x2 = variable("x2");
 | |
| 	Clause c1{x1, ~x2};
 | |
| 	Clause c2{~x1, x2};
 | |
| 	Clause c3{x1, x2};
 | |
| 	Clause c4{~x1, ~x2};
 | |
| 	unsatisfiable({c1, c2, c3, c4});
 | |
| }
 | |
| 
 | |
| BOOST_AUTO_TEST_CASE(basic_sat)
 | |
| {
 | |
| 	auto x1 = variable("x1");
 | |
| 	auto x2 = variable("x2");
 | |
| 	Clause c1{x1, ~x2};
 | |
| 	Clause c2{~x1, x2};
 | |
| 	Clause c3{x1, x2};
 | |
| 	Clause c4{~x1, ~x2};
 | |
| 	unsatisfiable({c1, c2, c3, c4});
 | |
| }
 | |
| 
 | |
| BOOST_AUTO_TEST_CASE(learning)
 | |
| {
 | |
| 	auto x1 = variable("x1");
 | |
| 	auto x2 = variable("x2");
 | |
| 	auto x3 = variable("x3");
 | |
| 	auto x4 = variable("x4");
 | |
| 	auto x7 = variable("x7");
 | |
| 	auto x8 = variable("x8");
 | |
| 	auto x9 = variable("x9");
 | |
| 	auto x10 = variable("x10");
 | |
| 	auto x11 = variable("x11");
 | |
| 	auto x12 = variable("x12");
 | |
| 	Clause c1{x1, x4};
 | |
| 	Clause c2{x1, ~x3, ~x8};
 | |
| 	Clause c3{x1, x8, x12};
 | |
| 	Clause c4{x2, x11};
 | |
| 	Clause c5{~x7, ~x3, x9};
 | |
| 	Clause c6{~x7, x8, ~x9};
 | |
| 	Clause c7{x7, x8, ~x10};
 | |
| 	Clause c8{x7, x10, ~x12};
 | |
| 	satisfiable({c1, c2, c3, c4, c5, c6, c7, c8});
 | |
| }
 | |
| 
 | |
| 
 | |
| BOOST_AUTO_TEST_SUITE_END()
 | |
| 
 | |
| }
 |