<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> <meta http-equiv="X-UA-Compatible" content="IE=9"/> <title>CVC3: dpllt_basic.cpp File Reference</title> <link href="tabs.css" rel="stylesheet" type="text/css"/> <script type="text/javascript" src="jquery.js"></script> <script type="text/javascript" src="dynsections.js"></script> <link href="doxygen.css" rel="stylesheet" type="text/css" /> </head> <body> <div id="top"><!-- do not remove this div, it is closed by doxygen! --> <div id="titlearea"> <table cellspacing="0" cellpadding="0"> <tbody> <tr style="height: 56px;"> <td style="padding-left: 0.5em;"> <div id="projectname">CVC3 </div> </td> </tr> </tbody> </table> </div> <!-- end header part --> <!-- Generated by Doxygen 1.8.2 --> <div id="navrow1" class="tabs"> <ul class="tablist"> <li><a href="index.html"><span>Main Page</span></a></li> <li><a href="pages.html"><span>Related Pages</span></a></li> <li><a href="modules.html"><span>Modules</span></a></li> <li><a href="namespaces.html"><span>Namespaces</span></a></li> <li><a href="annotated.html"><span>Classes</span></a></li> <li class="current"><a href="files.html"><span>Files</span></a></li> </ul> </div> <div id="navrow2" class="tabs2"> <ul class="tablist"> <li><a href="files.html"><span>File List</span></a></li> <li><a href="globals.html"><span>File Members</span></a></li> </ul> </div> <div id="nav-path" class="navpath"> <ul> <li class="navelem"><a class="el" href="dir_68267d1309a1af8e8297ef4c3efbcdba.html">src</a></li><li class="navelem"><a class="el" href="dir_a36840dfa927f36fc689e54a034a1fa1.html">sat</a></li> </ul> </div> </div><!-- top --> <div class="header"> <div class="summary"> <a href="#func-members">Functions</a> </div> <div class="headertitle"> <div class="title">dpllt_basic.cpp File Reference</div> </div> </div><!--header--> <div class="contents"> <p>Basic implementation of dpllt module using generic sat solver. <a href="#details">More...</a></p> <div class="textblock"><code>#include "<a class="el" href="dpllt__basic_8h_source.html">dpllt_basic.h</a>"</code><br/> <code>#include "<a class="el" href="cnf_8h_source.html">cnf.h</a>"</code><br/> <code>#include "<a class="el" href="sat__api_8h_source.html">sat_api.h</a>"</code><br/> <code>#include "<a class="el" href="exception_8h_source.html">exception.h</a>"</code><br/> </div> <p><a href="dpllt__basic_8cpp_source.html">Go to the source code of this file.</a></p> <table class="memberdecls"> <tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="func-members"></a> Functions</h2></td></tr> <tr class="memitem:a94f5febfa6e9f596f28dff5592b701bc"><td class="memItemLeft" align="right" valign="top">static void </td><td class="memItemRight" valign="bottom"><a class="el" href="dpllt__basic_8cpp.html#a94f5febfa6e9f596f28dff5592b701bc">SATDLevelHook</a> (void *cookie, int change)</td></tr> <tr class="separator:a94f5febfa6e9f596f28dff5592b701bc"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:a404b181a9c554aa0076d99c93d963b23"><td class="memItemLeft" align="right" valign="top">static <a class="el" href="unionSatSolver_1_1Lit.html">SatSolver::Lit</a> </td><td class="memItemRight" valign="bottom"><a class="el" href="dpllt__basic_8cpp.html#a404b181a9c554aa0076d99c93d963b23">SATDecisionHook</a> (void *cookie, bool *done)</td></tr> <tr class="separator:a404b181a9c554aa0076d99c93d963b23"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:a29427231527df333a516cb975df83d28"><td class="memItemLeft" align="right" valign="top">static void </td><td class="memItemRight" valign="bottom"><a class="el" href="dpllt__basic_8cpp.html#a29427231527df333a516cb975df83d28">SATAssignmentHook</a> (void *cookie, <a class="el" href="unionSatSolver_1_1Var.html">SatSolver::Var</a> var, int value)</td></tr> <tr class="separator:a29427231527df333a516cb975df83d28"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:a4f1ae66191e7e8cc326d540076eaeb3a"><td class="memItemLeft" align="right" valign="top">static void </td><td class="memItemRight" valign="bottom"><a class="el" href="dpllt__basic_8cpp.html#a4f1ae66191e7e8cc326d540076eaeb3a">SATDeductionHook</a> (void *cookie)</td></tr> <tr class="separator:a4f1ae66191e7e8cc326d540076eaeb3a"><td class="memSeparator" colspan="2"> </td></tr> </table> <a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> <div class="textblock"><p>Basic implementation of dpllt module using generic sat solver. </p> <p>Author: Clark Barrett</p> <p>Created: Mon Dec 12 19:09:43 2005</p> <hr/> <p>License to use, copy, modify, sell and/or distribute this software and its documentation for any purpose is hereby granted without royalty, subject to the terms and conditions defined in the <a class="el" href="LICENSE.html">LICENSE</a> file provided with this distribution.</p> <hr/> <p>Definition in file <a class="el" href="dpllt__basic_8cpp_source.html">dpllt_basic.cpp</a>.</p> </div><h2 class="groupheader">Function Documentation</h2> <a class="anchor" id="a94f5febfa6e9f596f28dff5592b701bc"></a> <div class="memitem"> <div class="memproto"> <table class="mlabels"> <tr> <td class="mlabels-left"> <table class="memname"> <tr> <td class="memname">static void SATDLevelHook </td> <td>(</td> <td class="paramtype">void * </td> <td class="paramname"><em>cookie</em>, </td> </tr> <tr> <td class="paramkey"></td> <td></td> <td class="paramtype">int </td> <td class="paramname"><em>change</em> </td> </tr> <tr> <td></td> <td>)</td> <td></td><td></td> </tr> </table> </td> <td class="mlabels-right"> <span class="mlabels"><span class="mlabel">static</span></span> </td> </tr> </table> </div><div class="memdoc"> <p>Definition at line <a class="el" href="dpllt__basic_8cpp_source.html#l00035">35</a> of file <a class="el" href="dpllt__basic_8cpp_source.html">dpllt_basic.cpp</a>.</p> <p>References <a class="el" href="classSAT_1_1DPLLT_1_1TheoryAPI.html#a51a08aab04c2185513676a316aee14b4">SAT::DPLLT::TheoryAPI::pop()</a>, <a class="el" href="classSAT_1_1DPLLT_1_1TheoryAPI.html#a771e84ea6308cb7d3f7d02e7858b37db">SAT::DPLLT::TheoryAPI::push()</a>, and <a class="el" href="dpllt_8h_source.html#l00117">SAT::DPLLT::theoryAPI()</a>.</p> <p>Referenced by <a class="el" href="dpllt__basic_8cpp_source.html#l00137">SAT::DPLLTBasic::createManager()</a>.</p> </div> </div> <a class="anchor" id="a404b181a9c554aa0076d99c93d963b23"></a> <div class="memitem"> <div class="memproto"> <table class="mlabels"> <tr> <td class="mlabels-left"> <table class="memname"> <tr> <td class="memname">static <a class="el" href="unionSatSolver_1_1Lit.html">SatSolver::Lit</a> SATDecisionHook </td> <td>(</td> <td class="paramtype">void * </td> <td class="paramname"><em>cookie</em>, </td> </tr> <tr> <td class="paramkey"></td> <td></td> <td class="paramtype">bool * </td> <td class="paramname"><em>done</em> </td> </tr> <tr> <td></td> <td>)</td> <td></td><td></td> </tr> </table> </td> <td class="mlabels-right"> <span class="mlabels"><span class="mlabel">static</span></span> </td> </tr> </table> </div><div class="memdoc"> <p>Definition at line <a class="el" href="dpllt__basic_8cpp_source.html#l00050">50</a> of file <a class="el" href="dpllt__basic_8cpp_source.html">dpllt_basic.cpp</a>.</p> <p>References <a class="el" href="dpllt__basic_8cpp_source.html#l00289">SAT::DPLLTBasic::addNewClauses()</a>, <a class="el" href="classSAT_1_1DPLLT_1_1TheoryAPI.html#a4b3f4a97dbac21236e479a157d866545">SAT::DPLLT::TheoryAPI::checkConsistent()</a>, <a class="el" href="dpllt__basic_8h_source.html#l00064">SAT::DPLLTBasic::cvc2SAT()</a>, <a class="el" href="debug_8h_source.html#l00408">DebugAssert</a>, <a class="el" href="dpllt_8h_source.html#l00118">SAT::DPLLT::decider()</a>, <a class="el" href="classSAT_1_1DPLLT_1_1TheoryAPI.html#a7d4bf4b22f7e9f19174a4f2813294acd">SAT::DPLLT::TheoryAPI::getNewClauses()</a>, <a class="el" href="sat__api_8h_source.html#l00060">SatSolver::Lit::id</a>, <a class="el" href="debug_8h_source.html#l00406">IF_DEBUG</a>, <a class="el" href="cnf_8h_source.html#l00063">SAT::Lit::isNull()</a>, <a class="el" href="classSAT_1_1DPLLT_1_1Decider.html#a9a15df2a6d6fdd38d9719f5681c068f2">SAT::DPLLT::Decider::makeDecision()</a>, <a class="el" href="classSAT_1_1DPLLT_1_1TheoryAPI.html#a6484231750edf5bd9d10d9408c6b5a59">SAT::DPLLT::TheoryAPI::outOfResources()</a>, and <a class="el" href="dpllt_8h_source.html#l00117">SAT::DPLLT::theoryAPI()</a>.</p> <p>Referenced by <a class="el" href="dpllt__basic_8cpp_source.html#l00137">SAT::DPLLTBasic::createManager()</a>.</p> </div> </div> <a class="anchor" id="a29427231527df333a516cb975df83d28"></a> <div class="memitem"> <div class="memproto"> <table class="mlabels"> <tr> <td class="mlabels-left"> <table class="memname"> <tr> <td class="memname">static void SATAssignmentHook </td> <td>(</td> <td class="paramtype">void * </td> <td class="paramname"><em>cookie</em>, </td> </tr> <tr> <td class="paramkey"></td> <td></td> <td class="paramtype"><a class="el" href="unionSatSolver_1_1Var.html">SatSolver::Var</a> </td> <td class="paramname"><em>var</em>, </td> </tr> <tr> <td class="paramkey"></td> <td></td> <td class="paramtype">int </td> <td class="paramname"><em>value</em> </td> </tr> <tr> <td></td> <td>)</td> <td></td><td></td> </tr> </table> </td> <td class="mlabels-right"> <span class="mlabels"><span class="mlabel">static</span></span> </td> </tr> </table> </div><div class="memdoc"> <p>Definition at line <a class="el" href="dpllt__basic_8cpp_source.html#l00098">98</a> of file <a class="el" href="dpllt__basic_8cpp_source.html">dpllt_basic.cpp</a>.</p> <p>References <a class="el" href="dpllt__basic_8cpp_source.html#l00289">SAT::DPLLTBasic::addNewClauses()</a>, <a class="el" href="classSAT_1_1DPLLT_1_1TheoryAPI.html#a3b3ef70567e0298cd3e971fd57d26fa6">SAT::DPLLT::TheoryAPI::assertLit()</a>, <a class="el" href="classSAT_1_1DPLLT_1_1TheoryAPI.html#a4b3f4a97dbac21236e479a157d866545">SAT::DPLLT::TheoryAPI::checkConsistent()</a>, <a class="el" href="classSatSolver.html#a78a8661d31ba8f3aca7e4c73a84f0bcf">SatSolver::GetVarIndex()</a>, <a class="el" href="sat__api_8h_source.html#l00052">SatSolver::Var::id</a>, <a class="el" href="dpllt__basic_8h_source.html#l00073">SAT::DPLLTBasic::satSolver()</a>, <a class="el" href="dpllt_8h_source.html#l00117">SAT::DPLLT::theoryAPI()</a>, and <a class="el" href="kinds_8h_source.html#l00099">TRACE</a>.</p> <p>Referenced by <a class="el" href="dpllt__basic_8cpp_source.html#l00137">SAT::DPLLTBasic::createManager()</a>.</p> </div> </div> <a class="anchor" id="a4f1ae66191e7e8cc326d540076eaeb3a"></a> <div class="memitem"> <div class="memproto"> <table class="mlabels"> <tr> <td class="mlabels-left"> <table class="memname"> <tr> <td class="memname">static void SATDeductionHook </td> <td>(</td> <td class="paramtype">void * </td> <td class="paramname"><em>cookie</em></td><td>)</td> <td></td> </tr> </table> </td> <td class="mlabels-right"> <span class="mlabels"><span class="mlabel">static</span></span> </td> </tr> </table> </div><div class="memdoc"> <p>Definition at line <a class="el" href="dpllt__basic_8cpp_source.html#l00117">117</a> of file <a class="el" href="dpllt__basic_8cpp_source.html">dpllt_basic.cpp</a>.</p> <p>References <a class="el" href="dpllt__basic_8cpp_source.html#l00289">SAT::DPLLTBasic::addNewClauses()</a>, <a class="el" href="classSAT_1_1DPLLT_1_1TheoryAPI.html#ab7a85a15823cb0771d1e9bb4c0ce0703">SAT::DPLLT::TheoryAPI::getExplanation()</a>, <a class="el" href="classSAT_1_1DPLLT_1_1TheoryAPI.html#ad61236a10860b9771e1e09505ab501b5">SAT::DPLLT::TheoryAPI::getImplication()</a>, <a class="el" href="classSAT_1_1DPLLT_1_1TheoryAPI.html#a7d4bf4b22f7e9f19174a4f2813294acd">SAT::DPLLT::TheoryAPI::getNewClauses()</a>, <a class="el" href="cnf_8h_source.html#l00063">SAT::Lit::isNull()</a>, <a class="el" href="cnf_8cpp_source.html#l00174">SAT::CNF_Formula_Impl::reset()</a>, and <a class="el" href="dpllt_8h_source.html#l00117">SAT::DPLLT::theoryAPI()</a>.</p> <p>Referenced by <a class="el" href="dpllt__basic_8cpp_source.html#l00137">SAT::DPLLTBasic::createManager()</a>.</p> </div> </div> </div><!-- contents --> <!-- start footer part --> <hr class="footer"/><address class="footer"><small> Generated on Thu May 16 2013 13:25:16 for CVC3 by  <a href="http://www.doxygen.org/index.html"> <img class="footer" src="doxygen.png" alt="doxygen"/> </a> 1.8.2 </small></address> </body> </html>