graph__evat_8h-source.html

来自「这是一个用于数据挖掘的常用算法的模板库(数据挖掘的C++模板库for UNIX)」· HTML 代码 · 共 389 行 · 第 1/3 页

HTML
389
字号
<a name="l00261"></a>00261 <span class="preprocessor"></span>        pair&lt;int, int&gt; new_occurrence;<a name="l00262"></a>00262         <span class="keywordflow">if</span>(!l2_eq)<a name="l00263"></a>00263           new_occurrence.first=(is_fwd_chain?it_evat_v1-&gt;second: it_evat_v1-&gt;first);<a name="l00264"></a>00264         <span class="keywordflow">else</span><a name="l00265"></a>00265           new_occurrence.first=(!l2_swap?it_evat_v1-&gt;second: it_evat_v1-&gt;first);<a name="l00266"></a>00266         new_occurrence.second=(swap_vids?it_evat_v2-&gt;first: it_evat_v2-&gt;second);<a name="l00267"></a>00267     <a name="l00268"></a>00268         <span class="comment">// now append this occurrence to vat</span><a name="l00269"></a>00269         <span class="keywordflow">if</span>(!is_fwd_chain) {<a name="l00270"></a>00270           <span class="keywordflow">if</span>(!cand_vat.empty() &amp;&amp; cand_vat.back().first==v1.first) { <span class="comment">// new occurrence in same tid</span><a name="l00271"></a>00271 #ifdef PRINT<a name="l00272"></a>00272             cout&lt;&lt;<span class="stringliteral">"!fwd_chain, same tid"</span>&lt;&lt;endl;<a name="l00273"></a>00273 <span class="preprocessor">#endif</span><a name="l00274"></a>00274 <span class="preprocessor"></span>            cand_vat.insert_occurrence(new_occurrence); <a name="l00275"></a>00275             cand_vat.insert_vid(new_occurrence.first);<a name="l00276"></a>00276             cand_vat.insert_vid(new_occurrence.second);<a name="l00277"></a>00277           }<a name="l00278"></a>00278           <span class="keywordflow">else</span> { <span class="comment">// new tid</span><a name="l00279"></a>00279 <span class="preprocessor">#ifdef PRINT</span><a name="l00280"></a>00280 <span class="preprocessor"></span>            cout&lt;&lt;<span class="stringliteral">"!fwd_chain, new tid"</span>&lt;&lt;endl;<a name="l00281"></a>00281 <span class="preprocessor">#endif</span><a name="l00282"></a>00282 <span class="preprocessor"></span>            cand_vat.insert_occurrence_tid(v1.first, new_occurrence);<a name="l00283"></a>00283             cand_vat.insert_vid(new_occurrence.first);<a name="l00284"></a>00284             cand_vat.insert_vid(new_occurrence.second);<a name="l00285"></a>00285           }<a name="l00286"></a>00286         }<a name="l00287"></a>00287         <span class="keywordflow">else</span> { <span class="comment">//assert: a new entry for this tid would have been created </span><a name="l00288"></a>00288                <span class="comment">// by the copied vats</span><a name="l00289"></a>00289           <span class="keywordflow">if</span>(cand_vat.back().second.size()==(unsigned) rmp_index) { <a name="l00290"></a>00290             <span class="comment">// this is the first time this edge's evat is being inserted</span><a name="l00291"></a>00291 <span class="preprocessor">#ifdef PRINT</span><a name="l00292"></a>00292 <span class="preprocessor"></span>            cout&lt;&lt;<span class="stringliteral">"fwd_chain, new evat"</span>&lt;&lt;endl;<a name="l00293"></a>00293 <span class="preprocessor">#endif</span><a name="l00294"></a>00294 <span class="preprocessor"></span>            cand_vat.insert_occurrence_evat(new_occurrence);<a name="l00295"></a>00295             cand_vat.insert_vid(new_occurrence.first);<a name="l00296"></a>00296             cand_vat.insert_vid(new_occurrence.second);<a name="l00297"></a>00297           }<a name="l00298"></a>00298           <span class="keywordflow">else</span> {<a name="l00299"></a>00299 <span class="preprocessor">#ifdef PRINT</span><a name="l00300"></a>00300 <span class="preprocessor"></span>            cout&lt;&lt;<span class="stringliteral">"fwd_chain, new occurrence"</span>&lt;&lt;endl;<a name="l00301"></a>00301 <span class="preprocessor">#endif</span><a name="l00302"></a>00302 <span class="preprocessor"></span>            cand_vat.insert_occurrence(new_occurrence);<a name="l00303"></a>00303             cand_vat.insert_vid(new_occurrence.first);<a name="l00304"></a>00304             cand_vat.insert_vid(new_occurrence.second);<a name="l00305"></a>00305           }<a name="l00306"></a>00306         }<a name="l00307"></a>00307       }<span class="comment">//end for it_evat_v2</span><a name="l00308"></a>00308     }<a name="l00309"></a>00309   }<span class="comment">//end fwd_intersect()</span><a name="l00310"></a>00310   <a name="l00311"></a>00311 <a name="l00314"></a>00314   <span class="keyword">template</span>&lt;<span class="keyword">template</span>&lt;<span class="keyword">typename</span>, <span class="keyword">typename</span>&gt; <span class="keyword">class </span>VAT_ST, <span class="keyword">typename</span> VAT, <span class="keyword">template</span> &lt;<span class="keyword">typename</span>&gt; <span class="keyword">class </span>ALLOC&gt;<a name="l00315"></a><a class="code" href="classevat.html#a1fea2d152697ef4dafab9bb9679a1cc">00315</a>   <span class="keyword">static</span> <span class="keywordtype">void</span> <a class="code" href="classevat.html#a1fea2d152697ef4dafab9bb9679a1cc">back_intersect</a>(<span class="keyword">const</span> VAT&amp; vat_v1, <span class="keyword">const</span> <a class="code" href="classevat.html">evat</a>&amp; evat_v1, <span class="keyword">const</span> <a class="code" href="classevat.html">evat</a>&amp; evat_v2, VAT&amp; cand_vat, <a name="l00316"></a>00316                              <span class="keyword">const</span> <span class="keywordtype">int</span>&amp; back_idx, <span class="keyword">const</span> <span class="keywordtype">int</span>&amp; new_edge_state, <span class="keyword">const</span> <span class="keywordtype">int</span>&amp; tid) {<a name="l00317"></a>00317 <span class="preprocessor">#ifdef PRINT</span><a name="l00318"></a>00318 <span class="preprocessor"></span>    cout&lt;&lt;<span class="stringliteral">"evat.back_intersect entered with back_idx="</span>&lt;&lt;back_idx&lt;&lt;<span class="stringliteral">" "</span>&lt;&lt;<span class="stringliteral">"new_edge_stat="</span>&lt;&lt;new_edge_state&lt;&lt;<span class="stringliteral">" tid="</span>&lt;&lt;tid&lt;&lt;endl;<a name="l00319"></a>00319 <span class="preprocessor">#endif</span><a name="l00320"></a>00320 <span class="preprocessor"></span>    <span class="keyword">const</span> VAT_ST&lt;typename VAT::VSET, ALLOC&lt;typename VAT::VSET&gt; &gt;&amp; v1_vids=vat_v1._vids[tid];<a name="l00321"></a>00321     <span class="keyword">const</span> pair&lt;int, VAT_ST&lt;evat, ALLOC&lt;evat&gt; &gt; &gt;&amp; v1=vat_v1._vat[tid];<a name="l00322"></a>00322     CONST_IT it_evat_v1, it_evat_v2;<a name="l00323"></a>00323 <a name="l00324"></a>00324     <span class="keywordtype">int</span> offset_v1;<a name="l00325"></a>00325     <a name="l00326"></a>00326     <span class="keywordtype">bool</span> swap_vids; <span class="comment">// flag to denote if vids in evat_v2 should be swapped </span><a name="l00327"></a>00327                     <span class="comment">// before comparison with v1</span><a name="l00328"></a>00328 <a name="l00329"></a>00329     <span class="keywordflow">for</span>(it_evat_v1=evat_v1.<a class="code" href="classevat.html#576e837271071e10535be5b0276c06c6">begin</a>(), offset_v1=0; it_evat_v1!=evat_v1.<a class="code" href="classevat.html#eb2eff3b7a1e3a340731d33ecb472ebf">end</a>(); it_evat_v1++, offset_v1++)<a name="l00330"></a>00330       <span class="keywordflow">for</span>(it_evat_v2=evat_v2.<a class="code" href="classevat.html#576e837271071e10535be5b0276c06c6">begin</a>(); it_evat_v2!=evat_v2.<a class="code" href="classevat.html#eb2eff3b7a1e3a340731d33ecb472ebf">end</a>(); it_evat_v2++) {<a name="l00332"></a>00332 <a name="l00333"></a>00333         <span class="keywordflow">if</span>(!new_edge_state) {<a name="l00334"></a>00334           <span class="keywordflow">if</span>(it_evat_v1-&gt;second!=it_evat_v2-&gt;first)<a name="l00335"></a>00335             <span class="keywordflow">if</span>(it_evat_v1-&gt;second!=it_evat_v2-&gt;second) <span class="comment">// none of the vids in v2 matches</span><a name="l00336"></a>00336               <span class="keywordflow">continue</span>;<a name="l00337"></a>00337             <span class="keywordflow">else</span><a name="l00338"></a>00338               swap_vids=1;<a name="l00339"></a>00339           <span class="keywordflow">else</span><a name="l00340"></a>00340             swap_vids=0;<a name="l00341"></a>00341         }<a name="l00342"></a>00342         <span class="keywordflow">else</span> {<a name="l00343"></a>00343           swap_vids=new_edge_state-1;<a name="l00344"></a>00344 <a name="l00345"></a>00345           <span class="comment">// check it's of the form A-B, B-C</span><a name="l00346"></a>00346           <span class="keywordflow">if</span>(!swap_vids &amp;&amp; it_evat_v1-&gt;second!=it_evat_v2-&gt;first)<a name="l00347"></a>00347             <span class="keywordflow">continue</span>;<a name="l00348"></a>00348           <span class="keywordflow">if</span>(swap_vids &amp;&amp; it_evat_v1-&gt;second!=it_evat_v2-&gt;second)<a name="l00349"></a>00349             <span class="keywordflow">continue</span>;<a name="l00350"></a>00350         }<a name="l00351"></a>00351 <a name="l00352"></a>00352         <span class="comment">// check that the back vertex is right one in this occurrence</span><a name="l00353"></a>00353         <span class="keywordflow">if</span>(!swap_vids &amp;&amp; v1.second[back_idx][offset_v1].first!=it_evat_v2-&gt;second)<a name="l00354"></a>00354           <span class="keywordflow">continue</span>;<a name="l00355"></a>00355         <span class="keywordflow">if</span>(swap_vids &amp;&amp; v1.second[back_idx][offset_v1].first!=it_evat_v2-&gt;first)<a name="l00356"></a>00356           <span class="keywordflow">continue</span>;<a name="l00357"></a>00357 <a name="l00358"></a>00358         <span class="comment">// this is a valid back extension</span><a name="l00359"></a>00359         <span class="comment">// no new evat is prepared for a back extension</span><a name="l00360"></a>00360         <span class="comment">// simply copy the appropriate ones to cand_vat</span><a name="l00361"></a>00361         <span class="keywordflow">if</span>(!cand_vat.empty() &amp;&amp; cand_vat.back().first==v1.first) {<a name="l00362"></a>00362           <span class="comment">// this tid exists</span><a name="l00363"></a>00363           cand_vat.copy_vats(v1, offset_v1, v1.second.size());<a name="l00364"></a>00364           cand_vat.copy_vids_hs(v1_vids[offset_v1]);<a name="l00365"></a>00365         }<a name="l00366"></a>00366           <span class="keywordflow">else</span> {<a name="l00367"></a>00367             <span class="comment">// this is a new tid, create a new entry in vat</span><a name="l00368"></a>00368             cand_vat.copy_vats_tid(v1, offset_v1, v1.second.size());<a name="l00369"></a>00369             cand_vat.copy_vids_tid(v1_vids[offset_v1]);<a name="l00370"></a>00370           }<a name="l00371"></a>00371         }<span class="comment">//end for it_evat_v2</span><a name="l00372"></a>00372       }<span class="comment">//end back_intersect()</span><a name="l00373"></a>00373 <a name="l00374"></a>00374  <span class="keyword">private</span>:<a name="l00375"></a>00375   <a class="code" href="classevat.html#38c8ee4ef89ea8e9476013cabc7e217e">EVAT</a> _evat;<a name="l00376"></a>00376 };<a name="l00377"></a>00377 <a name="l00378"></a>00378 <span class="keyword">template</span> &lt;<span class="keyword">template</span> &lt;<span class="keyword">typename</span>&gt; <span class="keyword">class </span>ALLOC &gt;<a name="l00379"></a>00379 ostream&amp; operator&lt;&lt; (ostream&amp; ostr, const evat&lt;ALLOC&gt;&amp; ev) {<a name="l00380"></a>00380   <span class="keyword">typename</span> <a class="code" href="classevat.html">evat&lt;ALLOC&gt;::CONST_IT</a> it;<a name="l00381"></a>00381   <span class="keywordflow">for</span>(it=ev.begin(); it!=ev.end(); it++)<a name="l00382"></a>00382     ostr&lt;&lt;it-&gt;first&lt;&lt;<span class="stringliteral">","</span>&lt;&lt;it-&gt;second&lt;&lt;<span class="stringliteral">" "</span>;<a name="l00383"></a>00383   <span class="keywordflow">return</span> ostr;<a name="l00384"></a>00384 }<a name="l00385"></a>00385 <a name="l00386"></a>00386 <span class="preprocessor">#endif</span></pre></div><hr size="1"><address style="align: right;"><small>Generated on Wed Jul 26 14:01:08 2006 for DMTL by&nbsp;<a href="http://www.doxygen.org/index.html"><img src="doxygen.png" alt="doxygen" align="middle" border="0"></a> 1.4.7 </small></address></body></html>

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?