Sophie

Sophie

distrib > Fedora > 15 > i386 > by-pkgid > 583ffa4ba069126c3ba0bc565dc0485a > files > 53

cvc3-doc-2.4.1-1.fc15.noarch.rpm

<!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"/>
<title>CVC3: arith_theorem_producer3.cpp Source File</title>
<link href="tabs.css" rel="stylesheet" type="text/css"/>
<link href="doxygen.css" rel="stylesheet" type="text/css"/>
</head>
<body>
<!-- Generated by Doxygen 1.7.4 -->
<div id="top">
<div id="titlearea">
<table cellspacing="0" cellpadding="0">
 <tbody>
 <tr style="height: 56px;">
  <td style="padding-left: 0.5em;">
   <div id="projectname">CVC3&#160;<span id="projectnumber">2.4.1</span></div>
  </td>
 </tr>
 </tbody>
</table>
</div>
  <div id="navrow1" class="tabs">
    <ul class="tablist">
      <li><a href="index.html"><span>Main&#160;Page</span></a></li>
      <li><a href="pages.html"><span>Related&#160;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&#160;List</span></a></li>
      <li><a href="globals.html"><span>File&#160;Members</span></a></li>
    </ul>
  </div>
<div class="header">
  <div class="headertitle">
<div class="title">arith_theorem_producer3.cpp</div>  </div>
</div>
<div class="contents">
<a href="arith__theorem__producer3_8cpp.html">Go to the documentation of this file.</a><div class="fragment"><pre class="fragment"><a name="l00001"></a>00001 <span class="comment">/*****************************************************************************/</span><span class="comment"></span>
<a name="l00002"></a>00002 <span class="comment">/*!</span>
<a name="l00003"></a>00003 <span class="comment"> * \file arith_theorem_producer.cpp</span>
<a name="l00004"></a>00004 <span class="comment"> *</span>
<a name="l00005"></a>00005 <span class="comment"> * Author: Vijay Ganesh, Sergey Berezin</span>
<a name="l00006"></a>00006 <span class="comment"> *</span>
<a name="l00007"></a>00007 <span class="comment"> * Created: Dec 13 02:09:04 GMT 2002</span>
<a name="l00008"></a>00008 <span class="comment"> *</span>
<a name="l00009"></a>00009 <span class="comment"> * &lt;hr&gt;</span>
<a name="l00010"></a>00010 <span class="comment"> *</span>
<a name="l00011"></a>00011 <span class="comment"> * License to use, copy, modify, sell and/or distribute this software</span>
<a name="l00012"></a>00012 <span class="comment"> * and its documentation for any purpose is hereby granted without</span>
<a name="l00013"></a>00013 <span class="comment"> * royalty, subject to the terms and conditions defined in the \ref</span>
<a name="l00014"></a>00014 <span class="comment"> * LICENSE file provided with this distribution.</span>
<a name="l00015"></a>00015 <span class="comment"> *</span>
<a name="l00016"></a>00016 <span class="comment"> * &lt;hr&gt;</span>
<a name="l00017"></a>00017 <span class="comment"> *</span>
<a name="l00018"></a>00018 <span class="comment"> */</span>
<a name="l00019"></a>00019 <span class="comment">/*****************************************************************************/</span>
<a name="l00020"></a>00020 <span class="comment">// CLASS: ArithProofRules</span>
<a name="l00021"></a>00021 <span class="comment">//</span>
<a name="l00022"></a>00022 <span class="comment">// AUTHOR: Sergey Berezin, 12/11/2002</span>
<a name="l00023"></a>00023 <span class="comment">// AUTHOR: Vijay Ganesh,   05/30/2003</span>
<a name="l00024"></a>00024 <span class="comment">//</span>
<a name="l00025"></a>00025 <span class="comment">// Description: TRUSTED implementation of arithmetic proof rules.</span>
<a name="l00026"></a>00026 <span class="comment">//</span><span class="comment"></span>
<a name="l00027"></a>00027 <span class="comment">///////////////////////////////////////////////////////////////////////////////</span>
<a name="l00028"></a>00028 <span class="comment"></span>
<a name="l00029"></a>00029 <span class="comment">// This code is trusted</span>
<a name="l00030"></a><a class="code" href="arith__theorem__producer3_8cpp.html#a8663c36bbf15bb5a0dcb01b97897fa95">00030</a> <span class="preprocessor">#define _CVC3_TRUSTED_</span>
<a name="l00031"></a>00031 <span class="preprocessor"></span>
<a name="l00032"></a>00032 <span class="preprocessor">#include &quot;<a class="code" href="arith__theorem__producer3_8h.html" title="TRUSTED implementation of arithmetic proof rules.">arith_theorem_producer3.h</a>&quot;</span>
<a name="l00033"></a>00033 <span class="preprocessor">#include &quot;<a class="code" href="theory__core_8h.html">theory_core.h</a>&quot;</span>
<a name="l00034"></a>00034 <span class="preprocessor">#include &quot;<a class="code" href="theory__arith3_8h.html">theory_arith3.h</a>&quot;</span>
<a name="l00035"></a>00035 
<a name="l00036"></a>00036 <span class="keyword">using namespace </span>std;
<a name="l00037"></a>00037 <span class="keyword">using namespace </span>CVC3;
<a name="l00038"></a>00038 <span class="comment"></span>
<a name="l00039"></a>00039 <span class="comment">////////////////////////////////////////////////////////////////////</span>
<a name="l00040"></a>00040 <span class="comment"></span><span class="comment">// TheoryArith: trusted method for creating ArithTheoremProducer3</span><span class="comment"></span>
<a name="l00041"></a>00041 <span class="comment">////////////////////////////////////////////////////////////////////</span>
<a name="l00042"></a>00042 <span class="comment"></span>
<a name="l00043"></a><a class="code" href="classCVC3_1_1TheoryArith3.html#af8a9ccde61831efd7b0e9093ed1d9770">00043</a> <a class="code" href="classCVC3_1_1ArithProofRules.html">ArithProofRules</a>* TheoryArith3::createProofRules3() {
<a name="l00044"></a>00044   <span class="keywordflow">return</span> <span class="keyword">new</span> <a class="code" href="classCVC3_1_1ArithTheoremProducer3.html">ArithTheoremProducer3</a>(theoryCore()-&gt;getTM(), <span class="keyword">this</span>);
<a name="l00045"></a>00045 }
<a name="l00046"></a>00046 <span class="comment"></span>
<a name="l00047"></a>00047 <span class="comment">////////////////////////////////////////////////////////////////////</span>
<a name="l00048"></a>00048 <span class="comment"></span><span class="comment">// Canonization rules</span><span class="comment"></span>
<a name="l00049"></a>00049 <span class="comment">////////////////////////////////////////////////////////////////////</span>
<a name="l00050"></a>00050 <span class="comment"></span>
<a name="l00051"></a>00051 
<a name="l00052"></a><a class="code" href="arith__theorem__producer3_8cpp.html#a79f2713d570c7065f61a160134ea765b">00052</a> <span class="preprocessor">#define CLASS_NAME &quot;ArithTheoremProducer3&quot;</span>
<a name="l00053"></a>00053 <span class="preprocessor"></span>
<a name="l00054"></a>00054 
<a name="l00055"></a>00055 <span class="comment">// Rule for variables: e == 1 * e</span>
<a name="l00056"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a23340f90880cb869fdcfe6e69a7a2631">00056</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::varToMult(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; e) {
<a name="l00057"></a>00057   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l00058"></a>00058   <span class="keywordflow">if</span>(withProof()) pf = newPf(<span class="stringliteral">&quot;var_to_mult&quot;</span>, e);
<a name="l00059"></a>00059   <span class="keywordflow">return</span> newRWTheorem(e, (rat(1) * e), Assumptions::emptyAssump(), pf);
<a name="l00060"></a>00060 }
<a name="l00061"></a>00061 
<a name="l00062"></a>00062 
<a name="l00063"></a>00063 <span class="comment">// Rule for unary minus: -e == (-1) * e</span>
<a name="l00064"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a878e091ad5cfd2877ddce73d6f664e16">00064</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::uMinusToMult(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; e) {
<a name="l00065"></a>00065   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l00066"></a>00066   <span class="keywordflow">if</span>(withProof()) pf = newPf(<span class="stringliteral">&quot;uminus_to_mult&quot;</span>, e);
<a name="l00067"></a>00067   <span class="keywordflow">return</span> newRWTheorem((-e), (rat(-1) * e), Assumptions::emptyAssump(), pf);
<a name="l00068"></a>00068 }
<a name="l00069"></a>00069 
<a name="l00070"></a>00070 
<a name="l00071"></a>00071 <span class="comment">// ==&gt; x - y = x + (-1) * y</span>
<a name="l00072"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#ab0d610d377cc20e3ce16823713d25403">00072</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::minusToPlus(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; x, <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; y)
<a name="l00073"></a>00073 {
<a name="l00074"></a>00074   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l00075"></a>00075   <span class="keywordflow">if</span>(withProof()) pf = newPf(<span class="stringliteral">&quot;minus_to_plus&quot;</span>, x, y);
<a name="l00076"></a>00076   <span class="keywordflow">return</span> newRWTheorem((x-y), (x + (rat(-1) * y)), Assumptions::emptyAssump(), pf);
<a name="l00077"></a>00077 }
<a name="l00078"></a>00078 
<a name="l00079"></a>00079 
<a name="l00080"></a>00080 <span class="comment">// Rule for unary minus: -e == e/(-1)</span>
<a name="l00081"></a>00081 <span class="comment">// This is to reduce the number of almost identical rules for uminus and div</span>
<a name="l00082"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a9bf439248afb24bb63ea435193b68524">00082</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::canonUMinusToDivide(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; e) {
<a name="l00083"></a>00083   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l00084"></a>00084   <span class="keywordflow">if</span>(withProof()) pf = newPf(<span class="stringliteral">&quot;canon_uminus&quot;</span>, e);
<a name="l00085"></a>00085   <span class="keywordflow">return</span> newRWTheorem((-e), (e / rat(-1)), Assumptions::emptyAssump(), pf);
<a name="l00086"></a>00086 }
<a name="l00087"></a>00087 
<a name="l00088"></a>00088 <span class="comment">// Rules for division by constant</span>
<a name="l00089"></a>00089 
<a name="l00090"></a>00090 <span class="comment">// (c)/(d) ==&gt; (c/d).  When d==0, c/0 = 0 (our total extension).</span>
<a name="l00091"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a3a2bf5e3b8c71543b1512f1606825a02">00091</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::canonDivideConst(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; c,
<a name="l00092"></a>00092                                                <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; d) {
<a name="l00093"></a>00093   <span class="comment">// Make sure c and d are a const</span>
<a name="l00094"></a>00094   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l00095"></a>00095     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#ac0334a083d6782caa17ca0d337fddddf">isRational</a>(c),
<a name="l00096"></a>00096                 <a class="code" href="arith__theorem__producer3_8cpp.html#a79f2713d570c7065f61a160134ea765b">CLASS_NAME</a> <span class="stringliteral">&quot;::canonDivideConst:\n c not a constant: &quot;</span>
<a name="l00097"></a>00097                 + c.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l00098"></a>00098     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#ac0334a083d6782caa17ca0d337fddddf">isRational</a>(d),
<a name="l00099"></a>00099                 <a class="code" href="arith__theorem__producer3_8cpp.html#a79f2713d570c7065f61a160134ea765b">CLASS_NAME</a> <span class="stringliteral">&quot;::canonDivideConst:\n d not a constant: &quot;</span>
<a name="l00100"></a>00100                 + d.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l00101"></a>00101   }
<a name="l00102"></a>00102   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l00103"></a>00103   <span class="keywordflow">if</span>(withProof())
<a name="l00104"></a>00104     pf = newPf(<span class="stringliteral">&quot;canon_divide_const&quot;</span>, c, d, d_hole);
<a name="l00105"></a>00105   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Rational.html">Rational</a>&amp; dr = d.<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>();
<a name="l00106"></a>00106   <span class="keywordflow">return</span> newRWTheorem((c/d), (rat(dr==0? 0 : (c.<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>()/dr))), Assumptions::emptyAssump(), pf);
<a name="l00107"></a>00107 }
<a name="l00108"></a>00108 
<a name="l00109"></a>00109 <span class="comment">// (c * x)/d ==&gt; (c/d) * x, takes (c*x) and d</span>
<a name="l00110"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a39a2efadcc13383fd860340c6d76db54">00110</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::canonDivideMult(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; cx,
<a name="l00111"></a>00111                                               <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; d) {
<a name="l00112"></a>00112   <span class="comment">// Check the format of c*x</span>
<a name="l00113"></a>00113   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l00114"></a>00114     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#a28ae8672047db708e99602ebaca89777">isMult</a>(cx) &amp;&amp; <a class="code" href="namespaceCVC3.html#ac0334a083d6782caa17ca0d337fddddf">isRational</a>(cx[0]),
<a name="l00115"></a>00115                 <a class="code" href="arith__theorem__producer3_8cpp.html#a79f2713d570c7065f61a160134ea765b">CLASS_NAME</a> <span class="stringliteral">&quot;::canonDivideMult:\n  &quot;</span>
<a name="l00116"></a>00116                 <span class="stringliteral">&quot;Not a (c * x) expression: &quot;</span>
<a name="l00117"></a>00117                 + cx.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l00118"></a>00118     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#ac0334a083d6782caa17ca0d337fddddf">isRational</a>(d),
<a name="l00119"></a>00119                 <a class="code" href="arith__theorem__producer3_8cpp.html#a79f2713d570c7065f61a160134ea765b">CLASS_NAME</a> <span class="stringliteral">&quot;::canonDivideMult:\n  &quot;</span>
<a name="l00120"></a>00120                 <span class="stringliteral">&quot;d is not a constant: &quot;</span> + d.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l00121"></a>00121   }
<a name="l00122"></a>00122   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Rational.html">Rational</a>&amp; dr = d.<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>();
<a name="l00123"></a>00123   <a class="code" href="classCVC3_1_1Rational.html">Rational</a> cdr(dr==0? 0 : (cx[0].getRational()/dr));
<a name="l00124"></a>00124   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> cd(rat(cdr));
<a name="l00125"></a>00125   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l00126"></a>00126   <span class="keywordflow">if</span>(withProof())
<a name="l00127"></a>00127     pf = newPf(<span class="stringliteral">&quot;canon_divide_mult&quot;</span>, cx[0], cx[1], d);
<a name="l00128"></a>00128   <span class="comment">// (c/d) may be == 1, so we also need to canonize 1*x to x</span>
<a name="l00129"></a>00129   <span class="keywordflow">if</span>(cdr == 1)
<a name="l00130"></a>00130     <span class="keywordflow">return</span> newRWTheorem((cx/d), (cx[1]), Assumptions::emptyAssump(), pf);
<a name="l00131"></a>00131   <span class="keywordflow">else</span> <span class="keywordflow">if</span>(cdr == 0) <span class="comment">// c/0 == 0 case</span>
<a name="l00132"></a>00132     <span class="keywordflow">return</span> newRWTheorem((cx/d), cd, Assumptions::emptyAssump(), pf);
<a name="l00133"></a>00133   <span class="keywordflow">else</span>
<a name="l00134"></a>00134     <span class="keywordflow">return</span> newRWTheorem((cx/d), (cd*cx[1]), Assumptions::emptyAssump(), pf);
<a name="l00135"></a>00135 }
<a name="l00136"></a>00136 
<a name="l00137"></a>00137 <span class="comment">// (+ t1 ... tn)/d ==&gt; (+ (t1/d) ... (tn/d))</span>
<a name="l00138"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a897c950b6bb741189f1c33752159b587">00138</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::canonDividePlus(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; sum, <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; d) {
<a name="l00139"></a>00139   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l00140"></a>00140     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#afb0f7d15ddbd87f9abb128108101f557">isPlus</a>(sum) &amp;&amp; sum.<a class="code" href="group__ExprPkg.html#ga28b901d05e52a5c646f83a95cc74f94b">arity</a>() &gt;= 2 &amp;&amp; <a class="code" href="namespaceCVC3.html#ac0334a083d6782caa17ca0d337fddddf">isRational</a>(sum[0]),
<a name="l00141"></a>00141                 <a class="code" href="arith__theorem__producer3_8cpp.html#a79f2713d570c7065f61a160134ea765b">CLASS_NAME</a> <span class="stringliteral">&quot;::canonUMinusPlus:\n  &quot;</span>
<a name="l00142"></a>00142                 <span class="stringliteral">&quot;Expr is not a canonical sum: &quot;</span>
<a name="l00143"></a>00143                 + sum.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l00144"></a>00144     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#ac0334a083d6782caa17ca0d337fddddf">isRational</a>(d),
<a name="l00145"></a>00145                 <a class="code" href="arith__theorem__producer3_8cpp.html#a79f2713d570c7065f61a160134ea765b">CLASS_NAME</a> <span class="stringliteral">&quot;::canonUMinusPlus:\n  &quot;</span>
<a name="l00146"></a>00146                 <span class="stringliteral">&quot;d is not a const: &quot;</span> + d.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l00147"></a>00147   }
<a name="l00148"></a>00148   <span class="comment">// First, propagate &#39;/d&#39; down to the args</span>
<a name="l00149"></a>00149   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l00150"></a>00150   <span class="keywordflow">if</span>(withProof())
<a name="l00151"></a>00151     pf = newPf(<span class="stringliteral">&quot;canon_divide_plus&quot;</span>, rat(sum.<a class="code" href="group__ExprPkg.html#ga28b901d05e52a5c646f83a95cc74f94b">arity</a>()),
<a name="l00152"></a>00152                sum.<a class="code" href="group__ExprPkg.html#gac890e13db184610276fc533fa4b4fe99" title="Begin iterator.">begin</a>(), sum.<a class="code" href="group__ExprPkg.html#gaf6048a5030c8fa2511bf5dfee868e653" title="End iterator.">end</a>());
<a name="l00153"></a>00153   vector&lt;Expr&gt; newKids;
<a name="l00154"></a>00154   <span class="keywordflow">for</span>(<a class="code" href="classCVC3_1_1Expr_1_1iterator.html">Expr::iterator</a> i=sum.<a class="code" href="group__ExprPkg.html#gac890e13db184610276fc533fa4b4fe99" title="Begin iterator.">begin</a>(), iend=sum.<a class="code" href="group__ExprPkg.html#gaf6048a5030c8fa2511bf5dfee868e653" title="End iterator.">end</a>(); i!=iend; ++i)
<a name="l00155"></a>00155     newKids.push_back((*i)/d);
<a name="l00156"></a>00156   <span class="comment">// (+ t1 ... tn)/d == (+ (t1/d) ... (tn/d))</span>
<a name="l00157"></a>00157   <span class="keywordflow">return</span> newRWTheorem((sum/d), (<a class="code" href="namespaceCVC3.html#accd3d7d38b0e04136afbc3e5191bc8bb">plusExpr</a>(newKids)), Assumptions::emptyAssump(), pf);
<a name="l00158"></a>00158 }
<a name="l00159"></a>00159 
<a name="l00160"></a>00160 <span class="comment">// x/(d) ==&gt; (1/d) * x, unless d == 1</span>
<a name="l00161"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a9fddb49ed54796e6a5487be554eb14f4">00161</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::canonDivideVar(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; e, <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; d) {
<a name="l00162"></a>00162   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l00163"></a>00163     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#ac0334a083d6782caa17ca0d337fddddf">isRational</a>(d),
<a name="l00164"></a>00164                 <a class="code" href="arith__theorem__producer3_8cpp.html#a79f2713d570c7065f61a160134ea765b">CLASS_NAME</a> <span class="stringliteral">&quot;::canonDivideVar:\n  &quot;</span>
<a name="l00165"></a>00165                 <span class="stringliteral">&quot;d is not a const: &quot;</span> + d.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l00166"></a>00166   }
<a name="l00167"></a>00167   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l00168"></a>00168 
<a name="l00169"></a>00169   <span class="keywordflow">if</span>(withProof())
<a name="l00170"></a>00170     pf = newPf(<span class="stringliteral">&quot;canon_divide_var&quot;</span>, e);
<a name="l00171"></a>00171 
<a name="l00172"></a>00172   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Rational.html">Rational</a>&amp; dr = d.<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>();
<a name="l00173"></a>00173   <span class="keywordflow">if</span>(dr == 1)
<a name="l00174"></a>00174     <span class="keywordflow">return</span> newRWTheorem(e/d, e, Assumptions::emptyAssump(), pf);
<a name="l00175"></a>00175   <span class="keywordflow">if</span>(dr == 0) <span class="comment">// e/0 == 0 (total extension of division)</span>
<a name="l00176"></a>00176     <span class="keywordflow">return</span> newRWTheorem(e/d, d, Assumptions::emptyAssump(), pf);
<a name="l00177"></a>00177   <span class="keywordflow">else</span>
<a name="l00178"></a>00178     <span class="keywordflow">return</span> newRWTheorem(e/d, rat(1/dr) * e, Assumptions::emptyAssump(), pf);
<a name="l00179"></a>00179 }
<a name="l00180"></a>00180 
<a name="l00181"></a>00181 
<a name="l00182"></a>00182 <span class="comment">// Multiplication</span>
<a name="l00183"></a>00183 <span class="comment">// (MULT expr1 expr2 expr3 ...)</span>
<a name="l00184"></a>00184 <span class="comment">// Each expr is in canonical form, i.e. it can be a</span>
<a name="l00185"></a>00185 <span class="comment">// 1) Rational constant</span>
<a name="l00186"></a>00186 <span class="comment">// 2) Arithmetic Leaf (var or term from another theory)</span>
<a name="l00187"></a>00187 <span class="comment">// 3) (POW rational leaf)</span>
<a name="l00188"></a>00188 <span class="comment">// where rational cannot be 0 or 1</span>
<a name="l00189"></a>00189 <span class="comment">// 4) (MULT rational mterm&#39;_1 ...) where each mterm&#39; is of type (2) or (3)</span>
<a name="l00190"></a>00190 <span class="comment">// If rational == 1 then there should be at least two mterms</span>
<a name="l00191"></a>00191 <span class="comment">// 5) (PLUS rational sterm_1 ...) where each sterm is of</span>
<a name="l00192"></a>00192 <span class="comment">//     type (2) or (3) or (4)</span>
<a name="l00193"></a>00193 <span class="comment">//    if rational == 0 then there should be at least two sterms</span>
<a name="l00194"></a>00194 
<a name="l00195"></a>00195 
<a name="l00196"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#aea589889127864f327d4d71800f096b7">00196</a> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> ArithTheoremProducer3::simplifiedMultExpr(std::vector&lt;Expr&gt; &amp; mulKids)
<a name="l00197"></a>00197 {
<a name="l00198"></a>00198   <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(mulKids.size() &gt;= 1 &amp;&amp; mulKids[0].isRational(), <span class="stringliteral">&quot;&quot;</span>);
<a name="l00199"></a>00199   <span class="keywordflow">if</span> (mulKids.size() == 1) {
<a name="l00200"></a>00200     <span class="keywordflow">return</span> mulKids[0];
<a name="l00201"></a>00201   }
<a name="l00202"></a>00202   <span class="keywordflow">if</span> ((mulKids[0] == rat(1)) &amp;&amp; mulKids.size() == 2) {
<a name="l00203"></a>00203     <span class="keywordflow">return</span> mulKids[1];
<a name="l00204"></a>00204   }
<a name="l00205"></a>00205   <span class="keywordflow">else</span>
<a name="l00206"></a>00206     <span class="keywordflow">return</span> <a class="code" href="namespaceCVC3.html#adb35e0739f86730543924dbc8211a778">multExpr</a>(mulKids);
<a name="l00207"></a>00207 }
<a name="l00208"></a>00208 
<a name="l00209"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#ad49508debdf58df9d8333cd140c850a3">00209</a> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> ArithTheoremProducer3::canonMultConstMult(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> &amp; c,
<a name="l00210"></a>00210                                               <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> &amp; e)
<a name="l00211"></a>00211 {
<a name="l00212"></a>00212   <span class="comment">// c is a rational</span>
<a name="l00213"></a>00213   <span class="comment">// e is (MULT rat mterm&#39;_1 ....)</span>
<a name="l00214"></a>00214   <span class="comment">// assume that e2 is already in canonic form</span>
<a name="l00215"></a>00215   <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(c.<a class="code" href="group__ExprPkg.html#gac5ced6adc7a60945ea6707ef494aa28f">isRational</a>() &amp;&amp; e.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>() == <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024ad77e825b0133e40de2760344377ee1fa">MULT</a>, <span class="stringliteral">&quot;&quot;</span>);
<a name="l00216"></a>00216   std::vector&lt;Expr&gt; mulKids;
<a name="l00217"></a>00217   <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a> ((e.<a class="code" href="group__ExprPkg.html#ga28b901d05e52a5c646f83a95cc74f94b">arity</a>() &gt; 1) &amp;&amp; (e[0].<a class="code" href="namespaceCVC3.html#ac0334a083d6782caa17ca0d337fddddf">isRational</a>()),
<a name="l00218"></a>00218                <span class="stringliteral">&quot;ArithTheoremProducer3::canonMultConstMult: &quot;</span>
<a name="l00219"></a>00219                <span class="stringliteral">&quot;a canonized MULT expression must have arity &quot;</span>
<a name="l00220"></a>00220                <span class="stringliteral">&quot;greater than 1: and first child must be &quot;</span>
<a name="l00221"></a>00221                <span class="stringliteral">&quot;rational &quot;</span> + e.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l00222"></a>00222   <a class="code" href="classCVC3_1_1Expr_1_1iterator.html">Expr::iterator</a> i = e.<a class="code" href="group__ExprPkg.html#gac890e13db184610276fc533fa4b4fe99" title="Begin iterator.">begin</a>();
<a name="l00223"></a>00223   mulKids.push_back(rat(c.<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>() * (*i).getRational()));
<a name="l00224"></a>00224   ++i;
<a name="l00225"></a>00225   <span class="keywordflow">for</span>(; i != e.<a class="code" href="group__ExprPkg.html#gaf6048a5030c8fa2511bf5dfee868e653" title="End iterator.">end</a>(); ++i) {
<a name="l00226"></a>00226     mulKids.push_back(*i);
<a name="l00227"></a>00227   }
<a name="l00228"></a>00228   <span class="keywordflow">return</span> simplifiedMultExpr(mulKids);
<a name="l00229"></a>00229 }
<a name="l00230"></a>00230 
<a name="l00231"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a747b71c44a0bad76328039a2fc123363">00231</a> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> ArithTheoremProducer3::canonMultConstPlus(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> &amp; e1,
<a name="l00232"></a>00232                                               <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> &amp; e2)
<a name="l00233"></a>00233 {
<a name="l00234"></a>00234   <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(e1.<a class="code" href="group__ExprPkg.html#gac5ced6adc7a60945ea6707ef494aa28f">isRational</a>() &amp;&amp; e2.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>() == <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a9a12fbdcaa45ef17eaa1802161f9ca98">PLUS</a> &amp;&amp;
<a name="l00235"></a>00235               e2.<a class="code" href="group__ExprPkg.html#ga28b901d05e52a5c646f83a95cc74f94b">arity</a>() &gt; 0, <span class="stringliteral">&quot;&quot;</span>);
<a name="l00236"></a>00236   <span class="comment">// e1 is a rational</span>
<a name="l00237"></a>00237   <span class="comment">// e2 is of the form (PLUS rational sterm1 sterm2 ...)</span>
<a name="l00238"></a>00238   <span class="comment">// assume that e2 is already in canonic form</span>
<a name="l00239"></a>00239   std::vector&lt;Theorem&gt; thmPlusVector;
<a name="l00240"></a>00240   <a class="code" href="classCVC3_1_1Expr_1_1iterator.html">Expr::iterator</a> i = e2.<a class="code" href="group__ExprPkg.html#gac890e13db184610276fc533fa4b4fe99" title="Begin iterator.">begin</a>();
<a name="l00241"></a>00241   <span class="keywordflow">for</span>(; i!= e2.<a class="code" href="group__ExprPkg.html#gaf6048a5030c8fa2511bf5dfee868e653" title="End iterator.">end</a>(); ++i) {
<a name="l00242"></a>00242     thmPlusVector.push_back(canonMultMtermMterm(e1*(*i)));
<a name="l00243"></a>00243   }
<a name="l00244"></a>00244 
<a name="l00245"></a>00245   <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> thmPlus1 =
<a name="l00246"></a>00246     d_theoryArith-&gt;substitutivityRule(e2.<a class="code" href="group__ExprPkg.html#gace479f04faca399219496195152f7806" title="Get operator from expression.">getOp</a>(), thmPlusVector);
<a name="l00247"></a>00247   <span class="keywordflow">return</span> thmPlus1.<a class="code" href="classCVC3_1_1Theorem.html#a97d957fcbf9094480851b1d2e5d3729f">getRHS</a>();
<a name="l00248"></a>00248 }
<a name="l00249"></a>00249 
<a name="l00250"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#ae709408bffa6ff2016619a05febe63f5">00250</a> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> ArithTheoremProducer3::canonMultPowPow(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> &amp; e1,
<a name="l00251"></a>00251                                            <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> &amp; e2)
<a name="l00252"></a>00252 {
<a name="l00253"></a>00253   <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(e1.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>() == <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a880283f7bbc366efe54c9ea074c9f5e5">POW</a> &amp;&amp; e2.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>() == <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a880283f7bbc366efe54c9ea074c9f5e5">POW</a>, <span class="stringliteral">&quot;&quot;</span>);
<a name="l00254"></a>00254   <span class="comment">// (POW r1 leaf1) * (POW r2 leaf2)</span>
<a name="l00255"></a>00255   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> leaf1 = e1[1];
<a name="l00256"></a>00256   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> leaf2 = e2[1];
<a name="l00257"></a>00257   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> can_expr;
<a name="l00258"></a>00258   <span class="keywordflow">if</span> (leaf1 == leaf2) {
<a name="l00259"></a>00259     <a class="code" href="classCVC3_1_1Rational.html">Rational</a> rsum = e1[0].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>() + e2[0].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>();
<a name="l00260"></a>00260     <span class="keywordflow">if</span> (rsum == 0) {
<a name="l00261"></a>00261       <span class="keywordflow">return</span> rat(1);
<a name="l00262"></a>00262     }
<a name="l00263"></a>00263     <span class="keywordflow">else</span> <span class="keywordflow">if</span> (rsum == 1) {
<a name="l00264"></a>00264       <span class="keywordflow">return</span> leaf1;
<a name="l00265"></a>00265     }
<a name="l00266"></a>00266     <span class="keywordflow">else</span>
<a name="l00267"></a>00267       {
<a name="l00268"></a>00268         <span class="keywordflow">return</span> <a class="code" href="namespaceCVC3.html#aa123bf4eb1751181baf16c5e80b47740" title="Power (x^n, or base^{pow}) expressions.">powExpr</a>(rat(rsum), leaf1);
<a name="l00269"></a>00269       }
<a name="l00270"></a>00270   }
<a name="l00271"></a>00271   <span class="keywordflow">else</span>
<a name="l00272"></a>00272     {
<a name="l00273"></a>00273       std::vector&lt;Expr&gt; mulKids;
<a name="l00274"></a>00274       mulKids.push_back(rat(1));
<a name="l00275"></a>00275       <span class="comment">// the leafs should be put in decreasing order</span>
<a name="l00276"></a>00276       <span class="keywordflow">if</span> (leaf1 &lt; leaf2) {
<a name="l00277"></a>00277         mulKids.push_back(e2);
<a name="l00278"></a>00278         mulKids.push_back(e1);
<a name="l00279"></a>00279       }
<a name="l00280"></a>00280       <span class="keywordflow">else</span>
<a name="l00281"></a>00281         {
<a name="l00282"></a>00282           mulKids.push_back(e1);
<a name="l00283"></a>00283           mulKids.push_back(e2);
<a name="l00284"></a>00284         }
<a name="l00285"></a>00285       <span class="comment">// FIXME: don&#39;t really need to simplify, just wrap up a MULT?</span>
<a name="l00286"></a>00286       <span class="keywordflow">return</span> simplifiedMultExpr(mulKids);
<a name="l00287"></a>00287     }
<a name="l00288"></a>00288 }
<a name="l00289"></a>00289 
<a name="l00290"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a1765748e34d12d99b3bdf57f3ba49d49">00290</a> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> ArithTheoremProducer3::canonMultPowLeaf(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> &amp; e1,
<a name="l00291"></a>00291                                             <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> &amp; e2)
<a name="l00292"></a>00292 {
<a name="l00293"></a>00293   <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(e1.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>() == <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a880283f7bbc366efe54c9ea074c9f5e5">POW</a>, <span class="stringliteral">&quot;&quot;</span>);
<a name="l00294"></a>00294   <span class="comment">// (POW r1 leaf1) * leaf2</span>
<a name="l00295"></a>00295   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> leaf1 = e1[1];
<a name="l00296"></a>00296   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> leaf2 = e2;
<a name="l00297"></a>00297   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> can_expr;
<a name="l00298"></a>00298   <span class="keywordflow">if</span> (leaf1 == leaf2) {
<a name="l00299"></a>00299     <a class="code" href="classCVC3_1_1Rational.html">Rational</a> rsum = e1[0].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>() + 1;
<a name="l00300"></a>00300     <span class="keywordflow">if</span> (rsum == 0) {
<a name="l00301"></a>00301       <span class="keywordflow">return</span> rat(1);
<a name="l00302"></a>00302     }
<a name="l00303"></a>00303     <span class="keywordflow">else</span> <span class="keywordflow">if</span> (rsum == 1) {
<a name="l00304"></a>00304       <span class="keywordflow">return</span> leaf1;
<a name="l00305"></a>00305     }
<a name="l00306"></a>00306     <span class="keywordflow">else</span>
<a name="l00307"></a>00307       {
<a name="l00308"></a>00308         <span class="keywordflow">return</span> <a class="code" href="namespaceCVC3.html#aa123bf4eb1751181baf16c5e80b47740" title="Power (x^n, or base^{pow}) expressions.">powExpr</a>(rat(rsum), leaf1);
<a name="l00309"></a>00309       }
<a name="l00310"></a>00310   }
<a name="l00311"></a>00311   <span class="keywordflow">else</span>
<a name="l00312"></a>00312     {
<a name="l00313"></a>00313       std::vector&lt;Expr&gt; mulKids;
<a name="l00314"></a>00314       mulKids.push_back(rat(1));
<a name="l00315"></a>00315       <span class="comment">// the leafs should be put in decreasing order</span>
<a name="l00316"></a>00316       <span class="keywordflow">if</span> (leaf1 &lt; leaf2) {
<a name="l00317"></a>00317         mulKids.push_back(e2);
<a name="l00318"></a>00318         mulKids.push_back(e1);
<a name="l00319"></a>00319       }
<a name="l00320"></a>00320       <span class="keywordflow">else</span>
<a name="l00321"></a>00321         {
<a name="l00322"></a>00322           mulKids.push_back(e1);
<a name="l00323"></a>00323           mulKids.push_back(e2);
<a name="l00324"></a>00324         }
<a name="l00325"></a>00325       <span class="keywordflow">return</span> simplifiedMultExpr(mulKids);
<a name="l00326"></a>00326     }
<a name="l00327"></a>00327 }
<a name="l00328"></a>00328 
<a name="l00329"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#ad9ff33794685a95c453d41bf1fd9d0aa">00329</a> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> ArithTheoremProducer3::canonMultLeafLeaf(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> &amp; e1,
<a name="l00330"></a>00330                                              <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> &amp; e2)
<a name="l00331"></a>00331 {
<a name="l00332"></a>00332   <span class="comment">// leaf1 * leaf2</span>
<a name="l00333"></a>00333   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> leaf1 = e1;
<a name="l00334"></a>00334   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> leaf2 = e2;
<a name="l00335"></a>00335   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> can_expr;
<a name="l00336"></a>00336   <span class="keywordflow">if</span> (leaf1 == leaf2) {
<a name="l00337"></a>00337     <span class="keywordflow">return</span> <a class="code" href="namespaceCVC3.html#aa123bf4eb1751181baf16c5e80b47740" title="Power (x^n, or base^{pow}) expressions.">powExpr</a>(rat(2), leaf1);
<a name="l00338"></a>00338   }
<a name="l00339"></a>00339   <span class="keywordflow">else</span>
<a name="l00340"></a>00340     {
<a name="l00341"></a>00341       std::vector&lt;Expr&gt; mulKids;
<a name="l00342"></a>00342       mulKids.push_back(rat(1));
<a name="l00343"></a>00343       <span class="comment">// the leafs should be put in decreasing order</span>
<a name="l00344"></a>00344       <span class="keywordflow">if</span> (leaf1 &lt; leaf2) {
<a name="l00345"></a>00345         mulKids.push_back(e2);
<a name="l00346"></a>00346         mulKids.push_back(e1);
<a name="l00347"></a>00347       }
<a name="l00348"></a>00348       <span class="keywordflow">else</span>
<a name="l00349"></a>00349         {
<a name="l00350"></a>00350           mulKids.push_back(e1);
<a name="l00351"></a>00351           mulKids.push_back(e2);
<a name="l00352"></a>00352         }
<a name="l00353"></a>00353       <span class="keywordflow">return</span> simplifiedMultExpr(mulKids);
<a name="l00354"></a>00354     }
<a name="l00355"></a>00355 }
<a name="l00356"></a>00356 
<a name="l00357"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a9bf1d7c7d567deab2e5decc8c4e82fdc">00357</a> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> ArithTheoremProducer3::canonMultLeafOrPowMult(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> &amp; e1,
<a name="l00358"></a>00358                                                   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> &amp; e2)
<a name="l00359"></a>00359 {
<a name="l00360"></a>00360   <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(e2.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>() == <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024ad77e825b0133e40de2760344377ee1fa">MULT</a>, <span class="stringliteral">&quot;&quot;</span>);
<a name="l00361"></a>00361   <span class="comment">// Leaf * (MULT rat1 mterm1 ...)</span>
<a name="l00362"></a>00362   <span class="comment">// (POW r1 leaf1) * (MULT rat1 mterm1 ...) where</span>
<a name="l00363"></a>00363   <span class="comment">// each mterm is a leaf or (POW r leaf).  Furthermore the leafs</span>
<a name="l00364"></a>00364   <span class="comment">// in the mterms are in descending order</span>
<a name="l00365"></a>00365   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> leaf1 = e1.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>() == <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a880283f7bbc366efe54c9ea074c9f5e5">POW</a> ? e1[1] : e1;
<a name="l00366"></a>00366   std::vector&lt;Expr&gt; mulKids;
<a name="l00367"></a>00367   <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(e2.<a class="code" href="group__ExprPkg.html#ga28b901d05e52a5c646f83a95cc74f94b">arity</a>() &gt; 1, <span class="stringliteral">&quot;MULT expr must have arity 2 or more&quot;</span>);
<a name="l00368"></a>00368   <a class="code" href="classCVC3_1_1Expr_1_1iterator.html">Expr::iterator</a> i = e2.<a class="code" href="group__ExprPkg.html#gac890e13db184610276fc533fa4b4fe99" title="Begin iterator.">begin</a>();
<a name="l00369"></a>00369   <span class="comment">// push the rational</span>
<a name="l00370"></a>00370   mulKids.push_back(*i);
<a name="l00371"></a>00371   ++i;
<a name="l00372"></a>00372   <span class="comment">// Now i points to the first mterm</span>
<a name="l00373"></a>00373   <span class="keywordflow">for</span>(; i != e2.<a class="code" href="group__ExprPkg.html#gaf6048a5030c8fa2511bf5dfee868e653" title="End iterator.">end</a>(); ++i) {
<a name="l00374"></a>00374     <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> leaf2 = ((*i).getKind() == <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a880283f7bbc366efe54c9ea074c9f5e5">POW</a>) ? (*i)[1] : (*i);
<a name="l00375"></a>00375     <span class="keywordflow">if</span> (leaf1 == leaf2) {
<a name="l00376"></a>00376       <a class="code" href="classCVC3_1_1Rational.html">Rational</a> r1 = e1.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>() == <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a880283f7bbc366efe54c9ea074c9f5e5">POW</a> ? e1[0].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>() : 1;
<a name="l00377"></a>00377       <a class="code" href="classCVC3_1_1Rational.html">Rational</a> r2 =
<a name="l00378"></a>00378         ((*i).getKind() == <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a880283f7bbc366efe54c9ea074c9f5e5">POW</a> ? (*i)[0].getRational() : 1);
<a name="l00379"></a>00379       <span class="comment">// if r1 + r2 == 0 then it is the case of x^n * x^{-n}</span>
<a name="l00380"></a>00380       <span class="comment">// So, nothing needs to be added</span>
<a name="l00381"></a>00381       <span class="keywordflow">if</span> (r1 + r2 != 0) {
<a name="l00382"></a>00382         <span class="keywordflow">if</span> (r1 + r2 == 1) {
<a name="l00383"></a>00383           mulKids.push_back(leaf1);
<a name="l00384"></a>00384         }
<a name="l00385"></a>00385         <span class="keywordflow">else</span>
<a name="l00386"></a>00386           {
<a name="l00387"></a>00387             mulKids.push_back(<a class="code" href="namespaceCVC3.html#aa123bf4eb1751181baf16c5e80b47740" title="Power (x^n, or base^{pow}) expressions.">powExpr</a>(rat(r1 + r2), leaf1));
<a name="l00388"></a>00388           }
<a name="l00389"></a>00389       }
<a name="l00390"></a>00390       <span class="keywordflow">break</span>;
<a name="l00391"></a>00391     }
<a name="l00392"></a>00392     <span class="comment">// This ensures that the leaves in the mterms are also arranged</span>
<a name="l00393"></a>00393     <span class="comment">// in decreasing order</span>
<a name="l00394"></a>00394     <span class="comment">// Note that this will need to be changed if we want the order to</span>
<a name="l00395"></a>00395     <span class="comment">// be increasing order.</span>
<a name="l00396"></a>00396     <span class="keywordflow">else</span> <span class="keywordflow">if</span> (leaf2 &lt; leaf1) {
<a name="l00397"></a>00397       mulKids.push_back(e1);
<a name="l00398"></a>00398       mulKids.push_back(*i);
<a name="l00399"></a>00399       <span class="keywordflow">break</span>;
<a name="l00400"></a>00400     }
<a name="l00401"></a>00401     <span class="keywordflow">else</span> <span class="comment">// leaf1 &lt; leaf2</span>
<a name="l00402"></a>00402       mulKids.push_back(*i);
<a name="l00403"></a>00403   }
<a name="l00404"></a>00404   <span class="keywordflow">if</span> (i == e2.<a class="code" href="group__ExprPkg.html#gaf6048a5030c8fa2511bf5dfee868e653" title="End iterator.">end</a>()) {
<a name="l00405"></a>00405     mulKids.push_back(e1);
<a name="l00406"></a>00406   }
<a name="l00407"></a>00407   <span class="keywordflow">else</span>
<a name="l00408"></a>00408     {
<a name="l00409"></a>00409       <span class="comment">// e1 and *i have already been added</span>
<a name="l00410"></a>00410       <span class="keywordflow">for</span> (++i; i != e2.<a class="code" href="group__ExprPkg.html#gaf6048a5030c8fa2511bf5dfee868e653" title="End iterator.">end</a>(); ++i) {
<a name="l00411"></a>00411         mulKids.push_back(*i);
<a name="l00412"></a>00412       }
<a name="l00413"></a>00413     }
<a name="l00414"></a>00414   <span class="keywordflow">return</span> simplifiedMultExpr(mulKids);
<a name="l00415"></a>00415 }
<a name="l00416"></a>00416 
<a name="l00417"></a>00417 <span class="comment">// Local class for ordering monomials; note, that it flips the</span>
<a name="l00418"></a>00418 <span class="comment">// ordering given by greaterthan(), to sort in ascending order.</span>
<a name="l00419"></a>00419 <span class="keyword">class </span><a class="code" href="classMonomialLess.html">MonomialLess</a> {
<a name="l00420"></a>00420 <span class="keyword">public</span>:
<a name="l00421"></a><a class="code" href="classMonomialLess.html#a69db32fbde99647b028bbab4a6e61126">00421</a>   <span class="keywordtype">bool</span> <a class="code" href="classMonomialLess.html#a69db32fbde99647b028bbab4a6e61126">operator()</a>(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; e1, <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; e2)<span class="keyword"> const </span>{
<a name="l00422"></a>00422     <span class="keywordflow">return</span> ArithTheoremProducer3::greaterthan(e1,e2);
<a name="l00423"></a>00423   }
<a name="l00424"></a>00424 };
<a name="l00425"></a>00425 
<a name="l00426"></a><a class="code" href="arith__theorem__producer3_8cpp.html#a24fc78b84aff5214bf8b65ff0a2a99a3">00426</a> <span class="keyword">typedef</span> map&lt;Expr,Rational,MonomialLess&gt; <a class="code" href="arith__theorem__producer_8cpp.html#a24fc78b84aff5214bf8b65ff0a2a99a3">MonomMap</a>;
<a name="l00427"></a>00427 
<a name="l00428"></a>00428 <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>
<a name="l00429"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#af61545eb36910fba4fa1b69e6febb354">00429</a> ArithTheoremProducer3::canonCombineLikeTerms(<span class="keyword">const</span> std::vector&lt;Expr&gt; &amp; sumExprs)
<a name="l00430"></a>00430 {
<a name="l00431"></a>00431   <a class="code" href="classCVC3_1_1Rational.html">Rational</a> constant = 0;
<a name="l00432"></a>00432   <a class="code" href="arith__theorem__producer_8cpp.html#a24fc78b84aff5214bf8b65ff0a2a99a3">MonomMap</a> sumHashMap;
<a name="l00433"></a>00433   vector&lt;Expr&gt; sumKids;
<a name="l00434"></a>00434 
<a name="l00435"></a>00435   <span class="comment">// Add each distinct mterm (not including the rational) into</span>
<a name="l00436"></a>00436   <span class="comment">// an appropriate hash map entry</span>
<a name="l00437"></a>00437   std::vector&lt;Expr&gt;::const_iterator i = sumExprs.begin();
<a name="l00438"></a>00438   <span class="keywordflow">for</span> (; i != sumExprs.end(); ++i) {
<a name="l00439"></a>00439     <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> mul = *i;
<a name="l00440"></a>00440     <span class="keywordflow">if</span> (mul.<a class="code" href="group__ExprPkg.html#gac5ced6adc7a60945ea6707ef494aa28f">isRational</a>()) {
<a name="l00441"></a>00441       constant = constant + mul.<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>();
<a name="l00442"></a>00442     }
<a name="l00443"></a>00443     <span class="keywordflow">else</span> {
<a name="l00444"></a>00444       <span class="keywordflow">switch</span> (mul.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>()) {
<a name="l00445"></a>00445       <span class="keywordflow">case</span> <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024ad77e825b0133e40de2760344377ee1fa">MULT</a>: {
<a name="l00446"></a>00446         std::vector&lt;Expr&gt; mulKids;
<a name="l00447"></a>00447         <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(mul.<a class="code" href="group__ExprPkg.html#ga28b901d05e52a5c646f83a95cc74f94b">arity</a>() &gt; 1 &amp;&amp; mul[0].<a class="code" href="group__ExprPkg.html#gac5ced6adc7a60945ea6707ef494aa28f">isRational</a>(),<span class="stringliteral">&quot;&quot;</span>);
<a name="l00448"></a>00448         mulKids.push_back(rat(1));
<a name="l00449"></a>00449         <a class="code" href="classCVC3_1_1Expr_1_1iterator.html">Expr::iterator</a> j = mul.<a class="code" href="group__ExprPkg.html#gac890e13db184610276fc533fa4b4fe99" title="Begin iterator.">begin</a>();
<a name="l00450"></a>00450         ++j;
<a name="l00451"></a>00451         <span class="keywordflow">for</span> (; j!= mul.<a class="code" href="group__ExprPkg.html#gaf6048a5030c8fa2511bf5dfee868e653" title="End iterator.">end</a>(); ++j) {
<a name="l00452"></a>00452           mulKids.push_back(*j);
<a name="l00453"></a>00453         }
<a name="l00454"></a>00454 
<a name="l00455"></a>00455         <span class="comment">// make sure that tempExpr is also in canonic form</span>
<a name="l00456"></a>00456         <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> tempExpr = mulKids.size() &gt; 2 ? <a class="code" href="namespaceCVC3.html#adb35e0739f86730543924dbc8211a778">multExpr</a>(mulKids): mulKids[1];
<a name="l00457"></a>00457   MonomMap::iterator i=sumHashMap.find(tempExpr);
<a name="l00458"></a>00458         <span class="keywordflow">if</span> (i == sumHashMap.end()) {
<a name="l00459"></a>00459           sumHashMap[tempExpr] = mul[0].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>();
<a name="l00460"></a>00460         }
<a name="l00461"></a>00461         <span class="keywordflow">else</span> {
<a name="l00462"></a>00462           (*i).second += mul[0].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>();
<a name="l00463"></a>00463         }
<a name="l00464"></a>00464       }
<a name="l00465"></a>00465         <span class="keywordflow">break</span>;
<a name="l00466"></a>00466       <span class="keywordflow">default</span>: {
<a name="l00467"></a>00467   MonomMap::iterator i=sumHashMap.find(mul);
<a name="l00468"></a>00468         <span class="comment">// covers the case of POW, leaf</span>
<a name="l00469"></a>00469         <span class="keywordflow">if</span> (i == sumHashMap.end()) {
<a name="l00470"></a>00470           sumHashMap[mul] = 1;
<a name="l00471"></a>00471         }
<a name="l00472"></a>00472         <span class="keywordflow">else</span> {
<a name="l00473"></a>00473           (*i).second += 1;
<a name="l00474"></a>00474         }
<a name="l00475"></a>00475         <span class="keywordflow">break</span>;
<a name="l00476"></a>00476       }
<a name="l00477"></a>00477       }
<a name="l00478"></a>00478     }
<a name="l00479"></a>00479   }
<a name="l00480"></a>00480   <span class="comment">// Now transfer to sumKids</span>
<a name="l00481"></a>00481   sumKids.push_back(rat(constant));
<a name="l00482"></a>00482   MonomMap::iterator j = sumHashMap.begin(), jend=sumHashMap.end();
<a name="l00483"></a>00483   <span class="keywordflow">for</span>(; j != jend; ++j) {
<a name="l00484"></a>00484     <span class="keywordflow">if</span> ((*j).second != 0)
<a name="l00485"></a>00485       sumKids.push_back
<a name="l00486"></a>00486   (canonMultMtermMterm(rat((*j).second) * (*j).first).getRHS());
<a name="l00487"></a>00487   }
<a name="l00488"></a>00488 
<a name="l00489"></a>00489   <span class="comment">/*</span>
<a name="l00490"></a>00490 <span class="comment">    for (unsigned k = 0; k &lt; sumKids.size(); ++k)</span>
<a name="l00491"></a>00491 <span class="comment">    {</span>
<a name="l00492"></a>00492 <span class="comment">    cout &lt;&lt; &quot;sumKids[&quot; &lt;&lt; k &lt;&lt; &quot;] = &quot; &lt;&lt; sumKids[k].toString() &lt;&lt; endl;</span>
<a name="l00493"></a>00493 <span class="comment">    }</span>
<a name="l00494"></a>00494 <span class="comment">  */</span>
<a name="l00495"></a>00495 
<a name="l00496"></a>00496   <span class="comment">// The ordering in map guarantees the correct order; no need to sort</span>
<a name="l00497"></a>00497 
<a name="l00498"></a>00498   <span class="comment">// std::sort(sumKids.begin(), sumKids.end(), greaterthan);</span>
<a name="l00499"></a>00499 
<a name="l00500"></a>00500   <span class="keywordflow">if</span> ((constant == 0) &amp;&amp; (sumKids.size() == 2)) {
<a name="l00501"></a>00501     <span class="keywordflow">return</span> sumKids[1];
<a name="l00502"></a>00502   }
<a name="l00503"></a>00503   <span class="keywordflow">else</span> <span class="keywordflow">if</span> (sumKids.size() == 1) {
<a name="l00504"></a>00504     <span class="keywordflow">return</span> sumKids[0];
<a name="l00505"></a>00505   }
<a name="l00506"></a>00506   <span class="keywordflow">else</span>
<a name="l00507"></a>00507     <span class="keywordflow">return</span> <a class="code" href="namespaceCVC3.html#accd3d7d38b0e04136afbc3e5191bc8bb">plusExpr</a>(sumKids);
<a name="l00508"></a>00508 }
<a name="l00509"></a>00509 
<a name="l00510"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#ad5dec14920bc52be7b9fdfb458ba2e1b">00510</a> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> ArithTheoremProducer3::canonMultLeafOrPowOrMultPlus(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> &amp; e1,
<a name="l00511"></a>00511                                                         <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> &amp; e2)
<a name="l00512"></a>00512 {
<a name="l00513"></a>00513   <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(e2.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>() == <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a9a12fbdcaa45ef17eaa1802161f9ca98">PLUS</a>, <span class="stringliteral">&quot;&quot;</span>);
<a name="l00514"></a>00514   <span class="comment">// Leaf *  (PLUS rational sterm1 ...)</span>
<a name="l00515"></a>00515   <span class="comment">// or</span>
<a name="l00516"></a>00516   <span class="comment">// (POW n1 x1) * (PLUS rational sterm1 ...)</span>
<a name="l00517"></a>00517   <span class="comment">// or</span>
<a name="l00518"></a>00518   <span class="comment">// (MULT r1 m1 m2 ...) * (PLUS rational sterm1 ...)</span>
<a name="l00519"></a>00519   <span class="comment">// assume that e1 and e2 are themselves canonized</span>
<a name="l00520"></a>00520   std::vector&lt;Expr&gt; sumExprs;
<a name="l00521"></a>00521   <span class="comment">// Multiply each term in turn.</span>
<a name="l00522"></a>00522   <a class="code" href="classCVC3_1_1Expr_1_1iterator.html">Expr::iterator</a> i = e2.<a class="code" href="group__ExprPkg.html#gac890e13db184610276fc533fa4b4fe99" title="Begin iterator.">begin</a>();
<a name="l00523"></a>00523   <span class="keywordflow">for</span> (; i != e2.<a class="code" href="group__ExprPkg.html#gaf6048a5030c8fa2511bf5dfee868e653" title="End iterator.">end</a>(); ++i) {
<a name="l00524"></a>00524     sumExprs.push_back(canonMultMtermMterm(e1 * (*i)).getRHS());
<a name="l00525"></a>00525   }
<a name="l00526"></a>00526   <span class="keywordflow">return</span> canonCombineLikeTerms(sumExprs);
<a name="l00527"></a>00527 }
<a name="l00528"></a>00528 
<a name="l00529"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#ab327e6f313e952c0380fe7460bd7d36c">00529</a> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> ArithTheoremProducer3::canonMultPlusPlus(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> &amp; e1,
<a name="l00530"></a>00530                                              <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> &amp; e2)
<a name="l00531"></a>00531 {
<a name="l00532"></a>00532   <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(e1.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>() == <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a9a12fbdcaa45ef17eaa1802161f9ca98">PLUS</a> &amp;&amp; e2.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>() == <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a9a12fbdcaa45ef17eaa1802161f9ca98">PLUS</a>, <span class="stringliteral">&quot;&quot;</span>);
<a name="l00533"></a>00533   <span class="comment">// (PLUS r1 .... ) * (PLUS r1&#39; ...)</span>
<a name="l00534"></a>00534   <span class="comment">// assume that e1 and e2 are themselves canonized</span>
<a name="l00535"></a>00535 
<a name="l00536"></a>00536   std::vector&lt;Expr&gt; sumExprs;
<a name="l00537"></a>00537   <span class="comment">// Multiply each term in turn.</span>
<a name="l00538"></a>00538   <a class="code" href="classCVC3_1_1Expr_1_1iterator.html">Expr::iterator</a> i = e1.<a class="code" href="group__ExprPkg.html#gac890e13db184610276fc533fa4b4fe99" title="Begin iterator.">begin</a>();
<a name="l00539"></a>00539   <span class="keywordflow">for</span> (;  i != e1.<a class="code" href="group__ExprPkg.html#gaf6048a5030c8fa2511bf5dfee868e653" title="End iterator.">end</a>(); ++i) {
<a name="l00540"></a>00540     <a class="code" href="classCVC3_1_1Expr_1_1iterator.html">Expr::iterator</a> j = e2.<a class="code" href="group__ExprPkg.html#gac890e13db184610276fc533fa4b4fe99" title="Begin iterator.">begin</a>();
<a name="l00541"></a>00541     <span class="keywordflow">for</span> (;  j != e2.<a class="code" href="group__ExprPkg.html#gaf6048a5030c8fa2511bf5dfee868e653" title="End iterator.">end</a>(); ++j) {
<a name="l00542"></a>00542       sumExprs.push_back(canonMultMtermMterm((*i) * (*j)).getRHS());
<a name="l00543"></a>00543     }
<a name="l00544"></a>00544   }
<a name="l00545"></a>00545   <span class="keywordflow">return</span> canonCombineLikeTerms(sumExprs);
<a name="l00546"></a>00546 }
<a name="l00547"></a>00547 
<a name="l00548"></a>00548 
<a name="l00549"></a>00549 
<a name="l00550"></a>00550 <span class="comment">// The following produces a Theorem which is the result of multiplication</span>
<a name="l00551"></a>00551 <span class="comment">// of two canonized mterms.  e = e1*e2</span>
<a name="l00552"></a>00552 <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>
<a name="l00553"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#aa1ab000ca8a6a2605b2cb57f8b881d91">00553</a> ArithTheoremProducer3::canonMultMtermMterm(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; e)
<a name="l00554"></a>00554 {
<a name="l00555"></a>00555   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l00556"></a>00556     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#a28ae8672047db708e99602ebaca89777">isMult</a>(e) &amp;&amp; e.<a class="code" href="group__ExprPkg.html#ga28b901d05e52a5c646f83a95cc74f94b">arity</a>() == 2,
<a name="l00557"></a>00557     <span class="stringliteral">&quot;canonMultMtermMterm: e = &quot;</span>+e.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l00558"></a>00558   }
<a name="l00559"></a>00559   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l00560"></a>00560   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> rhs;
<a name="l00561"></a>00561   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; e1 = e[0];
<a name="l00562"></a>00562   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; e2 = e[1];
<a name="l00563"></a>00563   <span class="keywordtype">string</span> cmmm = <span class="stringliteral">&quot;canon_mult_mterm_mterm&quot;</span>;
<a name="l00564"></a>00564 
<a name="l00565"></a>00565   <span class="keywordflow">if</span> (e1.<a class="code" href="group__ExprPkg.html#gac5ced6adc7a60945ea6707ef494aa28f">isRational</a>()) {
<a name="l00566"></a>00566     <span class="comment">// e1 is a Rational</span>
<a name="l00567"></a>00567     <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Rational.html">Rational</a>&amp; c = e1.<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>();
<a name="l00568"></a>00568     <span class="keywordflow">if</span> (c == 0)
<a name="l00569"></a>00569       <span class="keywordflow">return</span> canonMultZero(e2);
<a name="l00570"></a>00570     <span class="keywordflow">else</span> <span class="keywordflow">if</span> (c == 1)
<a name="l00571"></a>00571       <span class="keywordflow">return</span> canonMultOne(e2);
<a name="l00572"></a>00572     <span class="keywordflow">else</span> {
<a name="l00573"></a>00573       <span class="keywordflow">switch</span> (e2.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>()) {
<a name="l00574"></a>00574       <span class="keywordflow">case</span> <a class="code" href="kinds_8h.html#aa10c9e8951b8ccf714a59ec321bdac5bae07a708ec52c578b62f8b0f701571d56">RATIONAL_EXPR</a> :
<a name="l00575"></a>00575         <span class="comment">// rat * rat</span>
<a name="l00576"></a>00576         <span class="keywordflow">return</span> canonMultConstConst(e1,e2);
<a name="l00577"></a>00577         <span class="keywordflow">break</span>;
<a name="l00578"></a>00578         <span class="comment">// TODO case of leaf</span>
<a name="l00579"></a>00579       <span class="keywordflow">case</span> <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a880283f7bbc366efe54c9ea074c9f5e5">POW</a>:
<a name="l00580"></a>00580         <span class="comment">// rat * (POW rat leaf)</span>
<a name="l00581"></a>00581         <span class="comment">// nothing to simplify</span>
<a name="l00582"></a>00582         <span class="keywordflow">return</span> d_theoryArith-&gt;reflexivityRule (e);
<a name="l00583"></a>00583 
<a name="l00584"></a>00584         <span class="keywordflow">break</span>;
<a name="l00585"></a>00585       <span class="keywordflow">case</span> <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024ad77e825b0133e40de2760344377ee1fa">MULT</a>:
<a name="l00586"></a>00586         rhs = canonMultConstMult(e1,e2);
<a name="l00587"></a>00587         <span class="keywordflow">if</span>(withProof()) pf = newPf(cmmm,e,rhs);
<a name="l00588"></a>00588         <span class="keywordflow">return</span> newRWTheorem(e, rhs, Assumptions::emptyAssump(), pf);
<a name="l00589"></a>00589         <span class="keywordflow">break</span>;
<a name="l00590"></a>00590       <span class="keywordflow">case</span> <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a9a12fbdcaa45ef17eaa1802161f9ca98">PLUS</a>:
<a name="l00591"></a>00591         rhs = canonMultConstPlus(e1,e2);
<a name="l00592"></a>00592         <span class="keywordflow">if</span>(withProof()) pf = newPf(cmmm,e,rhs);
<a name="l00593"></a>00593         <span class="keywordflow">return</span> newRWTheorem(e, rhs, Assumptions::emptyAssump(), pf);
<a name="l00594"></a>00594         <span class="keywordflow">break</span>;
<a name="l00595"></a>00595       <span class="keywordflow">default</span>:
<a name="l00596"></a>00596         <span class="comment">// TODO: I am going to assume that this is just a leaf</span>
<a name="l00597"></a>00597         <span class="comment">// i.e., a variable or term from another theory</span>
<a name="l00598"></a>00598         <span class="keywordflow">return</span> d_theoryArith-&gt;reflexivityRule(e);
<a name="l00599"></a>00599         <span class="keywordflow">break</span>;
<a name="l00600"></a>00600       }
<a name="l00601"></a>00601     }
<a name="l00602"></a>00602   }
<a name="l00603"></a>00603   <span class="keywordflow">else</span> <span class="keywordflow">if</span> (e1.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>() == <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a880283f7bbc366efe54c9ea074c9f5e5">POW</a>) {
<a name="l00604"></a>00604     <span class="keywordflow">switch</span> (e2.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>()) {
<a name="l00605"></a>00605     <span class="keywordflow">case</span> <a class="code" href="kinds_8h.html#aa10c9e8951b8ccf714a59ec321bdac5bae07a708ec52c578b62f8b0f701571d56">RATIONAL_EXPR</a>:
<a name="l00606"></a>00606       <span class="comment">// switch the order of the two arguments</span>
<a name="l00607"></a>00607       <span class="keywordflow">return</span> canonMultMtermMterm(e2 * e1);
<a name="l00608"></a>00608       <span class="keywordflow">break</span>;
<a name="l00609"></a>00609     <span class="keywordflow">case</span> <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a880283f7bbc366efe54c9ea074c9f5e5">POW</a>:
<a name="l00610"></a>00610       rhs = canonMultPowPow(e1,e2);
<a name="l00611"></a>00611       <span class="keywordflow">if</span>(withProof()) pf = newPf(cmmm,e,rhs);
<a name="l00612"></a>00612       <span class="keywordflow">return</span> newRWTheorem(e,rhs, Assumptions::emptyAssump(), pf);
<a name="l00613"></a>00613       <span class="keywordflow">break</span>;
<a name="l00614"></a>00614     <span class="keywordflow">case</span> <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024ad77e825b0133e40de2760344377ee1fa">MULT</a>:
<a name="l00615"></a>00615       rhs = canonMultLeafOrPowMult(e1,e2);
<a name="l00616"></a>00616       <span class="keywordflow">if</span>(withProof()) pf = newPf(cmmm,e,rhs);
<a name="l00617"></a>00617       <span class="keywordflow">return</span> newRWTheorem(e, rhs, Assumptions::emptyAssump(), pf);
<a name="l00618"></a>00618       <span class="keywordflow">break</span>;
<a name="l00619"></a>00619     <span class="keywordflow">case</span> <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a9a12fbdcaa45ef17eaa1802161f9ca98">PLUS</a>:
<a name="l00620"></a>00620       rhs = canonMultLeafOrPowOrMultPlus(e1,e2);
<a name="l00621"></a>00621       <span class="keywordflow">if</span>(withProof()) pf = newPf(cmmm,e,rhs);
<a name="l00622"></a>00622       <span class="keywordflow">return</span> newRWTheorem(e, rhs, Assumptions::emptyAssump(), pf);
<a name="l00623"></a>00623       <span class="keywordflow">break</span>;
<a name="l00624"></a>00624     <span class="keywordflow">default</span>:
<a name="l00625"></a>00625       rhs = canonMultPowLeaf(e1,e2);
<a name="l00626"></a>00626       <span class="keywordflow">if</span>(withProof()) pf = newPf(cmmm,e,rhs);
<a name="l00627"></a>00627       <span class="keywordflow">return</span> newRWTheorem(e,rhs, Assumptions::emptyAssump(), pf);
<a name="l00628"></a>00628       <span class="keywordflow">break</span>;
<a name="l00629"></a>00629     }
<a name="l00630"></a>00630   }
<a name="l00631"></a>00631   <span class="keywordflow">else</span> <span class="keywordflow">if</span> (e1.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>() == <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024ad77e825b0133e40de2760344377ee1fa">MULT</a>) {
<a name="l00632"></a>00632     <span class="keywordflow">switch</span> (e2.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>()) {
<a name="l00633"></a>00633     <span class="keywordflow">case</span> <a class="code" href="kinds_8h.html#aa10c9e8951b8ccf714a59ec321bdac5bae07a708ec52c578b62f8b0f701571d56">RATIONAL_EXPR</a>:
<a name="l00634"></a>00634     <span class="keywordflow">case</span> <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a880283f7bbc366efe54c9ea074c9f5e5">POW</a>:
<a name="l00635"></a>00635       <span class="comment">// switch the order of the two arguments</span>
<a name="l00636"></a>00636       <span class="keywordflow">return</span> canonMultMtermMterm(e2 * e1);
<a name="l00637"></a>00637       <span class="keywordflow">break</span>;
<a name="l00638"></a>00638     <span class="keywordflow">case</span> <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024ad77e825b0133e40de2760344377ee1fa">MULT</a>:
<a name="l00639"></a>00639       {
<a name="l00640"></a>00640         <span class="comment">// (Mult r m1 m2 ...) (Mult r&#39; m1&#39; m2&#39; ...)</span>
<a name="l00641"></a>00641         <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> result = e2;
<a name="l00642"></a>00642         <a class="code" href="classCVC3_1_1Expr_1_1iterator.html">Expr::iterator</a> i = e1.begin();
<a name="l00643"></a>00643         <span class="keywordflow">for</span> (; i != e1.end(); ++i) {
<a name="l00644"></a>00644           result = canonMultMtermMterm((*i) * result).getRHS();
<a name="l00645"></a>00645         }
<a name="l00646"></a>00646         <span class="keywordflow">if</span>(withProof()) pf = newPf(cmmm,e,result);
<a name="l00647"></a>00647         <span class="keywordflow">return</span> newRWTheorem(e, result, Assumptions::emptyAssump(), pf);
<a name="l00648"></a>00648       }
<a name="l00649"></a>00649       <span class="keywordflow">break</span>;
<a name="l00650"></a>00650     <span class="keywordflow">case</span> <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a9a12fbdcaa45ef17eaa1802161f9ca98">PLUS</a>:
<a name="l00651"></a>00651       rhs = canonMultLeafOrPowOrMultPlus(e1,e2);
<a name="l00652"></a>00652       <span class="keywordflow">if</span>(withProof()) pf = newPf(cmmm,e,rhs);
<a name="l00653"></a>00653       <span class="keywordflow">return</span> newRWTheorem(e,rhs, Assumptions::emptyAssump(), pf);
<a name="l00654"></a>00654       <span class="keywordflow">break</span>;
<a name="l00655"></a>00655     <span class="keywordflow">default</span>:
<a name="l00656"></a>00656       <span class="comment">// leaf</span>
<a name="l00657"></a>00657       <span class="comment">// switch the order of the two arguments</span>
<a name="l00658"></a>00658       <span class="keywordflow">return</span> canonMultMtermMterm(e2 * e1);
<a name="l00659"></a>00659       <span class="keywordflow">break</span>;
<a name="l00660"></a>00660     }
<a name="l00661"></a>00661   }
<a name="l00662"></a>00662   <span class="keywordflow">else</span> <span class="keywordflow">if</span> (e1.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>() == <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a9a12fbdcaa45ef17eaa1802161f9ca98">PLUS</a>) {
<a name="l00663"></a>00663     <span class="keywordflow">switch</span> (e2.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>()) {
<a name="l00664"></a>00664     <span class="keywordflow">case</span> <a class="code" href="kinds_8h.html#aa10c9e8951b8ccf714a59ec321bdac5bae07a708ec52c578b62f8b0f701571d56">RATIONAL_EXPR</a>:
<a name="l00665"></a>00665     <span class="keywordflow">case</span> <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a880283f7bbc366efe54c9ea074c9f5e5">POW</a>:
<a name="l00666"></a>00666     <span class="keywordflow">case</span> <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024ad77e825b0133e40de2760344377ee1fa">MULT</a>:
<a name="l00667"></a>00667       <span class="comment">// switch the order of the two arguments</span>
<a name="l00668"></a>00668       <span class="keywordflow">return</span> canonMultMtermMterm(e2 * e1);
<a name="l00669"></a>00669       <span class="keywordflow">break</span>;
<a name="l00670"></a>00670     <span class="keywordflow">case</span> <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a9a12fbdcaa45ef17eaa1802161f9ca98">PLUS</a>:
<a name="l00671"></a>00671       rhs = canonMultPlusPlus(e1,e2);
<a name="l00672"></a>00672       <span class="keywordflow">if</span>(withProof()) pf = newPf(cmmm,e,rhs);
<a name="l00673"></a>00673       <span class="keywordflow">return</span> newRWTheorem(e, rhs, Assumptions::emptyAssump(), pf);
<a name="l00674"></a>00674       <span class="keywordflow">break</span>;
<a name="l00675"></a>00675     <span class="keywordflow">default</span>:
<a name="l00676"></a>00676       <span class="comment">// leaf</span>
<a name="l00677"></a>00677       <span class="comment">// switch the order of the two arguments</span>
<a name="l00678"></a>00678       <span class="keywordflow">return</span> canonMultMtermMterm(e2 * e1);
<a name="l00679"></a>00679       <span class="keywordflow">break</span>;
<a name="l00680"></a>00680     }
<a name="l00681"></a>00681   }
<a name="l00682"></a>00682   <span class="keywordflow">else</span> {
<a name="l00683"></a>00683     <span class="comment">// leaf</span>
<a name="l00684"></a>00684     <span class="keywordflow">switch</span> (e2.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>()) {
<a name="l00685"></a>00685     <span class="keywordflow">case</span> <a class="code" href="kinds_8h.html#aa10c9e8951b8ccf714a59ec321bdac5bae07a708ec52c578b62f8b0f701571d56">RATIONAL_EXPR</a>:
<a name="l00686"></a>00686       <span class="comment">// switch the order of the two arguments</span>
<a name="l00687"></a>00687       <span class="keywordflow">return</span> canonMultMtermMterm(e2 * e1);
<a name="l00688"></a>00688       <span class="keywordflow">break</span>;
<a name="l00689"></a>00689     <span class="keywordflow">case</span> <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a880283f7bbc366efe54c9ea074c9f5e5">POW</a>:
<a name="l00690"></a>00690       rhs = canonMultPowLeaf(e2,e1);
<a name="l00691"></a>00691       <span class="keywordflow">if</span>(withProof()) pf = newPf(cmmm,e,rhs);
<a name="l00692"></a>00692       <span class="keywordflow">return</span> newRWTheorem(e, rhs, Assumptions::emptyAssump(), pf);
<a name="l00693"></a>00693       <span class="keywordflow">break</span>;
<a name="l00694"></a>00694     <span class="keywordflow">case</span> <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024ad77e825b0133e40de2760344377ee1fa">MULT</a>:
<a name="l00695"></a>00695       rhs = canonMultLeafOrPowMult(e1,e2);;
<a name="l00696"></a>00696       <span class="keywordflow">if</span>(withProof()) pf = newPf(cmmm,e,rhs);
<a name="l00697"></a>00697       <span class="keywordflow">return</span> newRWTheorem(e, rhs, Assumptions::emptyAssump(), pf);
<a name="l00698"></a>00698       <span class="keywordflow">break</span>;
<a name="l00699"></a>00699     <span class="keywordflow">case</span> <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a9a12fbdcaa45ef17eaa1802161f9ca98">PLUS</a>:
<a name="l00700"></a>00700       rhs = canonMultLeafOrPowOrMultPlus(e1,e2);
<a name="l00701"></a>00701       <span class="keywordflow">if</span>(withProof()) pf = newPf(cmmm,e,rhs);
<a name="l00702"></a>00702       <span class="keywordflow">return</span> newRWTheorem(e, rhs, Assumptions::emptyAssump(), pf);
<a name="l00703"></a>00703       <span class="keywordflow">break</span>;
<a name="l00704"></a>00704     <span class="keywordflow">default</span>:
<a name="l00705"></a>00705       <span class="comment">// leaf * leaf</span>
<a name="l00706"></a>00706       rhs = canonMultLeafLeaf(e1,e2);
<a name="l00707"></a>00707       <span class="keywordflow">if</span>(withProof()) pf = newPf(cmmm,e,rhs);
<a name="l00708"></a>00708       <span class="keywordflow">return</span> newRWTheorem(e, rhs, Assumptions::emptyAssump(), pf);
<a name="l00709"></a>00709       <span class="keywordflow">break</span>;
<a name="l00710"></a>00710     }
<a name="l00711"></a>00711   }
<a name="l00712"></a>00712   <a class="code" href="debug_8h.html#a2637b2fffa22e3c9fad40cda8fcc3bce" title="If something goes horribly wrong, print a message and abort immediately with exit(1).">FatalAssert</a>(<span class="keyword">false</span>, <span class="stringliteral">&quot;Unreachable&quot;</span>);
<a name="l00713"></a>00713   <span class="keywordflow">return</span> newRWTheorem(e, rhs, Assumptions::emptyAssump(), pf);
<a name="l00714"></a>00714 }
<a name="l00715"></a>00715 
<a name="l00716"></a>00716 <span class="comment">// (PLUS expr1 expr2 ...) where each expr is itself in canonic form</span>
<a name="l00717"></a>00717 <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>
<a name="l00718"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#acbd2c2b8d5a0728aa00dcf55c7c646f2">00718</a> ArithTheoremProducer3::canonPlus(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; e)
<a name="l00719"></a>00719 {
<a name="l00720"></a>00720   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l00721"></a>00721 
<a name="l00722"></a>00722   <span class="keywordflow">if</span> (withProof()) {
<a name="l00723"></a>00723     pf = newPf(<span class="stringliteral">&quot;canon_plus&quot;</span>, e);
<a name="l00724"></a>00724   }
<a name="l00725"></a>00725   <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(e.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>() == <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a9a12fbdcaa45ef17eaa1802161f9ca98">PLUS</a>, <span class="stringliteral">&quot;&quot;</span>);
<a name="l00726"></a>00726 
<a name="l00727"></a>00727   <span class="comment">// First flatten the PLUS</span>
<a name="l00728"></a>00728 
<a name="l00729"></a>00729   std::vector&lt;Expr&gt; sumKids;
<a name="l00730"></a>00730   <a class="code" href="classCVC3_1_1Expr_1_1iterator.html">Expr::iterator</a> i = e.<a class="code" href="group__ExprPkg.html#gac890e13db184610276fc533fa4b4fe99" title="Begin iterator.">begin</a>();
<a name="l00731"></a>00731   <span class="keywordflow">for</span>(; i != e.<a class="code" href="group__ExprPkg.html#gaf6048a5030c8fa2511bf5dfee868e653" title="End iterator.">end</a>(); ++i) {
<a name="l00732"></a>00732     <span class="keywordflow">if</span> ((*i).getKind() != <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a9a12fbdcaa45ef17eaa1802161f9ca98">PLUS</a>) {
<a name="l00733"></a>00733       sumKids.push_back(*i);
<a name="l00734"></a>00734     }
<a name="l00735"></a>00735     <span class="keywordflow">else</span>
<a name="l00736"></a>00736       {
<a name="l00737"></a>00737         <a class="code" href="classCVC3_1_1Expr_1_1iterator.html">Expr::iterator</a> j = (*i).begin();
<a name="l00738"></a>00738         <span class="keywordflow">for</span>(; j != (*i).end(); ++j)
<a name="l00739"></a>00739           sumKids.push_back(*j);
<a name="l00740"></a>00740       }
<a name="l00741"></a>00741   }
<a name="l00742"></a>00742   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> val = canonCombineLikeTerms(sumKids);
<a name="l00743"></a>00743   <span class="keywordflow">if</span> (withProof()) {
<a name="l00744"></a>00744     pf = newPf(<span class="stringliteral">&quot;canon_plus&quot;</span>, e, val);
<a name="l00745"></a>00745   }
<a name="l00746"></a>00746   <span class="keywordflow">return</span> newRWTheorem(e, val, Assumptions::emptyAssump(), pf);
<a name="l00747"></a>00747 }
<a name="l00748"></a>00748 
<a name="l00749"></a>00749 <span class="comment">// (MULT expr1 expr2 ...) where each expr is itself in canonic form</span>
<a name="l00750"></a>00750 <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>
<a name="l00751"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a627a219305f83b200e36b28b1865729a">00751</a> ArithTheoremProducer3::canonMult(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; e)
<a name="l00752"></a>00752 {
<a name="l00753"></a>00753   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l00754"></a>00754   <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(e.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>() == <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024ad77e825b0133e40de2760344377ee1fa">MULT</a> &amp;&amp; e.<a class="code" href="group__ExprPkg.html#ga28b901d05e52a5c646f83a95cc74f94b">arity</a>() &gt; 1, <span class="stringliteral">&quot;&quot;</span>);
<a name="l00755"></a>00755   <a class="code" href="classCVC3_1_1Expr_1_1iterator.html">Expr::iterator</a> i = e.<a class="code" href="group__ExprPkg.html#gac890e13db184610276fc533fa4b4fe99" title="Begin iterator.">begin</a>();
<a name="l00756"></a>00756   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> result = *i;
<a name="l00757"></a>00757   ++i;
<a name="l00758"></a>00758   <span class="keywordflow">for</span> (; i != e.<a class="code" href="group__ExprPkg.html#gaf6048a5030c8fa2511bf5dfee868e653" title="End iterator.">end</a>(); ++i) {
<a name="l00759"></a>00759     result = canonMultMtermMterm(result * (*i)).getRHS();
<a name="l00760"></a>00760   }
<a name="l00761"></a>00761   <span class="keywordflow">if</span> (withProof()) {
<a name="l00762"></a>00762     pf = newPf(<span class="stringliteral">&quot;canon_mult&quot;</span>, e,result);
<a name="l00763"></a>00763   }
<a name="l00764"></a>00764   <span class="keywordflow">return</span> newRWTheorem(e, result, Assumptions::emptyAssump(), pf);
<a name="l00765"></a>00765 }
<a name="l00766"></a>00766 
<a name="l00767"></a>00767 
<a name="l00768"></a>00768 <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>
<a name="l00769"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#addd3884d42a6e4637e9bda79d4af6574">00769</a> ArithTheoremProducer3::canonInvertConst(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; e)
<a name="l00770"></a>00770 {
<a name="l00771"></a>00771   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>)
<a name="l00772"></a>00772     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#ac0334a083d6782caa17ca0d337fddddf">isRational</a>(e), <span class="stringliteral">&quot;expecting a rational: e = &quot;</span>+e.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l00773"></a>00773 
<a name="l00774"></a>00774   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l00775"></a>00775 
<a name="l00776"></a>00776   <span class="keywordflow">if</span> (withProof()) {
<a name="l00777"></a>00777     pf = newPf(<span class="stringliteral">&quot;canon_invert_const&quot;</span>, e);
<a name="l00778"></a>00778   }
<a name="l00779"></a>00779   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Rational.html">Rational</a>&amp; er = e.<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>();
<a name="l00780"></a>00780   <span class="keywordflow">return</span> newRWTheorem((rat(1)/e), rat(er==0? 0 : (1/er)), Assumptions::emptyAssump(), pf);
<a name="l00781"></a>00781 }
<a name="l00782"></a>00782 
<a name="l00783"></a>00783 
<a name="l00784"></a>00784 <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>
<a name="l00785"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a84b1ec96629fa2ae52792a582ba7a63a">00785</a> ArithTheoremProducer3::canonInvertLeaf(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; e)
<a name="l00786"></a>00786 {
<a name="l00787"></a>00787   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l00788"></a>00788 
<a name="l00789"></a>00789   <span class="keywordflow">if</span> (withProof()) {
<a name="l00790"></a>00790     pf = newPf(<span class="stringliteral">&quot;canon_invert_leaf&quot;</span>, e);
<a name="l00791"></a>00791   }
<a name="l00792"></a>00792   <span class="keywordflow">return</span> newRWTheorem((rat(1)/e), <a class="code" href="namespaceCVC3.html#aa123bf4eb1751181baf16c5e80b47740" title="Power (x^n, or base^{pow}) expressions.">powExpr</a>(rat(-1), e), Assumptions::emptyAssump(), pf);
<a name="l00793"></a>00793 }
<a name="l00794"></a>00794 
<a name="l00795"></a>00795 
<a name="l00796"></a>00796 <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>
<a name="l00797"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a02b89064723281b69105ce11ecaf80c7">00797</a> ArithTheoremProducer3::canonInvertPow(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; e)
<a name="l00798"></a>00798 {
<a name="l00799"></a>00799   <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(e.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>() == <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a880283f7bbc366efe54c9ea074c9f5e5">POW</a>, <span class="stringliteral">&quot;expecting a rational&quot;</span>+e[0].<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l00800"></a>00800 
<a name="l00801"></a>00801   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l00802"></a>00802 
<a name="l00803"></a>00803   <span class="keywordflow">if</span> (withProof()) {
<a name="l00804"></a>00804     pf = newPf(<span class="stringliteral">&quot;canon_invert_pow&quot;</span>, e);
<a name="l00805"></a>00805   }
<a name="l00806"></a>00806   <span class="keywordflow">if</span> (e[0].getRational() == -1)
<a name="l00807"></a>00807     <span class="keywordflow">return</span> newRWTheorem((rat(1)/e), e[1], Assumptions::emptyAssump(), pf);
<a name="l00808"></a>00808   <span class="keywordflow">else</span>
<a name="l00809"></a>00809     <span class="keywordflow">return</span> newRWTheorem((rat(1)/e),
<a name="l00810"></a>00810                         <a class="code" href="namespaceCVC3.html#aa123bf4eb1751181baf16c5e80b47740" title="Power (x^n, or base^{pow}) expressions.">powExpr</a>(rat(-e[0].getRational()), e),
<a name="l00811"></a>00811                         Assumptions::emptyAssump(),
<a name="l00812"></a>00812                         pf);
<a name="l00813"></a>00813 }
<a name="l00814"></a>00814 
<a name="l00815"></a>00815 <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>
<a name="l00816"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a94090722e5ab797e97cdb14458c40742">00816</a> ArithTheoremProducer3::canonInvertMult(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; e)
<a name="l00817"></a>00817 {
<a name="l00818"></a>00818   <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(e.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>() == <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024ad77e825b0133e40de2760344377ee1fa">MULT</a>, <span class="stringliteral">&quot;expecting a rational&quot;</span>+e[0].<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l00819"></a>00819 
<a name="l00820"></a>00820   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l00821"></a>00821 
<a name="l00822"></a>00822   <span class="keywordflow">if</span> (withProof()) {
<a name="l00823"></a>00823     pf = newPf(<span class="stringliteral">&quot;canon_invert_mult&quot;</span>, e);
<a name="l00824"></a>00824   }
<a name="l00825"></a>00825 
<a name="l00826"></a>00826   <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(e.<a class="code" href="group__ExprPkg.html#ga28b901d05e52a5c646f83a95cc74f94b">arity</a>() &gt; 1, <span class="stringliteral">&quot;MULT should have arity &gt; 1&quot;</span>+e.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l00827"></a>00827   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> result = canonInvert(e[0]).getRHS();
<a name="l00828"></a>00828   <span class="keywordflow">for</span> (<span class="keywordtype">int</span> i = 1; i &lt; e.<a class="code" href="group__ExprPkg.html#ga28b901d05e52a5c646f83a95cc74f94b">arity</a>(); ++i) {
<a name="l00829"></a>00829     result =
<a name="l00830"></a>00830       canonMultMtermMterm(result * canonInvert(e[i]).getRHS()).getRHS();
<a name="l00831"></a>00831   }
<a name="l00832"></a>00832   <span class="keywordflow">return</span> newRWTheorem((rat(1)/e), result, Assumptions::emptyAssump(), pf);
<a name="l00833"></a>00833 }
<a name="l00834"></a>00834 
<a name="l00835"></a>00835 
<a name="l00836"></a>00836 <span class="comment">// Given an expression e in Canonic form generate 1/e in canonic form</span>
<a name="l00837"></a>00837 <span class="comment">// This function assumes that e is not a PLUS expression</span>
<a name="l00838"></a>00838 <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>
<a name="l00839"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a1a4b78b01763b1ca5a80c0211bc3ba4b">00839</a> ArithTheoremProducer3::canonInvert(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; e)
<a name="l00840"></a>00840 {
<a name="l00841"></a>00841   <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(e.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>() != <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a9a12fbdcaa45ef17eaa1802161f9ca98">PLUS</a>,
<a name="l00842"></a>00842               <span class="stringliteral">&quot;Cannot do inverse on a PLUS&quot;</span>+e.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l00843"></a>00843   <span class="keywordflow">switch</span> (e.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>()) {
<a name="l00844"></a>00844   <span class="keywordflow">case</span> <a class="code" href="kinds_8h.html#aa10c9e8951b8ccf714a59ec321bdac5bae07a708ec52c578b62f8b0f701571d56">RATIONAL_EXPR</a>:
<a name="l00845"></a>00845     <span class="keywordflow">return</span> canonInvertConst(e);
<a name="l00846"></a>00846     <span class="keywordflow">break</span>;
<a name="l00847"></a>00847   <span class="keywordflow">case</span> <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a880283f7bbc366efe54c9ea074c9f5e5">POW</a>:
<a name="l00848"></a>00848     <span class="keywordflow">return</span> canonInvertPow(e);
<a name="l00849"></a>00849     <span class="keywordflow">break</span>;
<a name="l00850"></a>00850   <span class="keywordflow">case</span> <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024ad77e825b0133e40de2760344377ee1fa">MULT</a>:
<a name="l00851"></a>00851     <span class="keywordflow">return</span> canonInvertMult(e);
<a name="l00852"></a>00852     <span class="keywordflow">break</span>;
<a name="l00853"></a>00853   <span class="keywordflow">default</span>:
<a name="l00854"></a>00854     <span class="comment">// leaf</span>
<a name="l00855"></a>00855     <span class="keywordflow">return</span> canonInvertLeaf(e);
<a name="l00856"></a>00856     <span class="keywordflow">break</span>;
<a name="l00857"></a>00857   }
<a name="l00858"></a>00858 }
<a name="l00859"></a>00859 
<a name="l00860"></a>00860 
<a name="l00861"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#aad289f36b55fe8be7f7af0f62aedaae8">00861</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::moveSumConstantRight(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; e) {
<a name="l00862"></a>00862 
<a name="l00863"></a>00863   <span class="comment">// Check soundness of the rule if necessary</span>
<a name="l00864"></a>00864   <span class="keywordflow">if</span> (<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l00865"></a>00865     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#abbae617aaff89a9e5deb84ab649e14a0">isIneq</a>(e) || e.<a class="code" href="group__ExprPkg.html#gac4af2026c180da0f18d66ac616f61f3a">isEq</a>(), <span class="stringliteral">&quot;moveSumConstantRight: input must be Eq or Ineq: &quot;</span> + e.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l00866"></a>00866     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#ac0334a083d6782caa17ca0d337fddddf">isRational</a>(e[0]) || <a class="code" href="namespaceCVC3.html#afb0f7d15ddbd87f9abb128108101f557">isPlus</a>(e[0]), <span class="stringliteral">&quot;moveSumConstantRight: left side must be a canonised sum: &quot;</span> + e.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l00867"></a>00867     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#ac0334a083d6782caa17ca0d337fddddf">isRational</a>(e[1]) &amp;&amp; e[1].getRational() == 0, <span class="stringliteral">&quot;moveSumConstantRight: right side must be 0: &quot;</span> + e.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l00868"></a>00868   }
<a name="l00869"></a>00869 
<a name="l00870"></a>00870   <span class="comment">// The rational constant of the sum</span>
<a name="l00871"></a>00871   <a class="code" href="classCVC3_1_1Rational.html">Rational</a> r = 0;
<a name="l00872"></a>00872 
<a name="l00873"></a>00873   <span class="comment">// The right hand side of the expression</span>
<a name="l00874"></a>00874   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> <a class="code" href="namespaceMiniSat.html#a82558b7a36c52f5d3211d5d14bed99d4">right</a> = e[0];
<a name="l00875"></a>00875 
<a name="l00876"></a>00876   <span class="comment">// The vector of sum terms</span>
<a name="l00877"></a>00877   vector&lt;Expr&gt; sumTerms;
<a name="l00878"></a>00878 
<a name="l00879"></a>00879   <span class="comment">// Get all the non rational children and</span>
<a name="l00880"></a>00880   <span class="keywordflow">if</span> (!right.<a class="code" href="group__ExprPkg.html#gac5ced6adc7a60945ea6707ef494aa28f">isRational</a>())
<a name="l00881"></a>00881     <span class="keywordflow">for</span>(<a class="code" href="classCVC3_1_1Expr_1_1iterator.html">Expr::iterator</a> it = right.<a class="code" href="group__ExprPkg.html#gac890e13db184610276fc533fa4b4fe99" title="Begin iterator.">begin</a>(); it != right.<a class="code" href="group__ExprPkg.html#gaf6048a5030c8fa2511bf5dfee868e653" title="End iterator.">end</a>(); it ++) {
<a name="l00882"></a>00882       <span class="comment">// If the term is rational then add the rational number to r</span>
<a name="l00883"></a>00883       <span class="keywordflow">if</span> ((*it).isRational()) r = r + (*it).getRational();
<a name="l00884"></a>00884       <span class="comment">// Otherwise just add the sumTerm to the sumTerms</span>
<a name="l00885"></a>00885       <span class="keywordflow">else</span> sumTerms.push_back((*it));
<a name="l00886"></a>00886     }
<a name="l00887"></a>00887 
<a name="l00888"></a>00888   <span class="comment">// Setup the new expression</span>
<a name="l00889"></a>00889   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> transformed;
<a name="l00890"></a>00890   <span class="keywordflow">if</span> (sumTerms.size() &gt; 1)
<a name="l00891"></a>00891     <span class="comment">// If the number of summands is &gt; 1 return the sum of them</span>
<a name="l00892"></a>00892     transformed = <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>(e.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>(), <a class="code" href="namespaceCVC3.html#accd3d7d38b0e04136afbc3e5191bc8bb">plusExpr</a>(sumTerms), rat(-r));
<a name="l00893"></a>00893   <span class="keywordflow">else</span>
<a name="l00894"></a>00894     <span class="comment">// Otherwise return the one summand as itself</span>
<a name="l00895"></a>00895     transformed = <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>(e.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>(), sumTerms[0], rat(-r));
<a name="l00896"></a>00896 
<a name="l00897"></a>00897 
<a name="l00898"></a>00898   <span class="comment">// If proof is needed set it up</span>
<a name="l00899"></a>00899   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l00900"></a>00900   <span class="keywordflow">if</span> (withProof()) pf = newPf(<span class="stringliteral">&quot;arithm_sum_constant_right&quot;</span>, e);
<a name="l00901"></a>00901 
<a name="l00902"></a>00902   <span class="comment">// Retrun the theorem explaining the transformation</span>
<a name="l00903"></a>00903   <span class="keywordflow">return</span> newRWTheorem(e, transformed, Assumptions::emptyAssump(), pf);
<a name="l00904"></a>00904 }
<a name="l00905"></a>00905 
<a name="l00906"></a>00906 <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>
<a name="l00907"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#acfe4060947cb28e9fc9c4ea859df565c">00907</a> ArithTheoremProducer3::canonDivide(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; e)
<a name="l00908"></a>00908 {
<a name="l00909"></a>00909   <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(e.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>() == <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024ac3c38ad296d5671b7fde3373fdd87ea1">DIVIDE</a>, <span class="stringliteral">&quot;Expecting Divide&quot;</span>+e.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l00910"></a>00910   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l00911"></a>00911 
<a name="l00912"></a>00912   <span class="keywordflow">if</span> (withProof()) {
<a name="l00913"></a>00913     pf = newPf(<span class="stringliteral">&quot;canon_invert_divide&quot;</span>, e);
<a name="l00914"></a>00914   }
<a name="l00915"></a>00915 
<a name="l00916"></a>00916   <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> thm = newRWTheorem(e, e[0]*(canonInvert(e[1]).getRHS()), Assumptions::emptyAssump(), pf);
<a name="l00917"></a>00917 
<a name="l00918"></a>00918   <span class="keywordflow">return</span> d_theoryArith-&gt;transitivityRule(thm, canonMult(thm.<a class="code" href="classCVC3_1_1Theorem.html#a97d957fcbf9094480851b1d2e5d3729f">getRHS</a>()));
<a name="l00919"></a>00919 }
<a name="l00920"></a>00920 
<a name="l00921"></a>00921 
<a name="l00922"></a>00922 <span class="comment">// Rules for multiplication</span>
<a name="l00923"></a>00923 <span class="comment">// t*c ==&gt; c*t, takes constant c and term t</span>
<a name="l00924"></a>00924 <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>
<a name="l00925"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a401fca0c453a94c8c0053eb77e014af0">00925</a> ArithTheoremProducer3::canonMultTermConst(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; c, <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; t) {
<a name="l00926"></a>00926   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l00927"></a>00927   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l00928"></a>00928     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#ac0334a083d6782caa17ca0d337fddddf">isRational</a>(c),
<a name="l00929"></a>00929                 <a class="code" href="arith__theorem__producer3_8cpp.html#a79f2713d570c7065f61a160134ea765b">CLASS_NAME</a> <span class="stringliteral">&quot;::canonMultTermConst:\n  &quot;</span>
<a name="l00930"></a>00930                 <span class="stringliteral">&quot;c is not a constant: &quot;</span> + c.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l00931"></a>00931   }
<a name="l00932"></a>00932   <span class="keywordflow">if</span>(withProof()) pf = newPf(<span class="stringliteral">&quot;canon_mult_term_const&quot;</span>, c, t);
<a name="l00933"></a>00933   <span class="keywordflow">return</span> newRWTheorem((t*c), (c*t), Assumptions::emptyAssump(), pf);
<a name="l00934"></a>00934 }
<a name="l00935"></a>00935 
<a name="l00936"></a>00936 <span class="comment">// Rules for multiplication</span>
<a name="l00937"></a>00937 <span class="comment">// t1*t2 ==&gt; Error, takes t1 and t2 where both are non-constants</span>
<a name="l00938"></a>00938 <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>
<a name="l00939"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a294916be1e9ac30e3c824b0b8e4ff093">00939</a> ArithTheoremProducer3::canonMultTerm1Term2(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; t1, <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; t2) {
<a name="l00940"></a>00940   <span class="comment">// Proof pf;</span>
<a name="l00941"></a>00941   <span class="comment">// if(withProof()) pf = newPf(&quot;canon_mult_term1_term2&quot;, t1, t2);</span>
<a name="l00942"></a>00942   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l00943"></a>00943     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<span class="keyword">false</span>, <span class="stringliteral">&quot;Fatal Error: We don&#39;t support multiplication&quot;</span>
<a name="l00944"></a>00944                 <span class="stringliteral">&quot;of two non constant terms at this time &quot;</span>
<a name="l00945"></a>00945                 + t1.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>() + <span class="stringliteral">&quot; and &quot;</span> + t2.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l00946"></a>00946   }
<a name="l00947"></a>00947   <span class="keywordflow">return</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>();
<a name="l00948"></a>00948 }
<a name="l00949"></a>00949 
<a name="l00950"></a>00950 <span class="comment">// Rules for multiplication</span>
<a name="l00951"></a>00951 <span class="comment">// 0*x = 0, takes x</span>
<a name="l00952"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a55fb07d5df2b4068bf5df327ae0d89d4">00952</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::canonMultZero(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; e) {
<a name="l00953"></a>00953   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l00954"></a>00954   <span class="keywordflow">if</span>(withProof()) pf = newPf(<span class="stringliteral">&quot;canon_mult_zero&quot;</span>, e);
<a name="l00955"></a>00955   <span class="keywordflow">return</span> newRWTheorem((rat(0)*e), rat(0), Assumptions::emptyAssump(), pf);
<a name="l00956"></a>00956 }
<a name="l00957"></a>00957 
<a name="l00958"></a>00958 <span class="comment">// Rules for multiplication</span>
<a name="l00959"></a>00959 <span class="comment">// 1*x ==&gt; x, takes x</span>
<a name="l00960"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#aed0a2d1337910f3027ac867e0f18b8de">00960</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::canonMultOne(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; e) {
<a name="l00961"></a>00961   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l00962"></a>00962   <span class="keywordflow">if</span>(withProof()) pf = newPf(<span class="stringliteral">&quot;canon_mult_one&quot;</span>, e);
<a name="l00963"></a>00963   <span class="keywordflow">return</span> newRWTheorem((rat(1)*e), e, Assumptions::emptyAssump(), pf);
<a name="l00964"></a>00964 }
<a name="l00965"></a>00965 
<a name="l00966"></a>00966 <span class="comment">// Rules for multiplication</span>
<a name="l00967"></a>00967 <span class="comment">// c1*c2 ==&gt; c&#39;, takes constant c1*c2</span>
<a name="l00968"></a>00968 <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>
<a name="l00969"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a4ea3884dff8c1606fd05e61eb78e379d">00969</a> ArithTheoremProducer3::canonMultConstConst(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; c1, <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; c2) {
<a name="l00970"></a>00970   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l00971"></a>00971   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l00972"></a>00972     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#ac0334a083d6782caa17ca0d337fddddf">isRational</a>(c1),
<a name="l00973"></a>00973                 <a class="code" href="arith__theorem__producer3_8cpp.html#a79f2713d570c7065f61a160134ea765b">CLASS_NAME</a> <span class="stringliteral">&quot;::canonMultConstConst:\n  &quot;</span>
<a name="l00974"></a>00974                 <span class="stringliteral">&quot;c1 is not a constant: &quot;</span> + c1.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l00975"></a>00975     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#ac0334a083d6782caa17ca0d337fddddf">isRational</a>(c2),
<a name="l00976"></a>00976                 <a class="code" href="arith__theorem__producer3_8cpp.html#a79f2713d570c7065f61a160134ea765b">CLASS_NAME</a> <span class="stringliteral">&quot;::canonMultConstConst:\n  &quot;</span>
<a name="l00977"></a>00977                 <span class="stringliteral">&quot;c2 is not a constant: &quot;</span> + c2.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l00978"></a>00978   }
<a name="l00979"></a>00979   <span class="keywordflow">if</span>(withProof()) pf = newPf(<span class="stringliteral">&quot;canon_mult_const_const&quot;</span>, c1, c2);
<a name="l00980"></a>00980   <span class="keywordflow">return</span>
<a name="l00981"></a>00981     newRWTheorem((c1*c2), rat(c1.<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>()*c2.getRational()), Assumptions::emptyAssump(), pf);
<a name="l00982"></a>00982 }
<a name="l00983"></a>00983 
<a name="l00984"></a>00984 <span class="comment">// Rules for multiplication</span>
<a name="l00985"></a>00985 <span class="comment">// c1*(c2*t) ==&gt; c&#39;*t, takes c1 and c2 and t</span>
<a name="l00986"></a>00986 <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>
<a name="l00987"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a9e5b7c75f1f662071942150df1a4d69e">00987</a> ArithTheoremProducer3::canonMultConstTerm(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; c1,
<a name="l00988"></a>00988                                          <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; c2,<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; t) {
<a name="l00989"></a>00989   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l00990"></a>00990   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l00991"></a>00991     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#ac0334a083d6782caa17ca0d337fddddf">isRational</a>(c1),
<a name="l00992"></a>00992                 <a class="code" href="arith__theorem__producer3_8cpp.html#a79f2713d570c7065f61a160134ea765b">CLASS_NAME</a> <span class="stringliteral">&quot;::canonMultConstTerm:\n  &quot;</span>
<a name="l00993"></a>00993                 <span class="stringliteral">&quot;c1 is not a constant: &quot;</span> + c1.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l00994"></a>00994     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#ac0334a083d6782caa17ca0d337fddddf">isRational</a>(c2),
<a name="l00995"></a>00995                 <a class="code" href="arith__theorem__producer3_8cpp.html#a79f2713d570c7065f61a160134ea765b">CLASS_NAME</a> <span class="stringliteral">&quot;::canonMultConstTerm:\n  &quot;</span>
<a name="l00996"></a>00996                 <span class="stringliteral">&quot;c2 is not a constant: &quot;</span> + c2.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l00997"></a>00997   }
<a name="l00998"></a>00998 
<a name="l00999"></a>00999   <span class="keywordflow">if</span>(withProof()) pf = newPf(<span class="stringliteral">&quot;canon_mult_const_term&quot;</span>, c1, c2, t);
<a name="l01000"></a>01000   <span class="keywordflow">return</span>
<a name="l01001"></a>01001     newRWTheorem(c1*(c2*t), rat(c1.<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>()*c2.<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>())*t, Assumptions::emptyAssump(), pf);
<a name="l01002"></a>01002 }
<a name="l01003"></a>01003 
<a name="l01004"></a>01004 <span class="comment">// Rules for multiplication</span>
<a name="l01005"></a>01005 <span class="comment">// c1*(+ c2 v1 ...) ==&gt; (+ c1c2 c1v1 ...), takes c1 and the sum</span>
<a name="l01006"></a>01006 <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>
<a name="l01007"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a2765c1485aac81cc42ed3186f7a1f244">01007</a> ArithTheoremProducer3::canonMultConstSum(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; c1, <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; sum) {
<a name="l01008"></a>01008   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l01009"></a>01009   std::vector&lt;Expr&gt; sumKids;
<a name="l01010"></a>01010 
<a name="l01011"></a>01011   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l01012"></a>01012     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#ac0334a083d6782caa17ca0d337fddddf">isRational</a>(c1),
<a name="l01013"></a>01013                 <a class="code" href="arith__theorem__producer3_8cpp.html#a79f2713d570c7065f61a160134ea765b">CLASS_NAME</a> <span class="stringliteral">&quot;::canonMultConstTerm:\n  &quot;</span>
<a name="l01014"></a>01014                 <span class="stringliteral">&quot;c1 is not a constant: &quot;</span> + c1.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l01015"></a>01015     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a9a12fbdcaa45ef17eaa1802161f9ca98">PLUS</a> == sum.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>(),
<a name="l01016"></a>01016                 <a class="code" href="arith__theorem__producer3_8cpp.html#a79f2713d570c7065f61a160134ea765b">CLASS_NAME</a> <span class="stringliteral">&quot;::canonMultConstTerm:\n  &quot;</span>
<a name="l01017"></a>01017                 <span class="stringliteral">&quot;the kind must be a PLUS: &quot;</span> + sum.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l01018"></a>01018   }
<a name="l01019"></a>01019   <a class="code" href="classCVC3_1_1Expr_1_1iterator.html">Expr::iterator</a> i = sum.<a class="code" href="group__ExprPkg.html#gac890e13db184610276fc533fa4b4fe99" title="Begin iterator.">begin</a>();
<a name="l01020"></a>01020   <span class="keywordflow">for</span>(; i != sum.<a class="code" href="group__ExprPkg.html#gaf6048a5030c8fa2511bf5dfee868e653" title="End iterator.">end</a>(); ++i)
<a name="l01021"></a>01021     sumKids.push_back(c1*(*i));
<a name="l01022"></a>01022   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> ret = <a class="code" href="namespaceCVC3.html#accd3d7d38b0e04136afbc3e5191bc8bb">plusExpr</a>(sumKids);
<a name="l01023"></a>01023   <span class="keywordflow">if</span>(withProof()) pf = newPf(<span class="stringliteral">&quot;canon_mult_const_sum&quot;</span>, c1, sum, ret);
<a name="l01024"></a>01024   <span class="keywordflow">return</span> newRWTheorem((c1*sum),ret , Assumptions::emptyAssump(), pf);
<a name="l01025"></a>01025 }
<a name="l01026"></a>01026 
<a name="l01027"></a>01027 
<a name="l01028"></a>01028 <span class="comment">// c^n = c&#39; (compute the constant power expression)</span>
<a name="l01029"></a>01029 <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>
<a name="l01030"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a5347a8208d4d7aa05fad463bd6da8c41">01030</a> ArithTheoremProducer3::canonPowConst(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; e) {
<a name="l01031"></a>01031   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l01032"></a>01032     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(e.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>() == <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a880283f7bbc366efe54c9ea074c9f5e5">POW</a> &amp;&amp; e.<a class="code" href="group__ExprPkg.html#ga28b901d05e52a5c646f83a95cc74f94b">arity</a>() == 2
<a name="l01033"></a>01033     &amp;&amp; e[0].<a class="code" href="group__ExprPkg.html#gac5ced6adc7a60945ea6707ef494aa28f">isRational</a>() &amp;&amp; e[1].<a class="code" href="group__ExprPkg.html#gac5ced6adc7a60945ea6707ef494aa28f">isRational</a>(),
<a name="l01034"></a>01034     <span class="stringliteral">&quot;ArithTheoremProducer3::canonPowConst(&quot;</span>+e.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>()+<span class="stringliteral">&quot;)&quot;</span>);
<a name="l01035"></a>01035   }
<a name="l01036"></a>01036   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Rational.html">Rational</a>&amp; p = e[0].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>();
<a name="l01037"></a>01037   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Rational.html">Rational</a>&amp; base = e[1].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>();
<a name="l01038"></a>01038   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l01039"></a>01039     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(p.<a class="code" href="classCVC3_1_1Rational.html#a1366320f4de558bb964c67f8aecedb36">isInteger</a>(),
<a name="l01040"></a>01040     <span class="stringliteral">&quot;ArithTheoremProducer3::canonPowConst(&quot;</span>+e.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>()+<span class="stringliteral">&quot;)&quot;</span>);
<a name="l01041"></a>01041   }
<a name="l01042"></a>01042   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> res;
<a name="l01043"></a>01043   <span class="keywordflow">if</span> (base == 0 &amp;&amp; p &lt; 0) {
<a name="l01044"></a>01044     res = rat(0);
<a name="l01045"></a>01045   }
<a name="l01046"></a>01046   <span class="keywordflow">else</span> res = rat(<a class="code" href="namespaceCVC3.html#a28fc84bed3f9bc91ca9967de0f9cfa00" title="Raise &#39;base&#39; into the power of &#39;pow&#39; (pow must be an integer)">pow</a>(p, base));
<a name="l01047"></a>01047   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l01048"></a>01048   <span class="keywordflow">if</span>(withProof())
<a name="l01049"></a>01049     pf = newPf(<span class="stringliteral">&quot;canon_pow_const&quot;</span>, e);
<a name="l01050"></a>01050   <span class="keywordflow">return</span> newRWTheorem(e, res, Assumptions::emptyAssump(), pf);
<a name="l01051"></a>01051 }
<a name="l01052"></a>01052 
<a name="l01053"></a>01053 
<a name="l01054"></a>01054 <span class="comment">// Rules for addition</span>
<a name="l01055"></a>01055 <span class="comment">// flattens the input. accepts a PLUS expr</span>
<a name="l01056"></a>01056 <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>
<a name="l01057"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a5ec4889e730c0b1d4fb584d16af08a9d">01057</a> ArithTheoremProducer3::canonFlattenSum(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; e) {
<a name="l01058"></a>01058   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l01059"></a>01059   std::vector&lt;Expr&gt; sumKids;
<a name="l01060"></a>01060   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l01061"></a>01061     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a9a12fbdcaa45ef17eaa1802161f9ca98">PLUS</a> == e.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>(),
<a name="l01062"></a>01062                 <a class="code" href="arith__theorem__producer3_8cpp.html#a79f2713d570c7065f61a160134ea765b">CLASS_NAME</a> <span class="stringliteral">&quot;::canonFlattenSum:\n&quot;</span>
<a name="l01063"></a>01063                 <span class="stringliteral">&quot;input must be a PLUS:&quot;</span> + e.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l01064"></a>01064   }
<a name="l01065"></a>01065 
<a name="l01066"></a>01066   <a class="code" href="classCVC3_1_1Expr_1_1iterator.html">Expr::iterator</a> i = e.<a class="code" href="group__ExprPkg.html#gac890e13db184610276fc533fa4b4fe99" title="Begin iterator.">begin</a>();
<a name="l01067"></a>01067   <span class="keywordflow">for</span>(; i != e.<a class="code" href="group__ExprPkg.html#gaf6048a5030c8fa2511bf5dfee868e653" title="End iterator.">end</a>(); ++i){
<a name="l01068"></a>01068     <span class="keywordflow">if</span> (<a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a9a12fbdcaa45ef17eaa1802161f9ca98">PLUS</a> != (*i).getKind())
<a name="l01069"></a>01069       sumKids.push_back(*i);
<a name="l01070"></a>01070     <span class="keywordflow">else</span> {
<a name="l01071"></a>01071       <a class="code" href="classCVC3_1_1Expr_1_1iterator.html">Expr::iterator</a> j = (*i).begin();
<a name="l01072"></a>01072       <span class="keywordflow">for</span>(; j != (*i).end(); ++j)
<a name="l01073"></a>01073         sumKids.push_back(*j);
<a name="l01074"></a>01074     }
<a name="l01075"></a>01075   }
<a name="l01076"></a>01076   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> ret =  <a class="code" href="namespaceCVC3.html#accd3d7d38b0e04136afbc3e5191bc8bb">plusExpr</a>(sumKids);
<a name="l01077"></a>01077   <span class="keywordflow">if</span>(withProof()) pf = newPf(<span class="stringliteral">&quot;canon_flatten_sum&quot;</span>, e,ret);
<a name="l01078"></a>01078   <span class="keywordflow">return</span> newRWTheorem(e,ret, Assumptions::emptyAssump(), pf);
<a name="l01079"></a>01079 }
<a name="l01080"></a>01080 
<a name="l01081"></a>01081 <span class="comment">// Rules for addition</span>
<a name="l01082"></a>01082 <span class="comment">// combine like terms. accepts a flattened PLUS expr</span>
<a name="l01083"></a>01083 <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>
<a name="l01084"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a245f64776d0b1fbd14d18bb145f717e4">01084</a> ArithTheoremProducer3::canonComboLikeTerms(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; e) {
<a name="l01085"></a>01085   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l01086"></a>01086   std::vector&lt;Expr&gt; sumKids;
<a name="l01087"></a>01087   <a class="code" href="classCVC3_1_1ExprMap.html">ExprMap&lt;Rational&gt;</a> sumHashMap;
<a name="l01088"></a>01088   <a class="code" href="classCVC3_1_1Rational.html">Rational</a> constant = 0;
<a name="l01089"></a>01089 
<a name="l01090"></a>01090   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l01091"></a>01091     <a class="code" href="classCVC3_1_1Expr_1_1iterator.html">Expr::iterator</a> k = e.<a class="code" href="group__ExprPkg.html#gac890e13db184610276fc533fa4b4fe99" title="Begin iterator.">begin</a>();
<a name="l01092"></a>01092     <span class="keywordflow">for</span>(; k != e.<a class="code" href="group__ExprPkg.html#gaf6048a5030c8fa2511bf5dfee868e653" title="End iterator.">end</a>(); ++k)
<a name="l01093"></a>01093       <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(!<a class="code" href="namespaceCVC3.html#afb0f7d15ddbd87f9abb128108101f557">isPlus</a>(*k),
<a name="l01094"></a>01094                   <a class="code" href="arith__theorem__producer3_8cpp.html#a79f2713d570c7065f61a160134ea765b">CLASS_NAME</a> <span class="stringliteral">&quot;::canonComboLikeTerms:\n&quot;</span>
<a name="l01095"></a>01095                   <span class="stringliteral">&quot;input must be a flattened PLUS:&quot;</span> + k-&gt;toString());
<a name="l01096"></a>01096   }
<a name="l01097"></a>01097   <a class="code" href="classCVC3_1_1Expr_1_1iterator.html">Expr::iterator</a> i = e.<a class="code" href="group__ExprPkg.html#gac890e13db184610276fc533fa4b4fe99" title="Begin iterator.">begin</a>();
<a name="l01098"></a>01098   <span class="keywordflow">for</span>(; i != e.<a class="code" href="group__ExprPkg.html#gaf6048a5030c8fa2511bf5dfee868e653" title="End iterator.">end</a>(); ++i){
<a name="l01099"></a>01099     <span class="keywordflow">if</span>(i-&gt;isRational())
<a name="l01100"></a>01100       constant = constant + i-&gt;getRational();
<a name="l01101"></a>01101     <span class="keywordflow">else</span> {
<a name="l01102"></a>01102       <span class="keywordflow">if</span> (!<a class="code" href="namespaceCVC3.html#a28ae8672047db708e99602ebaca89777">isMult</a>(*i)) {
<a name="l01103"></a>01103         <span class="keywordflow">if</span>(0 == sumHashMap.<a class="code" href="classCVC3_1_1ExprMap.html#aa96dfa3a54a131cdb0964ef4b80e324f">count</a>((*i)))
<a name="l01104"></a>01104           sumHashMap[*i] = 1;
<a name="l01105"></a>01105         <span class="keywordflow">else</span>
<a name="l01106"></a>01106           sumHashMap[*i] += 1;
<a name="l01107"></a>01107       }
<a name="l01108"></a>01108       <span class="keywordflow">else</span> {
<a name="l01109"></a>01109         <span class="keywordflow">if</span>(0 == sumHashMap.<a class="code" href="classCVC3_1_1ExprMap.html#aa96dfa3a54a131cdb0964ef4b80e324f">count</a>((*i)[1]))
<a name="l01110"></a>01110           sumHashMap[(*i)[1]] = (*i)[0].getRational();
<a name="l01111"></a>01111         <span class="keywordflow">else</span>
<a name="l01112"></a>01112           sumHashMap[(*i)[1]] = sumHashMap[(*i)[1]] + (*i)[0].getRational();
<a name="l01113"></a>01113       }
<a name="l01114"></a>01114     }
<a name="l01115"></a>01115   }
<a name="l01116"></a>01116 
<a name="l01117"></a>01117   sumKids.push_back(rat(constant));
<a name="l01118"></a>01118   <a class="code" href="classCVC3_1_1ExprMap.html">ExprMap&lt;Rational&gt;::iterator</a> j = sumHashMap.<a class="code" href="classCVC3_1_1ExprMap.html#a3db85401f8535daf4054fde531cd46b1">begin</a>();
<a name="l01119"></a>01119   <span class="keywordflow">for</span>(; j != sumHashMap.<a class="code" href="classCVC3_1_1ExprMap.html#a283ae6c44308cbdda0d82da5a16e52c8">end</a>(); ++j) {
<a name="l01120"></a>01120     <span class="keywordflow">if</span>(0 == (*j).second)
<a name="l01121"></a>01121       ;<span class="comment">//do nothing</span>
<a name="l01122"></a>01122     <span class="keywordflow">else</span> <span class="keywordflow">if</span> (1 == (*j).second)
<a name="l01123"></a>01123       sumKids.push_back((*j).first);
<a name="l01124"></a>01124     <span class="keywordflow">else</span>
<a name="l01125"></a>01125       sumKids.push_back(rat((*j).second) * (*j).first);
<a name="l01126"></a>01126   }
<a name="l01127"></a>01127 
<a name="l01128"></a>01128   <span class="comment">//constant is same as sumKids[0].</span>
<a name="l01129"></a>01129   <span class="comment">//corner cases: &quot;0 + monomial&quot; and &quot;constant&quot;(no monomials)</span>
<a name="l01130"></a>01130 
<a name="l01131"></a>01131   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> ret;
<a name="l01132"></a>01132   <span class="keywordflow">if</span>(2 == sumKids.size() &amp;&amp; 0 == constant) ret = sumKids[1];
<a name="l01133"></a>01133   <span class="keywordflow">else</span> <span class="keywordflow">if</span> (1 == sumKids.size()) ret = sumKids[0];
<a name="l01134"></a>01134   <span class="keywordflow">else</span> ret = <a class="code" href="namespaceCVC3.html#accd3d7d38b0e04136afbc3e5191bc8bb">plusExpr</a>(sumKids);
<a name="l01135"></a>01135 
<a name="l01136"></a>01136   <span class="keywordflow">if</span>(withProof()) pf = newPf(<span class="stringliteral">&quot;canon_combo_like_terms&quot;</span>,e,ret);
<a name="l01137"></a>01137   <span class="keywordflow">return</span> newRWTheorem(e, ret, Assumptions::emptyAssump(), pf);
<a name="l01138"></a>01138 }
<a name="l01139"></a>01139 
<a name="l01140"></a>01140 
<a name="l01141"></a>01141 <span class="comment">// 0 = (* e1 e2 ...) &lt;=&gt; 0 = e1 OR 0 = e2 OR ...</span>
<a name="l01142"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a57eafe7c2a127ca4b4706437b777d610">01142</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::multEqZero(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; expr)
<a name="l01143"></a>01143 {
<a name="l01144"></a>01144   <span class="keywordflow">if</span> (<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l01145"></a>01145     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(expr.<a class="code" href="group__ExprPkg.html#gac4af2026c180da0f18d66ac616f61f3a">isEq</a>() &amp;&amp; expr[0].<a class="code" href="group__ExprPkg.html#gac5ced6adc7a60945ea6707ef494aa28f">isRational</a>() &amp;&amp;
<a name="l01146"></a>01146                 expr[0].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>() == 0 &amp;&amp;
<a name="l01147"></a>01147                 <a class="code" href="namespaceCVC3.html#a28ae8672047db708e99602ebaca89777">isMult</a>(expr[1]) &amp;&amp; expr[1].<a class="code" href="group__ExprPkg.html#ga28b901d05e52a5c646f83a95cc74f94b">arity</a>() &gt; 1,
<a name="l01148"></a>01148                 <span class="stringliteral">&quot;multEqZero invariant violated&quot;</span>+expr.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l01149"></a>01149   }
<a name="l01150"></a>01150   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l01151"></a>01151   vector&lt;Expr&gt; kids;
<a name="l01152"></a>01152   <a class="code" href="classCVC3_1_1Expr_1_1iterator.html">Expr::iterator</a> i = expr[1].<a class="code" href="group__ExprPkg.html#gac890e13db184610276fc533fa4b4fe99" title="Begin iterator.">begin</a>(), iend = expr[1].<a class="code" href="group__ExprPkg.html#gaf6048a5030c8fa2511bf5dfee868e653" title="End iterator.">end</a>();
<a name="l01153"></a>01153   <span class="keywordflow">for</span> (; i != iend; ++i) {
<a name="l01154"></a>01154     kids.push_back(rat(0).eqExpr(*i));
<a name="l01155"></a>01155   }
<a name="l01156"></a>01156   <span class="keywordflow">if</span> (withProof()) {
<a name="l01157"></a>01157     pf = newPf(<span class="stringliteral">&quot;multEqZero&quot;</span>, expr);
<a name="l01158"></a>01158   }
<a name="l01159"></a>01159   <span class="keywordflow">return</span> newRWTheorem(expr, <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>(<a class="code" href="kinds_8h.html#aa10c9e8951b8ccf714a59ec321bdac5ba96727447c0ad447987df1c6415aef074">OR</a>, kids), Assumptions::emptyAssump(), pf);
<a name="l01160"></a>01160 }
<a name="l01161"></a>01161 
<a name="l01162"></a>01162 
<a name="l01163"></a>01163 <span class="comment">// 0 = (^ c x) &lt;=&gt; false if c &lt;=0</span>
<a name="l01164"></a>01164 <span class="comment">//             &lt;=&gt; 0 = x if c &gt; 0</span>
<a name="l01165"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#acbea7826fe54b91e8d4bc2c21f7137ae">01165</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::powEqZero(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; expr)
<a name="l01166"></a>01166 {
<a name="l01167"></a>01167   <span class="keywordflow">if</span> (<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l01168"></a>01168     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(expr.<a class="code" href="group__ExprPkg.html#gac4af2026c180da0f18d66ac616f61f3a">isEq</a>() &amp;&amp; expr[0].<a class="code" href="group__ExprPkg.html#gac5ced6adc7a60945ea6707ef494aa28f">isRational</a>() &amp;&amp;
<a name="l01169"></a>01169                 expr[0].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>() == 0 &amp;&amp;
<a name="l01170"></a>01170                 <a class="code" href="namespaceCVC3.html#a7c2a9996013597a3e00c7562074f590b">isPow</a>(expr[1]) &amp;&amp; expr[1].<a class="code" href="group__ExprPkg.html#ga28b901d05e52a5c646f83a95cc74f94b">arity</a>() == 2 &amp;&amp;
<a name="l01171"></a>01171                 expr[1][0].<a class="code" href="group__ExprPkg.html#gac5ced6adc7a60945ea6707ef494aa28f">isRational</a>(),
<a name="l01172"></a>01172                 <span class="stringliteral">&quot;powEqZero invariant violated&quot;</span>+expr.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l01173"></a>01173   }
<a name="l01174"></a>01174   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l01175"></a>01175   <span class="keywordflow">if</span> (withProof()) {
<a name="l01176"></a>01176     pf = newPf(<span class="stringliteral">&quot;powEqZero&quot;</span>, expr);
<a name="l01177"></a>01177   }
<a name="l01178"></a>01178   <a class="code" href="classCVC3_1_1Rational.html">Rational</a> r = expr[1][0].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>();
<a name="l01179"></a>01179   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> res;
<a name="l01180"></a>01180   <span class="keywordflow">if</span> (r &lt;= 0) {
<a name="l01181"></a>01181     res = d_em-&gt;falseExpr();
<a name="l01182"></a>01182   }
<a name="l01183"></a>01183   <span class="keywordflow">else</span> {
<a name="l01184"></a>01184     res = rat(0).<a class="code" href="group__ExprPkg.html#gacb48495ca445c895f95d0c3c1ae2070b">eqExpr</a>(expr[1][1]);
<a name="l01185"></a>01185   }
<a name="l01186"></a>01186   <span class="keywordflow">return</span> newRWTheorem(expr, res, Assumptions::emptyAssump(), pf);
<a name="l01187"></a>01187 }
<a name="l01188"></a>01188 
<a name="l01189"></a>01189 
<a name="l01190"></a>01190 <span class="comment">// x^n = y^n &lt;=&gt; x = y (if n is odd)</span>
<a name="l01191"></a>01191 <span class="comment">// x^n = y^n &lt;=&gt; x = y OR x = -y (if n is even)</span>
<a name="l01192"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#ab29b63e40b7f2c624e6e4f11c4eff27e">01192</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::elimPower(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; expr)
<a name="l01193"></a>01193 {
<a name="l01194"></a>01194   <span class="keywordflow">if</span> (<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l01195"></a>01195     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(expr.<a class="code" href="group__ExprPkg.html#gac4af2026c180da0f18d66ac616f61f3a">isEq</a>() &amp;&amp; <a class="code" href="namespaceCVC3.html#a7c2a9996013597a3e00c7562074f590b">isPow</a>(expr[0]) &amp;&amp;
<a name="l01196"></a>01196                 <a class="code" href="namespaceCVC3.html#a7c2a9996013597a3e00c7562074f590b">isPow</a>(expr[1]) &amp;&amp;
<a name="l01197"></a>01197                 <a class="code" href="namespaceCVC3.html#aef45cea7af354d2928a8224f7ae8ae4f">isIntegerConst</a>(expr[0][0]) &amp;&amp;
<a name="l01198"></a>01198                 expr[0][0].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>() &gt; 0 &amp;&amp;
<a name="l01199"></a>01199                 expr[0][0] == expr[1][0],
<a name="l01200"></a>01200                 <span class="stringliteral">&quot;elimPower invariant violated&quot;</span>+expr.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l01201"></a>01201   }
<a name="l01202"></a>01202   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l01203"></a>01203   <span class="keywordflow">if</span> (withProof()) {
<a name="l01204"></a>01204     pf = newPf(<span class="stringliteral">&quot;elimPower&quot;</span>, expr);
<a name="l01205"></a>01205   }
<a name="l01206"></a>01206   <a class="code" href="classCVC3_1_1Rational.html">Rational</a> r = expr[0][0].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>();
<a name="l01207"></a>01207   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> res = expr[0][1].<a class="code" href="group__ExprPkg.html#gacb48495ca445c895f95d0c3c1ae2070b">eqExpr</a>(expr[1][1]);
<a name="l01208"></a>01208   <span class="keywordflow">if</span> (r % 2 == 0) {
<a name="l01209"></a>01209     res = res.<a class="code" href="group__ExprPkg.html#gaf310870d783fff343e77ba9c2277c626">orExpr</a>(expr[0][1].eqExpr(-expr[1][1]));
<a name="l01210"></a>01210   }
<a name="l01211"></a>01211   <span class="keywordflow">return</span> newRWTheorem(expr, res, Assumptions::emptyAssump(), pf);
<a name="l01212"></a>01212 }
<a name="l01213"></a>01213 
<a name="l01214"></a>01214 
<a name="l01215"></a>01215 <span class="comment">// x^n = c &lt;=&gt; x = root (if n is odd and root^n = c)</span>
<a name="l01216"></a>01216 <span class="comment">// x^n = c &lt;=&gt; x = root OR x = -root (if n is even and root^n = c)</span>
<a name="l01217"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a942f9f0fc0ceff798b607e9fe032175a">01217</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::elimPowerConst(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; expr, <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Rational.html">Rational</a>&amp; root)
<a name="l01218"></a>01218 {
<a name="l01219"></a>01219   <span class="keywordflow">if</span> (<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l01220"></a>01220     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(expr.<a class="code" href="group__ExprPkg.html#gac4af2026c180da0f18d66ac616f61f3a">isEq</a>() &amp;&amp; <a class="code" href="namespaceCVC3.html#a7c2a9996013597a3e00c7562074f590b">isPow</a>(expr[0]) &amp;&amp;
<a name="l01221"></a>01221                 <a class="code" href="namespaceCVC3.html#aef45cea7af354d2928a8224f7ae8ae4f">isIntegerConst</a>(expr[0][0]) &amp;&amp;
<a name="l01222"></a>01222                 expr[0][0].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>() &gt; 0 &amp;&amp;
<a name="l01223"></a>01223                 expr[1].<a class="code" href="group__ExprPkg.html#gac5ced6adc7a60945ea6707ef494aa28f">isRational</a>() &amp;&amp;
<a name="l01224"></a>01224                 <a class="code" href="namespaceCVC3.html#a28fc84bed3f9bc91ca9967de0f9cfa00" title="Raise &#39;base&#39; into the power of &#39;pow&#39; (pow must be an integer)">pow</a>(expr[0][0].getRational(), root) == expr[1].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>(),
<a name="l01225"></a>01225                 <span class="stringliteral">&quot;elimPowerConst invariant violated&quot;</span>+expr.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l01226"></a>01226   }
<a name="l01227"></a>01227   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l01228"></a>01228   <span class="keywordflow">if</span> (withProof()) {
<a name="l01229"></a>01229     pf = newPf(<span class="stringliteral">&quot;elimPowerConst&quot;</span>, expr, rat(root));
<a name="l01230"></a>01230   }
<a name="l01231"></a>01231   <a class="code" href="classCVC3_1_1Rational.html">Rational</a> r = expr[0][0].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>();
<a name="l01232"></a>01232   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> res = expr[0][1].<a class="code" href="group__ExprPkg.html#gacb48495ca445c895f95d0c3c1ae2070b">eqExpr</a>(rat(root));
<a name="l01233"></a>01233   <span class="keywordflow">if</span> (r % 2 == 0) {
<a name="l01234"></a>01234     res = res.<a class="code" href="group__ExprPkg.html#gaf310870d783fff343e77ba9c2277c626">orExpr</a>(expr[0][1].eqExpr(rat(-root)));
<a name="l01235"></a>01235   }
<a name="l01236"></a>01236   <span class="keywordflow">return</span> newRWTheorem(expr, res, Assumptions::emptyAssump(), pf);
<a name="l01237"></a>01237 }
<a name="l01238"></a>01238 
<a name="l01239"></a>01239 
<a name="l01240"></a>01240 <span class="comment">// x^n = c &lt;=&gt; false (if n is even and c is negative)</span>
<a name="l01241"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#abe913a6cc9430faf8f0ac50ec51aa36c">01241</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::evenPowerEqNegConst(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; expr)
<a name="l01242"></a>01242 {
<a name="l01243"></a>01243   <span class="keywordflow">if</span> (<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l01244"></a>01244     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(expr.<a class="code" href="group__ExprPkg.html#gac4af2026c180da0f18d66ac616f61f3a">isEq</a>() &amp;&amp; <a class="code" href="namespaceCVC3.html#a7c2a9996013597a3e00c7562074f590b">isPow</a>(expr[0]) &amp;&amp;
<a name="l01245"></a>01245                 expr[1].<a class="code" href="group__ExprPkg.html#gac5ced6adc7a60945ea6707ef494aa28f">isRational</a>() &amp;&amp;
<a name="l01246"></a>01246                 <a class="code" href="namespaceCVC3.html#aef45cea7af354d2928a8224f7ae8ae4f">isIntegerConst</a>(expr[0][0]) &amp;&amp;
<a name="l01247"></a>01247                 expr[0][0].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>() % 2 == 0 &amp;&amp;
<a name="l01248"></a>01248                 expr[1].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>() &lt; 0,
<a name="l01249"></a>01249                 <span class="stringliteral">&quot;evenPowerEqNegConst invariant violated&quot;</span>+expr.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l01250"></a>01250   }
<a name="l01251"></a>01251   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l01252"></a>01252   <span class="keywordflow">if</span> (withProof()) {
<a name="l01253"></a>01253     pf = newPf(<span class="stringliteral">&quot;evenPowerEqNegConst&quot;</span>, expr);
<a name="l01254"></a>01254   }
<a name="l01255"></a>01255   <span class="keywordflow">return</span> newRWTheorem(expr, d_em-&gt;falseExpr(), Assumptions::emptyAssump(), pf);
<a name="l01256"></a>01256 }
<a name="l01257"></a>01257 
<a name="l01258"></a>01258 
<a name="l01259"></a>01259 <span class="comment">// x^n = c &lt;=&gt; false (if x is an integer and c is not a perfect n power)</span>
<a name="l01260"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a946832931094bb746277d8b95c471690">01260</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::intEqIrrational(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; expr, <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; <a class="code" href="theory__quant_8cpp.html#ac9940420b1f3427ebe821902adbb578d">isIntx</a>)
<a name="l01261"></a>01261 {
<a name="l01262"></a>01262   <span class="keywordflow">if</span> (<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l01263"></a>01263     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(expr.<a class="code" href="group__ExprPkg.html#gac4af2026c180da0f18d66ac616f61f3a">isEq</a>() &amp;&amp; <a class="code" href="namespaceCVC3.html#a7c2a9996013597a3e00c7562074f590b">isPow</a>(expr[0]) &amp;&amp;
<a name="l01264"></a>01264                 expr[1].<a class="code" href="group__ExprPkg.html#gac5ced6adc7a60945ea6707ef494aa28f">isRational</a>() &amp;&amp;
<a name="l01265"></a>01265                 expr[1].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>() != 0 &amp;&amp;
<a name="l01266"></a>01266                 <a class="code" href="namespaceCVC3.html#aef45cea7af354d2928a8224f7ae8ae4f">isIntegerConst</a>(expr[0][0]) &amp;&amp;
<a name="l01267"></a>01267                 expr[0][0].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>() &gt; 0 &amp;&amp;
<a name="l01268"></a>01268                 <a class="code" href="namespaceCVC3.html#aad16f7bcc4d7a86af9b253e8587d264b" title="take nth root of base, return result if it is exact, 0 otherwise">ratRoot</a>(expr[1].getRational(), expr[0][0].getRational().getUnsigned()) == 0,
<a name="l01269"></a>01269                 <span class="stringliteral">&quot;intEqIrrational invariant violated&quot;</span>+expr.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l01270"></a>01270     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#aff7910c172ccdd1afb5e42964e2f248d">isIntPred</a>(isIntx.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>()) &amp;&amp; isIntx.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>()[0] == expr[0][1],
<a name="l01271"></a>01271     <span class="stringliteral">&quot;ArithTheoremProducer3::intEqIrrational:\n &quot;</span>
<a name="l01272"></a>01272     <span class="stringliteral">&quot;wrong integrality constraint:\n expr = &quot;</span>
<a name="l01273"></a>01273     +expr.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>()+<span class="stringliteral">&quot;\n isIntx = &quot;</span>
<a name="l01274"></a>01274     +isIntx.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>().<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l01275"></a>01275   }
<a name="l01276"></a>01276   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Assumptions.html">Assumptions</a>&amp; assump(isIntx.<a class="code" href="classCVC3_1_1Theorem.html#a5e9ab00a613df15cc02f55edb55a67b3">getAssumptionsRef</a>());
<a name="l01277"></a>01277   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l01278"></a>01278   <span class="keywordflow">if</span> (withProof()) {
<a name="l01279"></a>01279     pf = newPf(<span class="stringliteral">&quot;int_eq_irr&quot;</span>, expr, isIntx.<a class="code" href="classCVC3_1_1Theorem.html#a2d8352c07a756c3837683a27a1e659ef">getProof</a>());
<a name="l01280"></a>01280   }
<a name="l01281"></a>01281   <span class="keywordflow">return</span> newRWTheorem(expr, d_em-&gt;falseExpr(), assump, pf);
<a name="l01282"></a>01282 }
<a name="l01283"></a>01283 
<a name="l01284"></a>01284 
<a name="l01285"></a>01285 <span class="comment">// e[0] kind e[1] &lt;==&gt; true when e[0] kind e[1],</span>
<a name="l01286"></a>01286 <span class="comment">// false when e[0] !kind e[1], for constants only</span>
<a name="l01287"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a7a2a8059fa49da5a8877b28b1cfa445a">01287</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::constPredicate(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; e) {
<a name="l01288"></a>01288   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l01289"></a>01289     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(e.<a class="code" href="group__ExprPkg.html#ga28b901d05e52a5c646f83a95cc74f94b">arity</a>() == 2 &amp;&amp; <a class="code" href="namespaceCVC3.html#ac0334a083d6782caa17ca0d337fddddf">isRational</a>(e[0]) &amp;&amp; <a class="code" href="namespaceCVC3.html#ac0334a083d6782caa17ca0d337fddddf">isRational</a>(e[1]),
<a name="l01290"></a>01290                 <a class="code" href="arith__theorem__producer3_8cpp.html#a79f2713d570c7065f61a160134ea765b">CLASS_NAME</a> <span class="stringliteral">&quot;::constPredicate:\n  &quot;</span>
<a name="l01291"></a>01291                 <span class="stringliteral">&quot;non-const parameters: &quot;</span> + e.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l01292"></a>01292   }
<a name="l01293"></a>01293   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l01294"></a>01294   <span class="keywordtype">bool</span> result(<span class="keyword">false</span>);
<a name="l01295"></a>01295   <span class="keywordtype">int</span> kind = e.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>();
<a name="l01296"></a>01296   <a class="code" href="classCVC3_1_1Rational.html">Rational</a> r1 = e[0].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>(), r2 = e[1].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>();
<a name="l01297"></a>01297   <span class="keywordflow">switch</span>(kind) {
<a name="l01298"></a>01298   <span class="keywordflow">case</span> <a class="code" href="kinds_8h.html#aa10c9e8951b8ccf714a59ec321bdac5ba9efdc855f3c1477957fb50affec07f8f">EQ</a>:
<a name="l01299"></a>01299     result = (r1 == r2)?<span class="keyword">true</span> : <span class="keyword">false</span>;
<a name="l01300"></a>01300     <span class="keywordflow">break</span>;
<a name="l01301"></a>01301   <span class="keywordflow">case</span> <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a9e29ecc77281f945fb50c183cfae6749">LT</a>:
<a name="l01302"></a>01302     result = (r1 &lt; r2)?<span class="keyword">true</span> : <span class="keyword">false</span>;
<a name="l01303"></a>01303     <span class="keywordflow">break</span>;
<a name="l01304"></a>01304   <span class="keywordflow">case</span> <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a1b768cf71a18713c90cd71f82488ffb1">LE</a>:
<a name="l01305"></a>01305     result = (r1 &lt;= r2)?<span class="keyword">true</span> : <span class="keyword">false</span>;
<a name="l01306"></a>01306     <span class="keywordflow">break</span>;
<a name="l01307"></a>01307   <span class="keywordflow">case</span> <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a589b68b2d271254aa9fd3d89b4bf33b9">GT</a>:
<a name="l01308"></a>01308     result = (r1 &gt; r2)?<span class="keyword">true</span> : <span class="keyword">false</span>;
<a name="l01309"></a>01309     <span class="keywordflow">break</span>;
<a name="l01310"></a>01310   <span class="keywordflow">case</span> <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024aad2afa561f31a801e12ab3fdd50a6229">GE</a>:
<a name="l01311"></a>01311     result = (r1 &gt;= r2)?<span class="keyword">true</span> : <span class="keyword">false</span>;
<a name="l01312"></a>01312     <span class="keywordflow">break</span>;
<a name="l01313"></a>01313   <span class="keywordflow">default</span>:
<a name="l01314"></a>01314     <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l01315"></a>01315       <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<span class="keyword">false</span>,
<a name="l01316"></a>01316                   <span class="stringliteral">&quot;ArithTheoremProducer3::constPredicate: wrong kind&quot;</span>);
<a name="l01317"></a>01317     }
<a name="l01318"></a>01318     <span class="keywordflow">break</span>;
<a name="l01319"></a>01319   }
<a name="l01320"></a>01320   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> ret = (result) ? d_em-&gt;trueExpr() : d_em-&gt;falseExpr();
<a name="l01321"></a>01321   <span class="keywordflow">if</span>(withProof()) pf = newPf(<span class="stringliteral">&quot;const_predicate&quot;</span>, e,ret);
<a name="l01322"></a>01322   <span class="keywordflow">return</span> newRWTheorem(e, ret, Assumptions::emptyAssump(), pf);
<a name="l01323"></a>01323 }
<a name="l01324"></a>01324 
<a name="l01325"></a>01325 <span class="comment">// e[0] kind e[1] &lt;==&gt; 0 kind e[1] - e[0]</span>
<a name="l01326"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#aca76a2dbee73d7ad9e2529ac8ce142a4">01326</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::rightMinusLeft(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; e)
<a name="l01327"></a>01327 {
<a name="l01328"></a>01328   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l01329"></a>01329   <span class="keywordtype">int</span> kind = e.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>();
<a name="l01330"></a>01330   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l01331"></a>01331     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>((<a class="code" href="kinds_8h.html#aa10c9e8951b8ccf714a59ec321bdac5ba9efdc855f3c1477957fb50affec07f8f">EQ</a>==kind) ||
<a name="l01332"></a>01332                 (<a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a9e29ecc77281f945fb50c183cfae6749">LT</a>==kind) ||
<a name="l01333"></a>01333                 (<a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a1b768cf71a18713c90cd71f82488ffb1">LE</a>==kind) ||
<a name="l01334"></a>01334                 (<a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024aad2afa561f31a801e12ab3fdd50a6229">GE</a>==kind) ||
<a name="l01335"></a>01335                 (<a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a589b68b2d271254aa9fd3d89b4bf33b9">GT</a>==kind),
<a name="l01336"></a>01336                 <span class="stringliteral">&quot;ArithTheoremProducer3::rightMinusLeft: wrong kind&quot;</span>);
<a name="l01337"></a>01337   }
<a name="l01338"></a>01338   <span class="keywordflow">if</span>(withProof()) pf = newPf(<span class="stringliteral">&quot;right_minus_left&quot;</span>,e);
<a name="l01339"></a>01339   <span class="keywordflow">return</span> newRWTheorem(e, <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>(e.<a class="code" href="group__ExprPkg.html#gace479f04faca399219496195152f7806" title="Get operator from expression.">getOp</a>(), rat(0), e[1] - e[0]), Assumptions::emptyAssump(), pf);
<a name="l01340"></a>01340 }
<a name="l01341"></a>01341 
<a name="l01342"></a>01342 
<a name="l01343"></a>01343 <span class="comment">// e[0] kind e[1] &lt;==&gt; 0 kind e[1] - e[0]</span>
<a name="l01344"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#aedad2be1c60515921f8c3761581afca5">01344</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::leftMinusRight(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; e)
<a name="l01345"></a>01345 {
<a name="l01346"></a>01346   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l01347"></a>01347   <span class="keywordtype">int</span> kind = e.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>();
<a name="l01348"></a>01348   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l01349"></a>01349     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>((<a class="code" href="kinds_8h.html#aa10c9e8951b8ccf714a59ec321bdac5ba9efdc855f3c1477957fb50affec07f8f">EQ</a>==kind) ||
<a name="l01350"></a>01350                 (<a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a9e29ecc77281f945fb50c183cfae6749">LT</a>==kind) ||
<a name="l01351"></a>01351                 (<a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a1b768cf71a18713c90cd71f82488ffb1">LE</a>==kind) ||
<a name="l01352"></a>01352                 (<a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024aad2afa561f31a801e12ab3fdd50a6229">GE</a>==kind) ||
<a name="l01353"></a>01353                 (<a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a589b68b2d271254aa9fd3d89b4bf33b9">GT</a>==kind),
<a name="l01354"></a>01354                 <span class="stringliteral">&quot;ArithTheoremProducer3::rightMinusLeft: wrong kind&quot;</span>);
<a name="l01355"></a>01355   }
<a name="l01356"></a>01356   <span class="keywordflow">if</span>(withProof()) pf = newPf(<span class="stringliteral">&quot;left_minus_right&quot;</span>,e);
<a name="l01357"></a>01357   <span class="keywordflow">return</span> newRWTheorem(e, <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>(e.<a class="code" href="group__ExprPkg.html#gace479f04faca399219496195152f7806" title="Get operator from expression.">getOp</a>(), e[0] - e[1], rat(0)), Assumptions::emptyAssump(), pf);
<a name="l01358"></a>01358 }
<a name="l01359"></a>01359 
<a name="l01360"></a>01360 
<a name="l01361"></a>01361 <span class="comment">// x kind y &lt;==&gt; x + z kind y + z</span>
<a name="l01362"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#ab190e4d8fefb74f2a8117ca17ae49b48">01362</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::plusPredicate(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; x,
<a name="l01363"></a>01363                                       <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; y,
<a name="l01364"></a>01364                                       <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; z, <span class="keywordtype">int</span> kind) {
<a name="l01365"></a>01365   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l01366"></a>01366     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>((<a class="code" href="kinds_8h.html#aa10c9e8951b8ccf714a59ec321bdac5ba9efdc855f3c1477957fb50affec07f8f">EQ</a>==kind) ||
<a name="l01367"></a>01367                 (<a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a9e29ecc77281f945fb50c183cfae6749">LT</a>==kind) ||
<a name="l01368"></a>01368                 (<a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a1b768cf71a18713c90cd71f82488ffb1">LE</a>==kind) ||
<a name="l01369"></a>01369                 (<a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024aad2afa561f31a801e12ab3fdd50a6229">GE</a>==kind) ||
<a name="l01370"></a>01370                 (<a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a589b68b2d271254aa9fd3d89b4bf33b9">GT</a>==kind),
<a name="l01371"></a>01371                 <span class="stringliteral">&quot;ArithTheoremProducer3::plusPredicate: wrong kind&quot;</span>);
<a name="l01372"></a>01372   }
<a name="l01373"></a>01373   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l01374"></a>01374   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> <a class="code" href="namespaceMiniSat.html#ad93cb56673487974071ed3b75bf4ea83">left</a> = <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>(kind, x, y);
<a name="l01375"></a>01375   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> <a class="code" href="namespaceMiniSat.html#a82558b7a36c52f5d3211d5d14bed99d4">right</a> = <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>(kind, x + z, y + z);
<a name="l01376"></a>01376   <span class="keywordflow">if</span>(withProof()) pf = newPf(<span class="stringliteral">&quot;plus_predicate&quot;</span>,left,right);
<a name="l01377"></a>01377   <span class="keywordflow">return</span> newRWTheorem(left, right, Assumptions::emptyAssump(), pf);
<a name="l01378"></a>01378 }
<a name="l01379"></a>01379 
<a name="l01380"></a>01380 <span class="comment">// x = y &lt;==&gt; x * z = y * z</span>
<a name="l01381"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#afd7a6da45999fb3237cdbbbf9c5f19e8">01381</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::multEqn(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; x,
<a name="l01382"></a>01382                                       <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; y,
<a name="l01383"></a>01383                                       <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; z) {
<a name="l01384"></a>01384   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l01385"></a>01385   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>)
<a name="l01386"></a>01386     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(z.<a class="code" href="group__ExprPkg.html#gac5ced6adc7a60945ea6707ef494aa28f">isRational</a>() &amp;&amp; z.<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>() != 0,
<a name="l01387"></a>01387     <span class="stringliteral">&quot;ArithTheoremProducer3::multEqn(): multiplying equation by 0&quot;</span>);
<a name="l01388"></a>01388   <span class="keywordflow">if</span>(withProof()) pf = newPf(<span class="stringliteral">&quot;mult_eqn&quot;</span>, x, y, z);
<a name="l01389"></a>01389   <span class="keywordflow">return</span> newRWTheorem(x.<a class="code" href="group__ExprPkg.html#gacb48495ca445c895f95d0c3c1ae2070b">eqExpr</a>(y), (x * z).eqExpr(y * z), Assumptions::emptyAssump(), pf);
<a name="l01390"></a>01390 }
<a name="l01391"></a>01391 
<a name="l01392"></a>01392 
<a name="l01393"></a>01393 <span class="comment">// x = y &lt;==&gt; z=0 OR x * 1/z = y * 1/z</span>
<a name="l01394"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a7bf31f4d4bd6e3f7ff7e37dd5236a792">01394</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::divideEqnNonConst(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; x,
<a name="l01395"></a>01395                                                    <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; y,
<a name="l01396"></a>01396                                                    <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; z) {
<a name="l01397"></a>01397   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l01398"></a>01398   <span class="keywordflow">if</span>(withProof()) pf = newPf(<span class="stringliteral">&quot;mult_eqn_nonconst&quot;</span>, x, y, z);
<a name="l01399"></a>01399   <span class="keywordflow">return</span> newRWTheorem(x.<a class="code" href="group__ExprPkg.html#gacb48495ca445c895f95d0c3c1ae2070b">eqExpr</a>(y), (z.<a class="code" href="group__ExprPkg.html#gacb48495ca445c895f95d0c3c1ae2070b">eqExpr</a>(rat(0))).<a class="code" href="namespaceCVC3.html#a30f30b6e20c174f21ae63acea8618294">orExpr</a>((x / z).eqExpr(y / z)),
<a name="l01400"></a>01400                       Assumptions::emptyAssump(), pf);
<a name="l01401"></a>01401 }
<a name="l01402"></a>01402 
<a name="l01403"></a>01403 
<a name="l01404"></a>01404 <span class="comment">// if z is +ve, return e[0] LT|LE|GT|GE e[1] &lt;==&gt; e[0]*z LT|LE|GT|GE e[1]*z</span>
<a name="l01405"></a>01405 <span class="comment">// if z is -ve, return e[0] LT|LE|GT|GE e[1] &lt;==&gt; e[1]*z LT|LE|GT|GE e[0]*z</span>
<a name="l01406"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a8af6455fe4a8889cfb7b0b8c865b847c">01406</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::multIneqn(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; e, <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; z)
<a name="l01407"></a>01407 {
<a name="l01408"></a>01408   <span class="keywordtype">int</span> kind = e.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>();
<a name="l01409"></a>01409 
<a name="l01410"></a>01410   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l01411"></a>01411     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>((<a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a9e29ecc77281f945fb50c183cfae6749">LT</a>==kind) ||
<a name="l01412"></a>01412                 (<a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a1b768cf71a18713c90cd71f82488ffb1">LE</a>==kind) ||
<a name="l01413"></a>01413                 (<a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024aad2afa561f31a801e12ab3fdd50a6229">GE</a>==kind) ||
<a name="l01414"></a>01414                 (<a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a589b68b2d271254aa9fd3d89b4bf33b9">GT</a>==kind),
<a name="l01415"></a>01415                 <span class="stringliteral">&quot;ArithTheoremProducer3::multIneqn: wrong kind&quot;</span>);
<a name="l01416"></a>01416     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(z.<a class="code" href="group__ExprPkg.html#gac5ced6adc7a60945ea6707ef494aa28f">isRational</a>() &amp;&amp; z.<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>() != 0,
<a name="l01417"></a>01417                 <span class="stringliteral">&quot;ArithTheoremProducer3::multIneqn: &quot;</span>
<a name="l01418"></a>01418     <span class="stringliteral">&quot;z must be non-zero rational: &quot;</span> + z.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l01419"></a>01419   }
<a name="l01420"></a>01420   <a class="code" href="classCVC3_1_1Op.html">Op</a> op(e.<a class="code" href="group__ExprPkg.html#gace479f04faca399219496195152f7806" title="Get operator from expression.">getOp</a>());
<a name="l01421"></a>01421   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l01422"></a>01422 
<a name="l01423"></a>01423   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> ret;
<a name="l01424"></a>01424   <span class="keywordflow">if</span>(0 &lt; z.<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>())
<a name="l01425"></a>01425     ret = <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>(op, e[0]*z, e[1]*z);
<a name="l01426"></a>01426   <span class="keywordflow">else</span>
<a name="l01427"></a>01427     ret = <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>(op, e[1]*z, e[0]*z);
<a name="l01428"></a>01428   <span class="keywordflow">if</span>(withProof()) pf = newPf(<span class="stringliteral">&quot;mult_ineqn&quot;</span>, e, ret);
<a name="l01429"></a>01429   <span class="keywordflow">return</span> newRWTheorem(e, ret, Assumptions::emptyAssump(), pf);
<a name="l01430"></a>01430 }
<a name="l01431"></a>01431 
<a name="l01432"></a>01432 
<a name="l01433"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#ad2f144d3a2ffe108e0d8e7df8e263832">01433</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::eqToIneq(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; e) {
<a name="l01434"></a>01434 
<a name="l01435"></a>01435     <span class="comment">// Check soundness of the rule if necessary</span>
<a name="l01436"></a>01436   <span class="keywordflow">if</span> (<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>)
<a name="l01437"></a>01437     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(e.<a class="code" href="group__ExprPkg.html#gac4af2026c180da0f18d66ac616f61f3a">isEq</a>(), <span class="stringliteral">&quot;eqToIneq: input must be an equality: &quot;</span> + e.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l01438"></a>01438 
<a name="l01439"></a>01439     <span class="comment">// The proof object we will use</span>
<a name="l01440"></a>01440     <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l01441"></a>01441 
<a name="l01442"></a>01442   <span class="comment">// The parts of the equality x = y</span>
<a name="l01443"></a>01443     <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; x = e[0];
<a name="l01444"></a>01444     <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; y = e[1];
<a name="l01445"></a>01445 
<a name="l01446"></a>01446   <span class="comment">// Setup the proof if needed</span>
<a name="l01447"></a>01447     <span class="keywordflow">if</span> (withProof())
<a name="l01448"></a>01448       pf = newPf(<span class="stringliteral">&quot;eqToIneq&quot;</span>, e);
<a name="l01449"></a>01449 
<a name="l01450"></a>01450     <span class="comment">// Retrun the theorem explaining the transformation</span>
<a name="l01451"></a>01451   <span class="keywordflow">return</span> newRWTheorem(e, <a class="code" href="namespaceCVC3.html#aebfd8a82800bd3dff4c8db461a52cdea">leExpr</a>(x,y).<a class="code" href="namespaceCVC3.html#ad4258158bba138eb54b9080af7f8223a">andExpr</a>(<a class="code" href="namespaceCVC3.html#a520cf0df288be321d27ea6fa77ded2d2">geExpr</a>(x,y)), Assumptions::emptyAssump(), pf);
<a name="l01452"></a>01452 }
<a name="l01453"></a>01453 
<a name="l01454"></a>01454 <span class="comment">// &quot;op1 GE|GT op2&quot; &lt;==&gt; op2 LE|LT op1</span>
<a name="l01455"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a216a950228aad3cdef0c5dd5213be4fb">01455</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::flipInequality(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; e)
<a name="l01456"></a>01456 {
<a name="l01457"></a>01457   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l01458"></a>01458   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l01459"></a>01459     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#a7306d7566ccb21380f05058477aba009">isGT</a>(e) || <a class="code" href="namespaceCVC3.html#af85f3152a3b2fe195d795bc0aefaec71">isGE</a>(e),
<a name="l01460"></a>01460                 <span class="stringliteral">&quot;ArithTheoremProducer3::flipInequality: wrong kind: &quot;</span> +
<a name="l01461"></a>01461                 e.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l01462"></a>01462   }
<a name="l01463"></a>01463 
<a name="l01464"></a>01464   <span class="keywordtype">int</span> kind = <a class="code" href="namespaceCVC3.html#af85f3152a3b2fe195d795bc0aefaec71">isGE</a>(e) ? <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a1b768cf71a18713c90cd71f82488ffb1">LE</a> : <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a9e29ecc77281f945fb50c183cfae6749">LT</a>;
<a name="l01465"></a>01465   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> ret =  <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>(kind, e[1], e[0]);
<a name="l01466"></a>01466   <span class="keywordflow">if</span>(withProof()) pf = newPf(<span class="stringliteral">&quot;flip_inequality&quot;</span>, e,ret);
<a name="l01467"></a>01467   <span class="keywordflow">return</span> newRWTheorem(e,ret, Assumptions::emptyAssump(), pf);
<a name="l01468"></a>01468 }
<a name="l01469"></a>01469 
<a name="l01470"></a>01470 
<a name="l01471"></a>01471 <span class="comment">// NOT (op1 LT op2)  &lt;==&gt; (op1 GE op2)</span>
<a name="l01472"></a>01472 <span class="comment">// NOT (op1 LE op2)  &lt;==&gt; (op1 GT op2)</span>
<a name="l01473"></a>01473 <span class="comment">// NOT (op1 GT op2)  &lt;==&gt; (op1 LE op2)</span>
<a name="l01474"></a>01474 <span class="comment">// NOT (op1 GE op2)  &lt;==&gt; (op1 LT op2)</span>
<a name="l01475"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a27bb939c33616b21a83aabdb5d47a660">01475</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::negatedInequality(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; e)
<a name="l01476"></a>01476 {
<a name="l01477"></a>01477   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; ineq = e[0];
<a name="l01478"></a>01478   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l01479"></a>01479     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(e.<a class="code" href="group__ExprPkg.html#ga1a898858ccadce833df5a294c7740f11">isNot</a>(),
<a name="l01480"></a>01480                 <span class="stringliteral">&quot;ArithTheoremProducer3::negatedInequality: wrong kind: &quot;</span> +
<a name="l01481"></a>01481                 e.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l01482"></a>01482     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#abbae617aaff89a9e5deb84ab649e14a0">isIneq</a>(ineq),
<a name="l01483"></a>01483                 <span class="stringliteral">&quot;ArithTheoremProducer3::negatedInequality: wrong kind: &quot;</span> +
<a name="l01484"></a>01484                 (ineq).toString());
<a name="l01485"></a>01485   }
<a name="l01486"></a>01486   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l01487"></a>01487   <span class="keywordflow">if</span>(withProof()) pf = newPf(<span class="stringliteral">&quot;negated_inequality&quot;</span>, e);
<a name="l01488"></a>01488 
<a name="l01489"></a>01489   <span class="keywordtype">int</span> kind;
<a name="l01490"></a>01490   <span class="comment">// NOT (op1 LT op2)  &lt;==&gt; (op1 GE op2)</span>
<a name="l01491"></a>01491   <span class="comment">// NOT (op1 LE op2)  &lt;==&gt; (op1 GT op2)</span>
<a name="l01492"></a>01492   <span class="comment">// NOT (op1 GT op2)  &lt;==&gt; (op1 LE op2)</span>
<a name="l01493"></a>01493   <span class="comment">// NOT (op1 GE op2)  &lt;==&gt; (op1 LT op2)</span>
<a name="l01494"></a>01494   kind =
<a name="l01495"></a>01495     <a class="code" href="namespaceCVC3.html#a448b6e0d541113608bba5a7a005609e3">isLT</a>(ineq) ? <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024aad2afa561f31a801e12ab3fdd50a6229">GE</a> :
<a name="l01496"></a>01496     <a class="code" href="namespaceCVC3.html#a8ef991dfa16ee3a209b7f38014153101">isLE</a>(ineq) ? <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a589b68b2d271254aa9fd3d89b4bf33b9">GT</a> :
<a name="l01497"></a>01497     <a class="code" href="namespaceCVC3.html#a7306d7566ccb21380f05058477aba009">isGT</a>(ineq) ? <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a1b768cf71a18713c90cd71f82488ffb1">LE</a> :
<a name="l01498"></a>01498     <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a9e29ecc77281f945fb50c183cfae6749">LT</a>;
<a name="l01499"></a>01499   <span class="keywordflow">return</span> newRWTheorem(e, <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>(kind, ineq[0], ineq[1]), Assumptions::emptyAssump(), pf);
<a name="l01500"></a>01500 }
<a name="l01501"></a>01501 
<a name="l01502"></a>01502 <span class="comment">//takes two ineqs &quot;|- alpha LT|LE t&quot; and &quot;|- t LT|LE beta&quot;</span>
<a name="l01503"></a>01503 <span class="comment">//and returns &quot;|- alpha LT|LE beta&quot;</span>
<a name="l01504"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a6f08ce700f85f9ba2967ecee42e7a550">01504</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::realShadow(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; alphaLTt,
<a name="l01505"></a>01505                                          <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; tLTbeta)
<a name="l01506"></a>01506 {
<a name="l01507"></a>01507   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; expr1 = alphaLTt.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>();
<a name="l01508"></a>01508   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; expr2 = tLTbeta.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>();
<a name="l01509"></a>01509   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l01510"></a>01510     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>((<a class="code" href="namespaceCVC3.html#a8ef991dfa16ee3a209b7f38014153101">isLE</a>(expr1) || <a class="code" href="namespaceCVC3.html#a448b6e0d541113608bba5a7a005609e3">isLT</a>(expr1)) &amp;&amp;
<a name="l01511"></a>01511                 (<a class="code" href="namespaceCVC3.html#a8ef991dfa16ee3a209b7f38014153101">isLE</a>(expr2) || <a class="code" href="namespaceCVC3.html#a448b6e0d541113608bba5a7a005609e3">isLT</a>(expr2)),
<a name="l01512"></a>01512                 <span class="stringliteral">&quot;ArithTheoremProducer3::realShadow: Wrong Kind: &quot;</span> +
<a name="l01513"></a>01513                 alphaLTt.<a class="code" href="classCVC3_1_1Theorem.html#ac4b1c9570ffb9cc901627ef2abb9ff77">toString</a>() +  tLTbeta.<a class="code" href="classCVC3_1_1Theorem.html#ac4b1c9570ffb9cc901627ef2abb9ff77">toString</a>());
<a name="l01514"></a>01514 
<a name="l01515"></a>01515     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(expr1[1] == expr2[0],
<a name="l01516"></a>01516                 <span class="stringliteral">&quot;ArithTheoremProducer3::realShadow:&quot;</span>
<a name="l01517"></a>01517                 <span class="stringliteral">&quot; t must be same for both inputs: &quot;</span> +
<a name="l01518"></a>01518                 expr1[1].toString() + <span class="stringliteral">&quot; , &quot;</span> + expr2[0].toString());
<a name="l01519"></a>01519   }
<a name="l01520"></a>01520   <a class="code" href="classCVC3_1_1Assumptions.html">Assumptions</a> a(alphaLTt, tLTbeta);
<a name="l01521"></a>01521   <span class="keywordtype">int</span> firstKind = expr1.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>();
<a name="l01522"></a>01522   <span class="keywordtype">int</span> secondKind = expr2.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>();
<a name="l01523"></a>01523   <span class="keywordtype">int</span> kind = (firstKind == secondKind) ? firstKind : <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a9e29ecc77281f945fb50c183cfae6749">LT</a>;
<a name="l01524"></a>01524   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l01525"></a>01525   <span class="keywordflow">if</span>(withProof()) {
<a name="l01526"></a>01526     vector&lt;Proof&gt; pfs;
<a name="l01527"></a>01527     pfs.push_back(alphaLTt.<a class="code" href="classCVC3_1_1Theorem.html#a2d8352c07a756c3837683a27a1e659ef">getProof</a>());
<a name="l01528"></a>01528     pfs.push_back(tLTbeta.<a class="code" href="classCVC3_1_1Theorem.html#a2d8352c07a756c3837683a27a1e659ef">getProof</a>());
<a name="l01529"></a>01529     pf = newPf(<span class="stringliteral">&quot;real_shadow&quot;</span>,expr1, expr2, pfs);
<a name="l01530"></a>01530   }
<a name="l01531"></a>01531   <span class="keywordflow">return</span> newTheorem(<a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>(kind, expr1[0], expr2[1]), a, pf);
<a name="l01532"></a>01532 }
<a name="l01533"></a>01533 <span class="comment"></span>
<a name="l01534"></a>01534 <span class="comment">//! alpha &lt;= t &lt;= alpha ==&gt; t = alpha</span>
<a name="l01535"></a>01535 <span class="comment"></span><span class="comment"></span>
<a name="l01536"></a>01536 <span class="comment">/*! takes two ineqs &quot;|- alpha LE t&quot; and &quot;|- t LE alpha&quot;</span>
<a name="l01537"></a>01537 <span class="comment">  and returns &quot;|- t = alpha&quot;</span>
<a name="l01538"></a>01538 <span class="comment">*/</span>
<a name="l01539"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a955e74558aee9ebc9de4c084819e93ac">01539</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::realShadowEq(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; alphaLEt,
<a name="l01540"></a>01540                                            <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; tLEalpha)
<a name="l01541"></a>01541 {
<a name="l01542"></a>01542   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; expr1 = alphaLEt.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>();
<a name="l01543"></a>01543   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; expr2 = tLEalpha.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>();
<a name="l01544"></a>01544   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l01545"></a>01545     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#a8ef991dfa16ee3a209b7f38014153101">isLE</a>(expr1) &amp;&amp; <a class="code" href="namespaceCVC3.html#a8ef991dfa16ee3a209b7f38014153101">isLE</a>(expr2),
<a name="l01546"></a>01546                 <span class="stringliteral">&quot;ArithTheoremProducer3::realShadowLTLE: Wrong Kind: &quot;</span> +
<a name="l01547"></a>01547                 alphaLEt.<a class="code" href="classCVC3_1_1Theorem.html#ac4b1c9570ffb9cc901627ef2abb9ff77">toString</a>() +  tLEalpha.<a class="code" href="classCVC3_1_1Theorem.html#ac4b1c9570ffb9cc901627ef2abb9ff77">toString</a>());
<a name="l01548"></a>01548 
<a name="l01549"></a>01549     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(expr1[1] == expr2[0],
<a name="l01550"></a>01550                 <span class="stringliteral">&quot;ArithTheoremProducer3::realShadowLTLE:&quot;</span>
<a name="l01551"></a>01551                 <span class="stringliteral">&quot; t must be same for both inputs: &quot;</span> +
<a name="l01552"></a>01552                 alphaLEt.<a class="code" href="classCVC3_1_1Theorem.html#ac4b1c9570ffb9cc901627ef2abb9ff77">toString</a>() + <span class="stringliteral">&quot; , &quot;</span> + tLEalpha.<a class="code" href="classCVC3_1_1Theorem.html#ac4b1c9570ffb9cc901627ef2abb9ff77">toString</a>());
<a name="l01553"></a>01553 
<a name="l01554"></a>01554     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(expr1[0] == expr2[1],
<a name="l01555"></a>01555                 <span class="stringliteral">&quot;ArithTheoremProducer3::realShadowLTLE:&quot;</span>
<a name="l01556"></a>01556                 <span class="stringliteral">&quot; alpha must be same for both inputs: &quot;</span> +
<a name="l01557"></a>01557                 alphaLEt.<a class="code" href="classCVC3_1_1Theorem.html#ac4b1c9570ffb9cc901627ef2abb9ff77">toString</a>() + <span class="stringliteral">&quot; , &quot;</span> + tLEalpha.<a class="code" href="classCVC3_1_1Theorem.html#ac4b1c9570ffb9cc901627ef2abb9ff77">toString</a>());
<a name="l01558"></a>01558   }
<a name="l01559"></a>01559   <a class="code" href="classCVC3_1_1Assumptions.html">Assumptions</a> a(alphaLEt, tLEalpha);
<a name="l01560"></a>01560   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l01561"></a>01561   <span class="keywordflow">if</span>(withProof()) {
<a name="l01562"></a>01562     vector&lt;Proof&gt; pfs;
<a name="l01563"></a>01563     pfs.push_back(alphaLEt.<a class="code" href="classCVC3_1_1Theorem.html#a2d8352c07a756c3837683a27a1e659ef">getProof</a>());
<a name="l01564"></a>01564     pfs.push_back(tLEalpha.<a class="code" href="classCVC3_1_1Theorem.html#a2d8352c07a756c3837683a27a1e659ef">getProof</a>());
<a name="l01565"></a>01565     pf = newPf(<span class="stringliteral">&quot;real_shadow_eq&quot;</span>, alphaLEt.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>(), tLEalpha.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>(), pfs);
<a name="l01566"></a>01566   }
<a name="l01567"></a>01567   <span class="keywordflow">return</span> newRWTheorem(expr1[0], expr1[1], a, pf);
<a name="l01568"></a>01568 }
<a name="l01569"></a>01569 
<a name="l01570"></a>01570 <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>
<a name="l01571"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#aaba7798eb77a93ac0de8978507dca731">01571</a> ArithTheoremProducer3::finiteInterval(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; aLEt,
<a name="l01572"></a>01572              <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; tLEac,
<a name="l01573"></a>01573              <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; isInta,
<a name="l01574"></a>01574              <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; isIntt) {
<a name="l01575"></a>01575   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; e1 = aLEt.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>();
<a name="l01576"></a>01576   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; e2 = tLEac.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>();
<a name="l01577"></a>01577   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l01578"></a>01578     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#a8ef991dfa16ee3a209b7f38014153101">isLE</a>(e1) &amp;&amp; <a class="code" href="namespaceCVC3.html#a8ef991dfa16ee3a209b7f38014153101">isLE</a>(e2),
<a name="l01579"></a>01579     <span class="stringliteral">&quot;ArithTheoremProducer3::finiteInterval:\n e1 = &quot;</span>
<a name="l01580"></a>01580     +e1.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>()+<span class="stringliteral">&quot;\n e2 = &quot;</span>+e2.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l01581"></a>01581     <span class="comment">// term &#39;t&#39; is the same in both inequalities</span>
<a name="l01582"></a>01582     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(e1[1] == e2[0],
<a name="l01583"></a>01583     <span class="stringliteral">&quot;ArithTheoremProducer3::finiteInterval:\n e1 = &quot;</span>
<a name="l01584"></a>01584     +e1.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>()+<span class="stringliteral">&quot;\n e2 = &quot;</span>+e2.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l01585"></a>01585     <span class="comment">// RHS in e2 is (a+c)</span>
<a name="l01586"></a>01586     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#afb0f7d15ddbd87f9abb128108101f557">isPlus</a>(e2[1]) &amp;&amp; e2[1].arity() == 2,
<a name="l01587"></a>01587     <span class="stringliteral">&quot;ArithTheoremProducer3::finiteInterval:\n e1 = &quot;</span>
<a name="l01588"></a>01588     +e1.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>()+<span class="stringliteral">&quot;\n e2 = &quot;</span>+e2.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l01589"></a>01589     <span class="comment">// term &#39;a&#39; in LHS of e1 and RHS of e2 is the same</span>
<a name="l01590"></a>01590     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(e1[0] == e2[1][0],
<a name="l01591"></a>01591     <span class="stringliteral">&quot;ArithTheoremProducer3::finiteInterval:\n e1 = &quot;</span>
<a name="l01592"></a>01592     +e1.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>()+<span class="stringliteral">&quot;\n e2 = &quot;</span>+e2.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l01593"></a>01593     <span class="comment">// &#39;c&#39; in the RHS of e2 is a positive integer constant</span>
<a name="l01594"></a>01594     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(e2[1][1].<a class="code" href="namespaceCVC3.html#ac0334a083d6782caa17ca0d337fddddf">isRational</a>() &amp;&amp; e2[1][1].getRational().isInteger()
<a name="l01595"></a>01595     &amp;&amp; e2[1][1].getRational() &gt;= 1,
<a name="l01596"></a>01596     <span class="stringliteral">&quot;ArithTheoremProducer3::finiteInterval:\n e1 = &quot;</span>
<a name="l01597"></a>01597     +e1.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>()+<span class="stringliteral">&quot;\n e2 = &quot;</span>+e2.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l01598"></a>01598     <span class="comment">// Integrality constraints</span>
<a name="l01599"></a>01599     <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; isIntaExpr = isInta.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>();
<a name="l01600"></a>01600     <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; isInttExpr = isIntt.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>();
<a name="l01601"></a>01601     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#aff7910c172ccdd1afb5e42964e2f248d">isIntPred</a>(isIntaExpr) &amp;&amp; isIntaExpr[0] == e1[0],
<a name="l01602"></a>01602     <span class="stringliteral">&quot;Wrong integrality constraint:\n e1 = &quot;</span>
<a name="l01603"></a>01603     +e1.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>()+<span class="stringliteral">&quot;\n isInta = &quot;</span>+isIntaExpr.toString());
<a name="l01604"></a>01604     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#aff7910c172ccdd1afb5e42964e2f248d">isIntPred</a>(isInttExpr) &amp;&amp; isInttExpr[0] == e1[1],
<a name="l01605"></a>01605     <span class="stringliteral">&quot;Wrong integrality constraint:\n e1 = &quot;</span>
<a name="l01606"></a>01606     +e1.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>()+<span class="stringliteral">&quot;\n isIntt = &quot;</span>+isInttExpr.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l01607"></a>01607   }
<a name="l01608"></a>01608   vector&lt;Theorem&gt; thms;
<a name="l01609"></a>01609   thms.push_back(aLEt);
<a name="l01610"></a>01610   thms.push_back(tLEac);
<a name="l01611"></a>01611   thms.push_back(isInta);
<a name="l01612"></a>01612   thms.push_back(isIntt);
<a name="l01613"></a>01613   <a class="code" href="classCVC3_1_1Assumptions.html">Assumptions</a> a(thms);
<a name="l01614"></a>01614   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l01615"></a>01615   <span class="keywordflow">if</span>(withProof()) {
<a name="l01616"></a>01616     vector&lt;Expr&gt; es;
<a name="l01617"></a>01617     vector&lt;Proof&gt; pfs;
<a name="l01618"></a>01618     es.push_back(e1);
<a name="l01619"></a>01619     es.push_back(e2);
<a name="l01620"></a>01620     es.push_back(isInta.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>());
<a name="l01621"></a>01621     es.push_back(isIntt.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>());
<a name="l01622"></a>01622     pfs.push_back(aLEt.<a class="code" href="classCVC3_1_1Theorem.html#a2d8352c07a756c3837683a27a1e659ef">getProof</a>());
<a name="l01623"></a>01623     pfs.push_back(tLEac.<a class="code" href="classCVC3_1_1Theorem.html#a2d8352c07a756c3837683a27a1e659ef">getProof</a>());
<a name="l01624"></a>01624     pfs.push_back(isInta.<a class="code" href="classCVC3_1_1Theorem.html#a2d8352c07a756c3837683a27a1e659ef">getProof</a>());
<a name="l01625"></a>01625     pfs.push_back(isIntt.<a class="code" href="classCVC3_1_1Theorem.html#a2d8352c07a756c3837683a27a1e659ef">getProof</a>());
<a name="l01626"></a>01626     pf = newPf(<span class="stringliteral">&quot;finite_interval&quot;</span>, es, pfs);
<a name="l01627"></a>01627   }
<a name="l01628"></a>01628   <span class="comment">// Construct GRAY_SHADOW(t, a, 0, c)</span>
<a name="l01629"></a>01629   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> g(grayShadow(e1[1], e1[0], 0, e2[1][1].getRational()));
<a name="l01630"></a>01630   <span class="keywordflow">return</span> newTheorem(g, a, pf);
<a name="l01631"></a>01631 }
<a name="l01632"></a>01632 
<a name="l01633"></a>01633 
<a name="l01634"></a>01634 <span class="comment">// Dark &amp; Gray shadows when a &lt;= b</span>
<a name="l01635"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a2ad479414c401fb8a4ea9631cbdd95c0">01635</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::darkGrayShadow2ab(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; betaLEbx,
<a name="l01636"></a>01636             <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; axLEalpha,
<a name="l01637"></a>01637             <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; isIntAlpha,
<a name="l01638"></a>01638             <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; isIntBeta,
<a name="l01639"></a>01639             <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; <a class="code" href="theory__quant_8cpp.html#ac9940420b1f3427ebe821902adbb578d">isIntx</a>) {
<a name="l01640"></a>01640   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; expr1 = betaLEbx.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>();
<a name="l01641"></a>01641   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; expr2 = axLEalpha.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>();
<a name="l01642"></a>01642   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; isIntAlphaExpr = isIntAlpha.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>();
<a name="l01643"></a>01643   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; isIntBetaExpr = isIntBeta.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>();
<a name="l01644"></a>01644   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; isIntxExpr = isIntx.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>();
<a name="l01645"></a>01645 
<a name="l01646"></a>01646   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l01647"></a>01647     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#a8ef991dfa16ee3a209b7f38014153101">isLE</a>(expr1) &amp;&amp; <a class="code" href="namespaceCVC3.html#a8ef991dfa16ee3a209b7f38014153101">isLE</a>(expr2),
<a name="l01648"></a>01648                 <span class="stringliteral">&quot;ArithTheoremProducer3::darkGrayShadow2ab: Wrong Kind: &quot;</span> +
<a name="l01649"></a>01649                 betaLEbx.<a class="code" href="classCVC3_1_1Theorem.html#ac4b1c9570ffb9cc901627ef2abb9ff77">toString</a>() +  axLEalpha.<a class="code" href="classCVC3_1_1Theorem.html#ac4b1c9570ffb9cc901627ef2abb9ff77">toString</a>());
<a name="l01650"></a>01650   }
<a name="l01651"></a>01651 
<a name="l01652"></a>01652   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; beta = expr1[0];
<a name="l01653"></a>01653   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; bx = expr1[1];
<a name="l01654"></a>01654   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; ax = expr2[0];
<a name="l01655"></a>01655   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; alpha = expr2[1];
<a name="l01656"></a>01656   <a class="code" href="classCVC3_1_1Rational.html">Rational</a> a = <a class="code" href="namespaceCVC3.html#a28ae8672047db708e99602ebaca89777">isMult</a>(ax)? ax[0].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>() : 1;
<a name="l01657"></a>01657   <a class="code" href="classCVC3_1_1Rational.html">Rational</a> b = <a class="code" href="namespaceCVC3.html#a28ae8672047db708e99602ebaca89777">isMult</a>(bx)? bx[0].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>() : 1;
<a name="l01658"></a>01658   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; x = <a class="code" href="namespaceCVC3.html#a28ae8672047db708e99602ebaca89777">isMult</a>(ax)? ax[1] : ax;
<a name="l01659"></a>01659 
<a name="l01660"></a>01660   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l01661"></a>01661     <span class="comment">// Integrality constraints</span>
<a name="l01662"></a>01662     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#aff7910c172ccdd1afb5e42964e2f248d">isIntPred</a>(isIntAlphaExpr) &amp;&amp; isIntAlphaExpr[0] == alpha,
<a name="l01663"></a>01663     <span class="stringliteral">&quot;ArithTheoremProducer3::darkGrayShadow2ab:\n &quot;</span>
<a name="l01664"></a>01664     <span class="stringliteral">&quot;wrong integrality constraint:\n alpha = &quot;</span>
<a name="l01665"></a>01665     +alpha.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>()+<span class="stringliteral">&quot;\n isIntAlpha = &quot;</span>
<a name="l01666"></a>01666     +isIntAlphaExpr.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l01667"></a>01667     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#aff7910c172ccdd1afb5e42964e2f248d">isIntPred</a>(isIntBetaExpr) &amp;&amp; isIntBetaExpr[0] == beta,
<a name="l01668"></a>01668     <span class="stringliteral">&quot;ArithTheoremProducer3::darkGrayShadow2ab:\n &quot;</span>
<a name="l01669"></a>01669     <span class="stringliteral">&quot;wrong integrality constraint:\n beta = &quot;</span>
<a name="l01670"></a>01670     +beta.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>()+<span class="stringliteral">&quot;\n isIntBeta = &quot;</span>
<a name="l01671"></a>01671     +isIntBetaExpr.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l01672"></a>01672     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#aff7910c172ccdd1afb5e42964e2f248d">isIntPred</a>(isIntxExpr) &amp;&amp; isIntxExpr[0] == x,
<a name="l01673"></a>01673     <span class="stringliteral">&quot;ArithTheoremProducer3::darkGrayShadow2ab:\n &quot;</span>
<a name="l01674"></a>01674     <span class="stringliteral">&quot;wrong integrality constraint:\n x = &quot;</span>
<a name="l01675"></a>01675     +x.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>()+<span class="stringliteral">&quot;\n isIntx = &quot;</span>
<a name="l01676"></a>01676     +isIntxExpr.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l01677"></a>01677     <span class="comment">// Expressions ax and bx should match on x</span>
<a name="l01678"></a>01678     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(!<a class="code" href="namespaceCVC3.html#a28ae8672047db708e99602ebaca89777">isMult</a>(ax) || ax.<a class="code" href="group__ExprPkg.html#ga28b901d05e52a5c646f83a95cc74f94b">arity</a>() == 2,
<a name="l01679"></a>01679     <span class="stringliteral">&quot;ArithTheoremProducer3::darkGrayShadow2ab:\n ax&lt;=alpha: &quot;</span> +
<a name="l01680"></a>01680                 axLEalpha.<a class="code" href="classCVC3_1_1Theorem.html#ac4b1c9570ffb9cc901627ef2abb9ff77">toString</a>());
<a name="l01681"></a>01681     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(!<a class="code" href="namespaceCVC3.html#a28ae8672047db708e99602ebaca89777">isMult</a>(bx) || (bx.<a class="code" href="group__ExprPkg.html#ga28b901d05e52a5c646f83a95cc74f94b">arity</a>() == 2 &amp;&amp; bx[1] == x),
<a name="l01682"></a>01682     <span class="stringliteral">&quot;ArithTheoremProducer3::darkGrayShadow2ab:\n beta&lt;=bx: &quot;</span>
<a name="l01683"></a>01683     +betaLEbx.<a class="code" href="classCVC3_1_1Theorem.html#ac4b1c9570ffb9cc901627ef2abb9ff77">toString</a>()
<a name="l01684"></a>01684     +<span class="stringliteral">&quot;\n ax&lt;=alpha: &quot;</span>+ axLEalpha.<a class="code" href="classCVC3_1_1Theorem.html#ac4b1c9570ffb9cc901627ef2abb9ff77">toString</a>());
<a name="l01685"></a>01685     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(1 &lt;= a &amp;&amp; a &lt;= b &amp;&amp; 2 &lt;= b,
<a name="l01686"></a>01686     <span class="stringliteral">&quot;ArithTheoremProducer3::darkGrayShadow2ab:\n beta&lt;=bx: &quot;</span>
<a name="l01687"></a>01687     +betaLEbx.<a class="code" href="classCVC3_1_1Theorem.html#ac4b1c9570ffb9cc901627ef2abb9ff77">toString</a>()
<a name="l01688"></a>01688     +<span class="stringliteral">&quot;\n ax&lt;=alpha: &quot;</span>+ axLEalpha.<a class="code" href="classCVC3_1_1Theorem.html#ac4b1c9570ffb9cc901627ef2abb9ff77">toString</a>());
<a name="l01689"></a>01689   }
<a name="l01690"></a>01690   vector&lt;Theorem&gt; thms;
<a name="l01691"></a>01691   thms.push_back(betaLEbx);
<a name="l01692"></a>01692   thms.push_back(axLEalpha);
<a name="l01693"></a>01693   thms.push_back(isIntAlpha);
<a name="l01694"></a>01694   thms.push_back(isIntBeta);
<a name="l01695"></a>01695   thms.push_back(isIntx);
<a name="l01696"></a>01696   <a class="code" href="classCVC3_1_1Assumptions.html">Assumptions</a> A(thms);
<a name="l01697"></a>01697 
<a name="l01698"></a>01698   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> bAlpha = <a class="code" href="namespaceCVC3.html#adb35e0739f86730543924dbc8211a778">multExpr</a>(rat(b), alpha);
<a name="l01699"></a>01699   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> aBeta = <a class="code" href="namespaceCVC3.html#adb35e0739f86730543924dbc8211a778">multExpr</a>(rat(a), beta);
<a name="l01700"></a>01700   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> t = <a class="code" href="namespaceCVC3.html#a9ba326c305c5aeb61de515009aaa61f8">minusExpr</a>(bAlpha, aBeta);
<a name="l01701"></a>01701   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> d = darkShadow(rat(a*b-1), t);
<a name="l01702"></a>01702   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> g = grayShadow(ax, alpha, -a+1, 0);
<a name="l01703"></a>01703 
<a name="l01704"></a>01704   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l01705"></a>01705   <span class="keywordflow">if</span>(withProof()) {
<a name="l01706"></a>01706     vector&lt;Expr&gt; exprs;
<a name="l01707"></a>01707     exprs.push_back(expr1);
<a name="l01708"></a>01708     exprs.push_back(expr2);
<a name="l01709"></a>01709     exprs.push_back(d);
<a name="l01710"></a>01710     exprs.push_back(g);
<a name="l01711"></a>01711 
<a name="l01712"></a>01712     vector&lt;Proof&gt; pfs;
<a name="l01713"></a>01713     pfs.push_back(betaLEbx.<a class="code" href="classCVC3_1_1Theorem.html#a2d8352c07a756c3837683a27a1e659ef">getProof</a>());
<a name="l01714"></a>01714     pfs.push_back(axLEalpha.<a class="code" href="classCVC3_1_1Theorem.html#a2d8352c07a756c3837683a27a1e659ef">getProof</a>());
<a name="l01715"></a>01715     pfs.push_back(isIntAlpha.<a class="code" href="classCVC3_1_1Theorem.html#a2d8352c07a756c3837683a27a1e659ef">getProof</a>());
<a name="l01716"></a>01716     pfs.push_back(isIntBeta.<a class="code" href="classCVC3_1_1Theorem.html#a2d8352c07a756c3837683a27a1e659ef">getProof</a>());
<a name="l01717"></a>01717     pfs.push_back(isIntx.<a class="code" href="classCVC3_1_1Theorem.html#a2d8352c07a756c3837683a27a1e659ef">getProof</a>());
<a name="l01718"></a>01718 
<a name="l01719"></a>01719     pf = newPf(<span class="stringliteral">&quot;dark_grayshadow_2ab&quot;</span>, exprs, pfs);
<a name="l01720"></a>01720   }
<a name="l01721"></a>01721 
<a name="l01722"></a>01722   <span class="keywordflow">return</span> newTheorem((d || g), A, pf);
<a name="l01723"></a>01723 }
<a name="l01724"></a>01724 
<a name="l01725"></a>01725 <span class="comment">// Dark &amp; Gray shadows when b &lt;= a</span>
<a name="l01726"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a8b2e8589d24fc69616ba431588c50b3e">01726</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::darkGrayShadow2ba(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; betaLEbx,
<a name="l01727"></a>01727             <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; axLEalpha,
<a name="l01728"></a>01728             <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; isIntAlpha,
<a name="l01729"></a>01729             <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; isIntBeta,
<a name="l01730"></a>01730             <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; <a class="code" href="theory__quant_8cpp.html#ac9940420b1f3427ebe821902adbb578d">isIntx</a>) {
<a name="l01731"></a>01731   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; expr1 = betaLEbx.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>();
<a name="l01732"></a>01732   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; expr2 = axLEalpha.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>();
<a name="l01733"></a>01733   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; isIntAlphaExpr = isIntAlpha.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>();
<a name="l01734"></a>01734   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; isIntBetaExpr = isIntBeta.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>();
<a name="l01735"></a>01735   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; isIntxExpr = isIntx.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>();
<a name="l01736"></a>01736 
<a name="l01737"></a>01737   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l01738"></a>01738     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#a8ef991dfa16ee3a209b7f38014153101">isLE</a>(expr1) &amp;&amp; <a class="code" href="namespaceCVC3.html#a8ef991dfa16ee3a209b7f38014153101">isLE</a>(expr2),
<a name="l01739"></a>01739                 <span class="stringliteral">&quot;ArithTheoremProducer3::darkGrayShadow2ba: Wrong Kind: &quot;</span> +
<a name="l01740"></a>01740                 betaLEbx.<a class="code" href="classCVC3_1_1Theorem.html#ac4b1c9570ffb9cc901627ef2abb9ff77">toString</a>() +  axLEalpha.<a class="code" href="classCVC3_1_1Theorem.html#ac4b1c9570ffb9cc901627ef2abb9ff77">toString</a>());
<a name="l01741"></a>01741   }
<a name="l01742"></a>01742 
<a name="l01743"></a>01743   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; beta = expr1[0];
<a name="l01744"></a>01744   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; bx = expr1[1];
<a name="l01745"></a>01745   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; ax = expr2[0];
<a name="l01746"></a>01746   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; alpha = expr2[1];
<a name="l01747"></a>01747   <a class="code" href="classCVC3_1_1Rational.html">Rational</a> a = <a class="code" href="namespaceCVC3.html#a28ae8672047db708e99602ebaca89777">isMult</a>(ax)? ax[0].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>() : 1;
<a name="l01748"></a>01748   <a class="code" href="classCVC3_1_1Rational.html">Rational</a> b = <a class="code" href="namespaceCVC3.html#a28ae8672047db708e99602ebaca89777">isMult</a>(bx)? bx[0].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>() : 1;
<a name="l01749"></a>01749   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; x = <a class="code" href="namespaceCVC3.html#a28ae8672047db708e99602ebaca89777">isMult</a>(ax)? ax[1] : ax;
<a name="l01750"></a>01750 
<a name="l01751"></a>01751   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l01752"></a>01752     <span class="comment">// Integrality constraints</span>
<a name="l01753"></a>01753     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#aff7910c172ccdd1afb5e42964e2f248d">isIntPred</a>(isIntAlphaExpr) &amp;&amp; isIntAlphaExpr[0] == alpha,
<a name="l01754"></a>01754     <span class="stringliteral">&quot;ArithTheoremProducer3::darkGrayShadow2ab:\n &quot;</span>
<a name="l01755"></a>01755     <span class="stringliteral">&quot;wrong integrality constraint:\n alpha = &quot;</span>
<a name="l01756"></a>01756     +alpha.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>()+<span class="stringliteral">&quot;\n isIntAlpha = &quot;</span>
<a name="l01757"></a>01757     +isIntAlphaExpr.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l01758"></a>01758     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#aff7910c172ccdd1afb5e42964e2f248d">isIntPred</a>(isIntBetaExpr) &amp;&amp; isIntBetaExpr[0] == beta,
<a name="l01759"></a>01759     <span class="stringliteral">&quot;ArithTheoremProducer3::darkGrayShadow2ab:\n &quot;</span>
<a name="l01760"></a>01760     <span class="stringliteral">&quot;wrong integrality constraint:\n beta = &quot;</span>
<a name="l01761"></a>01761     +beta.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>()+<span class="stringliteral">&quot;\n isIntBeta = &quot;</span>
<a name="l01762"></a>01762     +isIntBetaExpr.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l01763"></a>01763     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#aff7910c172ccdd1afb5e42964e2f248d">isIntPred</a>(isIntxExpr) &amp;&amp; isIntxExpr[0] == x,
<a name="l01764"></a>01764     <span class="stringliteral">&quot;ArithTheoremProducer3::darkGrayShadow2ab:\n &quot;</span>
<a name="l01765"></a>01765     <span class="stringliteral">&quot;wrong integrality constraint:\n x = &quot;</span>
<a name="l01766"></a>01766     +x.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>()+<span class="stringliteral">&quot;\n isIntx = &quot;</span>
<a name="l01767"></a>01767     +isIntxExpr.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l01768"></a>01768     <span class="comment">// Expressions ax and bx should match on x</span>
<a name="l01769"></a>01769     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(!<a class="code" href="namespaceCVC3.html#a28ae8672047db708e99602ebaca89777">isMult</a>(ax) || ax.<a class="code" href="group__ExprPkg.html#ga28b901d05e52a5c646f83a95cc74f94b">arity</a>() == 2,
<a name="l01770"></a>01770     <span class="stringliteral">&quot;ArithTheoremProducer3::darkGrayShadow2ba:\n ax&lt;=alpha: &quot;</span> +
<a name="l01771"></a>01771                 axLEalpha.<a class="code" href="classCVC3_1_1Theorem.html#ac4b1c9570ffb9cc901627ef2abb9ff77">toString</a>());
<a name="l01772"></a>01772     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(!<a class="code" href="namespaceCVC3.html#a28ae8672047db708e99602ebaca89777">isMult</a>(bx) || (bx.<a class="code" href="group__ExprPkg.html#ga28b901d05e52a5c646f83a95cc74f94b">arity</a>() == 2 &amp;&amp; bx[1] == x),
<a name="l01773"></a>01773     <span class="stringliteral">&quot;ArithTheoremProducer3::darkGrayShadow2ba:\n beta&lt;=bx: &quot;</span>
<a name="l01774"></a>01774     +betaLEbx.<a class="code" href="classCVC3_1_1Theorem.html#ac4b1c9570ffb9cc901627ef2abb9ff77">toString</a>()
<a name="l01775"></a>01775     +<span class="stringliteral">&quot;\n ax&lt;=alpha: &quot;</span>+ axLEalpha.<a class="code" href="classCVC3_1_1Theorem.html#ac4b1c9570ffb9cc901627ef2abb9ff77">toString</a>());
<a name="l01776"></a>01776     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(1 &lt;= b &amp;&amp; b &lt;= a &amp;&amp; 2 &lt;= a,
<a name="l01777"></a>01777     <span class="stringliteral">&quot;ArithTheoremProducer3::darkGrayShadow2ba:\n beta&lt;=bx: &quot;</span>
<a name="l01778"></a>01778     +betaLEbx.<a class="code" href="classCVC3_1_1Theorem.html#ac4b1c9570ffb9cc901627ef2abb9ff77">toString</a>()
<a name="l01779"></a>01779     +<span class="stringliteral">&quot;\n ax&lt;=alpha: &quot;</span>+ axLEalpha.<a class="code" href="classCVC3_1_1Theorem.html#ac4b1c9570ffb9cc901627ef2abb9ff77">toString</a>());
<a name="l01780"></a>01780   }
<a name="l01781"></a>01781   vector&lt;Theorem&gt; thms;
<a name="l01782"></a>01782   thms.push_back(betaLEbx);
<a name="l01783"></a>01783   thms.push_back(axLEalpha);
<a name="l01784"></a>01784   thms.push_back(isIntAlpha);
<a name="l01785"></a>01785   thms.push_back(isIntBeta);
<a name="l01786"></a>01786   thms.push_back(isIntx);
<a name="l01787"></a>01787   <a class="code" href="classCVC3_1_1Assumptions.html">Assumptions</a> A(thms);
<a name="l01788"></a>01788   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l01789"></a>01789   <span class="keywordflow">if</span>(withProof()) {
<a name="l01790"></a>01790     vector&lt;Proof&gt; pfs;
<a name="l01791"></a>01791     pfs.push_back(betaLEbx.<a class="code" href="classCVC3_1_1Theorem.html#a2d8352c07a756c3837683a27a1e659ef">getProof</a>());
<a name="l01792"></a>01792     pfs.push_back(axLEalpha.<a class="code" href="classCVC3_1_1Theorem.html#a2d8352c07a756c3837683a27a1e659ef">getProof</a>());
<a name="l01793"></a>01793     pfs.push_back(isIntAlpha.<a class="code" href="classCVC3_1_1Theorem.html#a2d8352c07a756c3837683a27a1e659ef">getProof</a>());
<a name="l01794"></a>01794     pfs.push_back(isIntBeta.<a class="code" href="classCVC3_1_1Theorem.html#a2d8352c07a756c3837683a27a1e659ef">getProof</a>());
<a name="l01795"></a>01795     pfs.push_back(isIntx.<a class="code" href="classCVC3_1_1Theorem.html#a2d8352c07a756c3837683a27a1e659ef">getProof</a>());
<a name="l01796"></a>01796 
<a name="l01797"></a>01797     pf = newPf(<span class="stringliteral">&quot;dark_grayshadow_2ba&quot;</span>, betaLEbx.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>(),
<a name="l01798"></a>01798          axLEalpha.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>(), pfs);
<a name="l01799"></a>01799   }
<a name="l01800"></a>01800 
<a name="l01801"></a>01801   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> bAlpha = <a class="code" href="namespaceCVC3.html#adb35e0739f86730543924dbc8211a778">multExpr</a>(rat(b), alpha);
<a name="l01802"></a>01802   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> aBeta = <a class="code" href="namespaceCVC3.html#adb35e0739f86730543924dbc8211a778">multExpr</a>(rat(a), beta);
<a name="l01803"></a>01803   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> t = <a class="code" href="namespaceCVC3.html#a9ba326c305c5aeb61de515009aaa61f8">minusExpr</a>(bAlpha, aBeta);
<a name="l01804"></a>01804   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> d = darkShadow(rat(a*b-1), t);
<a name="l01805"></a>01805   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> g = grayShadow(bx, beta, 0, b-1);
<a name="l01806"></a>01806   <span class="keywordflow">return</span> newTheorem((d || g), A, pf);
<a name="l01807"></a>01807 }
<a name="l01808"></a>01808 <span class="comment"></span>
<a name="l01809"></a>01809 <span class="comment">/*! takes a dark shadow and expands it into an inequality.</span>
<a name="l01810"></a>01810 <span class="comment">*/</span>
<a name="l01811"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a372efa694fb08c901deff55f5f108ffb">01811</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::expandDarkShadow(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; darkShadow) {
<a name="l01812"></a>01812   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; theShadow = darkShadow.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>();
<a name="l01813"></a>01813   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>){
<a name="l01814"></a>01814     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#a61ff5938806e85a64c55e42c6fca5255">isDarkShadow</a>(theShadow),
<a name="l01815"></a>01815     <span class="stringliteral">&quot;ArithTheoremProducer3::expandDarkShadow: not DARK_SHADOW: &quot;</span> +
<a name="l01816"></a>01816     theShadow.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l01817"></a>01817   }
<a name="l01818"></a>01818   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l01819"></a>01819   <span class="keywordflow">if</span>(withProof())
<a name="l01820"></a>01820     pf = newPf(<span class="stringliteral">&quot;expand_dark_shadow&quot;</span>, theShadow, darkShadow.<a class="code" href="classCVC3_1_1Theorem.html#a2d8352c07a756c3837683a27a1e659ef">getProof</a>());
<a name="l01821"></a>01821   <span class="keywordflow">return</span> newTheorem(<a class="code" href="namespaceCVC3.html#aebfd8a82800bd3dff4c8db461a52cdea">leExpr</a>(theShadow[0], theShadow[1]), darkShadow.<a class="code" href="classCVC3_1_1Theorem.html#a5e9ab00a613df15cc02f55edb55a67b3">getAssumptionsRef</a>(), pf);
<a name="l01822"></a>01822 }
<a name="l01823"></a>01823 
<a name="l01824"></a>01824 
<a name="l01825"></a>01825 <span class="comment">// takes a grayShadow (c1==c2) and expands it into an equality</span>
<a name="l01826"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#aacc831490c52da277133fe625522216f">01826</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::expandGrayShadow0(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; grayShadow) {
<a name="l01827"></a>01827   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; theShadow = grayShadow.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>();
<a name="l01828"></a>01828   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l01829"></a>01829     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#ab9a9fba0a64da2bd1ee5194fdedffb07">isGrayShadow</a>(theShadow),
<a name="l01830"></a>01830     <span class="stringliteral">&quot;ArithTheoremProducer3::expandGrayShadowConst0:&quot;</span>
<a name="l01831"></a>01831     <span class="stringliteral">&quot; not GRAY_SHADOW: &quot;</span> +
<a name="l01832"></a>01832     theShadow.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l01833"></a>01833     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(theShadow[2] == theShadow[3],
<a name="l01834"></a>01834     <span class="stringliteral">&quot;ArithTheoremProducer3::expandGrayShadow0: c1!=c2: &quot;</span> +
<a name="l01835"></a>01835     theShadow.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l01836"></a>01836   }
<a name="l01837"></a>01837   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l01838"></a>01838   <span class="keywordflow">if</span>(withProof()) pf = newPf(<span class="stringliteral">&quot;expand_gray_shadowconst0&quot;</span>, theShadow,
<a name="l01839"></a>01839            grayShadow.<a class="code" href="classCVC3_1_1Theorem.html#a2d8352c07a756c3837683a27a1e659ef">getProof</a>());
<a name="l01840"></a>01840   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; v = theShadow[0];
<a name="l01841"></a>01841   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; e = theShadow[1];
<a name="l01842"></a>01842   <span class="keywordflow">return</span> newRWTheorem(v, e + theShadow[2], grayShadow.<a class="code" href="classCVC3_1_1Theorem.html#a5e9ab00a613df15cc02f55edb55a67b3">getAssumptionsRef</a>(), pf);
<a name="l01843"></a>01843 }
<a name="l01844"></a>01844 
<a name="l01845"></a>01845 
<a name="l01846"></a>01846 <span class="comment">// G ==&gt; (G1 or G2) and (!G1 or !G2),</span>
<a name="l01847"></a>01847 <span class="comment">// where G  = G(x, e, c1, c2),</span>
<a name="l01848"></a>01848 <span class="comment">//       G1 = G(x,e,c1,c)</span>
<a name="l01849"></a>01849 <span class="comment">//       G2 = G(x,e,c+1,c2),</span>
<a name="l01850"></a>01850 <span class="comment">// and    c = floor((c1+c2)/2)</span>
<a name="l01851"></a>01851 <span class="comment">// DEJAN: TRY THE MIDDLE IMMEDIATELY, WE MIGHT GET LUCKY</span>
<a name="l01852"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#ae609e58a7bee454d0f18dc1465cd2167">01852</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::splitGrayShadow(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; gThm) {
<a name="l01853"></a>01853   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; theShadow = gThm.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>();
<a name="l01854"></a>01854   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l01855"></a>01855     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#ab9a9fba0a64da2bd1ee5194fdedffb07">isGrayShadow</a>(theShadow),
<a name="l01856"></a>01856     <span class="stringliteral">&quot;ArithTheoremProducer3::expandGrayShadowConst: not a shadow&quot;</span> +
<a name="l01857"></a>01857     theShadow.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l01858"></a>01858   }
<a name="l01859"></a>01859 
<a name="l01860"></a>01860   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Rational.html">Rational</a>&amp; c1 = theShadow[2].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>();
<a name="l01861"></a>01861   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Rational.html">Rational</a>&amp; c2 = theShadow[3].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>();
<a name="l01862"></a>01862 
<a name="l01863"></a>01863   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l01864"></a>01864     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(c1.<a class="code" href="classCVC3_1_1Rational.html#a1366320f4de558bb964c67f8aecedb36">isInteger</a>() &amp;&amp; c2.<a class="code" href="classCVC3_1_1Rational.html#a1366320f4de558bb964c67f8aecedb36">isInteger</a>() &amp;&amp; c1 &lt; c2,
<a name="l01865"></a>01865     <span class="stringliteral">&quot;ArithTheoremProducer3::expandGrayShadow: &quot;</span> +
<a name="l01866"></a>01866     theShadow.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l01867"></a>01867   }
<a name="l01868"></a>01868 
<a name="l01869"></a>01869   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; v = theShadow[0];
<a name="l01870"></a>01870   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; e = theShadow[1];
<a name="l01871"></a>01871 
<a name="l01872"></a>01872   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l01873"></a>01873   <a class="code" href="classCVC3_1_1Rational.html">Rational</a> c(floor((c1+c2) / 2));
<a name="l01874"></a>01874   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> g1(grayShadow(v, e, c1, c));
<a name="l01875"></a>01875   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> g2(grayShadow(v, e, c+1, c2));
<a name="l01876"></a>01876 
<a name="l01877"></a>01877   <span class="keywordflow">if</span>(withProof()){
<a name="l01878"></a>01878     vector&lt;Expr&gt; exprs;
<a name="l01879"></a>01879     exprs.push_back(theShadow);
<a name="l01880"></a>01880     exprs.push_back(g1);
<a name="l01881"></a>01881     exprs.push_back(g2);
<a name="l01882"></a>01882     pf = newPf(<span class="stringliteral">&quot;split_gray_shadow&quot;</span>, exprs, gThm.<a class="code" href="classCVC3_1_1Theorem.html#a2d8352c07a756c3837683a27a1e659ef">getProof</a>());
<a name="l01883"></a>01883   }
<a name="l01884"></a>01884 
<a name="l01885"></a>01885   <span class="keywordflow">return</span> newTheorem((g1 || g2) &amp;&amp; (!g1 || !g2), gThm.<a class="code" href="classCVC3_1_1Theorem.html#a5e9ab00a613df15cc02f55edb55a67b3">getAssumptionsRef</a>(), pf);
<a name="l01886"></a>01886 }
<a name="l01887"></a>01887 
<a name="l01888"></a>01888 
<a name="l01889"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#ab9dd38464b6e02af6d7c570119c6aec3">01889</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::expandGrayShadow(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; gThm) {
<a name="l01890"></a>01890   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; theShadow = gThm.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>();
<a name="l01891"></a>01891   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l01892"></a>01892     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#ab9a9fba0a64da2bd1ee5194fdedffb07">isGrayShadow</a>(theShadow),
<a name="l01893"></a>01893     <span class="stringliteral">&quot;ArithTheoremProducer3::expandGrayShadowConst: not a shadow&quot;</span> +
<a name="l01894"></a>01894     theShadow.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l01895"></a>01895   }
<a name="l01896"></a>01896 
<a name="l01897"></a>01897   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Rational.html">Rational</a>&amp; c1 = theShadow[2].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>();
<a name="l01898"></a>01898   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Rational.html">Rational</a>&amp; c2 = theShadow[3].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>();
<a name="l01899"></a>01899 
<a name="l01900"></a>01900   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l01901"></a>01901     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(c1.<a class="code" href="classCVC3_1_1Rational.html#a1366320f4de558bb964c67f8aecedb36">isInteger</a>() &amp;&amp; c2.<a class="code" href="classCVC3_1_1Rational.html#a1366320f4de558bb964c67f8aecedb36">isInteger</a>() &amp;&amp; c1 &lt; c2,
<a name="l01902"></a>01902     <span class="stringliteral">&quot;ArithTheoremProducer3::expandGrayShadow: &quot;</span> +
<a name="l01903"></a>01903     theShadow.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l01904"></a>01904   }
<a name="l01905"></a>01905 
<a name="l01906"></a>01906   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; v = theShadow[0];
<a name="l01907"></a>01907   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; e = theShadow[1];
<a name="l01908"></a>01908 
<a name="l01909"></a>01909   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l01910"></a>01910   <span class="keywordflow">if</span>(withProof())
<a name="l01911"></a>01911     pf = newPf(<span class="stringliteral">&quot;expand_gray_shadow&quot;</span>, theShadow, gThm.<a class="code" href="classCVC3_1_1Theorem.html#a2d8352c07a756c3837683a27a1e659ef">getProof</a>());
<a name="l01912"></a>01912   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> ineq1(<a class="code" href="namespaceCVC3.html#aebfd8a82800bd3dff4c8db461a52cdea">leExpr</a>(e+rat(c1), v));
<a name="l01913"></a>01913   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> ineq2(<a class="code" href="namespaceCVC3.html#aebfd8a82800bd3dff4c8db461a52cdea">leExpr</a>(v, e+rat(c2)));
<a name="l01914"></a>01914   <span class="keywordflow">return</span> newTheorem(ineq1 &amp;&amp; ineq2, gThm.<a class="code" href="classCVC3_1_1Theorem.html#a5e9ab00a613df15cc02f55edb55a67b3">getAssumptionsRef</a>(), pf);
<a name="l01915"></a>01915 }
<a name="l01916"></a>01916 
<a name="l01917"></a>01917 
<a name="l01918"></a>01918 <span class="comment">// Expanding GRAY_SHADOW(a*x, c, b), where c is a constant</span>
<a name="l01919"></a>01919 <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>
<a name="l01920"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a43d1cf15faefe439c344508bf60e5e96">01920</a> ArithTheoremProducer3::expandGrayShadowConst(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; gThm) {
<a name="l01921"></a>01921   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; theShadow = gThm.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>();
<a name="l01922"></a>01922   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; ax = theShadow[0];
<a name="l01923"></a>01923   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; cExpr = theShadow[1];
<a name="l01924"></a>01924   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; bExpr = theShadow[2];
<a name="l01925"></a>01925 
<a name="l01926"></a>01926   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l01927"></a>01927     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(!<a class="code" href="namespaceCVC3.html#a28ae8672047db708e99602ebaca89777">isMult</a>(ax) || ax[0].<a class="code" href="namespaceCVC3.html#ac0334a083d6782caa17ca0d337fddddf">isRational</a>(),
<a name="l01928"></a>01928     <span class="stringliteral">&quot;ArithTheoremProducer3::expandGrayShadowConst: &quot;</span>
<a name="l01929"></a>01929     <span class="stringliteral">&quot;&#39;a&#39; in a*x is not a const: &quot;</span> +theShadow.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l01930"></a>01930   }
<a name="l01931"></a>01931 
<a name="l01932"></a>01932   <a class="code" href="classCVC3_1_1Rational.html">Rational</a> a = <a class="code" href="namespaceCVC3.html#a28ae8672047db708e99602ebaca89777">isMult</a>(ax)? ax[0].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>() : 1;
<a name="l01933"></a>01933 
<a name="l01934"></a>01934   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l01935"></a>01935     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#ab9a9fba0a64da2bd1ee5194fdedffb07">isGrayShadow</a>(theShadow),
<a name="l01936"></a>01936     <span class="stringliteral">&quot;ArithTheoremProducer3::expandGrayShadowConst: &quot;</span>
<a name="l01937"></a>01937     <span class="stringliteral">&quot;not a GRAY_SHADOW: &quot;</span> +theShadow.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l01938"></a>01938     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(a.<a class="code" href="classCVC3_1_1Rational.html#a1366320f4de558bb964c67f8aecedb36">isInteger</a>() &amp;&amp; a &gt;= 1,
<a name="l01939"></a>01939     <span class="stringliteral">&quot;ArithTheoremProducer3::expandGrayShadowConst: &quot;</span>
<a name="l01940"></a>01940     <span class="stringliteral">&quot;&#39;a&#39; is not integer: &quot;</span> +theShadow.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l01941"></a>01941     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(cExpr.<a class="code" href="group__ExprPkg.html#gac5ced6adc7a60945ea6707ef494aa28f">isRational</a>(),
<a name="l01942"></a>01942     <span class="stringliteral">&quot;ArithTheoremProducer3::expandGrayShadowConst: &quot;</span>
<a name="l01943"></a>01943     <span class="stringliteral">&quot;&#39;c&#39; is not rational&quot;</span> +theShadow.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l01944"></a>01944     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(bExpr.<a class="code" href="group__ExprPkg.html#gac5ced6adc7a60945ea6707ef494aa28f">isRational</a>() &amp;&amp; bExpr.<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>().<a class="code" href="classCVC3_1_1Rational.html#a1366320f4de558bb964c67f8aecedb36">isInteger</a>(),
<a name="l01945"></a>01945     <span class="stringliteral">&quot;ArithTheoremProducer3::expandGrayShadowConst: b not integer: &quot;</span>
<a name="l01946"></a>01946     +theShadow.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l01947"></a>01947   }
<a name="l01948"></a>01948 
<a name="l01949"></a>01949   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Rational.html">Rational</a>&amp; b = bExpr.<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>();
<a name="l01950"></a>01950   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Rational.html">Rational</a>&amp; c = cExpr.<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>();
<a name="l01951"></a>01951   <a class="code" href="classCVC3_1_1Rational.html">Rational</a> j = constRHSGrayShadow(c,b,a);
<a name="l01952"></a>01952   <span class="comment">// Compute sign(b)*j(c,b,a)</span>
<a name="l01953"></a>01953   <a class="code" href="classCVC3_1_1Rational.html">Rational</a> signB = (b&gt;0)? 1 : -1;
<a name="l01954"></a>01954   <span class="comment">// |b| (absolute value of b)</span>
<a name="l01955"></a>01955   <a class="code" href="classCVC3_1_1Rational.html">Rational</a> bAbs = <a class="code" href="namespaceCVC3.html#a39fc111339d6dffdc98d6a25b68dff0e">abs</a>(b);
<a name="l01956"></a>01956 
<a name="l01957"></a>01957   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Assumptions.html">Assumptions</a>&amp; assump(gThm.<a class="code" href="classCVC3_1_1Theorem.html#a5e9ab00a613df15cc02f55edb55a67b3">getAssumptionsRef</a>());
<a name="l01958"></a>01958   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l01959"></a>01959   <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> conc;  <span class="comment">// Conclusion of the rule</span>
<a name="l01960"></a>01960 
<a name="l01961"></a>01961   <span class="keywordflow">if</span>(bAbs &lt; j) {
<a name="l01962"></a>01962     <span class="keywordflow">if</span>(withProof())
<a name="l01963"></a>01963       pf = newPf(<span class="stringliteral">&quot;expand_gray_shadow_const_0&quot;</span>, theShadow,
<a name="l01964"></a>01964      gThm.<a class="code" href="classCVC3_1_1Theorem.html#a2d8352c07a756c3837683a27a1e659ef">getProof</a>());
<a name="l01965"></a>01965     conc = newTheorem(d_em-&gt;falseExpr(), assump, pf);
<a name="l01966"></a>01966   } <span class="keywordflow">else</span> <span class="keywordflow">if</span>(bAbs &lt; a+j) {
<a name="l01967"></a>01967     <span class="keywordflow">if</span>(withProof())
<a name="l01968"></a>01968       pf = newPf(<span class="stringliteral">&quot;expand_gray_shadow_const_1&quot;</span>, theShadow,
<a name="l01969"></a>01969      gThm.<a class="code" href="classCVC3_1_1Theorem.html#a2d8352c07a756c3837683a27a1e659ef">getProof</a>());
<a name="l01970"></a>01970     conc = newRWTheorem(ax, rat(c+b-signB*j), assump, pf);
<a name="l01971"></a>01971   } <span class="keywordflow">else</span> {
<a name="l01972"></a>01972     <span class="keywordflow">if</span>(withProof())
<a name="l01973"></a>01973       pf = newPf(<span class="stringliteral">&quot;expand_gray_shadow_const&quot;</span>, theShadow,
<a name="l01974"></a>01974      gThm.<a class="code" href="classCVC3_1_1Theorem.html#a2d8352c07a756c3837683a27a1e659ef">getProof</a>());
<a name="l01975"></a>01975     <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> newGrayShadow(<a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>(<a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024ae88f497d92023928ed529d704ecb1881">GRAY_SHADOW</a>, ax, cExpr, rat(b-signB*(a+j))));
<a name="l01976"></a>01976     conc = newTheorem(ax.<a class="code" href="group__ExprPkg.html#gacb48495ca445c895f95d0c3c1ae2070b">eqExpr</a>(rat(c+b-signB*j)).<a class="code" href="group__ExprPkg.html#gaf310870d783fff343e77ba9c2277c626">orExpr</a>(newGrayShadow),
<a name="l01977"></a>01977           assump, pf);
<a name="l01978"></a>01978   }
<a name="l01979"></a>01979 
<a name="l01980"></a>01980   <span class="keywordflow">return</span> conc;
<a name="l01981"></a>01981 }
<a name="l01982"></a>01982 
<a name="l01983"></a>01983 
<a name="l01984"></a>01984 <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>
<a name="l01985"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a0a5eb9028805dd1ee141713b7c70be77">01985</a> ArithTheoremProducer3::grayShadowConst(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; gThm) {
<a name="l01986"></a>01986   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; g = gThm.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>();
<a name="l01987"></a>01987   <span class="keywordtype">bool</span> checkProofs(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>);
<a name="l01988"></a>01988   <span class="keywordflow">if</span>(checkProofs) {
<a name="l01989"></a>01989     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#ab9a9fba0a64da2bd1ee5194fdedffb07">isGrayShadow</a>(g), <span class="stringliteral">&quot;ArithTheoremProducer3::grayShadowConst(&quot;</span>
<a name="l01990"></a>01990     +g.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>()+<span class="stringliteral">&quot;)&quot;</span>);
<a name="l01991"></a>01991   }
<a name="l01992"></a>01992 
<a name="l01993"></a>01993   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; ax = g[0];
<a name="l01994"></a>01994   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; e = g[1];
<a name="l01995"></a>01995   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Rational.html">Rational</a>&amp; c1 = g[2].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>();
<a name="l01996"></a>01996   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Rational.html">Rational</a>&amp; c2 = g[3].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>();
<a name="l01997"></a>01997   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> aExpr, x;
<a name="l01998"></a>01998   d_theoryArith-&gt;separateMonomial(ax, aExpr, x);
<a name="l01999"></a>01999 
<a name="l02000"></a>02000   <span class="keywordflow">if</span>(checkProofs) {
<a name="l02001"></a>02001     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(e.<a class="code" href="group__ExprPkg.html#gac5ced6adc7a60945ea6707ef494aa28f">isRational</a>() &amp;&amp; e.<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>().<a class="code" href="classCVC3_1_1Rational.html#a1366320f4de558bb964c67f8aecedb36">isInteger</a>(),
<a name="l02002"></a>02002     <span class="stringliteral">&quot;ArithTheoremProducer3::grayShadowConst(&quot;</span>+g.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>()+<span class="stringliteral">&quot;)&quot;</span>);
<a name="l02003"></a>02003     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(aExpr.<a class="code" href="group__ExprPkg.html#gac5ced6adc7a60945ea6707ef494aa28f">isRational</a>(),
<a name="l02004"></a>02004     <span class="stringliteral">&quot;ArithTheoremProducer3::grayShadowConst(&quot;</span>+g.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>()+<span class="stringliteral">&quot;)&quot;</span>);
<a name="l02005"></a>02005   }
<a name="l02006"></a>02006 
<a name="l02007"></a>02007   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Rational.html">Rational</a>&amp; a = aExpr.<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>();
<a name="l02008"></a>02008   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Rational.html">Rational</a>&amp; c = e.<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>();
<a name="l02009"></a>02009 
<a name="l02010"></a>02010   <span class="keywordflow">if</span>(checkProofs) {
<a name="l02011"></a>02011     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(a.<a class="code" href="classCVC3_1_1Rational.html#a1366320f4de558bb964c67f8aecedb36">isInteger</a>() &amp;&amp; a &gt;= 2,
<a name="l02012"></a>02012     <span class="stringliteral">&quot;ArithTheoremProducer3::grayShadowConst(&quot;</span>+g.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>()+<span class="stringliteral">&quot;)&quot;</span>);
<a name="l02013"></a>02013   }
<a name="l02014"></a>02014 
<a name="l02015"></a>02015   <a class="code" href="classCVC3_1_1Rational.html">Rational</a> newC1 = ceil((c1+c)/a), newC2 = floor((c2+c)/a);
<a name="l02016"></a>02016   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> newG((newC1 &gt; newC2)? d_em-&gt;falseExpr()
<a name="l02017"></a>02017       : grayShadow(x, rat(0), newC1, newC2));
<a name="l02018"></a>02018   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l02019"></a>02019   <span class="keywordflow">if</span>(withProof())
<a name="l02020"></a>02020     pf = newPf(<span class="stringliteral">&quot;gray_shadow_const&quot;</span>, g, newG, gThm.<a class="code" href="classCVC3_1_1Theorem.html#a2d8352c07a756c3837683a27a1e659ef">getProof</a>());
<a name="l02021"></a>02021   <span class="keywordflow">return</span> newTheorem(newG, gThm.<a class="code" href="classCVC3_1_1Theorem.html#a5e9ab00a613df15cc02f55edb55a67b3">getAssumptionsRef</a>(), pf);
<a name="l02022"></a>02022 }
<a name="l02023"></a>02023 
<a name="l02024"></a>02024 
<a name="l02025"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#afa3e14a6cb004a107d915df0088ed16c">02025</a> <a class="code" href="classCVC3_1_1Rational.html">Rational</a> ArithTheoremProducer3::constRHSGrayShadow(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Rational.html">Rational</a>&amp; c,
<a name="l02026"></a>02026               <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Rational.html">Rational</a>&amp; b,
<a name="l02027"></a>02027               <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Rational.html">Rational</a>&amp; a) {
<a name="l02028"></a>02028   <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(c.<a class="code" href="classCVC3_1_1Rational.html#a1366320f4de558bb964c67f8aecedb36">isInteger</a>() &amp;&amp;
<a name="l02029"></a>02029         b.<a class="code" href="classCVC3_1_1Rational.html#a1366320f4de558bb964c67f8aecedb36">isInteger</a>() &amp;&amp;
<a name="l02030"></a>02030         a.<a class="code" href="classCVC3_1_1Rational.html#a1366320f4de558bb964c67f8aecedb36">isInteger</a>() &amp;&amp;
<a name="l02031"></a>02031         b != 0,
<a name="l02032"></a>02032         <span class="stringliteral">&quot;ArithTheoremProducer3::constRHSGrayShadow: a, b, c must be ints&quot;</span>);
<a name="l02033"></a>02033   <span class="keywordflow">if</span> (b &gt; 0)
<a name="l02034"></a>02034     <span class="keywordflow">return</span> mod(c+b, a);
<a name="l02035"></a>02035   <span class="keywordflow">else</span>
<a name="l02036"></a>02036     <span class="keywordflow">return</span> mod(a-(c+b), a);
<a name="l02037"></a>02037 }
<a name="l02038"></a>02038 <span class="comment"></span>
<a name="l02039"></a>02039 <span class="comment">/*! Takes a Theorem(\\alpha &lt; \\beta) and returns</span>
<a name="l02040"></a>02040 <span class="comment"> *  Theorem(\\alpha &lt; \\beta &lt;==&gt; \\alpha &lt;= \\beta -1)</span>
<a name="l02041"></a>02041 <span class="comment"> * where \\alpha and \\beta are integer expressions</span>
<a name="l02042"></a>02042 <span class="comment"> */</span>
<a name="l02043"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a91447c7423622c037a2956114fd549f4">02043</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::lessThanToLE(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; less,
<a name="l02044"></a>02044              <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; isIntLHS,
<a name="l02045"></a>02045              <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; isIntRHS,
<a name="l02046"></a>02046              <span class="keywordtype">bool</span> changeRight) {
<a name="l02047"></a>02047   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; ineq = less.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>();
<a name="l02048"></a>02048   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; isIntLHSexpr = isIntLHS.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>();
<a name="l02049"></a>02049   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; isIntRHSexpr = isIntRHS.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>();
<a name="l02050"></a>02050 
<a name="l02051"></a>02051   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l02052"></a>02052     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#a448b6e0d541113608bba5a7a005609e3">isLT</a>(ineq),
<a name="l02053"></a>02053     <span class="stringliteral">&quot;ArithTheoremProducer3::LTtoLE: ineq must be &lt;&quot;</span>);
<a name="l02054"></a>02054     <span class="comment">// Integrality check</span>
<a name="l02055"></a>02055     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#aff7910c172ccdd1afb5e42964e2f248d">isIntPred</a>(isIntLHSexpr) &amp;&amp; isIntLHSexpr[0] == ineq[0],
<a name="l02056"></a>02056     <span class="stringliteral">&quot;ArithTheoremProducer3::lessThanToLE: bad integrality check:\n&quot;</span>
<a name="l02057"></a>02057     <span class="stringliteral">&quot; ineq = &quot;</span>+ineq.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>()+<span class="stringliteral">&quot;\n isIntLHS = &quot;</span>
<a name="l02058"></a>02058     +isIntLHSexpr.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l02059"></a>02059     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#aff7910c172ccdd1afb5e42964e2f248d">isIntPred</a>(isIntRHSexpr) &amp;&amp; isIntRHSexpr[0] == ineq[1],
<a name="l02060"></a>02060     <span class="stringliteral">&quot;ArithTheoremProducer3::lessThanToLE: bad integrality check:\n&quot;</span>
<a name="l02061"></a>02061     <span class="stringliteral">&quot; ineq = &quot;</span>+ineq.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>()+<span class="stringliteral">&quot;\n isIntRHS = &quot;</span>
<a name="l02062"></a>02062     +isIntRHSexpr.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l02063"></a>02063   }
<a name="l02064"></a>02064   vector&lt;Theorem&gt; thms;
<a name="l02065"></a>02065   thms.push_back(less);
<a name="l02066"></a>02066   thms.push_back(isIntLHS);
<a name="l02067"></a>02067   thms.push_back(isIntRHS);
<a name="l02068"></a>02068   <a class="code" href="classCVC3_1_1Assumptions.html">Assumptions</a> a(thms);
<a name="l02069"></a>02069   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l02070"></a>02070   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> le = changeRight?
<a name="l02071"></a>02071     <a class="code" href="namespaceCVC3.html#aebfd8a82800bd3dff4c8db461a52cdea">leExpr</a>(ineq[0], ineq[1] + rat(-1))
<a name="l02072"></a>02072     : <a class="code" href="namespaceCVC3.html#aebfd8a82800bd3dff4c8db461a52cdea">leExpr</a>(ineq[0] + rat(1), ineq[1]);
<a name="l02073"></a>02073   <span class="keywordflow">if</span>(withProof()) {
<a name="l02074"></a>02074     vector&lt;Proof&gt; pfs;
<a name="l02075"></a>02075     pfs.push_back(less.<a class="code" href="classCVC3_1_1Theorem.html#a2d8352c07a756c3837683a27a1e659ef">getProof</a>());
<a name="l02076"></a>02076     pfs.push_back(isIntLHS.<a class="code" href="classCVC3_1_1Theorem.html#a2d8352c07a756c3837683a27a1e659ef">getProof</a>());
<a name="l02077"></a>02077     pfs.push_back(isIntRHS.<a class="code" href="classCVC3_1_1Theorem.html#a2d8352c07a756c3837683a27a1e659ef">getProof</a>());
<a name="l02078"></a>02078     pf = newPf(changeRight? <span class="stringliteral">&quot;lessThan_To_LE_rhs&quot;</span> : <span class="stringliteral">&quot;lessThan_To_LE_lhs&quot;</span>,
<a name="l02079"></a>02079          ineq,le, pfs);
<a name="l02080"></a>02080   }
<a name="l02081"></a>02081 
<a name="l02082"></a>02082   <span class="keywordflow">return</span> newRWTheorem(ineq, le, a, pf);
<a name="l02083"></a>02083 }
<a name="l02084"></a>02084 
<a name="l02085"></a>02085 <span class="comment"></span>
<a name="l02086"></a>02086 <span class="comment">/*! \param eqn is an equation 0 = a.x or 0 = c + a.x</span>
<a name="l02087"></a>02087 <span class="comment"> *  \param isIntx is a proof of IS_INTEGER(x)</span>
<a name="l02088"></a>02088 <span class="comment"> *</span>
<a name="l02089"></a>02089 <span class="comment"> * \return the theorem 0 = c + a.x &lt;==&gt; x=-c/a if -c/a is int else</span>
<a name="l02090"></a>02090 <span class="comment"> *  return the theorem 0 = c + a.x &lt;==&gt; false.</span>
<a name="l02091"></a>02091 <span class="comment"> *</span>
<a name="l02092"></a>02092 <span class="comment"> * It also handles the special case of 0 = a.x &lt;==&gt; x = 0</span>
<a name="l02093"></a>02093 <span class="comment"> */</span>
<a name="l02094"></a>02094 <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>
<a name="l02095"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a608b3a7da8f2824d3cc8188d7606396e">02095</a> ArithTheoremProducer3::intVarEqnConst(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; eqn,
<a name="l02096"></a>02096              <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; <a class="code" href="theory__quant_8cpp.html#ac9940420b1f3427ebe821902adbb578d">isIntx</a>) {
<a name="l02097"></a>02097   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; <a class="code" href="namespaceMiniSat.html#ad93cb56673487974071ed3b75bf4ea83">left</a>(eqn[0]);
<a name="l02098"></a>02098   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; <a class="code" href="namespaceMiniSat.html#a82558b7a36c52f5d3211d5d14bed99d4">right</a>(eqn[1]);
<a name="l02099"></a>02099   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; isIntxexpr(isIntx.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>());
<a name="l02100"></a>02100 
<a name="l02101"></a>02101   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l02102"></a>02102     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>((<a class="code" href="namespaceCVC3.html#a28ae8672047db708e99602ebaca89777">isMult</a>(right) &amp;&amp; right[0].<a class="code" href="namespaceCVC3.html#ac0334a083d6782caa17ca0d337fddddf">isRational</a>())
<a name="l02103"></a>02103                 || (right.<a class="code" href="group__ExprPkg.html#ga28b901d05e52a5c646f83a95cc74f94b">arity</a>() == 2 &amp;&amp; <a class="code" href="namespaceCVC3.html#afb0f7d15ddbd87f9abb128108101f557">isPlus</a>(right)
<a name="l02104"></a>02104                     &amp;&amp; right[0].<a class="code" href="group__ExprPkg.html#gac5ced6adc7a60945ea6707ef494aa28f">isRational</a>()
<a name="l02105"></a>02105                     &amp;&amp; ((!<a class="code" href="namespaceCVC3.html#a28ae8672047db708e99602ebaca89777">isMult</a>(right[1]) || right[1][0].<a class="code" href="group__ExprPkg.html#gac5ced6adc7a60945ea6707ef494aa28f">isRational</a>()))),
<a name="l02106"></a>02106                 <span class="stringliteral">&quot;ArithTheoremProducer3::intVarEqnConst: &quot;</span>
<a name="l02107"></a>02107     <span class="stringliteral">&quot;rhs has a wrong format: &quot;</span> + right.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l02108"></a>02108     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(left.<a class="code" href="group__ExprPkg.html#gac5ced6adc7a60945ea6707ef494aa28f">isRational</a>() &amp;&amp; 0 == left.<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>(),
<a name="l02109"></a>02109                 <span class="stringliteral">&quot;ArithTheoremProducer3:intVarEqnConst:left is not a zero: &quot;</span> +
<a name="l02110"></a>02110                 left.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l02111"></a>02111   }
<a name="l02112"></a>02112   <span class="comment">// Integrality constraint</span>
<a name="l02113"></a>02113   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> x(right);
<a name="l02114"></a>02114   <a class="code" href="classCVC3_1_1Rational.html">Rational</a> a(1), c(0);
<a name="l02115"></a>02115   <span class="keywordflow">if</span>(<a class="code" href="namespaceCVC3.html#a28ae8672047db708e99602ebaca89777">isMult</a>(right)) {
<a name="l02116"></a>02116     <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> aExpr;
<a name="l02117"></a>02117     d_theoryArith-&gt;separateMonomial(right, aExpr, x);
<a name="l02118"></a>02118     a = aExpr.<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>();
<a name="l02119"></a>02119   } <span class="keywordflow">else</span> { <span class="comment">// right is a PLUS</span>
<a name="l02120"></a>02120     c = right[0].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>();
<a name="l02121"></a>02121     <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> aExpr;
<a name="l02122"></a>02122     d_theoryArith-&gt;separateMonomial(right[1], aExpr, x);
<a name="l02123"></a>02123     a = aExpr.<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>();
<a name="l02124"></a>02124   }
<a name="l02125"></a>02125   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l02126"></a>02126     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#aff7910c172ccdd1afb5e42964e2f248d">isIntPred</a>(isIntxexpr) &amp;&amp; isIntxexpr[0] == x,
<a name="l02127"></a>02127                 <span class="stringliteral">&quot;ArithTheoremProducer3:intVarEqnConst: &quot;</span>
<a name="l02128"></a>02128     <span class="stringliteral">&quot;bad integrality constraint:\n right = &quot;</span> +
<a name="l02129"></a>02129                 right.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>()+<span class="stringliteral">&quot;\n isIntx = &quot;</span>+isIntxexpr.toString());
<a name="l02130"></a>02130     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(a!=0, <span class="stringliteral">&quot;ArithTheoremProducer3:intVarEqnConst: eqn = &quot;</span>
<a name="l02131"></a>02131     +eqn.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l02132"></a>02132   }
<a name="l02133"></a>02133   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Assumptions.html">Assumptions</a>&amp; assump(isIntx.<a class="code" href="classCVC3_1_1Theorem.html#a5e9ab00a613df15cc02f55edb55a67b3">getAssumptionsRef</a>());
<a name="l02134"></a>02134 
<a name="l02135"></a>02135   <span class="comment">/*</span>
<a name="l02136"></a>02136 <span class="comment">      Proof pf;</span>
<a name="l02137"></a>02137 <span class="comment">  if(withProof())</span>
<a name="l02138"></a>02138 <span class="comment">    pf = newPf(&quot;int_const_eq&quot;, eqn, isIntx.getProof());</span>
<a name="l02139"></a>02139 <span class="comment"></span>
<a name="l02140"></a>02140 <span class="comment">  // Solve for x:   x = r = -c/a</span>
<a name="l02141"></a>02141 <span class="comment">  Rational r(-c/a);</span>
<a name="l02142"></a>02142 <span class="comment"></span>
<a name="l02143"></a>02143 <span class="comment">  if(r.isInteger()){</span>
<a name="l02144"></a>02144 <span class="comment">    return newRWTheorem(eqn, x.eqExpr(rat(r)), assump, pf);</span>
<a name="l02145"></a>02145 <span class="comment">  else</span>
<a name="l02146"></a>02146 <span class="comment">    return newRWTheorem(eqn, d_em-&gt;falseExpr(), assump, pf);</span>
<a name="l02147"></a>02147 <span class="comment">  */</span>
<a name="l02148"></a>02148 
<a name="l02149"></a>02149   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l02150"></a>02150   <span class="comment">// Solve for x:   x = r = -c/a</span>
<a name="l02151"></a>02151   <a class="code" href="classCVC3_1_1Rational.html">Rational</a> r(-c/a);
<a name="l02152"></a>02152 
<a name="l02153"></a>02153   <span class="keywordflow">if</span>(r.<a class="code" href="classCVC3_1_1Rational.html#a1366320f4de558bb964c67f8aecedb36">isInteger</a>()){
<a name="l02154"></a>02154     <span class="keywordflow">if</span>(withProof())
<a name="l02155"></a>02155       pf = newPf(<span class="stringliteral">&quot;int_const_eq&quot;</span>, eqn, x.<a class="code" href="group__ExprPkg.html#gacb48495ca445c895f95d0c3c1ae2070b">eqExpr</a>(rat(r)),isIntx.<a class="code" href="classCVC3_1_1Theorem.html#a2d8352c07a756c3837683a27a1e659ef">getProof</a>());
<a name="l02156"></a>02156     <span class="keywordflow">return</span> newRWTheorem(eqn, x.<a class="code" href="group__ExprPkg.html#gacb48495ca445c895f95d0c3c1ae2070b">eqExpr</a>(rat(r)), assump, pf);
<a name="l02157"></a>02157   }
<a name="l02158"></a>02158   <span class="keywordflow">else</span>{
<a name="l02159"></a>02159     <span class="keywordflow">if</span>(withProof())
<a name="l02160"></a>02160       pf = newPf(<span class="stringliteral">&quot;int_const_eq&quot;</span>, eqn, d_em-&gt;falseExpr(),isIntx.<a class="code" href="classCVC3_1_1Theorem.html#a2d8352c07a756c3837683a27a1e659ef">getProof</a>());
<a name="l02161"></a>02161     <span class="keywordflow">return</span> newRWTheorem(eqn, d_em-&gt;falseExpr(), assump, pf);
<a name="l02162"></a>02162   }
<a name="l02163"></a>02163 }
<a name="l02164"></a>02164 
<a name="l02165"></a>02165 
<a name="l02166"></a>02166 <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>
<a name="l02167"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#ab70323686fd8775952a2709a6c8c754b">02167</a> ArithTheoremProducer3::create_t(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; eqn) {
<a name="l02168"></a>02168   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; lhs = eqn[0];
<a name="l02169"></a>02169   <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(<a class="code" href="namespaceCVC3.html#a28ae8672047db708e99602ebaca89777">isMult</a>(lhs),
<a name="l02170"></a>02170               <a class="code" href="arith__theorem__producer3_8cpp.html#a79f2713d570c7065f61a160134ea765b">CLASS_NAME</a> <span class="stringliteral">&quot;create_t : lhs must be a MULT&quot;</span>
<a name="l02171"></a>02171               + lhs.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l02172"></a>02172   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; x = lhs[1];
<a name="l02173"></a>02173   <a class="code" href="classCVC3_1_1Rational.html">Rational</a> m = lhs[0].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>()+1;
<a name="l02174"></a>02174   <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(m &gt; 0, <span class="stringliteral">&quot;ArithTheoremProducer3::create_t: m = &quot;</span>+m.<a class="code" href="classCVC3_1_1Rational.html#a195c125a76cb9a6c5731369e244a2de3">toString</a>());
<a name="l02175"></a>02175   vector&lt;Expr&gt; kids;
<a name="l02176"></a>02176   <span class="keywordflow">if</span>(<a class="code" href="namespaceCVC3.html#afb0f7d15ddbd87f9abb128108101f557">isPlus</a>(eqn[1]))
<a name="l02177"></a>02177     sumModM(kids, eqn[1], m, m);
<a name="l02178"></a>02178   <span class="keywordflow">else</span>
<a name="l02179"></a>02179     kids.push_back(monomialModM(eqn[1], m, m));
<a name="l02180"></a>02180 
<a name="l02181"></a>02181   kids.push_back(<a class="code" href="namespaceCVC3.html#adb35e0739f86730543924dbc8211a778">multExpr</a>(rat(1/m), x));
<a name="l02182"></a>02182   <span class="keywordflow">return</span> <a class="code" href="namespaceCVC3.html#accd3d7d38b0e04136afbc3e5191bc8bb">plusExpr</a>(kids);
<a name="l02183"></a>02183 }
<a name="l02184"></a>02184 
<a name="l02185"></a>02185 <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>
<a name="l02186"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#adf974179ea62c2196a87fb9c2199f6cd">02186</a> ArithTheoremProducer3::create_t2(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; lhs, <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; rhs,
<a name="l02187"></a>02187         <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; sigma) {
<a name="l02188"></a>02188   <a class="code" href="classCVC3_1_1Rational.html">Rational</a> m = lhs[0].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>()+1;
<a name="l02189"></a>02189   <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(m &gt; 0, <span class="stringliteral">&quot;ArithTheoremProducer3::create_t2: m = &quot;</span>+m.<a class="code" href="classCVC3_1_1Rational.html#a195c125a76cb9a6c5731369e244a2de3">toString</a>());
<a name="l02190"></a>02190   vector&lt;Expr&gt; kids;
<a name="l02191"></a>02191   <span class="keywordflow">if</span>(<a class="code" href="namespaceCVC3.html#afb0f7d15ddbd87f9abb128108101f557">isPlus</a>(rhs))
<a name="l02192"></a>02192     sumModM(kids, rhs, m, -1);
<a name="l02193"></a>02193   <span class="keywordflow">else</span> {
<a name="l02194"></a>02194     kids.push_back(rat(0)); <span class="comment">// For canonical form</span>
<a name="l02195"></a>02195     <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> monom = monomialModM(rhs, m, -1);
<a name="l02196"></a>02196     <span class="keywordflow">if</span>(!monom.<a class="code" href="group__ExprPkg.html#gac5ced6adc7a60945ea6707ef494aa28f">isRational</a>())
<a name="l02197"></a>02197       kids.push_back(monom);
<a name="l02198"></a>02198     <span class="keywordflow">else</span>
<a name="l02199"></a>02199       <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(monom.<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>() == 0, <span class="stringliteral">&quot;&quot;</span>);
<a name="l02200"></a>02200   }
<a name="l02201"></a>02201   kids.push_back(rat(m)*sigma);
<a name="l02202"></a>02202   <span class="keywordflow">return</span> <a class="code" href="namespaceCVC3.html#accd3d7d38b0e04136afbc3e5191bc8bb">plusExpr</a>(kids);
<a name="l02203"></a>02203 }
<a name="l02204"></a>02204 
<a name="l02205"></a>02205 <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>
<a name="l02206"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a6bad08f3833720448803251dfa234e36">02206</a> ArithTheoremProducer3::create_t3(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; lhs, <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; rhs,
<a name="l02207"></a>02207         <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; sigma) {
<a name="l02208"></a>02208   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Rational.html">Rational</a>&amp; a = lhs[0].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>();
<a name="l02209"></a>02209   <a class="code" href="classCVC3_1_1Rational.html">Rational</a> m = a+1;
<a name="l02210"></a>02210   <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(m &gt; 0, <span class="stringliteral">&quot;ArithTheoremProducer3::create_t3: m = &quot;</span>+m.<a class="code" href="classCVC3_1_1Rational.html#a195c125a76cb9a6c5731369e244a2de3">toString</a>());
<a name="l02211"></a>02211   vector&lt;Expr&gt; kids;
<a name="l02212"></a>02212   <span class="keywordflow">if</span>(<a class="code" href="namespaceCVC3.html#afb0f7d15ddbd87f9abb128108101f557">isPlus</a>(rhs))
<a name="l02213"></a>02213     sumMulF(kids, rhs, m, 1);
<a name="l02214"></a>02214   <span class="keywordflow">else</span> {
<a name="l02215"></a>02215     kids.push_back(rat(0)); <span class="comment">// For canonical form</span>
<a name="l02216"></a>02216     <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> monom = monomialMulF(rhs, m, 1);
<a name="l02217"></a>02217     <span class="keywordflow">if</span>(!monom.<a class="code" href="group__ExprPkg.html#gac5ced6adc7a60945ea6707ef494aa28f">isRational</a>())
<a name="l02218"></a>02218       kids.push_back(monom);
<a name="l02219"></a>02219     <span class="keywordflow">else</span>
<a name="l02220"></a>02220       <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(monom.<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>() == 0, <span class="stringliteral">&quot;&quot;</span>);
<a name="l02221"></a>02221   }
<a name="l02222"></a>02222   kids.push_back(rat(-a)*sigma);
<a name="l02223"></a>02223   <span class="keywordflow">return</span> <a class="code" href="namespaceCVC3.html#accd3d7d38b0e04136afbc3e5191bc8bb">plusExpr</a>(kids);
<a name="l02224"></a>02224 }
<a name="l02225"></a>02225 
<a name="l02226"></a>02226 <a class="code" href="classCVC3_1_1Rational.html">Rational</a>
<a name="l02227"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#ada3b48ce9720177b4a427237efe0453f">02227</a> ArithTheoremProducer3::modEq(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Rational.html">Rational</a>&amp; i, <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Rational.html">Rational</a>&amp; m) {
<a name="l02228"></a>02228   <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(m &gt; 0, <span class="stringliteral">&quot;ArithTheoremProducer3::modEq: m = &quot;</span>+m.<a class="code" href="classCVC3_1_1Rational.html#a195c125a76cb9a6c5731369e244a2de3">toString</a>());
<a name="l02229"></a>02229   <a class="code" href="classCVC3_1_1Rational.html">Rational</a> half(1,2);
<a name="l02230"></a>02230   <a class="code" href="classCVC3_1_1Rational.html">Rational</a> res((i - m*(floor((i/m) + half))));
<a name="l02231"></a>02231   <a class="code" href="kinds_8h.html#aa10c9e8951b8ccf714a59ec321bdac5ba7fa27e82c6c4f69434225ed81e5d151e">TRACE</a>(<span class="stringliteral">&quot;arith eq&quot;</span>, <span class="stringliteral">&quot;modEq(&quot;</span>+i.<a class="code" href="classCVC3_1_1Rational.html#a195c125a76cb9a6c5731369e244a2de3">toString</a>()+<span class="stringliteral">&quot;, &quot;</span>+m.<a class="code" href="classCVC3_1_1Rational.html#a195c125a76cb9a6c5731369e244a2de3">toString</a>()+<span class="stringliteral">&quot;) = &quot;</span>, res, <span class="stringliteral">&quot;&quot;</span>);
<a name="l02232"></a>02232   <span class="keywordflow">return</span> res;
<a name="l02233"></a>02233 }
<a name="l02234"></a>02234 
<a name="l02235"></a>02235 <a class="code" href="classCVC3_1_1Rational.html">Rational</a>
<a name="l02236"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a077f8d0dab986b01d390668f6af1afa2">02236</a> ArithTheoremProducer3::f(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Rational.html">Rational</a>&amp; i, <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Rational.html">Rational</a>&amp; m) {
<a name="l02237"></a>02237   <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(m &gt; 0, <span class="stringliteral">&quot;ArithTheoremProducer3::f: m = &quot;</span>+m.<a class="code" href="classCVC3_1_1Rational.html#a195c125a76cb9a6c5731369e244a2de3">toString</a>());
<a name="l02238"></a>02238   <a class="code" href="classCVC3_1_1Rational.html">Rational</a> half(1,2);
<a name="l02239"></a>02239   <span class="keywordflow">return</span> (floor(i/m + half)+modEq(i,m));
<a name="l02240"></a>02240 }
<a name="l02241"></a>02241 
<a name="l02242"></a>02242 <span class="keywordtype">void</span>
<a name="l02243"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#aa21c4aa75f54e05bdc772b0e2d37b669">02243</a> ArithTheoremProducer3::sumModM(vector&lt;Expr&gt;&amp; summands, <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; sum,
<a name="l02244"></a>02244                               <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Rational.html">Rational</a>&amp; m, <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Rational.html">Rational</a>&amp; divisor) {
<a name="l02245"></a>02245   <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(divisor != 0, <span class="stringliteral">&quot;ArithTheoremProducer3::sumModM: divisor = &quot;</span>
<a name="l02246"></a>02246         +divisor.<a class="code" href="classCVC3_1_1Rational.html#a195c125a76cb9a6c5731369e244a2de3">toString</a>());
<a name="l02247"></a>02247   <a class="code" href="classCVC3_1_1Expr_1_1iterator.html">Expr::iterator</a> i = sum.<a class="code" href="group__ExprPkg.html#gac890e13db184610276fc533fa4b4fe99" title="Begin iterator.">begin</a>();
<a name="l02248"></a>02248   <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(i != sum.<a class="code" href="group__ExprPkg.html#gaf6048a5030c8fa2511bf5dfee868e653" title="End iterator.">end</a>(), <a class="code" href="arith__theorem__producer3_8cpp.html#a79f2713d570c7065f61a160134ea765b">CLASS_NAME</a> <span class="stringliteral">&quot;::sumModM&quot;</span>);
<a name="l02249"></a>02249   <a class="code" href="classCVC3_1_1Rational.html">Rational</a> C = i-&gt;getRational();
<a name="l02250"></a>02250   C = modEq(C,m)/divisor;
<a name="l02251"></a>02251   summands.push_back(rat(C));
<a name="l02252"></a>02252   i++;
<a name="l02253"></a>02253   <span class="keywordflow">for</span>(<a class="code" href="classCVC3_1_1Expr_1_1iterator.html">Expr::iterator</a> iend=sum.<a class="code" href="group__ExprPkg.html#gaf6048a5030c8fa2511bf5dfee868e653" title="End iterator.">end</a>(); i!=iend; ++i) {
<a name="l02254"></a>02254     <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> monom = monomialModM(*i, m, divisor);
<a name="l02255"></a>02255     <span class="keywordflow">if</span>(!monom.<a class="code" href="group__ExprPkg.html#gac5ced6adc7a60945ea6707ef494aa28f">isRational</a>())
<a name="l02256"></a>02256       summands.push_back(monom);
<a name="l02257"></a>02257     <span class="keywordflow">else</span>
<a name="l02258"></a>02258       <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(monom.<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>() == 0, <span class="stringliteral">&quot;&quot;</span>);
<a name="l02259"></a>02259   }
<a name="l02260"></a>02260 }
<a name="l02261"></a>02261 
<a name="l02262"></a>02262 <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>
<a name="l02263"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a5245a34c6f9e903db87e17df1d33c09d">02263</a> ArithTheoremProducer3::monomialModM(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; i,
<a name="l02264"></a>02264                                    <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Rational.html">Rational</a>&amp; m, <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Rational.html">Rational</a>&amp; divisor)
<a name="l02265"></a>02265 {
<a name="l02266"></a>02266   <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(divisor != 0, <span class="stringliteral">&quot;ArithTheoremProducer3::monomialModM: divisor = &quot;</span>
<a name="l02267"></a>02267         +divisor.<a class="code" href="classCVC3_1_1Rational.html#a195c125a76cb9a6c5731369e244a2de3">toString</a>());
<a name="l02268"></a>02268   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> res;
<a name="l02269"></a>02269   <span class="keywordflow">if</span>(<a class="code" href="namespaceCVC3.html#a28ae8672047db708e99602ebaca89777">isMult</a>(i)) {
<a name="l02270"></a>02270     <a class="code" href="classCVC3_1_1Rational.html">Rational</a> ai = i[0].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>();
<a name="l02271"></a>02271     ai = modEq(ai,m)/divisor;
<a name="l02272"></a>02272     <span class="keywordflow">if</span>(0 == ai) res = rat(0);
<a name="l02273"></a>02273     <span class="keywordflow">else</span> <span class="keywordflow">if</span>(1 == ai &amp;&amp; i.<a class="code" href="group__ExprPkg.html#ga28b901d05e52a5c646f83a95cc74f94b">arity</a>() == 2) res = i[1];
<a name="l02274"></a>02274     <span class="keywordflow">else</span> {
<a name="l02275"></a>02275       vector&lt;Expr&gt; kids = i.<a class="code" href="group__ExprPkg.html#ga1e18ae89889e781591eb2874a4196b73">getKids</a>();
<a name="l02276"></a>02276       kids[0] = rat(ai);
<a name="l02277"></a>02277       res = <a class="code" href="namespaceCVC3.html#adb35e0739f86730543924dbc8211a778">multExpr</a>(kids);
<a name="l02278"></a>02278     }
<a name="l02279"></a>02279   } <span class="keywordflow">else</span> { <span class="comment">// It&#39;s a single variable</span>
<a name="l02280"></a>02280     <a class="code" href="classCVC3_1_1Rational.html">Rational</a> ai = modEq(1,m)/divisor;
<a name="l02281"></a>02281     <span class="keywordflow">if</span>(1 == ai) res = i;
<a name="l02282"></a>02282     <span class="keywordflow">else</span> res = rat(ai)*i;
<a name="l02283"></a>02283   }
<a name="l02284"></a>02284   <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(!res.isNull(), <span class="stringliteral">&quot;ArithTheoremProducer3::monomialModM()&quot;</span>);
<a name="l02285"></a>02285   <a class="code" href="kinds_8h.html#aa10c9e8951b8ccf714a59ec321bdac5ba7fa27e82c6c4f69434225ed81e5d151e">TRACE</a>(<span class="stringliteral">&quot;arith eq&quot;</span>, <span class="stringliteral">&quot;monomialModM(i=&quot;</span>+i.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>()+<span class="stringliteral">&quot;, m=&quot;</span>+m.<a class="code" href="classCVC3_1_1Rational.html#a195c125a76cb9a6c5731369e244a2de3">toString</a>()
<a name="l02286"></a>02286   +<span class="stringliteral">&quot;, div=&quot;</span>+divisor.<a class="code" href="classCVC3_1_1Rational.html#a195c125a76cb9a6c5731369e244a2de3">toString</a>()+<span class="stringliteral">&quot;) = &quot;</span>, res, <span class="stringliteral">&quot;&quot;</span>);
<a name="l02287"></a>02287   <span class="keywordflow">return</span> res;
<a name="l02288"></a>02288 }
<a name="l02289"></a>02289 
<a name="l02290"></a>02290 <span class="keywordtype">void</span>
<a name="l02291"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a36838065b24c16503ef6cf8164de44a8">02291</a> ArithTheoremProducer3::sumMulF(vector&lt;Expr&gt;&amp; summands, <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; sum,
<a name="l02292"></a>02292                               <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Rational.html">Rational</a>&amp; m, <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Rational.html">Rational</a>&amp; divisor) {
<a name="l02293"></a>02293   <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(divisor != 0, <span class="stringliteral">&quot;ArithTheoremProducer3::sumMulF: divisor = &quot;</span>
<a name="l02294"></a>02294         +divisor.<a class="code" href="classCVC3_1_1Rational.html#a195c125a76cb9a6c5731369e244a2de3">toString</a>());
<a name="l02295"></a>02295   <a class="code" href="classCVC3_1_1Expr_1_1iterator.html">Expr::iterator</a> i = sum.<a class="code" href="group__ExprPkg.html#gac890e13db184610276fc533fa4b4fe99" title="Begin iterator.">begin</a>();
<a name="l02296"></a>02296   <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(i != sum.<a class="code" href="group__ExprPkg.html#gaf6048a5030c8fa2511bf5dfee868e653" title="End iterator.">end</a>(), <a class="code" href="arith__theorem__producer3_8cpp.html#a79f2713d570c7065f61a160134ea765b">CLASS_NAME</a> <span class="stringliteral">&quot;::sumModM&quot;</span>);
<a name="l02297"></a>02297   <a class="code" href="classCVC3_1_1Rational.html">Rational</a> C = i-&gt;getRational();
<a name="l02298"></a>02298   C = f(C,m)/divisor;
<a name="l02299"></a>02299   summands.push_back(rat(C));
<a name="l02300"></a>02300   i++;
<a name="l02301"></a>02301   <span class="keywordflow">for</span>(<a class="code" href="classCVC3_1_1Expr_1_1iterator.html">Expr::iterator</a> iend=sum.<a class="code" href="group__ExprPkg.html#gaf6048a5030c8fa2511bf5dfee868e653" title="End iterator.">end</a>(); i!=iend; ++i) {
<a name="l02302"></a>02302     <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> monom = monomialMulF(*i, m, divisor);
<a name="l02303"></a>02303     <span class="keywordflow">if</span>(!monom.<a class="code" href="group__ExprPkg.html#gac5ced6adc7a60945ea6707ef494aa28f">isRational</a>())
<a name="l02304"></a>02304       summands.push_back(monom);
<a name="l02305"></a>02305     <span class="keywordflow">else</span>
<a name="l02306"></a>02306       <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(monom.<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>() == 0, <span class="stringliteral">&quot;&quot;</span>);
<a name="l02307"></a>02307   }
<a name="l02308"></a>02308 }
<a name="l02309"></a>02309 
<a name="l02310"></a>02310 <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>
<a name="l02311"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#aea07da55e987ccd27d0f57e08558af01">02311</a> ArithTheoremProducer3::monomialMulF(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; i,
<a name="l02312"></a>02312                                    <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Rational.html">Rational</a>&amp; m, <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Rational.html">Rational</a>&amp; divisor)
<a name="l02313"></a>02313 {
<a name="l02314"></a>02314   <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(divisor != 0, <span class="stringliteral">&quot;ArithTheoremProducer3::monomialMulF: divisor = &quot;</span>
<a name="l02315"></a>02315         +divisor.<a class="code" href="classCVC3_1_1Rational.html#a195c125a76cb9a6c5731369e244a2de3">toString</a>());
<a name="l02316"></a>02316   <a class="code" href="classCVC3_1_1Rational.html">Rational</a> ai = <a class="code" href="namespaceCVC3.html#a28ae8672047db708e99602ebaca89777">isMult</a>(i) ? (i)[0].getRational() : 1;
<a name="l02317"></a>02317   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> xi = <a class="code" href="namespaceCVC3.html#a28ae8672047db708e99602ebaca89777">isMult</a>(i) ? (i)[1] : (i);
<a name="l02318"></a>02318   ai = f(ai,m)/divisor;
<a name="l02319"></a>02319   <span class="keywordflow">if</span>(0 == ai) <span class="keywordflow">return</span> rat(0);
<a name="l02320"></a>02320   <span class="keywordflow">if</span>(1 == ai) <span class="keywordflow">return</span> xi;
<a name="l02321"></a>02321   <span class="keywordflow">return</span> <a class="code" href="namespaceCVC3.html#adb35e0739f86730543924dbc8211a778">multExpr</a>(rat(ai), xi);
<a name="l02322"></a>02322 }
<a name="l02323"></a>02323 
<a name="l02324"></a>02324 <span class="comment">// This recursive function accepts a term, t, and a &#39;map&#39; of</span>
<a name="l02325"></a>02325 <span class="comment">// substitutions [x1/t1, x2/t2,...,xn/tn].  it returns a t&#39; which is</span>
<a name="l02326"></a>02326 <span class="comment">// basically t[x1/t1,x2/t2...xn/tn]</span>
<a name="l02327"></a>02327 <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>
<a name="l02328"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a3d0129d121975b0141d77ba6f458c182">02328</a> ArithTheoremProducer3::substitute(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; term, <a class="code" href="classCVC3_1_1ExprMap.html">ExprMap&lt;Expr&gt;</a>&amp; eMap)
<a name="l02329"></a>02329 {
<a name="l02330"></a>02330   <a class="code" href="classCVC3_1_1ExprMap.html">ExprMap&lt;Expr&gt;::iterator</a> i, iend = eMap.<a class="code" href="classCVC3_1_1ExprMap.html#a283ae6c44308cbdda0d82da5a16e52c8">end</a>();
<a name="l02331"></a>02331 
<a name="l02332"></a>02332   i = eMap.<a class="code" href="classCVC3_1_1ExprMap.html#ae50ab1874dd63b575553e7db769abe28">find</a>(term);
<a name="l02333"></a>02333   <span class="keywordflow">if</span>(iend != i)
<a name="l02334"></a>02334     <span class="keywordflow">return</span> (*i).second;
<a name="l02335"></a>02335 
<a name="l02336"></a>02336   if (<a class="code" href="namespaceCVC3.html#a28ae8672047db708e99602ebaca89777">isMult</a>(term)) {
<a name="l02337"></a>02337     <span class="comment">//in this case term is of the form c.x</span>
<a name="l02338"></a>02338     i = eMap.<a class="code" href="classCVC3_1_1ExprMap.html#ae50ab1874dd63b575553e7db769abe28">find</a>(term[1]);
<a name="l02339"></a>02339     <span class="keywordflow">if</span>(iend != i)
<a name="l02340"></a>02340       <span class="keywordflow">return</span> term[0]*(*i).second;
<a name="l02341"></a>02341     <span class="keywordflow">else</span>
<a name="l02342"></a>02342       <span class="keywordflow">return</span> term;
<a name="l02343"></a>02343   }
<a name="l02344"></a>02344 
<a name="l02345"></a>02345   <span class="keywordflow">if</span>(<a class="code" href="namespaceCVC3.html#afb0f7d15ddbd87f9abb128108101f557">isPlus</a>(term)) {
<a name="l02346"></a>02346     vector&lt;Expr&gt; output;
<a name="l02347"></a>02347     <span class="keywordflow">for</span>(<a class="code" href="classCVC3_1_1Expr_1_1iterator.html">Expr::iterator</a> j = term.<a class="code" href="group__ExprPkg.html#gac890e13db184610276fc533fa4b4fe99" title="Begin iterator.">begin</a>(), jend = term.<a class="code" href="group__ExprPkg.html#gaf6048a5030c8fa2511bf5dfee868e653" title="End iterator.">end</a>(); j != jend; ++j)
<a name="l02348"></a>02348       output.push_back(substitute(*j, eMap));
<a name="l02349"></a>02349     <span class="keywordflow">return</span> <a class="code" href="namespaceCVC3.html#accd3d7d38b0e04136afbc3e5191bc8bb">plusExpr</a>(output);
<a name="l02350"></a>02350   }
<a name="l02351"></a>02351   <span class="keywordflow">return</span> term;
<a name="l02352"></a>02352 }
<a name="l02353"></a>02353 
<a name="l02354"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a1923e590a205cefe9ef50d336e99c9e5">02354</a> <span class="keywordtype">bool</span> ArithTheoremProducer3::greaterthan(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> &amp; l, <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> &amp; r)
<a name="l02355"></a>02355 {
<a name="l02356"></a>02356   <span class="comment">//    DebugAssert(l != r, &quot;&quot;);</span>
<a name="l02357"></a>02357   <span class="keywordflow">if</span> (l==r) <span class="keywordflow">return</span> <span class="keyword">false</span>;
<a name="l02358"></a>02358 
<a name="l02359"></a>02359   <span class="keywordflow">switch</span>(l.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>()) {
<a name="l02360"></a>02360   <span class="keywordflow">case</span> <a class="code" href="kinds_8h.html#aa10c9e8951b8ccf714a59ec321bdac5bae07a708ec52c578b62f8b0f701571d56">RATIONAL_EXPR</a>:
<a name="l02361"></a>02361     <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(!r.<a class="code" href="group__ExprPkg.html#gac5ced6adc7a60945ea6707ef494aa28f">isRational</a>(), <span class="stringliteral">&quot;&quot;</span>);
<a name="l02362"></a>02362     <span class="keywordflow">return</span> <span class="keyword">true</span>;
<a name="l02363"></a>02363     <span class="keywordflow">break</span>;
<a name="l02364"></a>02364   <span class="keywordflow">case</span> <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a880283f7bbc366efe54c9ea074c9f5e5">POW</a>:
<a name="l02365"></a>02365     <span class="keywordflow">switch</span> (r.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>()) {
<a name="l02366"></a>02366     <span class="keywordflow">case</span> <a class="code" href="kinds_8h.html#aa10c9e8951b8ccf714a59ec321bdac5bae07a708ec52c578b62f8b0f701571d56">RATIONAL_EXPR</a>:
<a name="l02367"></a>02367       <span class="comment">// TODO:</span>
<a name="l02368"></a>02368       <span class="comment">// alternately I could return (not greaterthan(r,l))</span>
<a name="l02369"></a>02369       <span class="keywordflow">return</span> <span class="keyword">false</span>;
<a name="l02370"></a>02370       <span class="keywordflow">break</span>;
<a name="l02371"></a>02371     <span class="keywordflow">case</span> <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a880283f7bbc366efe54c9ea074c9f5e5">POW</a>:
<a name="l02372"></a>02372       <span class="comment">// x^n &gt; y^n if x &gt; y</span>
<a name="l02373"></a>02373       <span class="comment">// x^n1 &gt; x^n2 if n1 &gt; n2</span>
<a name="l02374"></a>02374       <span class="keywordflow">return</span>
<a name="l02375"></a>02375         ((r[1] &lt; l[1]) ||
<a name="l02376"></a>02376          ((r[1]==l[1]) &amp;&amp; (r[0].getRational() &lt; l[0].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>())));
<a name="l02377"></a>02377       <span class="keywordflow">break</span>;
<a name="l02378"></a>02378 
<a name="l02379"></a>02379     <span class="keywordflow">case</span> <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024ad77e825b0133e40de2760344377ee1fa">MULT</a>:
<a name="l02380"></a>02380       <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(r.<a class="code" href="group__ExprPkg.html#ga28b901d05e52a5c646f83a95cc74f94b">arity</a>() &gt; 1, <span class="stringliteral">&quot;&quot;</span>);
<a name="l02381"></a>02381       <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>((r.<a class="code" href="group__ExprPkg.html#ga28b901d05e52a5c646f83a95cc74f94b">arity</a>() &gt; 2) || (r[1] != l), <span class="stringliteral">&quot;&quot;</span>);
<a name="l02382"></a>02382       <span class="keywordflow">if</span> (r[1] == l) <span class="keywordflow">return</span> <span class="keyword">false</span>;
<a name="l02383"></a>02383       <span class="keywordflow">return</span> greaterthan(l, r[1]);
<a name="l02384"></a>02384       <span class="keywordflow">break</span>;
<a name="l02385"></a>02385     <span class="keywordflow">case</span> <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a9a12fbdcaa45ef17eaa1802161f9ca98">PLUS</a>:
<a name="l02386"></a>02386       <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(<span class="keyword">false</span>, <span class="stringliteral">&quot;&quot;</span>);
<a name="l02387"></a>02387       <span class="keywordflow">return</span> <span class="keyword">true</span>;
<a name="l02388"></a>02388       <span class="keywordflow">break</span>;
<a name="l02389"></a>02389     <span class="keywordflow">default</span>:
<a name="l02390"></a>02390       <span class="comment">// leaf</span>
<a name="l02391"></a>02391       <span class="keywordflow">return</span> ((r &lt; l[1]) || ((r == l[1]) &amp;&amp; l[0].getRational() &gt; 1));
<a name="l02392"></a>02392       <span class="keywordflow">break</span>;
<a name="l02393"></a>02393     }
<a name="l02394"></a>02394     <span class="keywordflow">break</span>;
<a name="l02395"></a>02395   <span class="keywordflow">case</span> <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024ad77e825b0133e40de2760344377ee1fa">MULT</a>:
<a name="l02396"></a>02396     <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(l.<a class="code" href="group__ExprPkg.html#ga28b901d05e52a5c646f83a95cc74f94b">arity</a>() &gt; 1, <span class="stringliteral">&quot;&quot;</span>);
<a name="l02397"></a>02397     <span class="keywordflow">switch</span> (r.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>()) {
<a name="l02398"></a>02398     <span class="keywordflow">case</span> <a class="code" href="kinds_8h.html#aa10c9e8951b8ccf714a59ec321bdac5bae07a708ec52c578b62f8b0f701571d56">RATIONAL_EXPR</a>:
<a name="l02399"></a>02399       <span class="keywordflow">return</span> <span class="keyword">false</span>;
<a name="l02400"></a>02400       <span class="keywordflow">break</span>;
<a name="l02401"></a>02401     <span class="keywordflow">case</span> <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a880283f7bbc366efe54c9ea074c9f5e5">POW</a>:
<a name="l02402"></a>02402       <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(l.<a class="code" href="group__ExprPkg.html#ga28b901d05e52a5c646f83a95cc74f94b">arity</a>() &gt; 1, <span class="stringliteral">&quot;&quot;</span>);
<a name="l02403"></a>02403       <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>((l.<a class="code" href="group__ExprPkg.html#ga28b901d05e52a5c646f83a95cc74f94b">arity</a>() &gt; 2) || (l[1] != r), <span class="stringliteral">&quot;&quot;</span>);
<a name="l02404"></a>02404       <span class="comment">// TODO:</span>
<a name="l02405"></a>02405       <span class="comment">// alternately return (not greaterthan(r,l)</span>
<a name="l02406"></a>02406       <span class="keywordflow">return</span> ((l[1] == r) || greaterthan(l[1], r));
<a name="l02407"></a>02407       <span class="keywordflow">break</span>;
<a name="l02408"></a>02408     <span class="keywordflow">case</span> <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024ad77e825b0133e40de2760344377ee1fa">MULT</a>:
<a name="l02409"></a>02409       {
<a name="l02410"></a>02410 
<a name="l02411"></a>02411         <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(r.<a class="code" href="group__ExprPkg.html#ga28b901d05e52a5c646f83a95cc74f94b">arity</a>() &gt; 1, <span class="stringliteral">&quot;&quot;</span>);
<a name="l02412"></a>02412         <a class="code" href="classCVC3_1_1Expr_1_1iterator.html">Expr::iterator</a> i = l.<a class="code" href="group__ExprPkg.html#gac890e13db184610276fc533fa4b4fe99" title="Begin iterator.">begin</a>();
<a name="l02413"></a>02413         <a class="code" href="classCVC3_1_1Expr_1_1iterator.html">Expr::iterator</a> j = r.<a class="code" href="group__ExprPkg.html#gac890e13db184610276fc533fa4b4fe99" title="Begin iterator.">begin</a>();
<a name="l02414"></a>02414         ++i;
<a name="l02415"></a>02415         ++j;
<a name="l02416"></a>02416         <span class="keywordflow">for</span> (; i != l.<a class="code" href="group__ExprPkg.html#gaf6048a5030c8fa2511bf5dfee868e653" title="End iterator.">end</a>() &amp;&amp; j != r.<a class="code" href="group__ExprPkg.html#gaf6048a5030c8fa2511bf5dfee868e653" title="End iterator.">end</a>(); ++i, ++j) {
<a name="l02417"></a>02417           <span class="keywordflow">if</span> (*i == *j)
<a name="l02418"></a>02418             <span class="keywordflow">continue</span>;
<a name="l02419"></a>02419           <span class="keywordflow">return</span> greaterthan(*i,*j);
<a name="l02420"></a>02420         }
<a name="l02421"></a>02421         <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(i != l.<a class="code" href="group__ExprPkg.html#gaf6048a5030c8fa2511bf5dfee868e653" title="End iterator.">end</a>() || j != r.<a class="code" href="group__ExprPkg.html#gaf6048a5030c8fa2511bf5dfee868e653" title="End iterator.">end</a>(), <span class="stringliteral">&quot;&quot;</span>);
<a name="l02422"></a>02422         <span class="keywordflow">if</span> (i == l.<a class="code" href="group__ExprPkg.html#gaf6048a5030c8fa2511bf5dfee868e653" title="End iterator.">end</a>()) {
<a name="l02423"></a>02423           <span class="comment">// r is bigger</span>
<a name="l02424"></a>02424           <span class="keywordflow">return</span> <span class="keyword">false</span>;
<a name="l02425"></a>02425         }
<a name="l02426"></a>02426         <span class="keywordflow">else</span>
<a name="l02427"></a>02427           {
<a name="l02428"></a>02428             <span class="comment">// l is bigger</span>
<a name="l02429"></a>02429             <span class="keywordflow">return</span> <span class="keyword">true</span>;
<a name="l02430"></a>02430           }
<a name="l02431"></a>02431       }
<a name="l02432"></a>02432       <span class="keywordflow">break</span>;
<a name="l02433"></a>02433     <span class="keywordflow">case</span> <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a9a12fbdcaa45ef17eaa1802161f9ca98">PLUS</a>:
<a name="l02434"></a>02434       <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(<span class="keyword">false</span>, <span class="stringliteral">&quot;&quot;</span>);
<a name="l02435"></a>02435       <span class="keywordflow">return</span> <span class="keyword">true</span>;
<a name="l02436"></a>02436       <span class="keywordflow">break</span>;
<a name="l02437"></a>02437     <span class="keywordflow">default</span>:
<a name="l02438"></a>02438       <span class="comment">// leaf</span>
<a name="l02439"></a>02439       <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>((l.<a class="code" href="group__ExprPkg.html#ga28b901d05e52a5c646f83a95cc74f94b">arity</a>() &gt; 2) || (l[1] != r), <span class="stringliteral">&quot;&quot;</span>);
<a name="l02440"></a>02440       <span class="keywordflow">return</span> ((l[1] == r) || greaterthan(l[1], r));
<a name="l02441"></a>02441       <span class="keywordflow">break</span>;
<a name="l02442"></a>02442     }
<a name="l02443"></a>02443     <span class="keywordflow">break</span>;
<a name="l02444"></a>02444   <span class="keywordflow">case</span> <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a9a12fbdcaa45ef17eaa1802161f9ca98">PLUS</a>:
<a name="l02445"></a>02445     <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(<span class="keyword">false</span>, <span class="stringliteral">&quot;&quot;</span>);
<a name="l02446"></a>02446     <span class="keywordflow">return</span> <span class="keyword">true</span>;
<a name="l02447"></a>02447     <span class="keywordflow">break</span>;
<a name="l02448"></a>02448   <span class="keywordflow">default</span>:
<a name="l02449"></a>02449     <span class="comment">// leaf</span>
<a name="l02450"></a>02450     <span class="keywordflow">switch</span> (r.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>()) {
<a name="l02451"></a>02451     <span class="keywordflow">case</span> <a class="code" href="kinds_8h.html#aa10c9e8951b8ccf714a59ec321bdac5bae07a708ec52c578b62f8b0f701571d56">RATIONAL_EXPR</a>:
<a name="l02452"></a>02452       <span class="keywordflow">return</span> <span class="keyword">false</span>;
<a name="l02453"></a>02453       <span class="keywordflow">break</span>;
<a name="l02454"></a>02454     <span class="keywordflow">case</span> <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a880283f7bbc366efe54c9ea074c9f5e5">POW</a>:
<a name="l02455"></a>02455       <span class="keywordflow">return</span> ((r[1] &lt; l) || ((r[1] == l) &amp;&amp; (r[0].getRational() &lt; 1)));
<a name="l02456"></a>02456       <span class="keywordflow">break</span>;
<a name="l02457"></a>02457     <span class="keywordflow">case</span> <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024ad77e825b0133e40de2760344377ee1fa">MULT</a>:
<a name="l02458"></a>02458       <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(r.<a class="code" href="group__ExprPkg.html#ga28b901d05e52a5c646f83a95cc74f94b">arity</a>() &gt; 1, <span class="stringliteral">&quot;&quot;</span>);
<a name="l02459"></a>02459       <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>((r.<a class="code" href="group__ExprPkg.html#ga28b901d05e52a5c646f83a95cc74f94b">arity</a>() &gt; 2) || (r[1] != l), <span class="stringliteral">&quot;&quot;</span>);
<a name="l02460"></a>02460       <span class="keywordflow">if</span> (l == r[1]) <span class="keywordflow">return</span> <span class="keyword">false</span>;
<a name="l02461"></a>02461       <span class="keywordflow">return</span> greaterthan(l,r[1]);
<a name="l02462"></a>02462       <span class="keywordflow">break</span>;
<a name="l02463"></a>02463     <span class="keywordflow">case</span> <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a9a12fbdcaa45ef17eaa1802161f9ca98">PLUS</a>:
<a name="l02464"></a>02464       <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(<span class="keyword">false</span>, <span class="stringliteral">&quot;&quot;</span>);
<a name="l02465"></a>02465       <span class="keywordflow">return</span> <span class="keyword">true</span>;
<a name="l02466"></a>02466       <span class="keywordflow">break</span>;
<a name="l02467"></a>02467     <span class="keywordflow">default</span>:
<a name="l02468"></a>02468       <span class="comment">// leaf</span>
<a name="l02469"></a>02469       <span class="keywordflow">return</span> (r &lt; l);
<a name="l02470"></a>02470       <span class="keywordflow">break</span>;
<a name="l02471"></a>02471     }
<a name="l02472"></a>02472     <span class="keywordflow">break</span>;
<a name="l02473"></a>02473   }
<a name="l02474"></a>02474 }
<a name="l02475"></a>02475 
<a name="l02476"></a>02476 <span class="comment"></span>
<a name="l02477"></a>02477 <span class="comment">/*! IS_INTEGER(x) |= EXISTS (y : INT) y = x</span>
<a name="l02478"></a>02478 <span class="comment"> * where x is not already known to be an integer.</span>
<a name="l02479"></a>02479 <span class="comment"> */</span>
<a name="l02480"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#ad2438a34ff1edb7268495d4105cb6c9c">02480</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::IsIntegerElim(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; <a class="code" href="theory__quant_8cpp.html#ac9940420b1f3427ebe821902adbb578d">isIntx</a>)
<a name="l02481"></a>02481 {
<a name="l02482"></a>02482   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> expr = isIntx.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>();
<a name="l02483"></a>02483   <span class="keywordflow">if</span> (<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l02484"></a>02484     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(expr.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>() == <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a3193c0a76bedff5b39b32531195ef779">IS_INTEGER</a>,
<a name="l02485"></a>02485                 <span class="stringliteral">&quot;Expected IS_INTEGER predicate&quot;</span>);
<a name="l02486"></a>02486   }
<a name="l02487"></a>02487   expr = expr[0];
<a name="l02488"></a>02488   <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(!d_theoryArith-&gt;isInteger(expr), <span class="stringliteral">&quot;Expected non-integer&quot;</span>);
<a name="l02489"></a>02489 
<a name="l02490"></a>02490   <a class="code" href="classCVC3_1_1Assumptions.html">Assumptions</a> a(isIntx);
<a name="l02491"></a>02491   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l02492"></a>02492 
<a name="l02493"></a>02493   <span class="keywordflow">if</span> (withProof())
<a name="l02494"></a>02494   {
<a name="l02495"></a>02495     pf = newPf(<span class="stringliteral">&quot;isIntElim&quot;</span>, isIntx.<a class="code" href="classCVC3_1_1Theorem.html#a2d8352c07a756c3837683a27a1e659ef">getProof</a>());
<a name="l02496"></a>02496   }
<a name="l02497"></a>02497 
<a name="l02498"></a>02498   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> newVar = d_em-&gt;newBoundVarExpr(d_theoryArith-&gt;intType());
<a name="l02499"></a>02499   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> res = d_em-&gt;newClosureExpr(<a class="code" href="kinds_8h.html#aa10c9e8951b8ccf714a59ec321bdac5ba3197625a1bb2264943f5a95f236d9973">EXISTS</a>, newVar, newVar.<a class="code" href="group__ExprPkg.html#gacb48495ca445c895f95d0c3c1ae2070b">eqExpr</a>(expr));
<a name="l02500"></a>02500 
<a name="l02501"></a>02501   <span class="keywordflow">return</span> newTheorem(res, a, pf);
<a name="l02502"></a>02502 }
<a name="l02503"></a>02503 
<a name="l02504"></a>02504 
<a name="l02505"></a>02505 <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>
<a name="l02506"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a1f5430f425efc533ca5881aaaeb42554">02506</a> ArithTheoremProducer3::eqElimIntRule(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; eqn, <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; <a class="code" href="theory__quant_8cpp.html#ac9940420b1f3427ebe821902adbb578d">isIntx</a>,
<a name="l02507"></a>02507             <span class="keyword">const</span> vector&lt;Theorem&gt;&amp; isIntVars) {
<a name="l02508"></a>02508   <a class="code" href="kinds_8h.html#aa10c9e8951b8ccf714a59ec321bdac5ba7fa27e82c6c4f69434225ed81e5d151e">TRACE</a>(<span class="stringliteral">&quot;arith eq&quot;</span>, <span class="stringliteral">&quot;eqElimIntRule(&quot;</span>, eqn.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>(), <span class="stringliteral">&quot;) {&quot;</span>);
<a name="l02509"></a>02509   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l02510"></a>02510 
<a name="l02511"></a>02511   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>)
<a name="l02512"></a>02512     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(eqn.<a class="code" href="classCVC3_1_1Theorem.html#a362c1d70e03803d804bbe300e5f6dc87">isRewrite</a>(),
<a name="l02513"></a>02513                 <span class="stringliteral">&quot;ArithTheoremProducer3::eqElimInt: input must be an equation&quot;</span> +
<a name="l02514"></a>02514                 eqn.<a class="code" href="classCVC3_1_1Theorem.html#ac4b1c9570ffb9cc901627ef2abb9ff77">toString</a>());
<a name="l02515"></a>02515 
<a name="l02516"></a>02516   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; lhs = eqn.<a class="code" href="classCVC3_1_1Theorem.html#a206c04f39fbbcacef2337148675553f4">getLHS</a>();
<a name="l02517"></a>02517   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; rhs = eqn.<a class="code" href="classCVC3_1_1Theorem.html#a97d957fcbf9094480851b1d2e5d3729f">getRHS</a>();
<a name="l02518"></a>02518   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> a, x;
<a name="l02519"></a>02519   d_theoryArith-&gt;separateMonomial(lhs, a, x);
<a name="l02520"></a>02520 
<a name="l02521"></a>02521   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l02522"></a>02522     <span class="comment">// Checking LHS</span>
<a name="l02523"></a>02523     <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; isIntxe = isIntx.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>();
<a name="l02524"></a>02524     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#aff7910c172ccdd1afb5e42964e2f248d">isIntPred</a>(isIntxe) &amp;&amp; isIntxe[0] == x,
<a name="l02525"></a>02525     <span class="stringliteral">&quot;ArithTheoremProducer3::eqElimInt\n eqn = &quot;</span>
<a name="l02526"></a>02526     +eqn.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>().<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>()
<a name="l02527"></a>02527     +<span class="stringliteral">&quot;\n isIntx = &quot;</span>+isIntxe.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l02528"></a>02528     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#ac0334a083d6782caa17ca0d337fddddf">isRational</a>(a) &amp;&amp; a.<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>().<a class="code" href="classCVC3_1_1Rational.html#a1366320f4de558bb964c67f8aecedb36">isInteger</a>()
<a name="l02529"></a>02529     &amp;&amp; a.<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>() &gt;= 2,
<a name="l02530"></a>02530     <span class="stringliteral">&quot;ArithTheoremProducer3::eqElimInt:\n lhs = &quot;</span>+lhs.<a class="code" href="classCVC3_1_1Rational.html#a195c125a76cb9a6c5731369e244a2de3">toString</a>());
<a name="l02531"></a>02531     <span class="comment">// Checking RHS</span>
<a name="l02532"></a>02532     <span class="comment">// It cannot be a division (we don&#39;t handle it)</span>
<a name="l02533"></a>02533     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(!<a class="code" href="namespaceCVC3.html#a10c6762fa24ef8adf8b5a5c3d6e4dad3">isDivide</a>(rhs),
<a name="l02534"></a>02534     <span class="stringliteral">&quot;ArithTheoremProducer3::eqElimInt:\n rhs = &quot;</span>+rhs.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l02535"></a>02535     <span class="comment">// If it&#39;s a single monomial, then it&#39;s the only &quot;variable&quot;</span>
<a name="l02536"></a>02536     <span class="keywordflow">if</span>(!<a class="code" href="namespaceCVC3.html#afb0f7d15ddbd87f9abb128108101f557">isPlus</a>(rhs)) {
<a name="l02537"></a>02537       <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> c, v;
<a name="l02538"></a>02538       d_theoryArith-&gt;separateMonomial(rhs, c, v);
<a name="l02539"></a>02539       <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(isIntVars.size() == 1
<a name="l02540"></a>02540       &amp;&amp; <a class="code" href="namespaceCVC3.html#aff7910c172ccdd1afb5e42964e2f248d">isIntPred</a>(isIntVars[0].getExpr())
<a name="l02541"></a>02541       &amp;&amp; isIntVars[0].getExpr()[0] == v
<a name="l02542"></a>02542       &amp;&amp; <a class="code" href="namespaceCVC3.html#ac0334a083d6782caa17ca0d337fddddf">isRational</a>(c) &amp;&amp; c.<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>().<a class="code" href="classCVC3_1_1Rational.html#a1366320f4de558bb964c67f8aecedb36">isInteger</a>(),
<a name="l02543"></a>02543       <span class="stringliteral">&quot;ArithTheoremProducer3::eqElimInt:\n rhs = &quot;</span>+rhs.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>()
<a name="l02544"></a>02544       +<span class="stringliteral">&quot;isIntVars.size = &quot;</span>+<a class="code" href="namespaceCVC3.html#af69618103f1f0f2eadada0796a2a940c">int2string</a>(isIntVars.size()));
<a name="l02545"></a>02545     } <span class="keywordflow">else</span> { <span class="comment">// RHS is a plus</span>
<a name="l02546"></a>02546       <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(isIntVars.size() + 1 == (size_t)rhs.<a class="code" href="group__ExprPkg.html#ga28b901d05e52a5c646f83a95cc74f94b">arity</a>(),
<a name="l02547"></a>02547       <span class="stringliteral">&quot;ArithTheoremProducer3::eqElimInt: rhs = &quot;</span>+rhs.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l02548"></a>02548       <span class="comment">// Check the free constant</span>
<a name="l02549"></a>02549       <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#ac0334a083d6782caa17ca0d337fddddf">isRational</a>(rhs[0]) &amp;&amp; rhs[0].getRational().isInteger(),
<a name="l02550"></a>02550       <span class="stringliteral">&quot;ArithTheoremProducer3::eqElimInt: rhs = &quot;</span>+rhs.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l02551"></a>02551       <span class="comment">// Check the vars</span>
<a name="l02552"></a>02552       <span class="keywordflow">for</span>(<span class="keywordtype">size_t</span> i=0, iend=isIntVars.size(); i&lt;iend; ++i) {
<a name="l02553"></a>02553   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> c, v;
<a name="l02554"></a>02554   d_theoryArith-&gt;separateMonomial(rhs[i+1], c, v);
<a name="l02555"></a>02555   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; <a class="code" href="namespaceCVC3.html#a8b193cc1fee34cb43707171b2ae6471e">isInt</a>(isIntVars[i].getExpr());
<a name="l02556"></a>02556   <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#aff7910c172ccdd1afb5e42964e2f248d">isIntPred</a>(isInt) &amp;&amp; isInt[0] == v
<a name="l02557"></a>02557         &amp;&amp; <a class="code" href="namespaceCVC3.html#ac0334a083d6782caa17ca0d337fddddf">isRational</a>(c) &amp;&amp; c.<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>().<a class="code" href="classCVC3_1_1Rational.html#a1366320f4de558bb964c67f8aecedb36">isInteger</a>(),
<a name="l02558"></a>02558         <span class="stringliteral">&quot;ArithTheoremProducer3::eqElimInt:\n rhs[&quot;</span>+<a class="code" href="namespaceCVC3.html#af69618103f1f0f2eadada0796a2a940c">int2string</a>(i+1)
<a name="l02559"></a>02559         +<span class="stringliteral">&quot;] = &quot;</span>+rhs[i+1].<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>()
<a name="l02560"></a>02560         +<span class="stringliteral">&quot;\n isInt = &quot;</span>+isInt.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l02561"></a>02561       }
<a name="l02562"></a>02562     }
<a name="l02563"></a>02563   }
<a name="l02564"></a>02564 
<a name="l02565"></a>02565   <span class="comment">// Creating a fresh bound variable</span>
<a name="l02566"></a>02566   <span class="keyword">static</span> <span class="keywordtype">int</span> varCount(0);
<a name="l02567"></a>02567   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> newVar = d_em-&gt;newBoundVarExpr(<span class="stringliteral">&quot;_int_var&quot;</span>, <a class="code" href="namespaceCVC3.html#af69618103f1f0f2eadada0796a2a940c">int2string</a>(varCount++));
<a name="l02568"></a>02568   newVar.<a class="code" href="group__ExprPkg.html#ga07d47f902598e00097086deabf04d9c5" title="Set the cached type.">setType</a>(intType());
<a name="l02569"></a>02569   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> t2 = create_t2(lhs, rhs, newVar);
<a name="l02570"></a>02570   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> t3 = create_t3(lhs, rhs, newVar);
<a name="l02571"></a>02571   vector&lt;Expr&gt; vars;
<a name="l02572"></a>02572   vars.push_back(newVar);
<a name="l02573"></a>02573   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> res = d_em-&gt;newClosureExpr(<a class="code" href="kinds_8h.html#aa10c9e8951b8ccf714a59ec321bdac5ba3197625a1bb2264943f5a95f236d9973">EXISTS</a>, vars,
<a name="l02574"></a>02574                                   x.<a class="code" href="group__ExprPkg.html#gacb48495ca445c895f95d0c3c1ae2070b">eqExpr</a>(t2) &amp;&amp; rat(0).<a class="code" href="group__ExprPkg.html#gacb48495ca445c895f95d0c3c1ae2070b">eqExpr</a>(t3));
<a name="l02575"></a>02575 
<a name="l02576"></a>02576   vector&lt;Theorem&gt; thms(isIntVars);
<a name="l02577"></a>02577   thms.push_back(isIntx);
<a name="l02578"></a>02578   thms.push_back(eqn);
<a name="l02579"></a>02579   <a class="code" href="classCVC3_1_1Assumptions.html">Assumptions</a> assump(thms);
<a name="l02580"></a>02580 
<a name="l02581"></a>02581   <span class="keywordflow">if</span>(withProof()) {
<a name="l02582"></a>02582     vector&lt;Proof&gt; pfs;
<a name="l02583"></a>02583     pfs.push_back(eqn.<a class="code" href="classCVC3_1_1Theorem.html#a2d8352c07a756c3837683a27a1e659ef">getProof</a>());
<a name="l02584"></a>02584     pfs.push_back(isIntx.<a class="code" href="classCVC3_1_1Theorem.html#a2d8352c07a756c3837683a27a1e659ef">getProof</a>());
<a name="l02585"></a>02585     vector&lt;Theorem&gt;::const_iterator i=isIntVars.begin(), iend=isIntVars.end();
<a name="l02586"></a>02586     <span class="keywordflow">for</span>(; i!=iend; ++i)
<a name="l02587"></a>02587       pfs.push_back(i-&gt;getProof());
<a name="l02588"></a>02588     pf = newPf(<span class="stringliteral">&quot;eq_elim_int&quot;</span>, eqn.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>(), res, pfs);
<a name="l02589"></a>02589   }
<a name="l02590"></a>02590 
<a name="l02591"></a>02591   <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> thm(newTheorem(res, assump, pf));
<a name="l02592"></a>02592   <a class="code" href="kinds_8h.html#aa10c9e8951b8ccf714a59ec321bdac5ba7fa27e82c6c4f69434225ed81e5d151e">TRACE</a>(<span class="stringliteral">&quot;arith eq&quot;</span>, <span class="stringliteral">&quot;eqElimIntRule =&gt; &quot;</span>, thm.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>(), <span class="stringliteral">&quot; }&quot;</span>);
<a name="l02593"></a>02593   <span class="keywordflow">return</span> thm;
<a name="l02594"></a>02594 }
<a name="l02595"></a>02595 
<a name="l02596"></a>02596 
<a name="l02597"></a>02597 <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>
<a name="l02598"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a24216d1be10b57272b918ba416783b76">02598</a> ArithTheoremProducer3::isIntConst(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; e) {
<a name="l02599"></a>02599   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l02600"></a>02600 
<a name="l02601"></a>02601   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l02602"></a>02602     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#aff7910c172ccdd1afb5e42964e2f248d">isIntPred</a>(e) &amp;&amp; e[0].<a class="code" href="namespaceCVC3.html#ac0334a083d6782caa17ca0d337fddddf">isRational</a>(),
<a name="l02603"></a>02603     <span class="stringliteral">&quot;ArithTheoremProducer3::isIntConst(e = &quot;</span>
<a name="l02604"></a>02604     +e.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>()+<span class="stringliteral">&quot;)&quot;</span>);
<a name="l02605"></a>02605   }
<a name="l02606"></a>02606   <span class="keywordflow">if</span>(withProof())
<a name="l02607"></a>02607     pf = newPf(<span class="stringliteral">&quot;is_int_const&quot;</span>, e);
<a name="l02608"></a>02608   <span class="keywordtype">bool</span> <a class="code" href="namespaceCVC3.html#a8b193cc1fee34cb43707171b2ae6471e">isInt</a> = e[0].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>().<a class="code" href="classCVC3_1_1Rational.html#a1366320f4de558bb964c67f8aecedb36">isInteger</a>();
<a name="l02609"></a>02609   <span class="keywordflow">return</span> newRWTheorem(e, isInt? d_em-&gt;trueExpr() : d_em-&gt;falseExpr(), Assumptions::emptyAssump(), pf);
<a name="l02610"></a>02610 }
<a name="l02611"></a>02611 
<a name="l02612"></a>02612 
<a name="l02613"></a>02613 <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>
<a name="l02614"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#acb64cdcb59f042dd38a9bf9b70f043ad">02614</a> ArithTheoremProducer3::equalLeaves1(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; thm)
<a name="l02615"></a>02615 {
<a name="l02616"></a>02616   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l02617"></a>02617   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; e = thm.<a class="code" href="classCVC3_1_1Theorem.html#a97d957fcbf9094480851b1d2e5d3729f">getRHS</a>();
<a name="l02618"></a>02618 
<a name="l02619"></a>02619   <span class="keywordflow">if</span> (<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l02620"></a>02620     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(e[1].getKind() == <a class="code" href="kinds_8h.html#aa10c9e8951b8ccf714a59ec321bdac5bae07a708ec52c578b62f8b0f701571d56">RATIONAL_EXPR</a> &amp;&amp;
<a name="l02621"></a>02621     e[1].getRational() == <a class="code" href="classCVC3_1_1Rational.html">Rational</a>(0) &amp;&amp;
<a name="l02622"></a>02622     e[0].getKind() == <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a9a12fbdcaa45ef17eaa1802161f9ca98">PLUS</a> &amp;&amp;
<a name="l02623"></a>02623     e[0].arity() == 3 &amp;&amp;
<a name="l02624"></a>02624     e[0][0].getKind() == <a class="code" href="kinds_8h.html#aa10c9e8951b8ccf714a59ec321bdac5bae07a708ec52c578b62f8b0f701571d56">RATIONAL_EXPR</a> &amp;&amp;
<a name="l02625"></a>02625     e[0][0].getRational() == <a class="code" href="classCVC3_1_1Rational.html">Rational</a>(0) &amp;&amp;
<a name="l02626"></a>02626     e[0][1].getKind() == <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024ad77e825b0133e40de2760344377ee1fa">MULT</a> &amp;&amp;
<a name="l02627"></a>02627     e[0][1].arity() == 2 &amp;&amp;
<a name="l02628"></a>02628     e[0][1][0].getKind() == <a class="code" href="kinds_8h.html#aa10c9e8951b8ccf714a59ec321bdac5bae07a708ec52c578b62f8b0f701571d56">RATIONAL_EXPR</a> &amp;&amp;
<a name="l02629"></a>02629     e[0][1][0].getRational() == <a class="code" href="classCVC3_1_1Rational.html">Rational</a>(-1),
<a name="l02630"></a>02630     <span class="stringliteral">&quot;equalLeaves1&quot;</span>);
<a name="l02631"></a>02631   }
<a name="l02632"></a>02632   <span class="keywordflow">if</span> (withProof())
<a name="l02633"></a>02633   {
<a name="l02634"></a>02634     vector&lt;Proof&gt; pfs;
<a name="l02635"></a>02635     pfs.push_back(thm.<a class="code" href="classCVC3_1_1Theorem.html#a2d8352c07a756c3837683a27a1e659ef">getProof</a>());
<a name="l02636"></a>02636     pf = newPf(<span class="stringliteral">&quot;equalLeaves1&quot;</span>, e, pfs);
<a name="l02637"></a>02637   }
<a name="l02638"></a>02638   <span class="keywordflow">return</span> newRWTheorem(e, e[0][1][1].eqExpr(e[0][2]), thm.<a class="code" href="classCVC3_1_1Theorem.html#a5e9ab00a613df15cc02f55edb55a67b3">getAssumptionsRef</a>(), pf);
<a name="l02639"></a>02639 }
<a name="l02640"></a>02640 
<a name="l02641"></a>02641 
<a name="l02642"></a>02642 <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>
<a name="l02643"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#ae97e571a8d541a31aef5c1c703190437">02643</a> ArithTheoremProducer3::equalLeaves2(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; thm)
<a name="l02644"></a>02644 {
<a name="l02645"></a>02645   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l02646"></a>02646   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; e = thm.<a class="code" href="classCVC3_1_1Theorem.html#a97d957fcbf9094480851b1d2e5d3729f">getRHS</a>();
<a name="l02647"></a>02647 
<a name="l02648"></a>02648   <span class="keywordflow">if</span> (<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l02649"></a>02649     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(e[0].getKind() == <a class="code" href="kinds_8h.html#aa10c9e8951b8ccf714a59ec321bdac5bae07a708ec52c578b62f8b0f701571d56">RATIONAL_EXPR</a> &amp;&amp;
<a name="l02650"></a>02650     e[0].getRational() == <a class="code" href="classCVC3_1_1Rational.html">Rational</a>(0) &amp;&amp;
<a name="l02651"></a>02651     e[1].getKind() == <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a9a12fbdcaa45ef17eaa1802161f9ca98">PLUS</a> &amp;&amp;
<a name="l02652"></a>02652     e[1].arity() == 3 &amp;&amp;
<a name="l02653"></a>02653     e[1][0].getKind() == <a class="code" href="kinds_8h.html#aa10c9e8951b8ccf714a59ec321bdac5bae07a708ec52c578b62f8b0f701571d56">RATIONAL_EXPR</a> &amp;&amp;
<a name="l02654"></a>02654     e[1][0].getRational() == <a class="code" href="classCVC3_1_1Rational.html">Rational</a>(0) &amp;&amp;
<a name="l02655"></a>02655     e[1][1].getKind() == <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024ad77e825b0133e40de2760344377ee1fa">MULT</a> &amp;&amp;
<a name="l02656"></a>02656     e[1][1].arity() == 2 &amp;&amp;
<a name="l02657"></a>02657     e[1][1][0].getKind() == <a class="code" href="kinds_8h.html#aa10c9e8951b8ccf714a59ec321bdac5bae07a708ec52c578b62f8b0f701571d56">RATIONAL_EXPR</a> &amp;&amp;
<a name="l02658"></a>02658     e[1][1][0].getRational() == <a class="code" href="classCVC3_1_1Rational.html">Rational</a>(-1),
<a name="l02659"></a>02659     <span class="stringliteral">&quot;equalLeaves2&quot;</span>);
<a name="l02660"></a>02660   }
<a name="l02661"></a>02661   <span class="keywordflow">if</span> (withProof())
<a name="l02662"></a>02662   {
<a name="l02663"></a>02663     vector&lt;Proof&gt; pfs;
<a name="l02664"></a>02664     pfs.push_back(thm.<a class="code" href="classCVC3_1_1Theorem.html#a2d8352c07a756c3837683a27a1e659ef">getProof</a>());
<a name="l02665"></a>02665     pf = newPf(<span class="stringliteral">&quot;equalLeaves2&quot;</span>, e, pfs);
<a name="l02666"></a>02666   }
<a name="l02667"></a>02667   <span class="keywordflow">return</span> newRWTheorem(e, e[1][1][1].eqExpr(e[1][2]), thm.<a class="code" href="classCVC3_1_1Theorem.html#a5e9ab00a613df15cc02f55edb55a67b3">getAssumptionsRef</a>(), pf);
<a name="l02668"></a>02668 }
<a name="l02669"></a>02669 
<a name="l02670"></a>02670 
<a name="l02671"></a>02671 <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>
<a name="l02672"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#aba1a7d51f8b8291c30cc32c0f3ff5a4d">02672</a> ArithTheoremProducer3::equalLeaves3(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; thm)
<a name="l02673"></a>02673 {
<a name="l02674"></a>02674   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l02675"></a>02675   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; e = thm.<a class="code" href="classCVC3_1_1Theorem.html#a97d957fcbf9094480851b1d2e5d3729f">getRHS</a>();
<a name="l02676"></a>02676 
<a name="l02677"></a>02677   <span class="keywordflow">if</span> (<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l02678"></a>02678     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(e[1].getKind() == <a class="code" href="kinds_8h.html#aa10c9e8951b8ccf714a59ec321bdac5bae07a708ec52c578b62f8b0f701571d56">RATIONAL_EXPR</a> &amp;&amp;
<a name="l02679"></a>02679     e[1].getRational() == <a class="code" href="classCVC3_1_1Rational.html">Rational</a>(0) &amp;&amp;
<a name="l02680"></a>02680     e[0].getKind() == <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a9a12fbdcaa45ef17eaa1802161f9ca98">PLUS</a> &amp;&amp;
<a name="l02681"></a>02681     e[0].arity() == 3 &amp;&amp;
<a name="l02682"></a>02682     e[0][0].getKind() == <a class="code" href="kinds_8h.html#aa10c9e8951b8ccf714a59ec321bdac5bae07a708ec52c578b62f8b0f701571d56">RATIONAL_EXPR</a> &amp;&amp;
<a name="l02683"></a>02683     e[0][0].getRational() == <a class="code" href="classCVC3_1_1Rational.html">Rational</a>(0) &amp;&amp;
<a name="l02684"></a>02684     e[0][2].getKind() == <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024ad77e825b0133e40de2760344377ee1fa">MULT</a> &amp;&amp;
<a name="l02685"></a>02685     e[0][2].arity() == 2 &amp;&amp;
<a name="l02686"></a>02686     e[0][2][0].getKind() == <a class="code" href="kinds_8h.html#aa10c9e8951b8ccf714a59ec321bdac5bae07a708ec52c578b62f8b0f701571d56">RATIONAL_EXPR</a> &amp;&amp;
<a name="l02687"></a>02687     e[0][2][0].getRational() == <a class="code" href="classCVC3_1_1Rational.html">Rational</a>(-1),
<a name="l02688"></a>02688     <span class="stringliteral">&quot;equalLeaves3&quot;</span>);
<a name="l02689"></a>02689   }
<a name="l02690"></a>02690   <span class="keywordflow">if</span> (withProof())
<a name="l02691"></a>02691   {
<a name="l02692"></a>02692     vector&lt;Proof&gt; pfs;
<a name="l02693"></a>02693     pfs.push_back(thm.<a class="code" href="classCVC3_1_1Theorem.html#a2d8352c07a756c3837683a27a1e659ef">getProof</a>());
<a name="l02694"></a>02694     pf = newPf(<span class="stringliteral">&quot;equalLeaves3&quot;</span>, e, pfs);
<a name="l02695"></a>02695   }
<a name="l02696"></a>02696   <span class="keywordflow">return</span> newRWTheorem(e, e[0][2][1].eqExpr(e[0][1]), thm.<a class="code" href="classCVC3_1_1Theorem.html#a5e9ab00a613df15cc02f55edb55a67b3">getAssumptionsRef</a>(), pf);
<a name="l02697"></a>02697 }
<a name="l02698"></a>02698 
<a name="l02699"></a>02699 
<a name="l02700"></a>02700 <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>
<a name="l02701"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a5876760c9171eca18490c779cc2bbc73">02701</a> ArithTheoremProducer3::equalLeaves4(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; thm)
<a name="l02702"></a>02702 {
<a name="l02703"></a>02703   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l02704"></a>02704   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; e = thm.<a class="code" href="classCVC3_1_1Theorem.html#a97d957fcbf9094480851b1d2e5d3729f">getRHS</a>();
<a name="l02705"></a>02705 
<a name="l02706"></a>02706   <span class="keywordflow">if</span> (<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l02707"></a>02707     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(e[0].getKind() == <a class="code" href="kinds_8h.html#aa10c9e8951b8ccf714a59ec321bdac5bae07a708ec52c578b62f8b0f701571d56">RATIONAL_EXPR</a> &amp;&amp;
<a name="l02708"></a>02708     e[0].getRational() == <a class="code" href="classCVC3_1_1Rational.html">Rational</a>(0) &amp;&amp;
<a name="l02709"></a>02709     e[1].getKind() == <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a9a12fbdcaa45ef17eaa1802161f9ca98">PLUS</a> &amp;&amp;
<a name="l02710"></a>02710     e[1].arity() == 3 &amp;&amp;
<a name="l02711"></a>02711     e[1][0].getKind() == <a class="code" href="kinds_8h.html#aa10c9e8951b8ccf714a59ec321bdac5bae07a708ec52c578b62f8b0f701571d56">RATIONAL_EXPR</a> &amp;&amp;
<a name="l02712"></a>02712     e[1][0].getRational() == <a class="code" href="classCVC3_1_1Rational.html">Rational</a>(0) &amp;&amp;
<a name="l02713"></a>02713     e[1][2].getKind() == <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024ad77e825b0133e40de2760344377ee1fa">MULT</a> &amp;&amp;
<a name="l02714"></a>02714     e[1][2].arity() == 2 &amp;&amp;
<a name="l02715"></a>02715     e[1][2][0].getKind() == <a class="code" href="kinds_8h.html#aa10c9e8951b8ccf714a59ec321bdac5bae07a708ec52c578b62f8b0f701571d56">RATIONAL_EXPR</a> &amp;&amp;
<a name="l02716"></a>02716     e[1][2][0].getRational() == <a class="code" href="classCVC3_1_1Rational.html">Rational</a>(-1),
<a name="l02717"></a>02717     <span class="stringliteral">&quot;equalLeaves4&quot;</span>);
<a name="l02718"></a>02718   }
<a name="l02719"></a>02719   <span class="keywordflow">if</span> (withProof())
<a name="l02720"></a>02720   {
<a name="l02721"></a>02721     vector&lt;Proof&gt; pfs;
<a name="l02722"></a>02722     pfs.push_back(thm.<a class="code" href="classCVC3_1_1Theorem.html#a2d8352c07a756c3837683a27a1e659ef">getProof</a>());
<a name="l02723"></a>02723     pf = newPf(<span class="stringliteral">&quot;equalLeaves4&quot;</span>, e, pfs);
<a name="l02724"></a>02724   }
<a name="l02725"></a>02725   <span class="keywordflow">return</span> newRWTheorem(e, e[1][2][1].eqExpr(e[1][1]), thm.<a class="code" href="classCVC3_1_1Theorem.html#a5e9ab00a613df15cc02f55edb55a67b3">getAssumptionsRef</a>(), pf);
<a name="l02726"></a>02726 }
<a name="l02727"></a>02727 
<a name="l02728"></a>02728 <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>
<a name="l02729"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a20fdbcbe80fa06a175aae548af7d2519">02729</a> ArithTheoremProducer3::diseqToIneq(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; diseq) {
<a name="l02730"></a>02730   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l02731"></a>02731 
<a name="l02732"></a>02732   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; e = diseq.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>();
<a name="l02733"></a>02733 
<a name="l02734"></a>02734   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l02735"></a>02735     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(e.<a class="code" href="group__ExprPkg.html#ga1a898858ccadce833df5a294c7740f11">isNot</a>() &amp;&amp; e[0].<a class="code" href="group__ExprPkg.html#gac4af2026c180da0f18d66ac616f61f3a">isEq</a>(),
<a name="l02736"></a>02736     <span class="stringliteral">&quot;ArithTheoremProducer3::diseqToIneq: expected disequality:\n&quot;</span>
<a name="l02737"></a>02737     <span class="stringliteral">&quot; e = &quot;</span>+e.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l02738"></a>02738   }
<a name="l02739"></a>02739 
<a name="l02740"></a>02740   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; x = e[0][0];
<a name="l02741"></a>02741   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; y = e[0][1];
<a name="l02742"></a>02742 
<a name="l02743"></a>02743   <span class="keywordflow">if</span>(withProof())
<a name="l02744"></a>02744     pf = newPf(e, diseq.<a class="code" href="classCVC3_1_1Theorem.html#a2d8352c07a756c3837683a27a1e659ef">getProof</a>());
<a name="l02745"></a>02745   <span class="keywordflow">return</span> newTheorem(<a class="code" href="namespaceCVC3.html#ac9ccba18a3c725634b1f8ba8e99e627f">ltExpr</a>(x,y).<a class="code" href="namespaceCVC3.html#a30f30b6e20c174f21ae63acea8618294">orExpr</a>(<a class="code" href="namespaceCVC3.html#a8ad355d6650f2dfa754419c634e36afb">gtExpr</a>(x,y)), diseq.<a class="code" href="classCVC3_1_1Theorem.html#a5e9ab00a613df15cc02f55edb55a67b3">getAssumptionsRef</a>(), pf);
<a name="l02746"></a>02746 }
<a name="l02747"></a>02747 
<a name="l02748"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#ae1e994559a2318ec45a758042371a71d">02748</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::dummyTheorem(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; e) {
<a name="l02749"></a>02749   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l02750"></a>02750   <span class="keywordflow">return</span> newRWTheorem(e, d_em-&gt;trueExpr(), Assumptions::emptyAssump(), pf);
<a name="l02751"></a>02751 }
<a name="l02752"></a>02752 
<a name="l02753"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a2caebbed8d00af9c80195413ed2cc568">02753</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::oneElimination(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; e) {
<a name="l02754"></a>02754 
<a name="l02755"></a>02755   <span class="comment">// Check soundness</span>
<a name="l02756"></a>02756   <span class="keywordflow">if</span> (<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>)
<a name="l02757"></a>02757     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#a28ae8672047db708e99602ebaca89777">isMult</a>(e) &amp;&amp;
<a name="l02758"></a>02758           e.<a class="code" href="group__ExprPkg.html#ga28b901d05e52a5c646f83a95cc74f94b">arity</a>() == 2 &amp;&amp;
<a name="l02759"></a>02759                 e[0].<a class="code" href="group__ExprPkg.html#gac5ced6adc7a60945ea6707ef494aa28f">isRational</a>() &amp;&amp;
<a name="l02760"></a>02760                 e[0].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>() == 1,
<a name="l02761"></a>02761                 <span class="stringliteral">&quot;oneElimination: input must be a multiplication by one&quot;</span> + e.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l02762"></a>02762 
<a name="l02763"></a>02763   <span class="comment">// The proof object that we will us</span>
<a name="l02764"></a>02764   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l02765"></a>02765 
<a name="l02766"></a>02766   <span class="comment">// Setup the proof if needed</span>
<a name="l02767"></a>02767   <span class="keywordflow">if</span> (withProof())
<a name="l02768"></a>02768     pf = newPf(<span class="stringliteral">&quot;oneElimination&quot;</span>, e);
<a name="l02769"></a>02769 
<a name="l02770"></a>02770   <span class="comment">// Return the rewrite theorem that explains the phenomenon</span>
<a name="l02771"></a>02771   <span class="keywordflow">return</span> newRWTheorem(e, e[1], Assumptions::emptyAssump(), pf);
<a name="l02772"></a>02772 }
<a name="l02773"></a>02773 
<a name="l02774"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#af05299dbe2defe9679365201cd60c516">02774</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::clashingBounds(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; lowerBound, <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; upperBound) {
<a name="l02775"></a>02775 
<a name="l02776"></a>02776   <span class="comment">// Get the expressions</span>
<a name="l02777"></a>02777   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; lowerBoundExpr = lowerBound.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>();
<a name="l02778"></a>02778   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; upperBoundExpr = upperBound.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>();
<a name="l02779"></a>02779 
<a name="l02780"></a>02780   <span class="comment">// Check soundness</span>
<a name="l02781"></a>02781   <span class="keywordflow">if</span> (<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l02782"></a>02782     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#a8ef991dfa16ee3a209b7f38014153101">isLE</a>(lowerBoundExpr) || <a class="code" href="namespaceCVC3.html#a448b6e0d541113608bba5a7a005609e3">isLT</a>(lowerBoundExpr), <span class="stringliteral">&quot;clashingBounds: lowerBound should be &gt;= or &gt; &quot;</span> + lowerBoundExpr.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l02783"></a>02783     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#af85f3152a3b2fe195d795bc0aefaec71">isGE</a>(upperBoundExpr) || <a class="code" href="namespaceCVC3.html#a7306d7566ccb21380f05058477aba009">isGT</a>(upperBoundExpr), <span class="stringliteral">&quot;clashingBounds: upperBound should be &lt;= or &lt; &quot;</span> + upperBoundExpr.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l02784"></a>02784     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(lowerBoundExpr[0].<a class="code" href="namespaceCVC3.html#ac0334a083d6782caa17ca0d337fddddf">isRational</a>(), <span class="stringliteral">&quot;clashingBounds: lowerBound left side should be a rational &quot;</span> + lowerBoundExpr.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l02785"></a>02785     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(upperBoundExpr[0].<a class="code" href="namespaceCVC3.html#ac0334a083d6782caa17ca0d337fddddf">isRational</a>(), <span class="stringliteral">&quot;clashingBounds: upperBound left side should be a rational &quot;</span> + upperBoundExpr.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l02786"></a>02786     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(lowerBoundExpr[1] == upperBoundExpr[1], <span class="stringliteral">&quot;clashingBounds: bounds not on the same term &quot;</span> + lowerBoundExpr.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>() + <span class="stringliteral">&quot;, &quot;</span> + upperBoundExpr.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l02787"></a>02787 
<a name="l02788"></a>02788     <span class="comment">// Get the bounds</span>
<a name="l02789"></a>02789     <a class="code" href="classCVC3_1_1Rational.html">Rational</a> lowerBoundR = lowerBoundExpr[0].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>();
<a name="l02790"></a>02790     <a class="code" href="classCVC3_1_1Rational.html">Rational</a> upperBoundR = upperBoundExpr[0].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>();
<a name="l02791"></a>02791 
<a name="l02792"></a>02792     <span class="keywordflow">if</span> (<a class="code" href="namespaceCVC3.html#a8ef991dfa16ee3a209b7f38014153101">isLE</a>(lowerBoundExpr) &amp;&amp; <a class="code" href="namespaceCVC3.html#af85f3152a3b2fe195d795bc0aefaec71">isGE</a>(upperBoundExpr)) {
<a name="l02793"></a>02793       <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(upperBoundR &lt; lowerBoundR, <span class="stringliteral">&quot;clashingBounds: bounds are satisfiable&quot;</span>);
<a name="l02794"></a>02794     } <span class="keywordflow">else</span> {
<a name="l02795"></a>02795       <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(upperBoundR &lt;= lowerBoundR, <span class="stringliteral">&quot;clashingBounds: bounds are satisfiable&quot;</span>);
<a name="l02796"></a>02796     }
<a name="l02797"></a>02797   }
<a name="l02798"></a>02798 
<a name="l02799"></a>02799   <span class="comment">// The proof object that we will use</span>
<a name="l02800"></a>02800   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l02801"></a>02801   <span class="comment">// Setup the proof if needed</span>
<a name="l02802"></a>02802   <span class="keywordflow">if</span> (withProof())
<a name="l02803"></a>02803     pf = newPf(<span class="stringliteral">&quot;clashingBounds&quot;</span>, lowerBoundExpr, upperBoundExpr);
<a name="l02804"></a>02804 
<a name="l02805"></a>02805   <span class="comment">// Put the bounds expressions in the assumptions</span>
<a name="l02806"></a>02806   <a class="code" href="classCVC3_1_1Assumptions.html">Assumptions</a> assumptions;
<a name="l02807"></a>02807   assumptions.<a class="code" href="classCVC3_1_1Assumptions.html#a72ece655220d8976c4090006eb7b0b40">add</a>(lowerBound);
<a name="l02808"></a>02808   assumptions.<a class="code" href="classCVC3_1_1Assumptions.html#a72ece655220d8976c4090006eb7b0b40">add</a>(upperBound);
<a name="l02809"></a>02809 
<a name="l02810"></a>02810   <span class="comment">// Return the theorem</span>
<a name="l02811"></a>02811   <span class="keywordflow">return</span> newTheorem(d_em-&gt;falseExpr(), assumptions, pf);
<a name="l02812"></a>02812 }
<a name="l02813"></a>02813 
<a name="l02814"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a301d62f207b9cfd50096417d1f5852df">02814</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::addInequalities(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; thm1, <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; thm2) {
<a name="l02815"></a>02815 
<a name="l02816"></a>02816   <span class="comment">// Get the expressions of the theorem</span>
<a name="l02817"></a>02817   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; expr1 = thm1.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>();
<a name="l02818"></a>02818   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; expr2 = thm2.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>();
<a name="l02819"></a>02819 
<a name="l02820"></a>02820   <span class="comment">// Check soundness</span>
<a name="l02821"></a>02821   <span class="keywordflow">if</span> (<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l02822"></a>02822 
<a name="l02823"></a>02823     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#abbae617aaff89a9e5deb84ab649e14a0">isIneq</a>(expr1), <span class="stringliteral">&quot;addInequalities: expecting an inequality for thm1, got &quot;</span> + expr1.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l02824"></a>02824     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#abbae617aaff89a9e5deb84ab649e14a0">isIneq</a>(expr2), <span class="stringliteral">&quot;addInequalities: expecting an inequality for thm2, got &quot;</span> + expr2.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l02825"></a>02825 
<a name="l02826"></a>02826     <span class="keywordflow">if</span> (<a class="code" href="namespaceCVC3.html#a8ef991dfa16ee3a209b7f38014153101">isLE</a>(expr1) || <a class="code" href="namespaceCVC3.html#a448b6e0d541113608bba5a7a005609e3">isLT</a>(expr1))
<a name="l02827"></a>02827       <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#a8ef991dfa16ee3a209b7f38014153101">isLE</a>(expr2) || <a class="code" href="namespaceCVC3.html#a448b6e0d541113608bba5a7a005609e3">isLT</a>(expr2), <span class="stringliteral">&quot;addInequalities: expr2 should be &lt;(=) also &quot;</span> + expr2.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l02828"></a>02828     <span class="keywordflow">if</span> (<a class="code" href="namespaceCVC3.html#af85f3152a3b2fe195d795bc0aefaec71">isGE</a>(expr1) || <a class="code" href="namespaceCVC3.html#a7306d7566ccb21380f05058477aba009">isGT</a>(expr1))
<a name="l02829"></a>02829       <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#af85f3152a3b2fe195d795bc0aefaec71">isGE</a>(expr2) || <a class="code" href="namespaceCVC3.html#a7306d7566ccb21380f05058477aba009">isGT</a>(expr2), <span class="stringliteral">&quot;addInequalities: expr2 should be &gt;(=) also&quot;</span> + expr2.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l02830"></a>02830   }
<a name="l02831"></a>02831 
<a name="l02832"></a>02832   <span class="comment">// Create the assumptions</span>
<a name="l02833"></a>02833   <a class="code" href="classCVC3_1_1Assumptions.html">Assumptions</a> a(thm1, thm2);
<a name="l02834"></a>02834 
<a name="l02835"></a>02835     <span class="comment">// Get the kinds of the inequalitites</span>
<a name="l02836"></a>02836     <span class="keywordtype">int</span> kind1  = expr1.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>();
<a name="l02837"></a>02837     <span class="keywordtype">int</span> kind2  = expr2.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>();
<a name="l02838"></a>02838 
<a name="l02839"></a>02839     <span class="comment">// Set-up the resulting inequality</span>
<a name="l02840"></a>02840     <span class="keywordtype">int</span> kind = (kind1 == kind2) ? kind1 : ((kind1 == <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a9e29ecc77281f945fb50c183cfae6749">LT</a>) || (kind2 == <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a9e29ecc77281f945fb50c183cfae6749">LT</a>))? <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a9e29ecc77281f945fb50c183cfae6749">LT</a> : <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a589b68b2d271254aa9fd3d89b4bf33b9">GT</a>;
<a name="l02841"></a>02841 
<a name="l02842"></a>02842     <span class="comment">// Create the proof object</span>
<a name="l02843"></a>02843     <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l02844"></a>02844     <span class="keywordflow">if</span>(withProof()) {
<a name="l02845"></a>02845       vector&lt;Proof&gt; pfs;
<a name="l02846"></a>02846       pfs.push_back(thm1.<a class="code" href="classCVC3_1_1Theorem.html#a2d8352c07a756c3837683a27a1e659ef">getProof</a>());
<a name="l02847"></a>02847       pfs.push_back(thm2.<a class="code" href="classCVC3_1_1Theorem.html#a2d8352c07a756c3837683a27a1e659ef">getProof</a>());
<a name="l02848"></a>02848       pf = newPf(<span class="stringliteral">&quot;addInequalities&quot;</span>, expr1, expr2, pfs);
<a name="l02849"></a>02849     }
<a name="l02850"></a>02850 
<a name="l02851"></a>02851     <span class="comment">// Create the new expressions</span>
<a name="l02852"></a>02852     <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> leftSide  = <a class="code" href="namespaceCVC3.html#accd3d7d38b0e04136afbc3e5191bc8bb">plusExpr</a>(expr1[0], expr2[0]);
<a name="l02853"></a>02853     <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> rightSide = <a class="code" href="namespaceCVC3.html#accd3d7d38b0e04136afbc3e5191bc8bb">plusExpr</a>(expr1[1], expr2[1]);
<a name="l02854"></a>02854 
<a name="l02855"></a>02855     <span class="comment">// Return the theorem</span>
<a name="l02856"></a>02856     <span class="keywordflow">return</span> newTheorem(<a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>(kind, leftSide, rightSide), a, pf);
<a name="l02857"></a>02857 }
<a name="l02858"></a>02858 
<a name="l02859"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#ae856ca9fab9699b655d7fd76cdf778d4">02859</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::implyWeakerInequality(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; expr1, <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; expr2) {
<a name="l02860"></a>02860 
<a name="l02861"></a>02861   <span class="comment">// Check soundness</span>
<a name="l02862"></a>02862   <span class="keywordflow">if</span> (<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l02863"></a>02863 
<a name="l02864"></a>02864     <span class="comment">// Both must be inequalitites</span>
<a name="l02865"></a>02865     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#abbae617aaff89a9e5deb84ab649e14a0">isIneq</a>(expr1), <span class="stringliteral">&quot;implyWeakerInequality: expr1 should be an inequality&quot;</span> + expr1.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l02866"></a>02866     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#abbae617aaff89a9e5deb84ab649e14a0">isIneq</a>(expr2), <span class="stringliteral">&quot;implyWeakerInequality: expr1 should be an inequality&quot;</span> + expr2.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l02867"></a>02867 
<a name="l02868"></a>02868     <span class="comment">// Should be of the same type</span>
<a name="l02869"></a>02869     <span class="keywordflow">if</span> (<a class="code" href="namespaceCVC3.html#a8ef991dfa16ee3a209b7f38014153101">isLE</a>(expr1) || <a class="code" href="namespaceCVC3.html#a448b6e0d541113608bba5a7a005609e3">isLT</a>(expr1))
<a name="l02870"></a>02870       <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#a8ef991dfa16ee3a209b7f38014153101">isLE</a>(expr2) || <a class="code" href="namespaceCVC3.html#a448b6e0d541113608bba5a7a005609e3">isLT</a>(expr2), <span class="stringliteral">&quot;implyWeakerInequality: expr2 should be &lt;(=) also &quot;</span> + expr2.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l02871"></a>02871     <span class="keywordflow">if</span> (<a class="code" href="namespaceCVC3.html#af85f3152a3b2fe195d795bc0aefaec71">isGE</a>(expr1) || <a class="code" href="namespaceCVC3.html#a7306d7566ccb21380f05058477aba009">isGT</a>(expr1))
<a name="l02872"></a>02872       <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#af85f3152a3b2fe195d795bc0aefaec71">isGE</a>(expr2) || <a class="code" href="namespaceCVC3.html#a7306d7566ccb21380f05058477aba009">isGT</a>(expr2), <span class="stringliteral">&quot;implyWeakerInequality: expr2 should be &gt;(=) also&quot;</span> + expr2.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l02873"></a>02873 
<a name="l02874"></a>02874     <span class="comment">// Left sides must be rational numbers</span>
<a name="l02875"></a>02875     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(expr1[0].<a class="code" href="namespaceCVC3.html#ac0334a083d6782caa17ca0d337fddddf">isRational</a>(), <span class="stringliteral">&quot;implyWeakerInequality: expr1 should have a rational on the left side&quot;</span> + expr1.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l02876"></a>02876     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(expr2[0].<a class="code" href="namespaceCVC3.html#ac0334a083d6782caa17ca0d337fddddf">isRational</a>(), <span class="stringliteral">&quot;implyWeakerInequality: expr2 should have a rational on the left side&quot;</span> + expr2.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l02877"></a>02877 
<a name="l02878"></a>02878     <span class="comment">// Right sides must be identical</span>
<a name="l02879"></a>02879     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(expr1[1] == expr2[1], <span class="stringliteral">&quot;implyWeakerInequality: the expression must be the same&quot;</span> + expr1.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>() + <span class="stringliteral">&quot; and &quot;</span> + expr2.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l02880"></a>02880 
<a name="l02881"></a>02881     <a class="code" href="classCVC3_1_1Rational.html">Rational</a> expr1rat = expr1[0].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>();
<a name="l02882"></a>02882     <a class="code" href="classCVC3_1_1Rational.html">Rational</a> expr2rat = expr2[0].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>();
<a name="l02883"></a>02883 
<a name="l02884"></a>02884 
<a name="l02885"></a>02885     <span class="comment">// Check the bounds</span>
<a name="l02886"></a>02886     <span class="keywordflow">if</span> (<a class="code" href="namespaceCVC3.html#a8ef991dfa16ee3a209b7f38014153101">isLE</a>(expr1) || <a class="code" href="namespaceCVC3.html#a448b6e0d541113608bba5a7a005609e3">isLT</a>(expr2)) {
<a name="l02887"></a>02887       <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(expr2rat &lt; expr1rat,  <span class="stringliteral">&quot;implyWeakerInequality: the implication doesn&#39;t apply&quot;</span> + expr1.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>() + <span class="stringliteral">&quot; and &quot;</span> + expr2.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l02888"></a>02888     } <span class="keywordflow">else</span> {
<a name="l02889"></a>02889       <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(expr2rat &lt;= expr1rat, <span class="stringliteral">&quot;implyWeakerInequality: the implication doesn&#39;t apply&quot;</span> + expr1.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>() + <span class="stringliteral">&quot; and &quot;</span> + expr2.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l02890"></a>02890     }
<a name="l02891"></a>02891     <span class="keywordflow">if</span> (<a class="code" href="namespaceCVC3.html#af85f3152a3b2fe195d795bc0aefaec71">isGE</a>(expr1) || <a class="code" href="namespaceCVC3.html#a7306d7566ccb21380f05058477aba009">isGT</a>(expr2)) {
<a name="l02892"></a>02892       <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(expr2rat &gt; expr1rat,  <span class="stringliteral">&quot;implyWeakerInequality: the implication doesn&#39;t apply&quot;</span> + expr1.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>() + <span class="stringliteral">&quot; and &quot;</span> + expr2.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l02893"></a>02893     } <span class="keywordflow">else</span> {
<a name="l02894"></a>02894       <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(expr2rat &gt;= expr1rat, <span class="stringliteral">&quot;implyWeakerInequality: the implication doesn&#39;t apply&quot;</span> + expr1.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>() + <span class="stringliteral">&quot; and &quot;</span> + expr2.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l02895"></a>02895     }
<a name="l02896"></a>02896   }
<a name="l02897"></a>02897 
<a name="l02898"></a>02898     <span class="comment">// Create the proof object</span>
<a name="l02899"></a>02899     <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l02900"></a>02900     <span class="keywordflow">if</span>(withProof()) pf = newPf(<span class="stringliteral">&quot;implyWeakerInequality&quot;</span>, expr1, expr2);
<a name="l02901"></a>02901 
<a name="l02902"></a>02902   <span class="comment">// Return the theorem</span>
<a name="l02903"></a>02903   <span class="keywordflow">return</span> newTheorem(expr1.<a class="code" href="group__ExprPkg.html#ga8dd97bcdeb9d8870238f94a263fd083b">impExpr</a>(expr2), Assumptions::emptyAssump(), pf);
<a name="l02904"></a>02904 }
<a name="l02905"></a>02905 
<a name="l02906"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a1797b422d1100edc2464666121d7017b">02906</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::implyNegatedInequality(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; expr1, <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; expr2) {
<a name="l02907"></a>02907 
<a name="l02908"></a>02908   <span class="comment">// Check soundness</span>
<a name="l02909"></a>02909   <span class="keywordflow">if</span> (<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l02910"></a>02910     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#abbae617aaff89a9e5deb84ab649e14a0">isIneq</a>(expr1), <span class="stringliteral">&quot;implyNegatedInequality: lowerBound should be an inequality &quot;</span> + expr1.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l02911"></a>02911     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#abbae617aaff89a9e5deb84ab649e14a0">isIneq</a>(expr2), <span class="stringliteral">&quot;implyNegatedInequality: upperBound should be be an inequality &quot;</span> + expr2.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l02912"></a>02912     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(expr1[0].<a class="code" href="namespaceCVC3.html#ac0334a083d6782caa17ca0d337fddddf">isRational</a>(), <span class="stringliteral">&quot;implyNegatedInequality: lowerBound left side should be a rational &quot;</span> + expr1.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l02913"></a>02913     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(expr2[0].<a class="code" href="namespaceCVC3.html#ac0334a083d6782caa17ca0d337fddddf">isRational</a>(), <span class="stringliteral">&quot;implyNegatedInequality: upperBound left side should be a rational &quot;</span> + expr2.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l02914"></a>02914     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(expr1[1] == expr2[1], <span class="stringliteral">&quot;implyNegatedInequality: bounds not on the same term &quot;</span> + expr1.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>() + <span class="stringliteral">&quot;, &quot;</span> + expr2.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l02915"></a>02915 
<a name="l02916"></a>02916     <span class="comment">// Get the bounds</span>
<a name="l02917"></a>02917     <a class="code" href="classCVC3_1_1Rational.html">Rational</a> lowerBoundR = expr1[0].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>();
<a name="l02918"></a>02918     <a class="code" href="classCVC3_1_1Rational.html">Rational</a> upperBoundR = expr2[0].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>();
<a name="l02919"></a>02919 
<a name="l02920"></a>02920     <span class="keywordflow">if</span> (<a class="code" href="namespaceCVC3.html#a8ef991dfa16ee3a209b7f38014153101">isLE</a>(expr1) &amp;&amp; <a class="code" href="namespaceCVC3.html#af85f3152a3b2fe195d795bc0aefaec71">isGE</a>(expr2))
<a name="l02921"></a>02921       <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(upperBoundR &lt; lowerBoundR, <span class="stringliteral">&quot;implyNegatedInequality: cant imply negation&quot;</span> + expr1.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>() + <span class="stringliteral">&quot;, &quot;</span> + expr2.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l02922"></a>02922     <span class="keywordflow">if</span> (<a class="code" href="namespaceCVC3.html#a448b6e0d541113608bba5a7a005609e3">isLT</a>(expr1) || <a class="code" href="namespaceCVC3.html#a7306d7566ccb21380f05058477aba009">isGT</a>(expr2))
<a name="l02923"></a>02923       <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(upperBoundR &lt;= lowerBoundR, <span class="stringliteral">&quot;implyNegatedInequality: cant imply negation&quot;</span> + expr1.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>() + <span class="stringliteral">&quot;, &quot;</span> + expr2.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l02924"></a>02924     <span class="keywordflow">if</span> (<a class="code" href="namespaceCVC3.html#af85f3152a3b2fe195d795bc0aefaec71">isGE</a>(expr1) &amp;&amp; <a class="code" href="namespaceCVC3.html#a8ef991dfa16ee3a209b7f38014153101">isLE</a>(expr2))
<a name="l02925"></a>02925       <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(upperBoundR &gt; lowerBoundR, <span class="stringliteral">&quot;implyNegatedInequality: cant imply negation&quot;</span> + expr1.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>() + <span class="stringliteral">&quot;, &quot;</span> + expr2.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l02926"></a>02926     <span class="keywordflow">if</span> (<a class="code" href="namespaceCVC3.html#a7306d7566ccb21380f05058477aba009">isGT</a>(expr1) || <a class="code" href="namespaceCVC3.html#a448b6e0d541113608bba5a7a005609e3">isLT</a>(expr2))
<a name="l02927"></a>02927       <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(upperBoundR &gt;= lowerBoundR, <span class="stringliteral">&quot;implyNegatedInequality: cant imply negation&quot;</span> + expr1.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>() + <span class="stringliteral">&quot;, &quot;</span> + expr2.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l02928"></a>02928   }
<a name="l02929"></a>02929 
<a name="l02930"></a>02930   <span class="comment">// The proof object that we will use</span>
<a name="l02931"></a>02931   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l02932"></a>02932   <span class="keywordflow">if</span> (withProof()) pf = newPf(<span class="stringliteral">&quot;implyNegatedInequality&quot;</span>, expr1, expr2);
<a name="l02933"></a>02933 
<a name="l02934"></a>02934   <span class="comment">// Return the theorem</span>
<a name="l02935"></a>02935   <span class="keywordflow">return</span> newTheorem(expr1.<a class="code" href="group__ExprPkg.html#ga8dd97bcdeb9d8870238f94a263fd083b">impExpr</a>(expr2.<a class="code" href="group__ExprPkg.html#gab1ce461dc931af73bf04e88c8d37dcbc">negate</a>()), Assumptions::emptyAssump(), pf);
<a name="l02936"></a>02936 }
<a name="l02937"></a>02937 
<a name="l02938"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#ad58ee7b299de278620860c9d67a2662b">02938</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::trustedRewrite(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; expr1, <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; expr2) {
<a name="l02939"></a>02939 
<a name="l02940"></a>02940   <span class="comment">// The proof object that we will us</span>
<a name="l02941"></a>02941   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l02942"></a>02942 
<a name="l02943"></a>02943   <span class="comment">// Setup the proof if needed</span>
<a name="l02944"></a>02944   <span class="keywordflow">if</span> (withProof()) pf = newPf(<span class="stringliteral">&quot;trustedRewrite&quot;</span>, expr1, expr2);
<a name="l02945"></a>02945 
<a name="l02946"></a>02946   <span class="comment">// Return the rewrite theorem that explains the phenomenon</span>
<a name="l02947"></a>02947   <span class="keywordflow">return</span> newRWTheorem(expr1, expr2, Assumptions::emptyAssump(), pf);
<a name="l02948"></a>02948 
<a name="l02949"></a>02949 }
<a name="l02950"></a>02950 
<a name="l02951"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#ae25218af53e642382f30948adc991313">02951</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::integerSplit(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; intVar, <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Rational.html">Rational</a>&amp; intPoint) {
<a name="l02952"></a>02952 
<a name="l02953"></a>02953   <span class="comment">// Check soundness</span>
<a name="l02954"></a>02954   <span class="keywordflow">if</span> (<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l02955"></a>02955     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(intPoint.<a class="code" href="classCVC3_1_1Rational.html#a1366320f4de558bb964c67f8aecedb36">isInteger</a>(), <span class="stringliteral">&quot;integerSplit: we can only split on integer points, given&quot;</span> + intPoint.<a class="code" href="classCVC3_1_1Rational.html#a195c125a76cb9a6c5731369e244a2de3">toString</a>());
<a name="l02956"></a>02956   }
<a name="l02957"></a>02957 
<a name="l02958"></a>02958   <span class="comment">// Create the expression</span>
<a name="l02959"></a>02959   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; split = <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>(<a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a3193c0a76bedff5b39b32531195ef779">IS_INTEGER</a>, intVar).<a class="code" href="group__ExprPkg.html#ga8dd97bcdeb9d8870238f94a263fd083b">impExpr</a>(<a class="code" href="namespaceCVC3.html#aebfd8a82800bd3dff4c8db461a52cdea">leExpr</a>(intVar, rat(intPoint)).<a class="code" href="namespaceCVC3.html#a30f30b6e20c174f21ae63acea8618294">orExpr</a>(<a class="code" href="namespaceCVC3.html#a520cf0df288be321d27ea6fa77ded2d2">geExpr</a>(intVar, rat(intPoint + 1))));
<a name="l02960"></a>02960 
<a name="l02961"></a>02961   <span class="comment">// The proof object that we will use</span>
<a name="l02962"></a>02962   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l02963"></a>02963   <span class="keywordflow">if</span> (withProof()) pf = newPf(<span class="stringliteral">&quot;integerSplit&quot;</span>, intVar, rat(intPoint));
<a name="l02964"></a>02964 
<a name="l02965"></a>02965   <span class="comment">// Return the theorem</span>
<a name="l02966"></a>02966   <span class="keywordflow">return</span> newTheorem(split, Assumptions::emptyAssump(), pf);
<a name="l02967"></a>02967 }
<a name="l02968"></a>02968 
<a name="l02969"></a>02969 
<a name="l02970"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a7638b18d73c05e7bedad7c4cdfeca809">02970</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::rafineStrictInteger(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; isIntConstrThm, <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; constr) {
<a name="l02971"></a>02971 
<a name="l02972"></a>02972 
<a name="l02973"></a>02973   <span class="comment">// Check soundness</span>
<a name="l02974"></a>02974   <span class="keywordflow">if</span> (<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l02975"></a>02975     <span class="comment">// Right side of the constraint should correspond to the proved integer expression</span>
<a name="l02976"></a>02976     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#abbae617aaff89a9e5deb84ab649e14a0">isIneq</a>(constr), <span class="stringliteral">&quot;rafineStrictInteger: expected a constraint got : &quot;</span> + constr.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l02977"></a>02977     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(isIntConstrThm.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>()[0] == constr[1], <span class="stringliteral">&quot;rafineStrictInteger: proof of intger doesn&#39;t correspond to the constarint right side&quot;</span>);
<a name="l02978"></a>02978     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(constr[0].<a class="code" href="namespaceCVC3.html#ac0334a083d6782caa17ca0d337fddddf">isRational</a>(), <span class="stringliteral">&quot;rafineStrictInteger: right side of the constraint muts be a rational&quot;</span>);
<a name="l02979"></a>02979   }
<a name="l02980"></a>02980 
<a name="l02981"></a>02981   <span class="comment">// Get the contraint bound</span>
<a name="l02982"></a>02982   <a class="code" href="classCVC3_1_1Rational.html">Rational</a> bound = constr[0].<a class="code" href="group__ExprPkg.html#gab0eee70e4a7f97c09954dc61b71b65e5" title="Get the Rational value out of RATIONAL_EXPR.">getRational</a>();
<a name="l02983"></a>02983 
<a name="l02984"></a>02984   <span class="comment">// Get the kind of the constraint</span>
<a name="l02985"></a>02985   <span class="keywordtype">int</span> kind = constr.<a class="code" href="group__ExprPkg.html#ga7814e4f55f65c7ca860c637413df5f4d">getKind</a>();
<a name="l02986"></a>02986 
<a name="l02987"></a>02987   <span class="comment">// If the bound is strict, make it non-strict</span>
<a name="l02988"></a>02988   <span class="keywordflow">switch</span> (kind) {
<a name="l02989"></a>02989     <span class="keywordflow">case</span> <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a9e29ecc77281f945fb50c183cfae6749">LT</a>:
<a name="l02990"></a>02990       kind = <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a1b768cf71a18713c90cd71f82488ffb1">LE</a>;
<a name="l02991"></a>02991       <span class="keywordflow">if</span> (bound.<a class="code" href="classCVC3_1_1Rational.html#a1366320f4de558bb964c67f8aecedb36">isInteger</a>()) bound ++;             <span class="comment">// 3 &lt; x   --&gt; 4 &lt;= x</span>
<a name="l02992"></a>02992       <span class="keywordflow">else</span> bound = ceil(bound);                    <span class="comment">// 3.4 &lt; x --&gt; 4 &lt;= x</span>
<a name="l02993"></a>02993       <span class="keywordflow">break</span>;
<a name="l02994"></a>02994     <span class="keywordflow">case</span> <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a1b768cf71a18713c90cd71f82488ffb1">LE</a>:
<a name="l02995"></a>02995       kind = <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a1b768cf71a18713c90cd71f82488ffb1">LE</a>;
<a name="l02996"></a>02996       <span class="keywordflow">if</span> (!bound.<a class="code" href="classCVC3_1_1Rational.html#a1366320f4de558bb964c67f8aecedb36">isInteger</a>()) bound = ceil(bound); <span class="comment">// 3.5 &lt;= x --&gt; 4 &lt;= x</span>
<a name="l02997"></a>02997       <span class="keywordflow">break</span>;
<a name="l02998"></a>02998     <span class="keywordflow">case</span> <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024a589b68b2d271254aa9fd3d89b4bf33b9">GT</a>:
<a name="l02999"></a>02999       kind = <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024aad2afa561f31a801e12ab3fdd50a6229">GE</a>;
<a name="l03000"></a>03000       <span class="keywordflow">if</span> (bound.<a class="code" href="classCVC3_1_1Rational.html#a1366320f4de558bb964c67f8aecedb36">isInteger</a>()) bound --;             <span class="comment">// 3 &gt; x   --&gt; 2 &gt;= x</span>
<a name="l03001"></a>03001       <span class="keywordflow">else</span> bound = floor(bound);                   <span class="comment">// 3.4 &gt; x --&gt; 3 &gt;= x</span>
<a name="l03002"></a>03002       <span class="keywordflow">break</span>;
<a name="l03003"></a>03003     <span class="keywordflow">case</span> <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024aad2afa561f31a801e12ab3fdd50a6229">GE</a>:
<a name="l03004"></a>03004       kind = <a class="code" href="namespaceCVC3.html#a32d50a30de0e9e5bc4c2451de0107024aad2afa561f31a801e12ab3fdd50a6229">GE</a>;
<a name="l03005"></a>03005       <span class="keywordflow">if</span> (!bound.<a class="code" href="classCVC3_1_1Rational.html#a1366320f4de558bb964c67f8aecedb36">isInteger</a>()) bound = floor(bound); <span class="comment">// 3.4 &gt;= x --&gt; 3 &gt;= x</span>
<a name="l03006"></a>03006       <span class="keywordflow">break</span>;
<a name="l03007"></a>03007   }
<a name="l03008"></a>03008 
<a name="l03009"></a>03009   <span class="comment">// The new constraint</span>
<a name="l03010"></a>03010   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> newConstr(kind, rat(bound), constr[1]);
<a name="l03011"></a>03011 
<a name="l03012"></a>03012   <span class="comment">// Pick up the assumptions from the integer proof</span>
<a name="l03013"></a>03013   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Assumptions.html">Assumptions</a>&amp; assump(isIntConstrThm.<a class="code" href="classCVC3_1_1Theorem.html#a5e9ab00a613df15cc02f55edb55a67b3">getAssumptionsRef</a>());
<a name="l03014"></a>03014 
<a name="l03015"></a>03015     <span class="comment">// Construct the proof object if necessary</span>
<a name="l03016"></a>03016     <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l03017"></a>03017   <span class="keywordflow">if</span> (withProof()) pf = newPf(<span class="stringliteral">&quot;rafineStrictInteger&quot;</span>, constr, isIntConstrThm.<a class="code" href="classCVC3_1_1Theorem.html#a2d8352c07a756c3837683a27a1e659ef">getProof</a>());
<a name="l03018"></a>03018 
<a name="l03019"></a>03019   <span class="comment">// Return the rewrite theorem that explains the phenomenon</span>
<a name="l03020"></a>03020   <span class="keywordflow">return</span> newRWTheorem(constr, newConstr, assump, pf);
<a name="l03021"></a>03021 }
<a name="l03022"></a>03022 
<a name="l03023"></a>03023 
<a name="l03024"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#aab0ccd490624628fa990b1dd473e7e8a">03024</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::splitGrayShadowSmall(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; gThm) {
<a name="l03025"></a>03025   <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(<span class="keyword">false</span>, <span class="stringliteral">&quot;Not implemented!!!&quot;</span>);
<a name="l03026"></a>03026   <span class="keywordflow">return</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>();
<a name="l03027"></a>03027 }
<a name="l03028"></a>03028 
<a name="l03029"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a8e90a0d0e2050a7f0eb1dde6df7f6842">03029</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::implyWeakerInequalityDiffLogic(<span class="keyword">const</span> std::vector&lt;Theorem&gt;&amp; antecedentThms, <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; implied) {
<a name="l03030"></a>03030   <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(<span class="keyword">false</span>, <span class="stringliteral">&quot;Not implemented!!!&quot;</span>);
<a name="l03031"></a>03031   <span class="keywordflow">return</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>();
<a name="l03032"></a>03032 }
<a name="l03033"></a>03033 
<a name="l03034"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a6ef98983cca8d3723f50fbea60c37cef">03034</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::implyNegatedInequalityDiffLogic(<span class="keyword">const</span> std::vector&lt;Theorem&gt;&amp; antecedentThms, <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; implied) {
<a name="l03035"></a>03035   <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(<span class="keyword">false</span>, <span class="stringliteral">&quot;Not implemented!!!&quot;</span>);
<a name="l03036"></a>03036   <span class="keywordflow">return</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>();
<a name="l03037"></a>03037 }
<a name="l03038"></a>03038 
<a name="l03039"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#aa9b6fa1339b7e68cb730bdf2f63c0914">03039</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::expandGrayShadowRewrite(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; theShadow) {
<a name="l03040"></a>03040   <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(<span class="keyword">false</span>, <span class="stringliteral">&quot;Not implemented!!!&quot;</span>);
<a name="l03041"></a>03041   <span class="keywordflow">return</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>();
<a name="l03042"></a>03042 }
<a name="l03043"></a>03043 
<a name="l03044"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#aac90a712f81d969d8aa0322b4d31de0b">03044</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::compactNonLinearTerm(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; nonLinear) {
<a name="l03045"></a>03045   <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(<span class="keyword">false</span>, <span class="stringliteral">&quot;Not implemented!!!&quot;</span>);
<a name="l03046"></a>03046   <span class="keywordflow">return</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>();
<a name="l03047"></a>03047 }
<a name="l03048"></a>03048 
<a name="l03049"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#aaa91789edbf7fb936789379dd15a3a4f">03049</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::nonLinearIneqSignSplit(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; ineqThm) {
<a name="l03050"></a>03050   <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(<span class="keyword">false</span>, <span class="stringliteral">&quot;Not implemented!!!&quot;</span>);
<a name="l03051"></a>03051   <span class="keywordflow">return</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>();
<a name="l03052"></a>03052 }
<a name="l03053"></a>03053 
<a name="l03054"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a9edd45196fbd8e61a4927134fde15e97">03054</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::implyDiffLogicBothBounds(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; x,
<a name="l03055"></a>03055               std::vector&lt;Theorem&gt;&amp; c1_le_x, <a class="code" href="classCVC3_1_1Rational.html">Rational</a> c1,
<a name="l03056"></a>03056                 std::vector&lt;Theorem&gt;&amp; x_le_c2, <a class="code" href="classCVC3_1_1Rational.html">Rational</a> c2) {
<a name="l03057"></a>03057   <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(<span class="keyword">false</span>, <span class="stringliteral">&quot;Not implemented!!!&quot;</span>);
<a name="l03058"></a>03058   <span class="keywordflow">return</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>();
<a name="l03059"></a>03059 }
<a name="l03060"></a>03060 
<a name="l03061"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#aa2d099917106ead1062c72dde26a17a5">03061</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::addInequalities(<span class="keyword">const</span> vector&lt;Theorem&gt;&amp; thms) {
<a name="l03062"></a>03062   <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(<span class="keyword">false</span>, <span class="stringliteral">&quot;Not implemented!!!&quot;</span>);
<a name="l03063"></a>03063   <span class="keywordflow">return</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>();
<a name="l03064"></a>03064 }
<a name="l03065"></a>03065 
<a name="l03066"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#abf49b0eeb6087702dd1a8e9c03f7379a">03066</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::powerOfOne(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; e) {
<a name="l03067"></a>03067   <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(<span class="keyword">false</span>, <span class="stringliteral">&quot;Not implemented!!!&quot;</span>);
<a name="l03068"></a>03068   <span class="keywordflow">return</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>();
<a name="l03069"></a>03069 }
<a name="l03070"></a>03070 
<a name="l03071"></a>03071 <span class="comment">//</span>
<a name="l03072"></a>03072 <span class="comment">// This one is here just to compile... the code is in old arithmetic</span>
<a name="l03073"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a6fe0e5ebaf81278f55759fff05c275c1">03073</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::simpleIneqInt(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; ineq, <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; isIntRHS)
<a name="l03074"></a>03074 {
<a name="l03075"></a>03075   <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(<span class="keyword">false</span>, <span class="stringliteral">&quot;Not implemented!!!&quot;</span>);
<a name="l03076"></a>03076   <span class="keywordflow">return</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>();
<a name="l03077"></a>03077 }
<a name="l03078"></a>03078 
<a name="l03079"></a>03079 <span class="comment">// Given:</span>
<a name="l03080"></a>03080 <span class="comment">// 0 = c + t</span>
<a name="l03081"></a>03081 <span class="comment">// where t is integer and c is not</span>
<a name="l03082"></a>03082 <span class="comment">// deduce bot</span>
<a name="l03083"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a84ec7197bec26c33753e98b6adf55dce">03083</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::intEqualityRationalConstant(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; isIntConstrThm, <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; constr) {
<a name="l03084"></a>03084   <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(<span class="keyword">false</span>, <span class="stringliteral">&quot;Not implemented!!!&quot;</span>);
<a name="l03085"></a>03085   <span class="keywordflow">return</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>();
<a name="l03086"></a>03086 }
<a name="l03087"></a>03087 
<a name="l03088"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a5411413ef39cb6029a8e85fc03908de3">03088</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::cycleConflict(<span class="keyword">const</span> vector&lt;Theorem&gt;&amp; inequalitites) {
<a name="l03089"></a>03089   <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(<span class="keyword">false</span>, <span class="stringliteral">&quot;Not implemented!!!&quot;</span>);
<a name="l03090"></a>03090   <span class="keywordflow">return</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>();
<a name="l03091"></a>03091 }
<a name="l03092"></a>03092 
<a name="l03093"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a1efa679a45d71f60bf2be6f4f7a4430d">03093</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::implyEqualities(<span class="keyword">const</span> vector&lt;Theorem&gt;&amp; inequalitites) {
<a name="l03094"></a>03094   <a class="code" href="debug_8h.html#a40dac3bdb2166ffc852ee8b1489d2b56">DebugAssert</a>(<span class="keyword">false</span>, <span class="stringliteral">&quot;Not implemented!!!&quot;</span>);
<a name="l03095"></a>03095   <span class="keywordflow">return</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>();
<a name="l03096"></a>03096 }
<a name="l03097"></a>03097 
<a name="l03098"></a>03098 <span class="comment"></span>
<a name="l03099"></a>03099 <span class="comment">/*! Takes a Theorem(\\alpha &lt; \\beta) and returns</span>
<a name="l03100"></a>03100 <span class="comment"> *  Theorem(\\alpha &lt; \\beta &lt;==&gt; \\alpha &lt;= \\beta -1)</span>
<a name="l03101"></a>03101 <span class="comment"> * where \\alpha and \\beta are integer expressions</span>
<a name="l03102"></a>03102 <span class="comment"> */</span>
<a name="l03103"></a><a class="code" href="classCVC3_1_1ArithTheoremProducer3.html#a55c056040dc960b598706a94650acccb">03103</a> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a> ArithTheoremProducer3::lessThanToLERewrite(<span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; ineq,
<a name="l03104"></a>03104                                                    <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; isIntLHS,
<a name="l03105"></a>03105                                                    <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Theorem.html">Theorem</a>&amp; isIntRHS,
<a name="l03106"></a>03106                                                    <span class="keywordtype">bool</span> changeRight) {
<a name="l03107"></a>03107 
<a name="l03108"></a>03108   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; isIntLHSexpr = isIntLHS.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>();
<a name="l03109"></a>03109   <span class="keyword">const</span> <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a>&amp; isIntRHSexpr = isIntRHS.<a class="code" href="classCVC3_1_1Theorem.html#af2b97ae5d270ddf1013bf4f3867a7e5d">getExpr</a>();
<a name="l03110"></a>03110 
<a name="l03111"></a>03111   <span class="keywordflow">if</span>(<a class="code" href="theorem__producer_8h.html#a74a97b789e1a9e6c016291960c657445">CHECK_PROOFS</a>) {
<a name="l03112"></a>03112     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#a448b6e0d541113608bba5a7a005609e3">isLT</a>(ineq), <span class="stringliteral">&quot;ArithTheoremProducerOld::LTtoLE: ineq must be &lt;&quot;</span>);
<a name="l03113"></a>03113     <span class="comment">// Integrality check</span>
<a name="l03114"></a>03114     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#aff7910c172ccdd1afb5e42964e2f248d">isIntPred</a>(isIntLHSexpr) &amp;&amp; isIntLHSexpr[0] == ineq[0],
<a name="l03115"></a>03115     <span class="stringliteral">&quot;ArithTheoremProducerOld::lessThanToLE: bad integrality check:\n&quot;</span>
<a name="l03116"></a>03116     <span class="stringliteral">&quot; ineq = &quot;</span>+ineq.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>()+<span class="stringliteral">&quot;\n isIntLHS = &quot;</span>
<a name="l03117"></a>03117     +isIntLHSexpr.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l03118"></a>03118     <a class="code" href="theorem__producer_8h.html#a03dbe872f723d32fd975528f811d646e">CHECK_SOUND</a>(<a class="code" href="namespaceCVC3.html#aff7910c172ccdd1afb5e42964e2f248d">isIntPred</a>(isIntRHSexpr) &amp;&amp; isIntRHSexpr[0] == ineq[1],
<a name="l03119"></a>03119     <span class="stringliteral">&quot;ArithTheoremProducerOld::lessThanToLE: bad integrality check:\n&quot;</span>
<a name="l03120"></a>03120     <span class="stringliteral">&quot; ineq = &quot;</span>+ineq.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>()+<span class="stringliteral">&quot;\n isIntRHS = &quot;</span>
<a name="l03121"></a>03121     +isIntRHSexpr.<a class="code" href="group__ExprPkg.html#gaf3028bb1619f8cc69b66ec712e1adb54" title="Print the expression to a string.">toString</a>());
<a name="l03122"></a>03122   }
<a name="l03123"></a>03123 
<a name="l03124"></a>03124   vector&lt;Theorem&gt; thms;
<a name="l03125"></a>03125   thms.push_back(isIntLHS);
<a name="l03126"></a>03126   thms.push_back(isIntRHS);
<a name="l03127"></a>03127   <a class="code" href="classCVC3_1_1Assumptions.html">Assumptions</a> a(thms);
<a name="l03128"></a>03128   <a class="code" href="classCVC3_1_1Proof.html">Proof</a> pf;
<a name="l03129"></a>03129   <a class="code" href="classCVC3_1_1Expr.html" title="Data structure of expressions in CVC3.">Expr</a> le = changeRight? <a class="code" href="namespaceCVC3.html#aebfd8a82800bd3dff4c8db461a52cdea">leExpr</a>(ineq[0], ineq[1] + rat(-1)) : <a class="code" href="namespaceCVC3.html#aebfd8a82800bd3dff4c8db461a52cdea">leExpr</a>(ineq[0] + rat(1), ineq[1]);
<a name="l03130"></a>03130   <span class="keywordflow">if</span>(withProof()) {
<a name="l03131"></a>03131     vector&lt;Proof&gt; pfs;
<a name="l03132"></a>03132     pfs.push_back(isIntLHS.<a class="code" href="classCVC3_1_1Theorem.html#a2d8352c07a756c3837683a27a1e659ef">getProof</a>());
<a name="l03133"></a>03133     pfs.push_back(isIntRHS.<a class="code" href="classCVC3_1_1Theorem.html#a2d8352c07a756c3837683a27a1e659ef">getProof</a>());
<a name="l03134"></a>03134     pf = newPf(changeRight? <span class="stringliteral">&quot;lessThan_To_LE_rhs&quot;</span> : <span class="stringliteral">&quot;lessThan_To_LE_lhs&quot;</span>, le, pfs);
<a name="l03135"></a>03135   }
<a name="l03136"></a>03136 
<a name="l03137"></a>03137   <span class="keywordflow">return</span> newRWTheorem(ineq, le, a, pf);
<a name="l03138"></a>03138 }
</pre></div></div>
</div>
<hr class="footer"/><address class="footer"><small>Generated on Wed Sep 7 2011 for CVC3 by&#160;
<a href="http://www.doxygen.org/index.html">
<img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.7.4 </small></address>
</body>
</html>