Sophie

Sophie

distrib > Mandriva > 2010.0 > i586 > media > contrib-release > by-pkgid > a24e1a39141f9b4ca49bd1e2e23a54ba > files > 804

polybori-doc-0.5rc.p9-6mdv2010.0.i586.rpm

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html><head><meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
<title>PolyBoRi: pbori_algo.h 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.5.9 -->
<div class="navigation" id="top">
  <div class="tabs">
    <ul>
      <li><a href="index.html"><span>Main&nbsp;Page</span></a></li>
      <li><a href="pages.html"><span>Related&nbsp;Pages</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 class="tabs">
    <ul>
      <li><a href="files.html"><span>File&nbsp;List</span></a></li>
      <li><a href="globals.html"><span>File&nbsp;Members</span></a></li>
    </ul>
  </div>
<h1>pbori_algo.h</h1><a href="pbori__algo_8h.html">Go to the documentation of this file.</a><div class="fragment"><pre class="fragment"><a name="l00001"></a>00001 <span class="comment">// -*- c++ -*-</span>
<a name="l00002"></a>00002 <span class="comment">//*****************************************************************************</span>
<a name="l00150"></a>00150 <span class="comment"></span><span class="comment">//*****************************************************************************</span>
<a name="l00151"></a>00151 
<a name="l00152"></a>00152 <span class="comment">// include polybori's definitions</span>
<a name="l00153"></a>00153 <span class="preprocessor">#include "<a class="code" href="pbori__defs_8h.html">pbori_defs.h</a>"</span>
<a name="l00154"></a>00154 
<a name="l00155"></a>00155 <span class="comment">// get polybori's functionals</span>
<a name="l00156"></a>00156 <span class="preprocessor">#include "<a class="code" href="pbori__func_8h.html">pbori_func.h</a>"</span>
<a name="l00157"></a>00157 <span class="preprocessor">#include "<a class="code" href="pbori__traits_8h.html">pbori_traits.h</a>"</span>
<a name="l00158"></a>00158 
<a name="l00159"></a>00159 <span class="comment">// temporarily</span>
<a name="l00160"></a>00160 <span class="preprocessor">#include "cudd.h"</span>
<a name="l00161"></a>00161 <span class="preprocessor">#include "cuddInt.h"</span>
<a name="l00162"></a>00162 <span class="preprocessor">#include "<a class="code" href="CCuddInterface_8h.html">CCuddInterface.h</a>"</span>
<a name="l00163"></a>00163 
<a name="l00164"></a>00164 <span class="preprocessor">#ifndef pbori_algo_h_</span>
<a name="l00165"></a>00165 <span class="preprocessor"></span><span class="preprocessor">#define pbori_algo_h_</span>
<a name="l00166"></a>00166 <span class="preprocessor"></span>
<a name="l00167"></a>00167 <a class="code" href="pbori__defs_8h.html#6ae360a591580558f31b6157ee792a10" title="Start project&amp;#39;s namespace.">BEGIN_NAMESPACE_PBORI</a>
<a name="l00168"></a>00168 
<a name="l00169"></a>00169 
<a name="l00171"></a>00171 <span class="keyword">template</span>&lt; <span class="keyword">class </span>NaviType, <span class="keyword">class </span>TermType, 
<a name="l00172"></a>00172           <span class="keyword">class </span>TernaryOperator, 
<a name="l00173"></a>00173           <span class="keyword">class </span>TerminalOperator &gt;
<a name="l00174"></a>00174 TermType
<a name="l00175"></a><a class="code" href="namespacepolybori.html#681b961708e4781decc938ba35aafe34">00175</a> <a class="code" href="namespacepolybori.html#681b961708e4781decc938ba35aafe34" title="Function templates for transforming decision diagrams.">dd_backward_transform</a>( NaviType navi, TermType init, TernaryOperator newNode,
<a name="l00176"></a>00176               TerminalOperator terminate ) {
<a name="l00177"></a>00177  
<a name="l00178"></a>00178   TermType result = init;
<a name="l00179"></a>00179 
<a name="l00180"></a>00180   <span class="keywordflow">if</span> (navi.isConstant()) {      <span class="comment">// Reached end of path</span>
<a name="l00181"></a>00181     <span class="keywordflow">if</span> (navi.terminalValue()){   <span class="comment">// Case of a valid path</span>
<a name="l00182"></a>00182       result = terminate();
<a name="l00183"></a>00183     }
<a name="l00184"></a>00184   }
<a name="l00185"></a>00185   <span class="keywordflow">else</span> {
<a name="l00186"></a>00186     result = <a class="code" href="namespacepolybori.html#681b961708e4781decc938ba35aafe34" title="Function templates for transforming decision diagrams.">dd_backward_transform</a>(navi.thenBranch(), init, newNode, terminate);
<a name="l00187"></a>00187     result = newNode(*navi, result, 
<a name="l00188"></a>00188                      <a class="code" href="namespacepolybori.html#681b961708e4781decc938ba35aafe34" title="Function templates for transforming decision diagrams.">dd_backward_transform</a>(navi.elseBranch(), init, newNode,
<a name="l00189"></a>00189                                            terminate) );
<a name="l00190"></a>00190   }
<a name="l00191"></a>00191   <span class="keywordflow">return</span> result;
<a name="l00192"></a>00192 }
<a name="l00193"></a>00193 
<a name="l00194"></a>00194 
<a name="l00196"></a>00196 <span class="keyword">template</span>&lt; <span class="keyword">class </span>NaviType, <span class="keyword">class </span>TermType, <span class="keyword">class </span>OutIterator,
<a name="l00197"></a>00197           <span class="keyword">class </span>ThenBinaryOperator, <span class="keyword">class </span>ElseBinaryOperator, 
<a name="l00198"></a>00198           <span class="keyword">class </span>TerminalOperator &gt;
<a name="l00199"></a>00199 OutIterator
<a name="l00200"></a><a class="code" href="namespacepolybori.html#094813e9371a53ba49be73a828c5a9dd">00200</a> <a class="code" href="namespacepolybori.html#094813e9371a53ba49be73a828c5a9dd" title="Function templates for transforming decision diagrams.">dd_transform</a>( NaviType navi, TermType init, OutIterator result, 
<a name="l00201"></a>00201               ThenBinaryOperator then_binop, ElseBinaryOperator else_binop,
<a name="l00202"></a>00202               TerminalOperator terminate ) {
<a name="l00203"></a>00203  
<a name="l00204"></a>00204 
<a name="l00205"></a>00205   <span class="keywordflow">if</span> (navi.isConstant()) {      <span class="comment">// Reached end of path</span>
<a name="l00206"></a>00206     <span class="keywordflow">if</span> (navi.terminalValue()){   <span class="comment">// Case of a valid path</span>
<a name="l00207"></a>00207       *result = terminate(init);
<a name="l00208"></a>00208       ++result;
<a name="l00209"></a>00209     }
<a name="l00210"></a>00210   }
<a name="l00211"></a>00211   <span class="keywordflow">else</span> {
<a name="l00212"></a>00212     result = <a class="code" href="namespacepolybori.html#094813e9371a53ba49be73a828c5a9dd" title="Function templates for transforming decision diagrams.">dd_transform</a>(navi.thenBranch(), then_binop(init, *navi), result,
<a name="l00213"></a>00213                  then_binop, else_binop, terminate);
<a name="l00214"></a>00214     result = <a class="code" href="namespacepolybori.html#094813e9371a53ba49be73a828c5a9dd" title="Function templates for transforming decision diagrams.">dd_transform</a>(navi.elseBranch(), else_binop(init, *navi), result,
<a name="l00215"></a>00215                  then_binop, else_binop, terminate);
<a name="l00216"></a>00216   }
<a name="l00217"></a>00217   <span class="keywordflow">return</span> result;
<a name="l00218"></a>00218 }
<a name="l00219"></a>00219 
<a name="l00222"></a>00222 <span class="keyword">template</span>&lt; <span class="keyword">class </span>NaviType, <span class="keyword">class </span>TermType, <span class="keyword">class </span>OutIterator,
<a name="l00223"></a>00223           <span class="keyword">class </span>ThenBinaryOperator, <span class="keyword">class </span>ElseBinaryOperator, 
<a name="l00224"></a>00224           <span class="keyword">class </span>TerminalOperator, <span class="keyword">class </span>FirstTermOp &gt;
<a name="l00225"></a>00225 OutIterator
<a name="l00226"></a><a class="code" href="namespacepolybori.html#786b86aa045cae7a738a47d9918ecce9">00226</a> <a class="code" href="namespacepolybori.html#094813e9371a53ba49be73a828c5a9dd" title="Function templates for transforming decision diagrams.">dd_transform</a>( NaviType navi, TermType init, OutIterator result, 
<a name="l00227"></a>00227               ThenBinaryOperator then_binop, ElseBinaryOperator else_binop,
<a name="l00228"></a>00228               TerminalOperator terminate, FirstTermOp terminate_first ) {
<a name="l00229"></a>00229 
<a name="l00230"></a>00230   <span class="keywordflow">if</span> (navi.isConstant()) {      <span class="comment">// Reached end of path</span>
<a name="l00231"></a>00231     <span class="keywordflow">if</span> (navi.terminalValue()){   <span class="comment">// Case of a valid path - here leading term</span>
<a name="l00232"></a>00232       *result = terminate_first(init);
<a name="l00233"></a>00233       ++result;
<a name="l00234"></a>00234     }
<a name="l00235"></a>00235   }
<a name="l00236"></a>00236   <span class="keywordflow">else</span> {
<a name="l00237"></a>00237     result = <a class="code" href="namespacepolybori.html#094813e9371a53ba49be73a828c5a9dd" title="Function templates for transforming decision diagrams.">dd_transform</a>(navi.thenBranch(), then_binop(init, *navi), result,
<a name="l00238"></a>00238                  then_binop, else_binop, terminate, terminate_first);
<a name="l00239"></a>00239     result = <a class="code" href="namespacepolybori.html#094813e9371a53ba49be73a828c5a9dd" title="Function templates for transforming decision diagrams.">dd_transform</a>(navi.elseBranch(), else_binop(init, *navi), result,
<a name="l00240"></a>00240                  then_binop, else_binop, terminate);
<a name="l00241"></a>00241   }
<a name="l00242"></a>00242   <span class="keywordflow">return</span> result;
<a name="l00243"></a>00243 }
<a name="l00244"></a>00244 
<a name="l00246"></a>00246 <span class="keyword">template</span>&lt; <span class="keyword">class </span>NaviType, <span class="keyword">class </span>TermType, <span class="keyword">class </span>OutIterator,
<a name="l00247"></a>00247           <span class="keyword">class </span>ThenBinaryOperator, <span class="keyword">class </span>ElseBinaryOperator &gt;
<a name="l00248"></a>00248 <span class="keywordtype">void</span>
<a name="l00249"></a><a class="code" href="namespacepolybori.html#ec5429fd8cdb912534290d56eb5d78d5">00249</a> <a class="code" href="namespacepolybori.html#094813e9371a53ba49be73a828c5a9dd" title="Function templates for transforming decision diagrams.">dd_transform</a>( <span class="keyword">const</span> NaviType&amp; navi, <span class="keyword">const</span> TermType&amp; init, 
<a name="l00250"></a>00250               <span class="keyword">const</span> OutIterator&amp; result, 
<a name="l00251"></a>00251               <span class="keyword">const</span> ThenBinaryOperator&amp; then_binop, 
<a name="l00252"></a>00252               <span class="keyword">const</span> ElseBinaryOperator&amp; else_binop ) {
<a name="l00253"></a>00253 
<a name="l00254"></a>00254   <a class="code" href="namespacepolybori.html#094813e9371a53ba49be73a828c5a9dd" title="Function templates for transforming decision diagrams.">dd_transform</a>(navi, init, result, then_binop, else_binop, 
<a name="l00255"></a>00255                <a class="code" href="classproject__ith.html" title="Virtually does nothing with the given arguments.">project_ith&lt;1&gt;</a>() );
<a name="l00256"></a>00256 }
<a name="l00257"></a>00257 
<a name="l00259"></a>00259 <span class="keyword">template</span>&lt; <span class="keyword">class </span>NaviType, <span class="keyword">class </span>TermType, <span class="keyword">class </span>OutIterator,
<a name="l00260"></a>00260           <span class="keyword">class </span>ThenBinaryOperator &gt;
<a name="l00261"></a>00261 <span class="keywordtype">void</span>
<a name="l00262"></a><a class="code" href="namespacepolybori.html#eb1a56a93f04c61bc5924739c1176d05">00262</a> <a class="code" href="namespacepolybori.html#094813e9371a53ba49be73a828c5a9dd" title="Function templates for transforming decision diagrams.">dd_transform</a>( <span class="keyword">const</span> NaviType&amp; navi, <span class="keyword">const</span> TermType&amp; init, 
<a name="l00263"></a>00263               <span class="keyword">const</span> OutIterator&amp; result, 
<a name="l00264"></a>00264               <span class="keyword">const</span> ThenBinaryOperator&amp; then_binop ) {
<a name="l00265"></a>00265 
<a name="l00266"></a>00266   <a class="code" href="namespacepolybori.html#094813e9371a53ba49be73a828c5a9dd" title="Function templates for transforming decision diagrams.">dd_transform</a>(navi, init, result, then_binop,
<a name="l00267"></a>00267                <a class="code" href="classproject__ith.html" title="Virtually does nothing with the given arguments.">project_ith&lt;1, 2&gt;</a>(),
<a name="l00268"></a>00268                <a class="code" href="classproject__ith.html" title="Virtually does nothing with the given arguments.">project_ith&lt;1&gt;</a>() );
<a name="l00269"></a>00269 }
<a name="l00270"></a>00270 
<a name="l00271"></a>00271 
<a name="l00272"></a>00272 <span class="keyword">template</span> &lt;<span class="keyword">class </span>InputIterator, <span class="keyword">class </span>OutputIterator, 
<a name="l00273"></a>00273           <span class="keyword">class </span>FirstFunction, <span class="keyword">class </span>UnaryFunction&gt;
<a name="l00274"></a>00274 OutputIterator 
<a name="l00275"></a><a class="code" href="namespacepolybori.html#623299a572ab265b87536471038a051b">00275</a> <a class="code" href="namespacepolybori.html#623299a572ab265b87536471038a051b">special_first_transform</a>(InputIterator first, InputIterator last,
<a name="l00276"></a>00276                         OutputIterator result, 
<a name="l00277"></a>00277                          UnaryFunction op, FirstFunction firstop) {
<a name="l00278"></a>00278   InputIterator second(first);
<a name="l00279"></a>00279   <span class="keywordflow">if</span> (second != last) {
<a name="l00280"></a>00280     ++second;
<a name="l00281"></a>00281     result = std::transform(first, second, result, firstop);
<a name="l00282"></a>00282   }
<a name="l00283"></a>00283   <span class="keywordflow">return</span> std::transform(second, last, result, op);
<a name="l00284"></a>00284 }
<a name="l00285"></a>00285 
<a name="l00286"></a>00286 
<a name="l00288"></a>00288 <span class="keyword">template</span> &lt;<span class="keyword">class</span> InputIterator, <span class="keyword">class</span> Intermediate, <span class="keyword">class</span> OutputIterator&gt;
<a name="l00289"></a>00289 OutputIterator
<a name="l00290"></a><a class="code" href="namespacepolybori.html#39e393c4286cf8905dd845f004f04443">00290</a> <a class="code" href="namespacepolybori.html#39e393c4286cf8905dd845f004f04443" title="Function templates doing a reversed copy using intermediate storage.">reversed_inter_copy</a>( InputIterator start, InputIterator finish,
<a name="l00291"></a>00291                      Intermediate&amp; inter, OutputIterator output ) {
<a name="l00292"></a>00292 
<a name="l00293"></a>00293     std::copy(start, finish, inter.begin());
<a name="l00294"></a>00294     <span class="comment">// force constant</span>
<a name="l00295"></a>00295     <span class="keywordflow">return</span> std::copy( const_cast&lt;const Intermediate&amp;&gt;(inter).rbegin(),
<a name="l00296"></a>00296                       const_cast&lt;const Intermediate&amp;&gt;(inter).rend(), 
<a name="l00297"></a>00297                       output );
<a name="l00298"></a>00298 }
<a name="l00299"></a>00299 
<a name="l00302"></a>00302 <span class="keyword">template</span> &lt;<span class="keyword">class</span> NaviType&gt;
<a name="l00303"></a>00303 <span class="keywordtype">bool</span>
<a name="l00304"></a><a class="code" href="namespacepolybori.html#e0f426c9c7e4e2fe4d75775a4ef99ee9">00304</a> <a class="code" href="namespacepolybori.html#e0f426c9c7e4e2fe4d75775a4ef99ee9">dd_on_path</a>(NaviType navi) {
<a name="l00305"></a>00305  
<a name="l00306"></a>00306   <span class="keywordflow">if</span> (navi.isConstant()) 
<a name="l00307"></a>00307     <span class="keywordflow">return</span> navi.terminalValue();
<a name="l00308"></a>00308 
<a name="l00309"></a>00309   <span class="keywordflow">return</span> <a class="code" href="namespacepolybori.html#e0f426c9c7e4e2fe4d75775a4ef99ee9">dd_on_path</a>(navi.thenBranch()) || <a class="code" href="namespacepolybori.html#e0f426c9c7e4e2fe4d75775a4ef99ee9">dd_on_path</a>(navi.elseBranch());
<a name="l00310"></a>00310 }
<a name="l00311"></a>00311 
<a name="l00314"></a>00314 <span class="keyword">template</span> &lt;<span class="keyword">class</span> NaviType, <span class="keyword">class</span> OrderedIterator&gt;
<a name="l00315"></a>00315 <span class="keywordtype">bool</span>
<a name="l00316"></a><a class="code" href="namespacepolybori.html#cb6344d5ff20ba21b11d4480ee9e78e2">00316</a> <a class="code" href="namespacepolybori.html#cb6344d5ff20ba21b11d4480ee9e78e2">dd_owns_term_of_indices</a>(NaviType navi, 
<a name="l00317"></a>00317                           OrderedIterator start, OrderedIterator finish) {
<a name="l00318"></a>00318  
<a name="l00319"></a>00319   <span class="keywordflow">if</span> (!navi.isConstant()) {     <span class="comment">// Not at end of path</span>
<a name="l00320"></a>00320     <span class="keywordtype">bool</span> not_at_end;
<a name="l00321"></a>00321 
<a name="l00322"></a>00322     <span class="keywordflow">while</span>( (not_at_end = (start != finish)) &amp;&amp; (*start &lt; *navi) )
<a name="l00323"></a>00323       ++start;
<a name="l00324"></a>00324 
<a name="l00325"></a>00325     NaviType elsenode = navi.elseBranch();
<a name="l00326"></a>00326 
<a name="l00327"></a>00327     <span class="keywordflow">if</span> (elsenode.isConstant() &amp;&amp; elsenode.terminalValue())
<a name="l00328"></a>00328       <span class="keywordflow">return</span> <span class="keyword">true</span>;
<a name="l00329"></a>00329       
<a name="l00330"></a>00330 
<a name="l00331"></a>00331     <span class="keywordflow">if</span> (not_at_end){
<a name="l00332"></a>00332       
<a name="l00333"></a>00333       <span class="keywordflow">if</span> ( (*start == *navi) &amp;&amp; 
<a name="l00334"></a>00334            <a class="code" href="namespacepolybori.html#cb6344d5ff20ba21b11d4480ee9e78e2">dd_owns_term_of_indices</a>(navi.thenBranch(), start, finish))
<a name="l00335"></a>00335         <span class="keywordflow">return</span> <span class="keyword">true</span>;
<a name="l00336"></a>00336       <span class="keywordflow">else</span>  
<a name="l00337"></a>00337         <span class="keywordflow">return</span> <a class="code" href="namespacepolybori.html#cb6344d5ff20ba21b11d4480ee9e78e2">dd_owns_term_of_indices</a>(elsenode, start, finish);
<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       <span class="keywordflow">while</span>(!elsenode.isConstant()) 
<a name="l00342"></a>00342         elsenode.incrementElse();
<a name="l00343"></a>00343       <span class="keywordflow">return</span> elsenode.terminalValue();
<a name="l00344"></a>00344     }
<a name="l00345"></a>00345    
<a name="l00346"></a>00346   }
<a name="l00347"></a>00347   <span class="keywordflow">return</span> navi.terminalValue();
<a name="l00348"></a>00348 }
<a name="l00349"></a>00349 
<a name="l00353"></a>00353 <span class="keyword">template</span> &lt;<span class="keyword">class</span> NaviType, <span class="keyword">class</span> OrderedIterator, <span class="keyword">class</span> NodeOperation&gt;
<a name="l00354"></a>00354 NaviType
<a name="l00355"></a><a class="code" href="namespacepolybori.html#f85e7fef57412e7c2b830144c68e2509">00355</a> <a class="code" href="namespacepolybori.html#f85e7fef57412e7c2b830144c68e2509">dd_intersect_some_index</a>(NaviType navi, 
<a name="l00356"></a>00356                         OrderedIterator start, OrderedIterator finish,
<a name="l00357"></a>00357                         NodeOperation newNode ) {
<a name="l00358"></a>00358  
<a name="l00359"></a>00359   <span class="keywordflow">if</span> (!navi.isConstant()) {     <span class="comment">// Not at end of path</span>
<a name="l00360"></a>00360     <span class="keywordtype">bool</span> not_at_end;
<a name="l00361"></a>00361     <span class="keywordflow">while</span>( (not_at_end = (start != finish)) &amp;&amp; (*start &lt; *navi) )
<a name="l00362"></a>00362       ++start;
<a name="l00363"></a>00363 
<a name="l00364"></a>00364     <span class="keywordflow">if</span> (not_at_end) {
<a name="l00365"></a>00365       NaviType elseNode = 
<a name="l00366"></a>00366         <a class="code" href="namespacepolybori.html#f85e7fef57412e7c2b830144c68e2509">dd_intersect_some_index</a>(navi.elseBranch(), start, finish, 
<a name="l00367"></a>00367                                 newNode);
<a name="l00368"></a>00368   
<a name="l00369"></a>00369       <span class="keywordflow">if</span> (*start == *navi) {
<a name="l00370"></a>00370 
<a name="l00371"></a>00371         NaviType thenNode = 
<a name="l00372"></a>00372           <a class="code" href="namespacepolybori.html#f85e7fef57412e7c2b830144c68e2509">dd_intersect_some_index</a>(navi.thenBranch(), start, finish, 
<a name="l00373"></a>00373                                   newNode);
<a name="l00374"></a>00374 
<a name="l00375"></a>00375         <span class="keywordflow">return</span> newNode(*start, navi, thenNode, elseNode); 
<a name="l00376"></a>00376       }
<a name="l00377"></a>00377       <span class="keywordflow">else</span>
<a name="l00378"></a>00378         <span class="keywordflow">return</span> elseNode;
<a name="l00379"></a>00379     }
<a name="l00380"></a>00380     <span class="keywordflow">else</span> {                      <span class="comment">// if the start == finish, we only check </span>
<a name="l00381"></a>00381                                 <span class="comment">// validity of the else-only branch </span>
<a name="l00382"></a>00382       <span class="keywordflow">while</span>(!navi.isConstant()) 
<a name="l00383"></a>00383         navi = navi.elseBranch();
<a name="l00384"></a>00384       <span class="keywordflow">return</span> newNode(navi);
<a name="l00385"></a>00385     }
<a name="l00386"></a>00386 
<a name="l00387"></a>00387   }
<a name="l00388"></a>00388 
<a name="l00389"></a>00389   <span class="keywordflow">return</span> newNode(navi);
<a name="l00390"></a>00390 }
<a name="l00391"></a>00391 
<a name="l00392"></a>00392 
<a name="l00393"></a>00393 
<a name="l00395"></a>00395 <span class="keyword">template</span> &lt;<span class="keyword">class</span> NaviType&gt;
<a name="l00396"></a>00396 <span class="keywordtype">void</span>
<a name="l00397"></a><a class="code" href="namespacepolybori.html#b5d7d5cc3e86f3707d30aeffc57bb685">00397</a> <a class="code" href="namespacepolybori.html#b5d7d5cc3e86f3707d30aeffc57bb685" title="Function templates for debugging, prints dd indices and reference counts.">dd_print</a>(NaviType navi) {
<a name="l00398"></a>00398  
<a name="l00399"></a>00399   <span class="keywordflow">if</span> (!navi.isConstant()) {     <span class="comment">// Not at end of path</span>
<a name="l00400"></a>00400  
<a name="l00401"></a>00401     std::cout &lt;&lt; std::endl&lt;&lt; <span class="stringliteral">"idx "</span> &lt;&lt; *navi &lt;&lt;<span class="stringliteral">" addr "</span>&lt;&lt;
<a name="l00402"></a>00402       ((DdNode*)navi)&lt;&lt;<span class="stringliteral">" ref "</span>&lt;&lt;
<a name="l00403"></a>00403       int(Cudd_Regular((DdNode*)navi)-&gt;ref) &lt;&lt; std::endl;
<a name="l00404"></a>00404 
<a name="l00405"></a>00405     <a class="code" href="namespacepolybori.html#b5d7d5cc3e86f3707d30aeffc57bb685" title="Function templates for debugging, prints dd indices and reference counts.">dd_print</a>(navi.thenBranch());
<a name="l00406"></a>00406     <a class="code" href="namespacepolybori.html#b5d7d5cc3e86f3707d30aeffc57bb685" title="Function templates for debugging, prints dd indices and reference counts.">dd_print</a>(navi.elseBranch());
<a name="l00407"></a>00407 
<a name="l00408"></a>00408   }
<a name="l00409"></a>00409   <span class="keywordflow">else</span> {
<a name="l00410"></a>00410     std::cout &lt;&lt; <span class="stringliteral">"const isvalid? "</span>&lt;&lt;navi.isValid()&lt;&lt;<span class="stringliteral">" addr "</span>
<a name="l00411"></a>00411               &lt;&lt;((DdNode*)navi)&lt;&lt;<span class="stringliteral">" ref "</span>&lt;&lt;
<a name="l00412"></a>00412       int(Cudd_Regular((DdNode*)navi)-&gt;ref)&lt;&lt;std::endl;
<a name="l00413"></a>00413 
<a name="l00414"></a>00414   }
<a name="l00415"></a>00415 }
<a name="l00416"></a>00416 
<a name="l00417"></a>00417 <span class="comment">// Determinine the minimum of the distance between two iterators and limit</span>
<a name="l00418"></a>00418 <span class="keyword">template</span> &lt;<span class="keyword">class</span> IteratorType, <span class="keyword">class</span> SizeType&gt;
<a name="l00419"></a>00419 SizeType
<a name="l00420"></a><a class="code" href="namespacepolybori.html#b82f8384b788b0d1ace855581c13c0c4">00420</a> <a class="code" href="namespacepolybori.html#b82f8384b788b0d1ace855581c13c0c4">limited_distance</a>(IteratorType start, IteratorType finish, SizeType limit) {
<a name="l00421"></a>00421 
<a name="l00422"></a>00422   SizeType result = 0;
<a name="l00423"></a>00423 
<a name="l00424"></a>00424   <span class="keywordflow">while</span> ((result &lt; limit) &amp;&amp; (start != finish)) {
<a name="l00425"></a>00425     ++start, ++result;
<a name="l00426"></a>00426   }
<a name="l00427"></a>00427 
<a name="l00428"></a>00428   <span class="keywordflow">return</span> result;
<a name="l00429"></a>00429 }
<a name="l00430"></a>00430 
<a name="l00431"></a>00431 <span class="preprocessor">#if 0</span>
<a name="l00432"></a>00432 <span class="preprocessor"></span><span class="comment">// Forward declaration of CTermIter template</span>
<a name="l00433"></a>00433 <span class="keyword">template</span> &lt;<span class="keyword">class</span>, <span class="keyword">class</span>, <span class="keyword">class</span>, <span class="keyword">class</span>, <span class="keyword">class</span>, <span class="keyword">class</span>&gt; <span class="keyword">class </span>CTermIter;
<a name="l00434"></a>00434 
<a name="l00435"></a>00435 <span class="comment">// Determinine the minimum of the number of terms and limit</span>
<a name="l00436"></a>00436 <span class="keyword">template</span> &lt;<span class="keyword">class</span> NaviType, <span class="keyword">class</span> SizeType&gt;
<a name="l00437"></a>00437 SizeType
<a name="l00438"></a>00438 limited_length(NaviType navi, SizeType limit) {
<a name="l00439"></a>00439 
<a name="l00440"></a>00440 
<a name="l00441"></a>00441   <span class="keyword">typedef</span> CTermIter&lt;dummy_iterator, NaviType, 
<a name="l00442"></a>00442                     <a class="code" href="classproject__ith.html" title="Virtually does nothing with the given arguments.">project_ith&lt;1&gt;</a>, project_ith&lt;1&gt;, <a class="code" href="classproject__ith.html" title="Virtually does nothing with the given arguments.">project_ith&lt;1, 2&gt;</a>, 
<a name="l00443"></a>00443     project_ith&lt;1&gt; &gt;
<a name="l00444"></a>00444   iterator;
<a name="l00445"></a>00445 
<a name="l00446"></a>00446   <span class="keywordflow">return</span> <a class="code" href="namespacepolybori.html#b82f8384b788b0d1ace855581c13c0c4">limited_distance</a>(iterator(navi), iterator(), limit);
<a name="l00447"></a>00447 }
<a name="l00448"></a>00448 <span class="preprocessor">#endif</span>
<a name="l00449"></a>00449 <span class="preprocessor"></span>
<a name="l00453"></a>00453 <span class="keyword">template</span> &lt;<span class="keyword">class</span> NaviType, <span class="keyword">class</span> DDType&gt;
<a name="l00454"></a>00454 DDType
<a name="l00455"></a><a class="code" href="namespacepolybori.html#f21584c7975eb3bde0a26902776245d9">00455</a> <a class="code" href="namespacepolybori.html#f21584c7975eb3bde0a26902776245d9">dd_minimal_elements</a>(NaviType navi, DDType dd, DDType&amp; multiples) {
<a name="l00456"></a>00456 
<a name="l00457"></a>00457 
<a name="l00458"></a>00458   <span class="keywordflow">if</span> (!navi.isConstant()) {     <span class="comment">// Not at end of path</span>
<a name="l00459"></a>00459 
<a name="l00460"></a>00460     DDType elsedd = dd.subset0(*navi);
<a name="l00461"></a>00461 
<a name="l00462"></a>00462 
<a name="l00463"></a>00463     DDType elseMultiples;
<a name="l00464"></a>00464     elsedd = <a class="code" href="namespacepolybori.html#f21584c7975eb3bde0a26902776245d9">dd_minimal_elements</a>(navi.elseBranch(), elsedd, elseMultiples);
<a name="l00465"></a>00465 
<a name="l00466"></a>00466     <span class="comment">// short cut if else and then branche equal or else contains 1</span>
<a name="l00467"></a>00467     <span class="keywordflow">if</span>((navi.elseBranch() == navi.thenBranch()) || elsedd.blankness()){
<a name="l00468"></a>00468       multiples = elseMultiples;
<a name="l00469"></a>00469       <span class="keywordflow">return</span> elsedd;
<a name="l00470"></a>00470     }
<a name="l00471"></a>00471 
<a name="l00472"></a>00472     NaviType elseNavi = elseMultiples.navigation();
<a name="l00473"></a>00473 
<a name="l00474"></a>00474     <span class="keywordtype">int</span> nmax;
<a name="l00475"></a>00475     <span class="keywordflow">if</span> (elseNavi.isConstant()){
<a name="l00476"></a>00476       <span class="keywordflow">if</span> (elseNavi.terminalValue())
<a name="l00477"></a>00477         nmax = dd.nVariables();
<a name="l00478"></a>00478       <span class="keywordflow">else</span>
<a name="l00479"></a>00479         nmax = *navi;
<a name="l00480"></a>00480     }
<a name="l00481"></a>00481     <span class="keywordflow">else</span>
<a name="l00482"></a>00482       nmax = *elseNavi;
<a name="l00483"></a>00483 
<a name="l00484"></a>00484 
<a name="l00485"></a>00485     <span class="keywordflow">for</span>(<span class="keywordtype">int</span> i = nmax-1; i &gt; *navi; --i){
<a name="l00486"></a>00486       elseMultiples.uniteAssign(elseMultiples.change(i)); 
<a name="l00487"></a>00487     }
<a name="l00488"></a>00488 
<a name="l00489"></a>00489 
<a name="l00490"></a>00490     DDType thendd = dd.subset1(*navi);
<a name="l00491"></a>00491     thendd = thendd.diff(elseMultiples);
<a name="l00492"></a>00492 
<a name="l00493"></a>00493     DDType thenMultiples;
<a name="l00494"></a>00494     thendd = <a class="code" href="namespacepolybori.html#f21584c7975eb3bde0a26902776245d9">dd_minimal_elements</a>(navi.thenBranch(), thendd, thenMultiples); 
<a name="l00495"></a>00495  
<a name="l00496"></a>00496     NaviType thenNavi = thenMultiples.navigation();
<a name="l00497"></a>00497 
<a name="l00498"></a>00498 
<a name="l00499"></a>00499     <span class="keywordflow">if</span> (thenNavi.isConstant()){
<a name="l00500"></a>00500       <span class="keywordflow">if</span> (thenNavi.terminalValue())
<a name="l00501"></a>00501         nmax =  dd.nVariables();
<a name="l00502"></a>00502       <span class="keywordflow">else</span>
<a name="l00503"></a>00503         nmax = *navi;
<a name="l00504"></a>00504     }
<a name="l00505"></a>00505     <span class="keywordflow">else</span>
<a name="l00506"></a>00506       nmax = *thenNavi;
<a name="l00507"></a>00507 
<a name="l00508"></a>00508 
<a name="l00509"></a>00509     <span class="keywordflow">for</span>(<span class="keywordtype">int</span> i = nmax-1; i &gt; *navi; --i){
<a name="l00510"></a>00510       thenMultiples.uniteAssign(thenMultiples.change(i)); 
<a name="l00511"></a>00511     }
<a name="l00512"></a>00512 
<a name="l00513"></a>00513 
<a name="l00514"></a>00514     thenMultiples = thenMultiples.unite(elseMultiples);
<a name="l00515"></a>00515     thenMultiples = thenMultiples.change(*navi);
<a name="l00516"></a>00516 
<a name="l00517"></a>00517 
<a name="l00518"></a>00518     multiples = thenMultiples.unite(elseMultiples);
<a name="l00519"></a>00519     thendd = thendd.change(*navi);
<a name="l00520"></a>00520 
<a name="l00521"></a>00521     DDType result =  thendd.unite(elsedd);
<a name="l00522"></a>00522 
<a name="l00523"></a>00523     <span class="keywordflow">return</span> result;
<a name="l00524"></a>00524 
<a name="l00525"></a>00525   }
<a name="l00526"></a>00526 
<a name="l00527"></a>00527   multiples = dd;
<a name="l00528"></a>00528   <span class="keywordflow">return</span> dd;
<a name="l00529"></a>00529 }
<a name="l00530"></a>00530 
<a name="l00531"></a>00531 <span class="keyword">template</span> &lt;<span class="keyword">class</span> MgrType&gt;
<a name="l00532"></a>00532 <span class="keyword">inline</span> <span class="keyword">const</span> MgrType&amp;
<a name="l00533"></a><a class="code" href="namespacepolybori.html#133ade2eba08cb872ac4355b389f2cdf">00533</a> <a class="code" href="namespacepolybori.html#133ade2eba08cb872ac4355b389f2cdf">get_mgr_core</a>(<span class="keyword">const</span> MgrType&amp; rhs) { 
<a name="l00534"></a>00534   <span class="keywordflow">return</span> rhs;
<a name="l00535"></a>00535 }
<a name="l00536"></a>00536 <span class="keyword">inline</span> Cudd*
<a name="l00537"></a><a class="code" href="namespacepolybori.html#c9ecc6f30d24c887aee5050125db8dfe">00537</a> <a class="code" href="namespacepolybori.html#133ade2eba08cb872ac4355b389f2cdf">get_mgr_core</a>(<span class="keyword">const</span> Cudd&amp; rhs) { 
<a name="l00538"></a>00538   <span class="keywordflow">return</span> &amp;<span class="keyword">const_cast&lt;</span>Cudd&amp;<span class="keyword">&gt;</span>(rhs);
<a name="l00539"></a>00539 }
<a name="l00540"></a>00540 
<a name="l00542"></a>00542 <span class="keyword">inline</span> CCuddInterface::mgrcore_ptr
<a name="l00543"></a><a class="code" href="namespacepolybori.html#704e9319a84420bbfed328e77d3ee460">00543</a> <a class="code" href="namespacepolybori.html#133ade2eba08cb872ac4355b389f2cdf">get_mgr_core</a>(<span class="keyword">const</span> <a class="code" href="classpolybori_1_1CCuddInterface.html" title="This class defines a C++ interface to CUDD&amp;#39;s decicion diagram manager.">CCuddInterface</a>&amp; mgr) {
<a name="l00544"></a>00544   <span class="keywordflow">return</span> mgr.<a class="code" href="classpolybori_1_1CCuddInterface.html#faf2deee4b5b79723c8719ca14dbfda6" title="Get (shared) pointer to initialized manager.">managerCore</a>();
<a name="l00545"></a>00545 }
<a name="l00546"></a>00546 
<a name="l00548"></a>00548 <span class="keyword">template</span>&lt;<span class="keyword">class</span> ManagerType, <span class="keyword">class</span> ReverseIterator, <span class="keyword">class</span> MultReverseIterator&gt;
<a name="l00549"></a>00549 <span class="keyword">typename</span> manager_traits&lt;ManagerType&gt;::dd_base
<a name="l00550"></a><a class="code" href="namespacepolybori.html#9f5a4551340ca9187a30a37dbccf3f56">00550</a> <a class="code" href="namespacepolybori.html#9f5a4551340ca9187a30a37dbccf3f56" title="temporarily (needs to be more generic)">cudd_generate_multiples</a>(<span class="keyword">const</span> ManagerType&amp; mgr, 
<a name="l00551"></a>00551                         ReverseIterator start, ReverseIterator finish,
<a name="l00552"></a>00552                         MultReverseIterator multStart, 
<a name="l00553"></a>00553                         MultReverseIterator multFinish) {
<a name="l00554"></a>00554 
<a name="l00555"></a>00555     DdNode* prev( (mgr.getManager())-&gt;one );
<a name="l00556"></a>00556 
<a name="l00557"></a>00557     DdNode* zeroNode( (mgr.getManager())-&gt;zero ); 
<a name="l00558"></a>00558 
<a name="l00559"></a>00559     Cudd_Ref(prev);
<a name="l00560"></a>00560     <span class="keywordflow">while</span>(start != finish) {
<a name="l00561"></a>00561 
<a name="l00562"></a>00562       <span class="keywordflow">while</span>((multStart != multFinish) &amp;&amp; (*start &lt; *multStart)) {
<a name="l00563"></a>00563 
<a name="l00564"></a>00564         DdNode* result = cuddUniqueInterZdd( mgr.getManager(), *multStart,
<a name="l00565"></a>00565                                              prev, prev );
<a name="l00566"></a>00566 
<a name="l00567"></a>00567         Cudd_Ref(result);
<a name="l00568"></a>00568         Cudd_RecursiveDerefZdd(mgr.getManager(), prev);
<a name="l00569"></a>00569 
<a name="l00570"></a>00570         prev = result;
<a name="l00571"></a>00571         ++multStart;
<a name="l00572"></a>00572 
<a name="l00573"></a>00573       };
<a name="l00574"></a>00574 
<a name="l00575"></a>00575       DdNode* result = cuddUniqueInterZdd( mgr.getManager(), *start,
<a name="l00576"></a>00576                                            prev, zeroNode );
<a name="l00577"></a>00577 
<a name="l00578"></a>00578       Cudd_Ref(result);
<a name="l00579"></a>00579       Cudd_RecursiveDerefZdd(mgr.getManager(), prev);
<a name="l00580"></a>00580 
<a name="l00581"></a>00581       prev = result;
<a name="l00582"></a>00582 
<a name="l00583"></a>00583 
<a name="l00584"></a>00584       <span class="keywordflow">if</span>((multStart != multFinish) &amp;&amp; (*start == *multStart))
<a name="l00585"></a>00585         ++multStart;
<a name="l00586"></a>00586 
<a name="l00587"></a>00587 
<a name="l00588"></a>00588       ++start;
<a name="l00589"></a>00589     }
<a name="l00590"></a>00590 
<a name="l00591"></a>00591     <span class="keywordflow">while</span>(multStart != multFinish) {
<a name="l00592"></a>00592 
<a name="l00593"></a>00593       DdNode* result = cuddUniqueInterZdd( mgr.getManager(), *multStart,
<a name="l00594"></a>00594                                            prev, prev );
<a name="l00595"></a>00595 
<a name="l00596"></a>00596       Cudd_Ref(result);
<a name="l00597"></a>00597       Cudd_RecursiveDerefZdd(mgr.getManager(), prev);
<a name="l00598"></a>00598 
<a name="l00599"></a>00599       prev = result;
<a name="l00600"></a>00600       ++multStart;
<a name="l00601"></a>00601 
<a name="l00602"></a>00602     };
<a name="l00603"></a>00603 
<a name="l00604"></a>00604     Cudd_Deref(prev);
<a name="l00605"></a>00605 
<a name="l00606"></a>00606     <span class="keyword">typedef</span> <span class="keyword">typename</span> <a class="code" href="structpolybori_1_1manager__traits.html">manager_traits&lt;ManagerType&gt;::dd_base</a> dd_base;
<a name="l00607"></a>00607     <span class="keywordflow">return</span> dd_base(<a class="code" href="namespacepolybori.html#133ade2eba08cb872ac4355b389f2cdf">get_mgr_core</a>(mgr), prev);
<a name="l00608"></a>00608   }
<a name="l00609"></a>00609 
<a name="l00610"></a>00610 
<a name="l00611"></a>00611 
<a name="l00613"></a>00613 <span class="keyword">template</span>&lt;<span class="keyword">class</span> ManagerType, <span class="keyword">class</span> ReverseIterator&gt;
<a name="l00614"></a>00614 <span class="keyword">typename</span> manager_traits&lt;ManagerType&gt;::dd_base
<a name="l00615"></a><a class="code" href="namespacepolybori.html#220b46f13d6e432df1cd40432dddbabb">00615</a> <a class="code" href="namespacepolybori.html#220b46f13d6e432df1cd40432dddbabb" title="temporarily (needs to be more generic)">cudd_generate_divisors</a>(<span class="keyword">const</span> ManagerType&amp; mgr, 
<a name="l00616"></a>00616                        ReverseIterator start, ReverseIterator finish) {
<a name="l00617"></a>00617 
<a name="l00618"></a>00618   <span class="keyword">typedef</span> <span class="keyword">typename</span> <a class="code" href="structpolybori_1_1manager__traits.html">manager_traits&lt;ManagerType&gt;::dd_base</a> dd_base;
<a name="l00619"></a>00619     DdNode* prev= (mgr.getManager())-&gt;one;
<a name="l00620"></a>00620 
<a name="l00621"></a>00621     Cudd_Ref(prev);
<a name="l00622"></a>00622     <span class="keywordflow">while</span>(start != finish) {
<a name="l00623"></a>00623  
<a name="l00624"></a>00624       DdNode* result = cuddUniqueInterZdd( mgr.getManager(), *start,
<a name="l00625"></a>00625                                            prev, prev);
<a name="l00626"></a>00626 
<a name="l00627"></a>00627       Cudd_Ref(result);
<a name="l00628"></a>00628       Cudd_RecursiveDerefZdd(mgr.getManager(), prev);
<a name="l00629"></a>00629  
<a name="l00630"></a>00630       prev = result;
<a name="l00631"></a>00631       ++start;
<a name="l00632"></a>00632     }
<a name="l00633"></a>00633 
<a name="l00634"></a>00634     Cudd_Deref(prev);
<a name="l00636"></a>00636       <span class="keywordflow">return</span> dd_base(<a class="code" href="namespacepolybori.html#133ade2eba08cb872ac4355b389f2cdf">get_mgr_core</a>(mgr), prev);
<a name="l00637"></a>00637 
<a name="l00638"></a>00638 }
<a name="l00639"></a>00639 
<a name="l00640"></a>00640 
<a name="l00641"></a>00641 <span class="keyword">template</span>&lt;<span class="keyword">class</span> Iterator, <span class="keyword">class</span> SizeType&gt;
<a name="l00642"></a>00642 Iterator
<a name="l00643"></a><a class="code" href="namespacepolybori.html#56c065103475f23d2b514ebf419fa79e">00643</a> <a class="code" href="namespacepolybori.html#56c065103475f23d2b514ebf419fa79e">bounded_max_element</a>(Iterator start, Iterator finish, SizeType bound){
<a name="l00644"></a>00644 
<a name="l00645"></a>00645   <span class="keywordflow">if</span> (*start &gt;= bound)
<a name="l00646"></a>00646     <span class="keywordflow">return</span> start;
<a name="l00647"></a>00647 
<a name="l00648"></a>00648   Iterator result(start);
<a name="l00649"></a>00649   <span class="keywordflow">if</span> (start != finish)
<a name="l00650"></a>00650     ++start;
<a name="l00651"></a>00651 
<a name="l00652"></a>00652   <span class="keywordflow">while</span> (start != finish) {
<a name="l00653"></a>00653     <span class="keywordflow">if</span>(*start &gt;= bound)
<a name="l00654"></a>00654       <span class="keywordflow">return</span> start;
<a name="l00655"></a>00655     <span class="keywordflow">if</span>(*start &gt; *result)
<a name="l00656"></a>00656       result = start;
<a name="l00657"></a>00657     ++start;
<a name="l00658"></a>00658   }
<a name="l00659"></a>00659 
<a name="l00660"></a>00660   <span class="keywordflow">return</span> result;
<a name="l00661"></a>00661 }
<a name="l00662"></a>00662 
<a name="l00665"></a>00665 <span class="keyword">template</span> &lt;<span class="keyword">class</span> LhsType, <span class="keyword">class</span> RhsType, <span class="keyword">class</span> BinaryPredicate&gt;
<a name="l00666"></a>00666 CTypes::comp_type
<a name="l00667"></a><a class="code" href="namespacepolybori.html#5d5bac8b009548eb8ec17ca2f47eced8">00667</a> <a class="code" href="namespacepolybori.html#5d5bac8b009548eb8ec17ca2f47eced8" title="defines lexicographic comparison for variable indices">generic_compare_3way</a>(<span class="keyword">const</span> LhsType&amp; lhs, <span class="keyword">const</span> RhsType&amp; rhs, BinaryPredicate comp) {
<a name="l00668"></a>00668 
<a name="l00669"></a>00669   <span class="keywordflow">if</span> (lhs == rhs)
<a name="l00670"></a>00670     <span class="keywordflow">return</span> CTypes::equality;
<a name="l00671"></a>00671 
<a name="l00672"></a>00672   <span class="keywordflow">return</span> (comp(lhs, rhs)?  CTypes::greater_than: CTypes::less_than);
<a name="l00673"></a>00673 }
<a name="l00674"></a>00674 
<a name="l00675"></a>00675 
<a name="l00676"></a>00676 
<a name="l00677"></a>00677 <span class="keyword">template</span> &lt;<span class="keyword">class</span> IteratorLike, <span class="keyword">class</span> ForwardIteratorTag&gt;
<a name="l00678"></a>00678 IteratorLike 
<a name="l00679"></a><a class="code" href="namespacepolybori.html#d7c8a70512fdf0903425cc0e4b6d7125">00679</a> <a class="code" href="namespacepolybori.html#d7c8a70512fdf0903425cc0e4b6d7125">increment_iteratorlike</a>(IteratorLike iter, ForwardIteratorTag) {
<a name="l00680"></a>00680 
<a name="l00681"></a>00681   <span class="keywordflow">return</span> ++iter;
<a name="l00682"></a>00682 }
<a name="l00683"></a>00683 
<a name="l00684"></a>00684 <span class="keyword">template</span> &lt;<span class="keyword">class</span> IteratorLike&gt;
<a name="l00685"></a>00685 IteratorLike 
<a name="l00686"></a><a class="code" href="namespacepolybori.html#6e736eaf4ce650ab31ef125ebb052f5b">00686</a> <a class="code" href="namespacepolybori.html#d7c8a70512fdf0903425cc0e4b6d7125">increment_iteratorlike</a>(IteratorLike iter, <a class="code" href="structpolybori_1_1navigator__tag.html" title="for iterator_category">navigator_tag</a>) {
<a name="l00687"></a>00687 
<a name="l00688"></a>00688   <span class="keywordflow">return</span> iter.thenBranch();
<a name="l00689"></a>00689 }
<a name="l00690"></a>00690 
<a name="l00691"></a>00691 
<a name="l00692"></a>00692 <span class="keyword">template</span> &lt;<span class="keyword">class</span> IteratorLike&gt;
<a name="l00693"></a>00693 IteratorLike 
<a name="l00694"></a><a class="code" href="namespacepolybori.html#2032714f022961f802e7f4500ccbf8bd">00694</a> <a class="code" href="namespacepolybori.html#d7c8a70512fdf0903425cc0e4b6d7125">increment_iteratorlike</a>(IteratorLike iter) {
<a name="l00695"></a>00695 
<a name="l00696"></a>00696   <span class="keyword">typedef</span> <span class="keyword">typename</span> std::iterator_traits&lt;IteratorLike&gt;::iterator_category
<a name="l00697"></a>00697     iterator_category;
<a name="l00698"></a>00698 
<a name="l00699"></a>00699   <span class="keywordflow">return</span> <a class="code" href="namespacepolybori.html#d7c8a70512fdf0903425cc0e4b6d7125">increment_iteratorlike</a>(iter, iterator_category());
<a name="l00700"></a>00700 }
<a name="l00701"></a>00701 
<a name="l00702"></a>00702 <span class="preprocessor">#ifdef PBORI_LOWLEVEL_XOR </span>
<a name="l00703"></a>00703 <span class="preprocessor"></span>
<a name="l00704"></a>00704 <span class="comment">// dummy for cuddcache (implemented in pbori_routines.cc)</span>
<a name="l00705"></a>00705 DdNode* 
<a name="l00706"></a>00706 <a class="code" href="namespacepolybori.html#c8eef4822df804ee3e8a6c97ecb722ef">pboriCuddZddUnionXor__</a>(DdManager *, DdNode *, DdNode *);
<a name="l00707"></a>00707 
<a name="l00708"></a>00708 
<a name="l00712"></a>00712 <span class="keyword">template</span> &lt;<span class="keyword">class</span> MgrType, <span class="keyword">class</span> NodeType&gt;
<a name="l00713"></a>00713 NodeType
<a name="l00714"></a><a class="code" href="namespacepolybori.html#e49cee209098fb6dd51dbd9f5af13c21">00714</a> <a class="code" href="namespacepolybori.html#e49cee209098fb6dd51dbd9f5af13c21">pboriCuddZddUnionXor</a>(MgrType zdd, NodeType P, NodeType Q) {
<a name="l00715"></a>00715 
<a name="l00716"></a>00716   <span class="keywordtype">int</span>           p_top, q_top;
<a name="l00717"></a>00717   NodeType empty = DD_ZERO(zdd), t, e, res;
<a name="l00718"></a>00718   MgrType table = zdd;
<a name="l00719"></a>00719   
<a name="l00720"></a>00720   statLine(zdd);
<a name="l00721"></a>00721   
<a name="l00722"></a>00722   <span class="keywordflow">if</span> (P == empty)
<a name="l00723"></a>00723     <span class="keywordflow">return</span>(Q); 
<a name="l00724"></a>00724   <span class="keywordflow">if</span> (Q == empty)
<a name="l00725"></a>00725     <span class="keywordflow">return</span>(P);
<a name="l00726"></a>00726   <span class="keywordflow">if</span> (P == Q)
<a name="l00727"></a>00727     <span class="keywordflow">return</span>(empty);
<a name="l00728"></a>00728 
<a name="l00729"></a>00729   <span class="comment">/* Check cache */</span>
<a name="l00730"></a>00730   res = cuddCacheLookup2Zdd(table, <a class="code" href="namespacepolybori.html#c8eef4822df804ee3e8a6c97ecb722ef">pboriCuddZddUnionXor__</a>, P, Q);
<a name="l00731"></a>00731   <span class="keywordflow">if</span> (res != NULL)
<a name="l00732"></a>00732     <span class="keywordflow">return</span>(res);
<a name="l00733"></a>00733   
<a name="l00734"></a>00734   <span class="keywordflow">if</span> (cuddIsConstant(P))
<a name="l00735"></a>00735     p_top = P-&gt;index;
<a name="l00736"></a>00736   <span class="keywordflow">else</span>
<a name="l00737"></a>00737     p_top = P-&gt;index;<span class="comment">/* zdd-&gt;permZ[P-&gt;index]; */</span>
<a name="l00738"></a>00738   <span class="keywordflow">if</span> (cuddIsConstant(Q))
<a name="l00739"></a>00739     q_top = Q-&gt;index;
<a name="l00740"></a>00740   <span class="keywordflow">else</span>
<a name="l00741"></a>00741     q_top = Q-&gt;index; <span class="comment">/* zdd-&gt;permZ[Q-&gt;index]; */</span>
<a name="l00742"></a>00742   <span class="keywordflow">if</span> (p_top &lt; q_top) {
<a name="l00743"></a>00743     e = <a class="code" href="namespacepolybori.html#e49cee209098fb6dd51dbd9f5af13c21">pboriCuddZddUnionXor</a>(zdd, cuddE(P), Q);
<a name="l00744"></a>00744     <span class="keywordflow">if</span> (e == NULL) <span class="keywordflow">return</span> (NULL);
<a name="l00745"></a>00745     Cudd_Ref(e);
<a name="l00746"></a>00746     res = cuddZddGetNode(zdd, P-&gt;index, cuddT(P), e);
<a name="l00747"></a>00747     <span class="keywordflow">if</span> (res == NULL) {
<a name="l00748"></a>00748       Cudd_RecursiveDerefZdd(table, e);
<a name="l00749"></a>00749       <span class="keywordflow">return</span>(NULL);
<a name="l00750"></a>00750     }
<a name="l00751"></a>00751     Cudd_Deref(e);
<a name="l00752"></a>00752   } <span class="keywordflow">else</span> <span class="keywordflow">if</span> (p_top &gt; q_top) {
<a name="l00753"></a>00753     e = <a class="code" href="namespacepolybori.html#e49cee209098fb6dd51dbd9f5af13c21">pboriCuddZddUnionXor</a>(zdd, P, cuddE(Q));
<a name="l00754"></a>00754     <span class="keywordflow">if</span> (e == NULL) <span class="keywordflow">return</span>(NULL);
<a name="l00755"></a>00755     Cudd_Ref(e);
<a name="l00756"></a>00756     res = cuddZddGetNode(zdd, Q-&gt;index, cuddT(Q), e);
<a name="l00757"></a>00757     <span class="keywordflow">if</span> (res == NULL) {
<a name="l00758"></a>00758       Cudd_RecursiveDerefZdd(table, e);
<a name="l00759"></a>00759       <span class="keywordflow">return</span>(NULL);
<a name="l00760"></a>00760     }
<a name="l00761"></a>00761     Cudd_Deref(e);
<a name="l00762"></a>00762   } <span class="keywordflow">else</span> {
<a name="l00763"></a>00763     t = <a class="code" href="namespacepolybori.html#e49cee209098fb6dd51dbd9f5af13c21">pboriCuddZddUnionXor</a>(zdd, cuddT(P), cuddT(Q));
<a name="l00764"></a>00764     <span class="keywordflow">if</span> (t == NULL) <span class="keywordflow">return</span>(NULL);
<a name="l00765"></a>00765     Cudd_Ref(t);
<a name="l00766"></a>00766     e = <a class="code" href="namespacepolybori.html#e49cee209098fb6dd51dbd9f5af13c21">pboriCuddZddUnionXor</a>(zdd, cuddE(P), cuddE(Q));
<a name="l00767"></a>00767     <span class="keywordflow">if</span> (e == NULL) {
<a name="l00768"></a>00768       Cudd_RecursiveDerefZdd(table, t);
<a name="l00769"></a>00769       <span class="keywordflow">return</span>(NULL);
<a name="l00770"></a>00770     }
<a name="l00771"></a>00771     Cudd_Ref(e);
<a name="l00772"></a>00772     res = cuddZddGetNode(zdd, P-&gt;index, t, e);
<a name="l00773"></a>00773     <span class="keywordflow">if</span> (res == NULL) {
<a name="l00774"></a>00774       Cudd_RecursiveDerefZdd(table, t);
<a name="l00775"></a>00775       Cudd_RecursiveDerefZdd(table, e);
<a name="l00776"></a>00776       <span class="keywordflow">return</span>(NULL);
<a name="l00777"></a>00777     }
<a name="l00778"></a>00778     Cudd_Deref(t);
<a name="l00779"></a>00779     Cudd_Deref(e);
<a name="l00780"></a>00780   }
<a name="l00781"></a>00781   
<a name="l00782"></a>00782   cuddCacheInsert2(table, <a class="code" href="namespacepolybori.html#c8eef4822df804ee3e8a6c97ecb722ef">pboriCuddZddUnionXor__</a>, P, Q, res);
<a name="l00783"></a>00783   
<a name="l00784"></a>00784   <span class="keywordflow">return</span>(res);
<a name="l00785"></a>00785 } <span class="comment">/* end of pboriCuddZddUnionXor */</span>
<a name="l00786"></a>00786 
<a name="l00787"></a>00787 <span class="keyword">template</span> &lt;<span class="keyword">class</span> MgrType, <span class="keyword">class</span> NodeType&gt;
<a name="l00788"></a>00788 NodeType
<a name="l00789"></a><a class="code" href="namespacepolybori.html#41700debc9ce9c13c5e1b325e4148fcc">00789</a> <a class="code" href="namespacepolybori.html#41700debc9ce9c13c5e1b325e4148fcc">pboriCudd_zddUnionXor</a>(MgrType dd, NodeType P, NodeType Q) {
<a name="l00790"></a>00790 
<a name="l00791"></a>00791   NodeType res;
<a name="l00792"></a>00792   <span class="keywordflow">do</span> {
<a name="l00793"></a>00793     dd-&gt;reordered = 0;
<a name="l00794"></a>00794     res = <a class="code" href="namespacepolybori.html#e49cee209098fb6dd51dbd9f5af13c21">pboriCuddZddUnionXor</a>(dd, P, Q);
<a name="l00795"></a>00795     } <span class="keywordflow">while</span> (dd-&gt;reordered == 1);
<a name="l00796"></a>00796   <span class="keywordflow">return</span>(res);
<a name="l00797"></a>00797 }
<a name="l00798"></a>00798 
<a name="l00799"></a>00799 <span class="preprocessor">#endif // PBORI_LOWLEVEL_XOR </span>
<a name="l00800"></a>00800 <span class="preprocessor"></span>
<a name="l00801"></a>00801 
<a name="l00802"></a>00802 <span class="keyword">template</span> &lt;<span class="keyword">class</span> NaviType&gt;
<a name="l00803"></a>00803 <span class="keywordtype">bool</span>
<a name="l00804"></a><a class="code" href="namespacepolybori.html#c33297fcea6d9ca92eabacdeeb2e050e">00804</a> <a class="code" href="namespacepolybori.html#c33297fcea6d9ca92eabacdeeb2e050e">dd_is_singleton</a>(NaviType navi) {
<a name="l00805"></a>00805 
<a name="l00806"></a>00806   <span class="keywordflow">while</span>(!navi.isConstant()) {
<a name="l00807"></a>00807     <span class="keywordflow">if</span> (!navi.elseBranch().isEmpty())
<a name="l00808"></a>00808       <span class="keywordflow">return</span> <span class="keyword">false</span>;
<a name="l00809"></a>00809     navi.incrementThen();
<a name="l00810"></a>00810   }
<a name="l00811"></a>00811   <span class="keywordflow">return</span> <span class="keyword">true</span>;
<a name="l00812"></a>00812 }
<a name="l00813"></a>00813 
<a name="l00814"></a>00814 <span class="keyword">template</span> &lt;<span class="keyword">class</span> NaviType, <span class="keyword">class</span> BooleConstant&gt;
<a name="l00815"></a>00815 BooleConstant
<a name="l00816"></a><a class="code" href="namespacepolybori.html#4e8278bdd0e2fb5175daff3f3d193f9d">00816</a> <a class="code" href="namespacepolybori.html#4e8278bdd0e2fb5175daff3f3d193f9d">dd_pair_check</a>(NaviType navi, <a class="code" href="classpolybori_1_1BooleConstant.html" title="This class wraps a bool value, which was not converted to a boolean polynomial or...">BooleConstant</a> allowSingleton) {
<a name="l00817"></a>00817 
<a name="l00818"></a>00818   <span class="keywordflow">while</span>(!navi.isConstant()) {
<a name="l00819"></a>00819 
<a name="l00820"></a>00820     <span class="keywordflow">if</span> (!navi.elseBranch().isEmpty())
<a name="l00821"></a>00821       <span class="keywordflow">return</span> <a class="code" href="namespacepolybori.html#c33297fcea6d9ca92eabacdeeb2e050e">dd_is_singleton</a>(navi.elseBranch()) &amp;&amp; 
<a name="l00822"></a>00822         <a class="code" href="namespacepolybori.html#c33297fcea6d9ca92eabacdeeb2e050e">dd_is_singleton</a>(navi.thenBranch());
<a name="l00823"></a>00823 
<a name="l00824"></a>00824     navi.incrementThen();
<a name="l00825"></a>00825   }
<a name="l00826"></a>00826   <span class="keywordflow">return</span> allowSingleton;<span class="comment">//();</span>
<a name="l00827"></a>00827 }
<a name="l00828"></a>00828 
<a name="l00829"></a>00829 
<a name="l00830"></a>00830 <span class="keyword">template</span> &lt;<span class="keyword">class</span> NaviType&gt;
<a name="l00831"></a>00831 <span class="keywordtype">bool</span>
<a name="l00832"></a><a class="code" href="namespacepolybori.html#e0805d1b223014c55931ebb35a19b435">00832</a> <a class="code" href="namespacepolybori.html#e0805d1b223014c55931ebb35a19b435">dd_is_singleton_or_pair</a>(NaviType navi) {
<a name="l00833"></a>00833 
<a name="l00834"></a>00834   <span class="keywordflow">return</span> <a class="code" href="namespacepolybori.html#4e8278bdd0e2fb5175daff3f3d193f9d">dd_pair_check</a>(navi, <span class="keyword">true</span>);
<a name="l00835"></a>00835 }
<a name="l00836"></a>00836 
<a name="l00837"></a>00837 <span class="keyword">template</span> &lt;<span class="keyword">class</span> NaviType&gt;
<a name="l00838"></a>00838 <span class="keywordtype">bool</span>
<a name="l00839"></a><a class="code" href="namespacepolybori.html#1e37aeba5f3db38e566e81de60082baa">00839</a> <a class="code" href="namespacepolybori.html#1e37aeba5f3db38e566e81de60082baa">dd_is_pair</a>(NaviType navi) {
<a name="l00840"></a>00840 
<a name="l00841"></a>00841   <span class="keywordflow">return</span> <a class="code" href="namespacepolybori.html#4e8278bdd0e2fb5175daff3f3d193f9d">dd_pair_check</a>(navi, <span class="keyword">false</span>);
<a name="l00842"></a>00842 }
<a name="l00843"></a>00843 
<a name="l00844"></a>00844 
<a name="l00845"></a>00845 
<a name="l00846"></a>00846 <span class="keyword">template</span> &lt;<span class="keyword">class</span> SetType&gt;
<a name="l00847"></a><a class="code" href="namespacepolybori.html#b65c63c61dd7aad862079a7925b4e723">00847</a> <span class="keywordtype">void</span> <a class="code" href="namespacepolybori.html#b65c63c61dd7aad862079a7925b4e723">combine_sizes</a>(<span class="keyword">const</span> SetType&amp; bset, <span class="keywordtype">double</span>&amp; init) {
<a name="l00848"></a>00848   init += bset.sizeDouble();
<a name="l00849"></a>00849 }
<a name="l00850"></a>00850 
<a name="l00851"></a>00851 <span class="keyword">template</span> &lt;<span class="keyword">class</span> SetType&gt;
<a name="l00852"></a><a class="code" href="namespacepolybori.html#d21dcb084f3c03e9e7b2cbaa55e1aee4">00852</a> <span class="keywordtype">void</span> <a class="code" href="namespacepolybori.html#b65c63c61dd7aad862079a7925b4e723">combine_sizes</a>(<span class="keyword">const</span> SetType&amp; bset, 
<a name="l00853"></a>00853                    <span class="keyword">typename</span> SetType::size_type&amp; init) {
<a name="l00854"></a>00854   init += bset.size();
<a name="l00855"></a>00855 }
<a name="l00856"></a>00856 
<a name="l00857"></a>00857 
<a name="l00858"></a>00858 <span class="keyword">template</span> &lt;<span class="keyword">class</span> SizeType, <span class="keyword">class</span> IdxType, <span class="keyword">class</span> NaviType, <span class="keyword">class</span> SetType&gt;
<a name="l00859"></a>00859 SizeType&amp;
<a name="l00860"></a><a class="code" href="namespacepolybori.html#1ef23e0db31b7bdde5d643bd686f19ba">00860</a> <a class="code" href="namespacepolybori.html#1ef23e0db31b7bdde5d643bd686f19ba">count_index</a>(SizeType&amp; size, IdxType idx, NaviType navi, <span class="keyword">const</span> SetType&amp; init) {
<a name="l00861"></a>00861 
<a name="l00862"></a>00862   <span class="keywordflow">if</span> (*navi == idx)
<a name="l00863"></a>00863     <a class="code" href="namespacepolybori.html#b65c63c61dd7aad862079a7925b4e723">combine_sizes</a>(SetType(navi.incrementThen(), init.ring()), size);
<a name="l00864"></a>00864 
<a name="l00865"></a>00865   <span class="keywordflow">if</span> (*navi &lt; idx) {
<a name="l00866"></a>00866     <a class="code" href="namespacepolybori.html#1ef23e0db31b7bdde5d643bd686f19ba">count_index</a>(size, idx, navi.thenBranch(), init);
<a name="l00867"></a>00867     <a class="code" href="namespacepolybori.html#1ef23e0db31b7bdde5d643bd686f19ba">count_index</a>(size, idx, navi.elseBranch(), init);
<a name="l00868"></a>00868   }
<a name="l00869"></a>00869   <span class="keywordflow">return</span> size;
<a name="l00870"></a>00870 }
<a name="l00871"></a>00871 
<a name="l00872"></a>00872 
<a name="l00873"></a>00873 <span class="keyword">template</span> &lt;<span class="keyword">class</span> SizeType, <span class="keyword">class</span> IdxType, <span class="keyword">class</span> SetType&gt;
<a name="l00874"></a>00874 SizeType&amp;
<a name="l00875"></a><a class="code" href="namespacepolybori.html#d2cfa7f286fcb7edd2506ea988108d15">00875</a> <a class="code" href="namespacepolybori.html#1ef23e0db31b7bdde5d643bd686f19ba">count_index</a>(SizeType&amp; size, IdxType idx, <span class="keyword">const</span> SetType&amp; bset) {
<a name="l00876"></a>00876 
<a name="l00877"></a>00877   <span class="keywordflow">return</span> <a class="code" href="namespacepolybori.html#1ef23e0db31b7bdde5d643bd686f19ba">count_index</a>(size, idx, bset.navigation(), SetType());
<a name="l00878"></a>00878 }
<a name="l00879"></a>00879 
<a name="l00880"></a>00880 <a class="code" href="pbori__defs_8h.html#faf094fde6c1a7f1aad18bcb455f3b06" title="Finish project&amp;#39;s namespace.">END_NAMESPACE_PBORI</a>
<a name="l00881"></a>00881 
<a name="l00882"></a>00882 <span class="preprocessor">#endif</span>
</pre></div></div>
<hr size="1"><address style="text-align: right;"><small>Generated on Wed Sep 9 14:30:59 2009 for PolyBoRi by&nbsp;
<a href="http://www.doxygen.org/index.html">
<img src="doxygen.png" alt="doxygen" align="middle" border="0"></a> 1.5.9 </small></address>
</body>
</html>