~ubuntu-branches/ubuntu/trusty/bmagic/trusty

« back to all changes in this revision

Viewing changes to doc/html/a00086_source.html

  • Committer: Bazaar Package Importer
  • Author(s): Roberto C. Sanchez
  • Date: 2009-12-09 16:02:55 UTC
  • mfrom: (4.1.5 sid)
  • Revision ID: james.westby@ubuntu.com-20091209160255-hu2bnjrbncl92z5w
Tags: 3.6.1-1
New upstream release

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
2
 
<html><head><meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
3
 
<title>BitMagic: sample8.cpp Source File</title>
4
 
<link href="tabs.css" rel="stylesheet" type="text/css">
5
 
<link href="doxygen.css" rel="stylesheet" type="text/css">
6
 
</head><body>
7
 
<!-- Generated by Doxygen 1.5.9 -->
 
1
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
 
2
<html xmlns="http://www.w3.org/1999/xhtml">
 
3
<head>
 
4
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
 
5
<title>BitMagic: bmalgo_impl.h Source File</title>
 
6
<link href="tabs.css" rel="stylesheet" type="text/css"/>
 
7
<link href="doxygen.css" rel="stylesheet" type="text/css"/>
 
8
</head>
 
9
<body>
 
10
<!-- Generated by Doxygen 1.6.1 -->
8
11
<div class="navigation" id="top">
9
12
  <div class="tabs">
10
13
    <ul>
22
25
      <li><a href="globals.html"><span>Globals</span></a></li>
23
26
    </ul>
24
27
  </div>
25
 
<h1>sample8.cpp</h1><a href="a00086.html">Go to the documentation of this file.</a><div class="fragment"><pre class="fragment"><a name="l00001"></a>00001 <span class="comment">/*</span>
26
 
<a name="l00002"></a>00002 <span class="comment">Copyright(c) 2002-2005 Anatoliy Kuznetsov(anatoliy_kuznetsov at yahoo.com)</span>
27
 
<a name="l00003"></a>00003 <span class="comment"></span>
28
 
<a name="l00004"></a>00004 <span class="comment">Permission is hereby granted, free of charge, to any person </span>
29
 
<a name="l00005"></a>00005 <span class="comment">obtaining a copy of this software and associated documentation </span>
30
 
<a name="l00006"></a>00006 <span class="comment">files (the "Software"), to deal in the Software without restriction, </span>
31
 
<a name="l00007"></a>00007 <span class="comment">including without limitation the rights to use, copy, modify, merge, </span>
32
 
<a name="l00008"></a>00008 <span class="comment">publish, distribute, sublicense, and/or sell copies of the Software, </span>
33
 
<a name="l00009"></a>00009 <span class="comment">and to permit persons to whom the Software is furnished to do so, </span>
34
 
<a name="l00010"></a>00010 <span class="comment">subject to the following conditions:</span>
35
 
<a name="l00011"></a>00011 <span class="comment"></span>
36
 
<a name="l00012"></a>00012 <span class="comment">The above copyright notice and this permission notice shall be included </span>
37
 
<a name="l00013"></a>00013 <span class="comment">in all copies or substantial portions of the Software.</span>
38
 
<a name="l00014"></a>00014 <span class="comment"></span>
39
 
<a name="l00015"></a>00015 <span class="comment">THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, </span>
40
 
<a name="l00016"></a>00016 <span class="comment">EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES </span>
41
 
<a name="l00017"></a>00017 <span class="comment">OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. </span>
42
 
<a name="l00018"></a>00018 <span class="comment">IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, </span>
43
 
<a name="l00019"></a>00019 <span class="comment">DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, </span>
44
 
<a name="l00020"></a>00020 <span class="comment">ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR </span>
45
 
<a name="l00021"></a>00021 <span class="comment">OTHER DEALINGS IN THE SOFTWARE.</span>
46
 
<a name="l00022"></a>00022 <span class="comment">*/</span>
47
 
<a name="l00023"></a>00023 <span class="comment"></span>
48
 
<a name="l00024"></a>00024 <span class="comment">/** \example sample8.cpp</span>
49
 
<a name="l00025"></a>00025 <span class="comment"></span>
50
 
<a name="l00026"></a>00026 <span class="comment">    Example demonstrates some STL compatability set operations using</span>
51
 
<a name="l00027"></a>00027 <span class="comment">    set iterators.</span>
52
 
<a name="l00028"></a>00028 <span class="comment"> </span>
53
 
<a name="l00029"></a>00029 <span class="comment">  \sa bm::bvector&lt;&gt;::enumerator </span>
54
 
<a name="l00030"></a>00030 <span class="comment">  \sa bm::bvector&lt;&gt;::insert_iterator</span>
55
 
<a name="l00031"></a>00031 <span class="comment"></span>
56
 
<a name="l00032"></a>00032 <span class="comment">   For more information please visit:  http://bmagic.sourceforge.net</span>
57
 
<a name="l00033"></a>00033 <span class="comment"></span>
58
 
<a name="l00034"></a>00034 <span class="comment">*/</span>
59
 
<a name="l00035"></a>00035 
60
 
<a name="l00036"></a>00036 <span class="preprocessor">#include &lt;iostream&gt;</span>
61
 
<a name="l00037"></a>00037 <span class="preprocessor">#include &lt;algorithm&gt;</span>
62
 
<a name="l00038"></a>00038 <span class="preprocessor">#include &lt;vector&gt;</span>
63
 
<a name="l00039"></a>00039 <span class="preprocessor">#include &lt;list&gt;</span>
64
 
<a name="l00040"></a>00040 
65
 
<a name="l00041"></a>00041 <span class="keyword">using</span> std::vector;
66
 
<a name="l00042"></a>00042 <span class="keyword">using</span> std::list;
67
 
<a name="l00043"></a>00043 
68
 
<a name="l00044"></a>00044 <span class="comment">// This example requires STL compatibility</span>
69
 
<a name="l00045"></a>00045 <span class="preprocessor">#ifdef BM_NO_STL</span>
70
 
<a name="l00046"></a>00046 <span class="preprocessor"></span><span class="preprocessor"># undef BM_NO_STL</span>
71
 
<a name="l00047"></a>00047 <span class="preprocessor"></span><span class="preprocessor">#endif</span>
72
 
<a name="l00048"></a>00048 <span class="preprocessor"></span>
73
 
<a name="l00049"></a>00049 <span class="preprocessor">#include "<a class="code" href="a00068.html">bm.h</a>"</span>
74
 
<a name="l00050"></a>00050 
75
 
<a name="l00051"></a>00051 <span class="keyword">using namespace </span>std;
76
 
<a name="l00052"></a>00052 
77
 
<a name="l00053"></a><a class="code" href="a00086.html#80085d7c877f4c6f36d10c67dc163845">00053</a> <span class="keywordtype">void</span> <a class="code" href="a00083.html#80085d7c877f4c6f36d10c67dc163845">Print</a>(<span class="keywordtype">unsigned</span> n)
 
28
<h1>bmalgo_impl.h</h1><a href="a00086.html">Go to the documentation of this file.</a><div class="fragment"><pre class="fragment"><a name="l00001"></a>00001 <span class="preprocessor">#ifndef BMALGO_IMPL__H__INCLUDED__</span>
 
29
<a name="l00002"></a>00002 <span class="preprocessor"></span><span class="preprocessor">#define BMALGO_IMPL__H__INCLUDED__</span>
 
30
<a name="l00003"></a>00003 <span class="preprocessor"></span><span class="comment">/*</span>
 
31
<a name="l00004"></a>00004 <span class="comment">Copyright(c) 2002-2009 Anatoliy Kuznetsov(anatoliy_kuznetsov at yahoo.com)</span>
 
32
<a name="l00005"></a>00005 <span class="comment"></span>
 
33
<a name="l00006"></a>00006 <span class="comment">Permission is hereby granted, free of charge, to any person </span>
 
34
<a name="l00007"></a>00007 <span class="comment">obtaining a copy of this software and associated documentation </span>
 
35
<a name="l00008"></a>00008 <span class="comment">files (the &quot;Software&quot;), to deal in the Software without restriction, </span>
 
36
<a name="l00009"></a>00009 <span class="comment">including without limitation the rights to use, copy, modify, merge, </span>
 
37
<a name="l00010"></a>00010 <span class="comment">publish, distribute, sublicense, and/or sell copies of the Software, </span>
 
38
<a name="l00011"></a>00011 <span class="comment">and to permit persons to whom the Software is furnished to do so, </span>
 
39
<a name="l00012"></a>00012 <span class="comment">subject to the following conditions:</span>
 
40
<a name="l00013"></a>00013 <span class="comment"></span>
 
41
<a name="l00014"></a>00014 <span class="comment">The above copyright notice and this permission notice shall be included </span>
 
42
<a name="l00015"></a>00015 <span class="comment">in all copies or substantial portions of the Software.</span>
 
43
<a name="l00016"></a>00016 <span class="comment"></span>
 
44
<a name="l00017"></a>00017 <span class="comment">THE SOFTWARE IS PROVIDED &quot;AS IS&quot;, WITHOUT WARRANTY OF ANY KIND, </span>
 
45
<a name="l00018"></a>00018 <span class="comment">EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES </span>
 
46
<a name="l00019"></a>00019 <span class="comment">OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. </span>
 
47
<a name="l00020"></a>00020 <span class="comment">IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, </span>
 
48
<a name="l00021"></a>00021 <span class="comment">DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, </span>
 
49
<a name="l00022"></a>00022 <span class="comment">ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR </span>
 
50
<a name="l00023"></a>00023 <span class="comment">OTHER DEALINGS IN THE SOFTWARE.</span>
 
51
<a name="l00024"></a>00024 <span class="comment"></span>
 
52
<a name="l00025"></a>00025 <span class="comment">For more information please visit:  http://bmagic.sourceforge.net</span>
 
53
<a name="l00026"></a>00026 <span class="comment"></span>
 
54
<a name="l00027"></a>00027 <span class="comment">*/</span>
 
55
<a name="l00028"></a>00028 
 
56
<a name="l00029"></a>00029 <span class="preprocessor">#ifdef _MSC_VER</span>
 
57
<a name="l00030"></a>00030 <span class="preprocessor"></span><span class="preprocessor">#pragma warning( disable : 4311 4312)</span>
 
58
<a name="l00031"></a>00031 <span class="preprocessor"></span><span class="preprocessor">#endif</span>
 
59
<a name="l00032"></a>00032 <span class="preprocessor"></span>
 
60
<a name="l00033"></a>00033 <span class="preprocessor">#include &quot;<a class="code" href="a00089.html">bmdef.h</a>&quot;</span>
 
61
<a name="l00034"></a>00034 
 
62
<a name="l00035"></a>00035 <span class="keyword">namespace </span>bm
 
63
<a name="l00036"></a>00036 {
 
64
<a name="l00037"></a>00037 <span class="comment"></span>
 
65
<a name="l00038"></a>00038 <span class="comment">/*! \defgroup setalgo Set algorithms </span>
 
66
<a name="l00039"></a>00039 <span class="comment"> *  Set algorithms </span>
 
67
<a name="l00040"></a>00040 <span class="comment"> *  \ingroup bmagic</span>
 
68
<a name="l00041"></a>00041 <span class="comment"> */</span>
 
69
<a name="l00042"></a>00042 <span class="comment"></span>
 
70
<a name="l00043"></a>00043 <span class="comment">/*! \defgroup distance Distance metrics </span>
 
71
<a name="l00044"></a>00044 <span class="comment"> *  Algorithms to compute binary distance metrics</span>
 
72
<a name="l00045"></a>00045 <span class="comment"> *  \ingroup setalgo</span>
 
73
<a name="l00046"></a>00046 <span class="comment"> */</span>
 
74
<a name="l00047"></a>00047 
 
75
<a name="l00048"></a>00048 <span class="comment"></span>
 
76
<a name="l00049"></a>00049 <span class="comment">/*! </span>
 
77
<a name="l00050"></a>00050 <span class="comment">    \brief    Distance metrics codes defined for vectors A and B</span>
 
78
<a name="l00051"></a>00051 <span class="comment">    \ingroup  distance</span>
 
79
<a name="l00052"></a>00052 <span class="comment">*/</span>
 
80
<a name="l00053"></a><a class="code" href="a00120.html#gac38d64c8b27b652413a664cddd4d40ab">00053</a> <span class="keyword">enum</span> <a class="code" href="a00120.html#gac38d64c8b27b652413a664cddd4d40ab" title="Distance metrics codes defined for vectors A and B.">distance_metric</a>
78
81
<a name="l00054"></a>00054 {
79
 
<a name="l00055"></a>00055     cout &lt;&lt; n &lt;&lt; endl;;
80
 
<a name="l00056"></a>00056 }
81
 
<a name="l00057"></a>00057 
82
 
<a name="l00058"></a>00058 <span class="comment">// Utility template function used to print container</span>
83
 
<a name="l00059"></a><a class="code" href="a00086.html#b7f435443f8dbf9f50e4ad0efea8b1f8">00059</a> <span class="keyword">template</span>&lt;<span class="keyword">class</span> T&gt; <span class="keywordtype">void</span> <a class="code" href="a00086.html#b7f435443f8dbf9f50e4ad0efea8b1f8">PrintContainer</a>(T first, T last)
84
 
<a name="l00060"></a>00060 {
85
 
<a name="l00061"></a>00061     <span class="keywordflow">if</span> (first == last)
86
 
<a name="l00062"></a>00062         cout &lt;&lt; <span class="stringliteral">"&lt;EMPTY SET&gt;"</span>;
87
 
<a name="l00063"></a>00063     <span class="keywordflow">else</span>
88
 
<a name="l00064"></a>00064         <span class="keywordflow">for</span>(;first != last; ++first)
89
 
<a name="l00065"></a>00065             cout &lt;&lt; *first &lt;&lt; <span class="stringliteral">";"</span>;
90
 
<a name="l00066"></a>00066     cout &lt;&lt; endl;
91
 
<a name="l00067"></a>00067 }
92
 
<a name="l00068"></a>00068 
93
 
<a name="l00069"></a><a class="code" href="a00086.html#840291bc02cba5474a4cb46a9b9566fe">00069</a> <span class="keywordtype">int</span> <a class="code" href="a00079.html#840291bc02cba5474a4cb46a9b9566fe">main</a>(<span class="keywordtype">void</span>)
 
82
<a name="l00055"></a><a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abacb39376469ba778e9a9099ddbae5e7ce">00055</a>     <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abacb39376469ba778e9a9099ddbae5e7ce" title="(A &amp;amp; B).count()">COUNT_AND</a> = <a class="code" href="a00110.html#a76b70d2b9182a6dcac151d1bd9ec6109a378be4b14cee6a341e859fd3157ab959">set_COUNT_AND</a>,          <span class="comment">//!&lt; (A &amp; B).count()</span>
 
83
<a name="l00056"></a><a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40aba3e4861dde6e1179457ee0d3502ae8061">00056</a> <span class="comment"></span>    <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40aba3e4861dde6e1179457ee0d3502ae8061" title="(A ^ B).count()">COUNT_XOR</a> = <a class="code" href="a00110.html#a76b70d2b9182a6dcac151d1bd9ec6109a1373054e4f243dffb762a55b8a8bfe4c">set_COUNT_XOR</a>,          <span class="comment">//!&lt; (A ^ B).count()</span>
 
84
<a name="l00057"></a><a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abad0bd2d56c8ebd03f55c01b3cc6faaaeb">00057</a> <span class="comment"></span>    <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abad0bd2d56c8ebd03f55c01b3cc6faaaeb" title="(A | B).count()">COUNT_OR</a>  = <a class="code" href="a00110.html#a76b70d2b9182a6dcac151d1bd9ec6109a27e34c148d06e3d8a405482d820cd7fb">set_COUNT_OR</a>,           <span class="comment">//!&lt; (A | B).count()</span>
 
85
<a name="l00058"></a><a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40aba9c101dab8904c0432f72ccce0a207e62">00058</a> <span class="comment"></span>    <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40aba9c101dab8904c0432f72ccce0a207e62" title="(A - B).count()">COUNT_SUB_AB</a> = <a class="code" href="a00110.html#a76b70d2b9182a6dcac151d1bd9ec6109a0028cc7084b37fe66ce5ae459b93b7f1">set_COUNT_SUB_AB</a>,    <span class="comment">//!&lt; (A - B).count()</span>
 
86
<a name="l00059"></a><a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abafa036fb9d54bc659ed3c9e4185ccf400">00059</a> <span class="comment"></span>    <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abafa036fb9d54bc659ed3c9e4185ccf400" title="(B - A).count()">COUNT_SUB_BA</a> = <a class="code" href="a00110.html#a76b70d2b9182a6dcac151d1bd9ec6109a2f7b894c11c058598d02722a7eeef03b">set_COUNT_SUB_BA</a>,    <span class="comment">//!&lt; (B - A).count()</span>
 
87
<a name="l00060"></a><a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abaac7947d53eb3acf81251ee4130e6a4a2">00060</a> <span class="comment"></span>    <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abaac7947d53eb3acf81251ee4130e6a4a2" title="A.count().">COUNT_A</a>      = <a class="code" href="a00110.html#a76b70d2b9182a6dcac151d1bd9ec6109abafe8a971864164aeec7f43d1205ed29">set_COUNT_A</a>,         <span class="comment">//!&lt; A.count()</span>
 
88
<a name="l00061"></a><a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abac6dbadf2ab9405daa47dc0f10d082516">00061</a> <span class="comment"></span>    <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abac6dbadf2ab9405daa47dc0f10d082516" title="B.count().">COUNT_B</a>      = <a class="code" href="a00110.html#a76b70d2b9182a6dcac151d1bd9ec6109a2ac4eb7f41d00f8387d5dd3ffb9d0617">set_COUNT_B</a>          <span class="comment">//!&lt; B.count()</span>
 
89
<a name="l00062"></a>00062 <span class="comment"></span>};
 
90
<a name="l00063"></a>00063 <span class="comment"></span>
 
91
<a name="l00064"></a>00064 <span class="comment">/**</span>
 
92
<a name="l00065"></a>00065 <span class="comment">    Convert set operation into compatible distance metric</span>
 
93
<a name="l00066"></a>00066 <span class="comment">    \ingroup  distance</span>
 
94
<a name="l00067"></a>00067 <span class="comment">*/</span>
 
95
<a name="l00068"></a>00068 <span class="keyword">inline</span>
 
96
<a name="l00069"></a><a class="code" href="a00120.html#ga158946ea41ca66c3e1bca62c92684788">00069</a> <a class="code" href="a00120.html#gac38d64c8b27b652413a664cddd4d40ab" title="Distance metrics codes defined for vectors A and B.">distance_metric</a> <a class="code" href="a00120.html#ga158946ea41ca66c3e1bca62c92684788" title="Convert set operation into compatible distance metric.">operation2metric</a>(<a class="code" href="a00110.html#a76b70d2b9182a6dcac151d1bd9ec6109" title="Nomenclature of set operations.">set_operation</a> op)
94
97
<a name="l00070"></a>00070 {
95
 
<a name="l00071"></a>00071     <a class="code" href="a00036.html" title="bitvector with runtime compression of bits.">bm::bvector&lt;&gt;</a>   bv;    
96
 
<a name="l00072"></a>00072 
97
 
<a name="l00073"></a>00073     bv[10] = <span class="keyword">true</span>;
98
 
<a name="l00074"></a>00074     bv[100] = <span class="keyword">true</span>;
99
 
<a name="l00075"></a>00075     bv[10000] = <span class="keyword">true</span>;
100
 
<a name="l00076"></a>00076     
101
 
<a name="l00077"></a>00077     cout &lt;&lt; <span class="stringliteral">"Source set:"</span>;
102
 
<a name="l00078"></a>00078     <a class="code" href="a00086.html#b7f435443f8dbf9f50e4ad0efea8b1f8">PrintContainer</a>(bv.<a class="code" href="a00036.html#ad48c661f843e32c9893438a6f27a8f0" title="Returns enumerator pointing on the first non-zero bit.">first</a>(), bv.<a class="code" href="a00036.html#2c6e522f858fdc466765d2c0f269f590" title="Returns enumerator pointing on the next bit after the last.">end</a>());
103
 
<a name="l00079"></a>00079     
104
 
<a name="l00080"></a>00080     <span class="comment">// copy all bitset information into STL vector using copy algorithm</span>
105
 
<a name="l00081"></a>00081     {
106
 
<a name="l00082"></a>00082         vector&lt;unsigned&gt; vect;
107
 
<a name="l00083"></a>00083         vect.resize(bv.<a class="code" href="a00036.html#71077c1315555301532e24d4d2b95ea2" title="Returns count of bits which are 1.">count</a>());
108
 
<a name="l00084"></a>00084         std::copy(bv.<a class="code" href="a00036.html#ad48c661f843e32c9893438a6f27a8f0" title="Returns enumerator pointing on the first non-zero bit.">first</a>(), bv.<a class="code" href="a00036.html#2c6e522f858fdc466765d2c0f269f590" title="Returns enumerator pointing on the next bit after the last.">end</a>(), vect.begin());
109
 
<a name="l00085"></a>00085         cout &lt;&lt; <span class="stringliteral">"Vector:"</span>;
110
 
<a name="l00086"></a>00086         <a class="code" href="a00086.html#b7f435443f8dbf9f50e4ad0efea8b1f8">PrintContainer</a>(vect.begin(), vect.end());
111
 
<a name="l00087"></a>00087     }
112
 
<a name="l00088"></a>00088 
113
 
<a name="l00089"></a>00089     <span class="comment">// doing the same with the help of back_inserter</span>
114
 
<a name="l00090"></a>00090 
115
 
<a name="l00091"></a>00091     {
116
 
<a name="l00092"></a>00092         list&lt;unsigned&gt; lst;
117
 
<a name="l00093"></a>00093         std::copy(bv.<a class="code" href="a00036.html#ad48c661f843e32c9893438a6f27a8f0" title="Returns enumerator pointing on the first non-zero bit.">first</a>(), bv.<a class="code" href="a00036.html#2c6e522f858fdc466765d2c0f269f590" title="Returns enumerator pointing on the next bit after the last.">end</a>(), std::back_inserter(lst));
118
 
<a name="l00094"></a>00094         cout &lt;&lt; <span class="stringliteral">"List:"</span>;
119
 
<a name="l00095"></a>00095         <a class="code" href="a00086.html#b7f435443f8dbf9f50e4ad0efea8b1f8">PrintContainer</a>(lst.begin(), lst.end());
120
 
<a name="l00096"></a>00096     }
121
 
<a name="l00097"></a>00097 
122
 
<a name="l00098"></a>00098     {
123
 
<a name="l00099"></a>00099         vector&lt;unsigned&gt;   vect;
124
 
<a name="l00100"></a>00100         vector&lt;unsigned&gt;   res1, res2, res3;
125
 
<a name="l00101"></a>00101         
126
 
<a name="l00102"></a>00102         vect.push_back(100);
127
 
<a name="l00103"></a>00103         vect.push_back(15);
128
 
<a name="l00104"></a>00104         vect.push_back(150);
129
 
<a name="l00105"></a>00105         
130
 
<a name="l00106"></a>00106         cout &lt;&lt; <span class="stringliteral">"Argument vector for set operations:"</span>;
131
 
<a name="l00107"></a>00107         <a class="code" href="a00086.html#b7f435443f8dbf9f50e4ad0efea8b1f8">PrintContainer</a>(vect.begin(), vect.end());
132
 
<a name="l00108"></a>00108         
133
 
<a name="l00109"></a>00109         <span class="comment">// set should be ordered by &lt; to make set algorithms possible</span>
134
 
<a name="l00110"></a>00110         std::sort(vect.begin(), vect.end());
135
 
<a name="l00111"></a>00111         cout &lt;&lt; endl;
136
 
<a name="l00112"></a>00112         
137
 
<a name="l00113"></a>00113         std::set_union(bv.<a class="code" href="a00036.html#ad48c661f843e32c9893438a6f27a8f0" title="Returns enumerator pointing on the first non-zero bit.">first</a>(), bv.<a class="code" href="a00036.html#2c6e522f858fdc466765d2c0f269f590" title="Returns enumerator pointing on the next bit after the last.">end</a>(),
138
 
<a name="l00114"></a>00114                        vect.begin(), vect.end(),
139
 
<a name="l00115"></a>00115                        std::back_inserter(res1)); <span class="comment">//10;15;100;150;10000</span>
140
 
<a name="l00116"></a>00116         cout &lt;&lt; <span class="stringliteral">"Set union:"</span> &lt;&lt; endl;
141
 
<a name="l00117"></a>00117         <a class="code" href="a00086.html#b7f435443f8dbf9f50e4ad0efea8b1f8">PrintContainer</a>(res1.begin(), res1.end());
142
 
<a name="l00118"></a>00118         
143
 
<a name="l00119"></a>00119         std::set_intersection(bv.<a class="code" href="a00036.html#ad48c661f843e32c9893438a6f27a8f0" title="Returns enumerator pointing on the first non-zero bit.">first</a>(), bv.<a class="code" href="a00036.html#2c6e522f858fdc466765d2c0f269f590" title="Returns enumerator pointing on the next bit after the last.">end</a>(),
144
 
<a name="l00120"></a>00120                               vect.begin(), vect.end(),
145
 
<a name="l00121"></a>00121                               std::back_inserter(res2));  <span class="comment">// 100</span>
146
 
<a name="l00122"></a>00122         cout &lt;&lt; <span class="stringliteral">"Set intersection:"</span> &lt;&lt; endl;
147
 
<a name="l00123"></a>00123         <a class="code" href="a00086.html#b7f435443f8dbf9f50e4ad0efea8b1f8">PrintContainer</a>(res2.begin(), res2.end());
148
 
<a name="l00124"></a>00124 
149
 
<a name="l00125"></a>00125         vector&lt;unsigned&gt;::const_iterator it1 = vect.begin();
150
 
<a name="l00126"></a>00126         vector&lt;unsigned&gt;::const_iterator it2 = vect.end();
151
 
<a name="l00127"></a>00127         <a class="code" href="a00051.html" title="Constant input iterator designed to enumerate &amp;quot;ON&amp;quot; bits.">bm::bvector&lt;&gt;::enumerator</a> en = bv.<a class="code" href="a00036.html#ad48c661f843e32c9893438a6f27a8f0" title="Returns enumerator pointing on the first non-zero bit.">first</a>();
152
 
<a name="l00128"></a>00128         <a class="code" href="a00051.html" title="Constant input iterator designed to enumerate &amp;quot;ON&amp;quot; bits.">bm::bvector&lt;&gt;::enumerator</a> en2= bv.<a class="code" href="a00036.html#2c6e522f858fdc466765d2c0f269f590" title="Returns enumerator pointing on the next bit after the last.">end</a>();
153
 
<a name="l00129"></a>00129         
154
 
<a name="l00130"></a>00130         std::set_difference(en, en2,
155
 
<a name="l00131"></a>00131                             it1, it2,
156
 
<a name="l00132"></a>00132                             std::back_inserter(res3));  <span class="comment">// 10;10000</span>
157
 
<a name="l00133"></a>00133 
158
 
<a name="l00134"></a>00134         cout &lt;&lt; <span class="stringliteral">"Set diff:"</span> &lt;&lt; endl;
159
 
<a name="l00135"></a>00135         <a class="code" href="a00086.html#b7f435443f8dbf9f50e4ad0efea8b1f8">PrintContainer</a>(res3.begin(), res3.end());
160
 
<a name="l00136"></a>00136         
161
 
<a name="l00137"></a>00137     }
162
 
<a name="l00138"></a>00138 
163
 
<a name="l00139"></a>00139     <span class="comment">// Using bvector&lt;&gt;::insert_iterator to set bits</span>
164
 
<a name="l00140"></a>00140     {
165
 
<a name="l00141"></a>00141         <a class="code" href="a00036.html" title="bitvector with runtime compression of bits.">bm::bvector&lt;&gt;</a> bv1;
166
 
<a name="l00142"></a>00142         std::vector&lt;unsigned&gt; vect;
167
 
<a name="l00143"></a>00143         
168
 
<a name="l00144"></a>00144         vect.push_back(300);
169
 
<a name="l00145"></a>00145         vect.push_back(200);
170
 
<a name="l00146"></a>00146         vect.push_back(275);
171
 
<a name="l00147"></a>00147         vect.push_back(200);
172
 
<a name="l00148"></a>00148         
173
 
<a name="l00149"></a>00149         cout &lt;&lt; endl &lt;&lt; <span class="stringliteral">"Source vector:"</span>;
174
 
<a name="l00150"></a>00150         <a class="code" href="a00086.html#b7f435443f8dbf9f50e4ad0efea8b1f8">PrintContainer</a>(vect.begin(), vect.end()); <span class="comment">// 300;200;275;200;</span>
175
 
<a name="l00151"></a>00151         
176
 
<a name="l00152"></a>00152         <span class="comment">// The "side effect" of this operation is that we sorted</span>
177
 
<a name="l00153"></a>00153         <span class="comment">// the input sequence and eliminated duplicates</span>
178
 
<a name="l00154"></a>00154         
179
 
<a name="l00155"></a>00155         std::copy(vect.begin(), vect.end(), bv1.<a class="code" href="a00036.html#da0d32bbd1a135722a7790b13d866451">inserter</a>());
180
 
<a name="l00156"></a>00156         cout &lt;&lt; <span class="stringliteral">"Bitset:"</span>;
181
 
<a name="l00157"></a>00157         
182
 
<a name="l00158"></a>00158         <a class="code" href="a00086.html#b7f435443f8dbf9f50e4ad0efea8b1f8">PrintContainer</a>(bv1.<a class="code" href="a00036.html#ad48c661f843e32c9893438a6f27a8f0" title="Returns enumerator pointing on the first non-zero bit.">first</a>(), bv1.<a class="code" href="a00036.html#2c6e522f858fdc466765d2c0f269f590" title="Returns enumerator pointing on the next bit after the last.">end</a>());  <span class="comment">// 200;275;300</span>
183
 
<a name="l00159"></a>00159     }
184
 
<a name="l00160"></a>00160     
185
 
<a name="l00161"></a>00161     
186
 
<a name="l00162"></a>00162     <span class="keywordflow">return</span> 0;
187
 
<a name="l00163"></a>00163 }
188
 
<a name="l00164"></a>00164 
 
98
<a name="l00071"></a>00071     <a class="code" href="a00089.html#aa44515fab0ace8928d1cb82009a95bf8">BM_ASSERT</a>(<a class="code" href="a00110.html#a3deb310cdf11bca948817f94adfec160" title="Returns true if set operation is constant (bitcount).">is_const_set_operation</a>(op));
 
99
<a name="l00072"></a>00072     <span class="keywordflow">if</span> (op == <a class="code" href="a00110.html#a76b70d2b9182a6dcac151d1bd9ec6109a3f165b7944e33214e8721aaf2eb8378e">set_COUNT</a>) op = <a class="code" href="a00110.html#a76b70d2b9182a6dcac151d1bd9ec6109a2ac4eb7f41d00f8387d5dd3ffb9d0617">set_COUNT_B</a>;
 
100
<a name="l00073"></a>00073     <span class="comment">// distance metric is created as a set operation sub-class</span>
 
101
<a name="l00074"></a>00074     <span class="comment">// simple cast will work to convert</span>
 
102
<a name="l00075"></a>00075     <span class="keywordflow">return</span> (<a class="code" href="a00120.html#gac38d64c8b27b652413a664cddd4d40ab" title="Distance metrics codes defined for vectors A and B.">distance_metric</a>) op;
 
103
<a name="l00076"></a>00076 }
 
104
<a name="l00077"></a>00077 <span class="comment"></span>
 
105
<a name="l00078"></a>00078 <span class="comment">/*! </span>
 
106
<a name="l00079"></a>00079 <span class="comment">    \brief Distance metric descriptor, holds metric code and result.</span>
 
107
<a name="l00080"></a>00080 <span class="comment">    \sa distance_operation</span>
 
108
<a name="l00081"></a>00081 <span class="comment">*/</span>
 
109
<a name="l00082"></a>00082 
 
110
<a name="l00083"></a><a class="code" href="a00060.html">00083</a> <span class="keyword">struct </span><a class="code" href="a00060.html" title="Distance metric descriptor, holds metric code and result.">distance_metric_descriptor</a>
 
111
<a name="l00084"></a>00084 {
 
112
<a name="l00085"></a><a class="code" href="a00060.html#a3ece2ccdb7a6616f06a5a15679ccabb1">00085</a>      <a class="code" href="a00120.html#gac38d64c8b27b652413a664cddd4d40ab" title="Distance metrics codes defined for vectors A and B.">distance_metric</a>   <a class="code" href="a00060.html#a3ece2ccdb7a6616f06a5a15679ccabb1">metric</a>;
 
113
<a name="l00086"></a><a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">00086</a>      <a class="code" href="a00110.html#aa3824d882a037396370b16f2f0a8bf37">bm::id_t</a>          <a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a>;
 
114
<a name="l00087"></a>00087      
 
115
<a name="l00088"></a><a class="code" href="a00060.html#ab4cc0e59d35431f9a6fe110b7a1392df">00088</a>      <a class="code" href="a00060.html#a33061afe75bacd27a76abdcffbba65d5">distance_metric_descriptor</a>(<a class="code" href="a00120.html#gac38d64c8b27b652413a664cddd4d40ab" title="Distance metrics codes defined for vectors A and B.">distance_metric</a> m)
 
116
<a name="l00089"></a>00089      : <a class="code" href="a00060.html#a3ece2ccdb7a6616f06a5a15679ccabb1">metric</a>(m),
 
117
<a name="l00090"></a>00090        <a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a>(0)
 
118
<a name="l00091"></a>00091     {}
 
119
<a name="l00092"></a><a class="code" href="a00060.html#a33061afe75bacd27a76abdcffbba65d5">00092</a>     <a class="code" href="a00060.html#a33061afe75bacd27a76abdcffbba65d5">distance_metric_descriptor</a>()
 
120
<a name="l00093"></a>00093     : <a class="code" href="a00060.html#a3ece2ccdb7a6616f06a5a15679ccabb1">metric</a>(bm::<a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40aba3e4861dde6e1179457ee0d3502ae8061" title="(A ^ B).count()">COUNT_XOR</a>),
 
121
<a name="l00094"></a>00094       <a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a>(0)
 
122
<a name="l00095"></a>00095     {}
 
123
<a name="l00096"></a>00096     <span class="comment"></span>
 
124
<a name="l00097"></a>00097 <span class="comment">    /*! </span>
 
125
<a name="l00098"></a>00098 <span class="comment">        \brief Sets metric result to 0</span>
 
126
<a name="l00099"></a>00099 <span class="comment">    */</span>
 
127
<a name="l00100"></a><a class="code" href="a00060.html#a30de8a19da0c250c3d3645eb51ea942c">00100</a>     <span class="keywordtype">void</span> <a class="code" href="a00060.html#a30de8a19da0c250c3d3645eb51ea942c" title="Sets metric result to 0.">reset</a>()
 
128
<a name="l00101"></a>00101     {
 
129
<a name="l00102"></a>00102         <a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> = 0;
 
130
<a name="l00103"></a>00103     }
 
131
<a name="l00104"></a>00104 };
 
132
<a name="l00105"></a>00105 
 
133
<a name="l00106"></a>00106 <span class="comment"></span>
 
134
<a name="l00107"></a>00107 <span class="comment">/*!</span>
 
135
<a name="l00108"></a>00108 <span class="comment">    \brief Internal function computes different distance metrics.</span>
 
136
<a name="l00109"></a>00109 <span class="comment">    \internal </span>
 
137
<a name="l00110"></a>00110 <span class="comment">    \ingroup  distance</span>
 
138
<a name="l00111"></a>00111 <span class="comment">     </span>
 
139
<a name="l00112"></a>00112 <span class="comment">*/</span>
 
140
<a name="l00113"></a>00113 <span class="keyword">inline</span>
 
141
<a name="l00114"></a><a class="code" href="a00110.html#abecd5b24d5e394fd46a9db514cfa659a">00114</a> <span class="keywordtype">void</span> <a class="code" href="a00110.html#abecd5b24d5e394fd46a9db514cfa659a" title="Internal function computes different distance metrics.">combine_count_operation_with_block</a>(<span class="keyword">const</span> <a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>* blk,
 
142
<a name="l00115"></a>00115                                         <span class="keywordtype">unsigned</span> gap,
 
143
<a name="l00116"></a>00116                                         <span class="keyword">const</span> <a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>* arg_blk,
 
144
<a name="l00117"></a>00117                                         <span class="keywordtype">int</span> arg_gap,
 
145
<a name="l00118"></a>00118                                         <a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>* temp_blk,
 
146
<a name="l00119"></a>00119                                         <a class="code" href="a00060.html" title="Distance metric descriptor, holds metric code and result.">distance_metric_descriptor</a>* dmit,
 
147
<a name="l00120"></a>00120                                         <a class="code" href="a00060.html" title="Distance metric descriptor, holds metric code and result.">distance_metric_descriptor</a>* dmit_end)
 
148
<a name="l00121"></a>00121                                             
 
149
<a name="l00122"></a>00122 {
 
150
<a name="l00123"></a>00123      <a class="code" href="a00110.html#ac654d6319039a86546d235a236fc7cf6">gap_word_t</a>* res=0;
 
151
<a name="l00124"></a>00124      
 
152
<a name="l00125"></a>00125      <a class="code" href="a00110.html#ac654d6319039a86546d235a236fc7cf6">gap_word_t</a>* g1 = <a class="code" href="a00089.html#a6a7c8b8ee3f3b60ab907c1699acb7aa0">BMGAP_PTR</a>(blk);
 
153
<a name="l00126"></a>00126      <a class="code" href="a00110.html#ac654d6319039a86546d235a236fc7cf6">gap_word_t</a>* g2 = <a class="code" href="a00089.html#a6a7c8b8ee3f3b60ab907c1699acb7aa0">BMGAP_PTR</a>(arg_blk);
 
154
<a name="l00127"></a>00127      
 
155
<a name="l00128"></a>00128      <span class="keywordflow">if</span> (gap) <span class="comment">// first block GAP-type</span>
 
156
<a name="l00129"></a>00129      {
 
157
<a name="l00130"></a>00130          <span class="keywordflow">if</span> (arg_gap)  <span class="comment">// both blocks GAP-type</span>
 
158
<a name="l00131"></a>00131          {
 
159
<a name="l00132"></a>00132              <span class="comment">// TODO: optimize to avoid temp</span>
 
160
<a name="l00133"></a>00133              <a class="code" href="a00110.html#ac654d6319039a86546d235a236fc7cf6">gap_word_t</a> tmp_buf[<a class="code" href="a00110.html#a9b1715d6d9164d56172e75bbbd0e3000">bm::gap_equiv_len</a> * 3]; <span class="comment">// temporary result</span>
 
161
<a name="l00134"></a>00134              
 
162
<a name="l00135"></a>00135              <span class="keywordflow">for</span> (<a class="code" href="a00060.html" title="Distance metric descriptor, holds metric code and result.">distance_metric_descriptor</a>* it = dmit;it &lt; dmit_end; ++it)
 
163
<a name="l00136"></a>00136              {
 
164
<a name="l00137"></a>00137                  <a class="code" href="a00060.html" title="Distance metric descriptor, holds metric code and result.">distance_metric_descriptor</a>&amp; dmd = *it;
 
165
<a name="l00138"></a>00138                  <span class="keywordtype">unsigned</span> dsize = 0;
 
166
<a name="l00139"></a>00139                  
 
167
<a name="l00140"></a>00140                  <span class="keywordflow">switch</span> (dmd.<a class="code" href="a00060.html#a3ece2ccdb7a6616f06a5a15679ccabb1">metric</a>)
 
168
<a name="l00141"></a>00141                  {
 
169
<a name="l00142"></a>00142                  <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abacb39376469ba778e9a9099ddbae5e7ce" title="(A &amp;amp; B).count()">bm::COUNT_AND</a>:
 
170
<a name="l00143"></a>00143                      res = <a class="code" href="a00114.html#ga1666464d22f7fd473db9aafcf2f77a63" title="GAP AND operation.">gap_operation_and</a>(g1, g2, tmp_buf, dsize);
 
171
<a name="l00144"></a>00144                      <span class="keywordflow">break</span>;
 
172
<a name="l00145"></a>00145                  <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abad0bd2d56c8ebd03f55c01b3cc6faaaeb" title="(A | B).count()">bm::COUNT_OR</a>:
 
173
<a name="l00146"></a>00146                      res = <a class="code" href="a00114.html#gacda280af8910ae5fde37731a3a7a1226" title="GAP OR operation.">gap_operation_or</a>(g1, g2, tmp_buf, dsize);
 
174
<a name="l00147"></a>00147                      <span class="keywordflow">break</span>;
 
175
<a name="l00148"></a>00148                  <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40aba9c101dab8904c0432f72ccce0a207e62" title="(A - B).count()">bm::COUNT_SUB_AB</a>:
 
176
<a name="l00149"></a>00149                      res = <a class="code" href="a00114.html#gabe4c83e5e162c38e297116dd1cd05ac4" title="GAP SUB (AND NOT) operation.">gap_operation_sub</a>(g1, g2, tmp_buf, dsize); 
 
177
<a name="l00150"></a>00150                      <span class="keywordflow">break</span>;
 
178
<a name="l00151"></a>00151                  <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abafa036fb9d54bc659ed3c9e4185ccf400" title="(B - A).count()">bm::COUNT_SUB_BA</a>:
 
179
<a name="l00152"></a>00152                      res = <a class="code" href="a00114.html#gabe4c83e5e162c38e297116dd1cd05ac4" title="GAP SUB (AND NOT) operation.">gap_operation_sub</a>(g2, g1, tmp_buf, dsize); 
 
180
<a name="l00153"></a>00153                      <span class="keywordflow">break</span>;
 
181
<a name="l00154"></a>00154                  <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40aba3e4861dde6e1179457ee0d3502ae8061" title="(A ^ B).count()">bm::COUNT_XOR</a>:
 
182
<a name="l00155"></a>00155                      res = <a class="code" href="a00114.html#gaa5e07ad0256bf784ad3397acbbd23bb2" title="GAP XOR operation.">gap_operation_xor</a>(g1, g2, tmp_buf, dsize); 
 
183
<a name="l00156"></a>00156                     <span class="keywordflow">break</span>;
 
184
<a name="l00157"></a>00157                  <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abaac7947d53eb3acf81251ee4130e6a4a2" title="A.count().">bm::COUNT_A</a>:
 
185
<a name="l00158"></a>00158                     res = g1;
 
186
<a name="l00159"></a>00159                     <span class="keywordflow">break</span>;
 
187
<a name="l00160"></a>00160                  <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abac6dbadf2ab9405daa47dc0f10d082516" title="B.count().">bm::COUNT_B</a>:
 
188
<a name="l00161"></a>00161                     res = g2;
 
189
<a name="l00162"></a>00162                     <span class="keywordflow">break</span>;
 
190
<a name="l00163"></a>00163                  } <span class="comment">// switch</span>
 
191
<a name="l00164"></a>00164                  
 
192
<a name="l00165"></a>00165                  <span class="keywordflow">if</span> (res)
 
193
<a name="l00166"></a>00166                      dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += <a class="code" href="a00114.html#ga570a6f573ffb9ac9e41a688d2bdc6004" title="Calculates number of bits ON in GAP buffer.">gap_bit_count</a>(res, dsize);
 
194
<a name="l00167"></a>00167                     
 
195
<a name="l00168"></a>00168              } <span class="comment">// for it</span>
 
196
<a name="l00169"></a>00169              
 
197
<a name="l00170"></a>00170              <span class="keywordflow">return</span>;
 
198
<a name="l00171"></a>00171 
 
199
<a name="l00172"></a>00172          }
 
200
<a name="l00173"></a>00173          <span class="keywordflow">else</span> <span class="comment">// first block - GAP, argument - BITSET</span>
 
201
<a name="l00174"></a>00174          {
 
202
<a name="l00175"></a>00175              <span class="keywordflow">for</span> (<a class="code" href="a00060.html" title="Distance metric descriptor, holds metric code and result.">distance_metric_descriptor</a>* it = dmit;it &lt; dmit_end; ++it)
 
203
<a name="l00176"></a>00176              {
 
204
<a name="l00177"></a>00177                  <a class="code" href="a00060.html" title="Distance metric descriptor, holds metric code and result.">distance_metric_descriptor</a>&amp; dmd = *it;
 
205
<a name="l00178"></a>00178                  
 
206
<a name="l00179"></a>00179                  <span class="keywordflow">switch</span> (dmd.<a class="code" href="a00060.html#a3ece2ccdb7a6616f06a5a15679ccabb1">metric</a>)
 
207
<a name="l00180"></a>00180                  {
 
208
<a name="l00181"></a>00181                  <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abacb39376469ba778e9a9099ddbae5e7ce" title="(A &amp;amp; B).count()">bm::COUNT_AND</a>:
 
209
<a name="l00182"></a>00182                      <span class="keywordflow">if</span> (arg_blk)
 
210
<a name="l00183"></a>00183                         dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += <a class="code" href="a00115.html#gab87384cbf46a04d86c008ab2463d02cc" title="Compute bitcount of bit block AND masked by GAP block.">gap_bitset_and_count</a>(arg_blk, g1);
 
211
<a name="l00184"></a>00184                      <span class="keywordflow">break</span>;
 
212
<a name="l00185"></a>00185                  <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abad0bd2d56c8ebd03f55c01b3cc6faaaeb" title="(A | B).count()">bm::COUNT_OR</a>:
 
213
<a name="l00186"></a>00186                      <span class="keywordflow">if</span> (!arg_blk)
 
214
<a name="l00187"></a>00187                         dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += <a class="code" href="a00114.html#ga570a6f573ffb9ac9e41a688d2bdc6004" title="Calculates number of bits ON in GAP buffer.">gap_bit_count</a>(g1);
 
215
<a name="l00188"></a>00188                      <span class="keywordflow">else</span>
 
216
<a name="l00189"></a>00189                         dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += <a class="code" href="a00115.html#ga23733890861063a59f787e26763a734a" title="Compute bitcount of bit block OR masked by GAP block.">gap_bitset_or_count</a>(arg_blk, g1); 
 
217
<a name="l00190"></a>00190                      <span class="keywordflow">break</span>;
 
218
<a name="l00191"></a>00191                  <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40aba9c101dab8904c0432f72ccce0a207e62" title="(A - B).count()">bm::COUNT_SUB_AB</a>:
 
219
<a name="l00192"></a>00192                      <a class="code" href="a00114.html#ga4862f4dcdcb7c0575e2e2db9e5f2a849" title="GAP block to bitblock conversion.">gap_convert_to_bitset</a>((<a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>*) temp_blk, g1);
 
220
<a name="l00193"></a>00193                      dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += 
 
221
<a name="l00194"></a>00194                        <a class="code" href="a00115.html#gaabb39bf01bf973cb7bf3648873921ab7" title="Performs bitblock SUB operation and calculates bitcount of the result.">bit_operation_sub_count</a>((<a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>*)temp_blk, 
 
222
<a name="l00195"></a>00195                           ((<a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>*)temp_blk) + <a class="code" href="a00110.html#a91319dbc0d0e1bf3a3efc4d92bac7972">bm::set_block_size</a>,
 
223
<a name="l00196"></a>00196                            arg_blk);
 
224
<a name="l00197"></a>00197                  
 
225
<a name="l00198"></a>00198                      <span class="keywordflow">break</span>;
 
226
<a name="l00199"></a>00199                  <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abafa036fb9d54bc659ed3c9e4185ccf400" title="(B - A).count()">bm::COUNT_SUB_BA</a>:
 
227
<a name="l00200"></a>00200                      dmd.<a class="code" href="a00060.html#a3ece2ccdb7a6616f06a5a15679ccabb1">metric</a> = <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40aba9c101dab8904c0432f72ccce0a207e62" title="(A - B).count()">bm::COUNT_SUB_AB</a>; <span class="comment">// recursive call to SUB_AB</span>
 
228
<a name="l00201"></a>00201                      <a class="code" href="a00110.html#abecd5b24d5e394fd46a9db514cfa659a" title="Internal function computes different distance metrics.">combine_count_operation_with_block</a>(arg_blk,
 
229
<a name="l00202"></a>00202                                                         arg_gap,
 
230
<a name="l00203"></a>00203                                                         blk,
 
231
<a name="l00204"></a>00204                                                         gap,
 
232
<a name="l00205"></a>00205                                                         temp_blk,
 
233
<a name="l00206"></a>00206                                                         it, it+1);
 
234
<a name="l00207"></a>00207                      dmd.<a class="code" href="a00060.html#a3ece2ccdb7a6616f06a5a15679ccabb1">metric</a> = <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abafa036fb9d54bc659ed3c9e4185ccf400" title="(B - A).count()">bm::COUNT_SUB_BA</a>; <span class="comment">// restore status quo</span>
 
235
<a name="l00208"></a>00208                      <span class="keywordflow">break</span>;
 
236
<a name="l00209"></a>00209                  <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40aba3e4861dde6e1179457ee0d3502ae8061" title="(A ^ B).count()">bm::COUNT_XOR</a>:
 
237
<a name="l00210"></a>00210                      <span class="keywordflow">if</span> (!arg_blk)
 
238
<a name="l00211"></a>00211                         dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += <a class="code" href="a00114.html#ga570a6f573ffb9ac9e41a688d2bdc6004" title="Calculates number of bits ON in GAP buffer.">gap_bit_count</a>(g1);
 
239
<a name="l00212"></a>00212                      <span class="keywordflow">else</span>
 
240
<a name="l00213"></a>00213                         dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += <a class="code" href="a00115.html#ga803fbc7c790f07b14175303e524bd2d8" title="Compute bitcount of bit block XOR masked by GAP block.">gap_bitset_xor_count</a>(arg_blk, g1);
 
241
<a name="l00214"></a>00214                      <span class="keywordflow">break</span>;
 
242
<a name="l00215"></a>00215                  <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abaac7947d53eb3acf81251ee4130e6a4a2" title="A.count().">bm::COUNT_A</a>:
 
243
<a name="l00216"></a>00216                     <span class="keywordflow">if</span> (g1)
 
244
<a name="l00217"></a>00217                         dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += <a class="code" href="a00114.html#ga570a6f573ffb9ac9e41a688d2bdc6004" title="Calculates number of bits ON in GAP buffer.">gap_bit_count</a>(g1);
 
245
<a name="l00218"></a>00218                     <span class="keywordflow">break</span>;
 
246
<a name="l00219"></a>00219                  <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abac6dbadf2ab9405daa47dc0f10d082516" title="B.count().">bm::COUNT_B</a>:
 
247
<a name="l00220"></a>00220                     <span class="keywordflow">if</span> (arg_blk)
 
248
<a name="l00221"></a>00221                     {
 
249
<a name="l00222"></a>00222                         dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += 
 
250
<a name="l00223"></a>00223                           <a class="code" href="a00115.html#gab30df14a61f036d690c091878feaff1c" title="Bitcount for bit string.">bit_block_calc_count</a>(arg_blk, 
 
251
<a name="l00224"></a>00224                                                arg_blk + <a class="code" href="a00110.html#a91319dbc0d0e1bf3a3efc4d92bac7972">bm::set_block_size</a>);
 
252
<a name="l00225"></a>00225                     }
 
253
<a name="l00226"></a>00226                     <span class="keywordflow">break</span>;
 
254
<a name="l00227"></a>00227                  } <span class="comment">// switch</span>
 
255
<a name="l00228"></a>00228                                      
 
256
<a name="l00229"></a>00229              } <span class="comment">// for it</span>
 
257
<a name="l00230"></a>00230              
 
258
<a name="l00231"></a>00231              <span class="keywordflow">return</span>;
 
259
<a name="l00232"></a>00232          
 
260
<a name="l00233"></a>00233          }
 
261
<a name="l00234"></a>00234      } 
 
262
<a name="l00235"></a>00235      <span class="keywordflow">else</span> <span class="comment">// first block is BITSET-type</span>
 
263
<a name="l00236"></a>00236      {     
 
264
<a name="l00237"></a>00237          <span class="keywordflow">if</span> (arg_gap) <span class="comment">// second argument block is GAP-type</span>
 
265
<a name="l00238"></a>00238          {
 
266
<a name="l00239"></a>00239              <span class="keywordflow">for</span> (<a class="code" href="a00060.html" title="Distance metric descriptor, holds metric code and result.">distance_metric_descriptor</a>* it = dmit;it &lt; dmit_end; ++it)
 
267
<a name="l00240"></a>00240              {
 
268
<a name="l00241"></a>00241                  <a class="code" href="a00060.html" title="Distance metric descriptor, holds metric code and result.">distance_metric_descriptor</a>&amp; dmd = *it;
 
269
<a name="l00242"></a>00242                  
 
270
<a name="l00243"></a>00243                  <span class="keywordflow">switch</span> (dmd.<a class="code" href="a00060.html#a3ece2ccdb7a6616f06a5a15679ccabb1">metric</a>)
 
271
<a name="l00244"></a>00244                  {
 
272
<a name="l00245"></a>00245                  <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abacb39376469ba778e9a9099ddbae5e7ce" title="(A &amp;amp; B).count()">bm::COUNT_AND</a>:
 
273
<a name="l00246"></a>00246                      <span class="keywordflow">if</span> (blk) 
 
274
<a name="l00247"></a>00247                         dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += <a class="code" href="a00115.html#gab87384cbf46a04d86c008ab2463d02cc" title="Compute bitcount of bit block AND masked by GAP block.">gap_bitset_and_count</a>(blk, g2);                         
 
275
<a name="l00248"></a>00248                      <span class="keywordflow">break</span>;
 
276
<a name="l00249"></a>00249                  <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abad0bd2d56c8ebd03f55c01b3cc6faaaeb" title="(A | B).count()">bm::COUNT_OR</a>:
 
277
<a name="l00250"></a>00250                      <span class="keywordflow">if</span> (!blk)
 
278
<a name="l00251"></a>00251                         dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += <a class="code" href="a00114.html#ga570a6f573ffb9ac9e41a688d2bdc6004" title="Calculates number of bits ON in GAP buffer.">gap_bit_count</a>(g2);
 
279
<a name="l00252"></a>00252                      <span class="keywordflow">else</span>
 
280
<a name="l00253"></a>00253                         dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += <a class="code" href="a00115.html#ga23733890861063a59f787e26763a734a" title="Compute bitcount of bit block OR masked by GAP block.">gap_bitset_or_count</a>(blk, g2);
 
281
<a name="l00254"></a>00254                      <span class="keywordflow">break</span>;
 
282
<a name="l00255"></a>00255                  <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40aba9c101dab8904c0432f72ccce0a207e62" title="(A - B).count()">bm::COUNT_SUB_AB</a>:
 
283
<a name="l00256"></a>00256                      <span class="keywordflow">if</span> (blk)
 
284
<a name="l00257"></a>00257                         dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += <a class="code" href="a00115.html#ga15a780da58d5aeb67ffc51c84fa6152e" title="Compute bitcount of bit block SUB masked by GAP block.">gap_bitset_sub_count</a>(blk, g2);
 
285
<a name="l00258"></a>00258                      <span class="keywordflow">break</span>;
 
286
<a name="l00259"></a>00259                  <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abafa036fb9d54bc659ed3c9e4185ccf400" title="(B - A).count()">bm::COUNT_SUB_BA</a>:
 
287
<a name="l00260"></a>00260                      dmd.<a class="code" href="a00060.html#a3ece2ccdb7a6616f06a5a15679ccabb1">metric</a> = <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40aba9c101dab8904c0432f72ccce0a207e62" title="(A - B).count()">bm::COUNT_SUB_AB</a>; <span class="comment">// recursive call to SUB_AB</span>
 
288
<a name="l00261"></a>00261                      <a class="code" href="a00110.html#abecd5b24d5e394fd46a9db514cfa659a" title="Internal function computes different distance metrics.">combine_count_operation_with_block</a>(arg_blk,
 
289
<a name="l00262"></a>00262                                                         arg_gap,
 
290
<a name="l00263"></a>00263                                                         blk,
 
291
<a name="l00264"></a>00264                                                         gap,
 
292
<a name="l00265"></a>00265                                                         temp_blk,
 
293
<a name="l00266"></a>00266                                                         it, it+1);
 
294
<a name="l00267"></a>00267                      dmd.<a class="code" href="a00060.html#a3ece2ccdb7a6616f06a5a15679ccabb1">metric</a> = <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abafa036fb9d54bc659ed3c9e4185ccf400" title="(B - A).count()">bm::COUNT_SUB_BA</a>; <span class="comment">// restore status quo</span>
 
295
<a name="l00268"></a>00268                      <span class="keywordflow">break</span>;
 
296
<a name="l00269"></a>00269                  <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40aba3e4861dde6e1179457ee0d3502ae8061" title="(A ^ B).count()">bm::COUNT_XOR</a>:
 
297
<a name="l00270"></a>00270                      <span class="keywordflow">if</span> (!blk)
 
298
<a name="l00271"></a>00271                         dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += <a class="code" href="a00114.html#ga570a6f573ffb9ac9e41a688d2bdc6004" title="Calculates number of bits ON in GAP buffer.">gap_bit_count</a>(g2);
 
299
<a name="l00272"></a>00272                      <span class="keywordflow">else</span>
 
300
<a name="l00273"></a>00273                         dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += <a class="code" href="a00115.html#ga803fbc7c790f07b14175303e524bd2d8" title="Compute bitcount of bit block XOR masked by GAP block.">gap_bitset_xor_count</a>(blk, g2); 
 
301
<a name="l00274"></a>00274                     <span class="keywordflow">break</span>;
 
302
<a name="l00275"></a>00275                  <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abaac7947d53eb3acf81251ee4130e6a4a2" title="A.count().">bm::COUNT_A</a>:
 
303
<a name="l00276"></a>00276                     <span class="keywordflow">if</span> (blk)
 
304
<a name="l00277"></a>00277                     {
 
305
<a name="l00278"></a>00278                         dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += 
 
306
<a name="l00279"></a>00279                             <a class="code" href="a00115.html#gab30df14a61f036d690c091878feaff1c" title="Bitcount for bit string.">bit_block_calc_count</a>(blk, 
 
307
<a name="l00280"></a>00280                                                  blk + <a class="code" href="a00110.html#a91319dbc0d0e1bf3a3efc4d92bac7972">bm::set_block_size</a>);
 
308
<a name="l00281"></a>00281                     }
 
309
<a name="l00282"></a>00282                     <span class="keywordflow">break</span>;
 
310
<a name="l00283"></a>00283                  <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abac6dbadf2ab9405daa47dc0f10d082516" title="B.count().">bm::COUNT_B</a>:
 
311
<a name="l00284"></a>00284                     <span class="keywordflow">if</span> (g2)
 
312
<a name="l00285"></a>00285                         dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += <a class="code" href="a00114.html#ga570a6f573ffb9ac9e41a688d2bdc6004" title="Calculates number of bits ON in GAP buffer.">gap_bit_count</a>(g2);
 
313
<a name="l00286"></a>00286                     <span class="keywordflow">break</span>;
 
314
<a name="l00287"></a>00287                  } <span class="comment">// switch</span>
 
315
<a name="l00288"></a>00288                                      
 
316
<a name="l00289"></a>00289              } <span class="comment">// for it</span>
 
317
<a name="l00290"></a>00290              
 
318
<a name="l00291"></a>00291              <span class="keywordflow">return</span>;
 
319
<a name="l00292"></a>00292          }
 
320
<a name="l00293"></a>00293      }
 
321
<a name="l00294"></a>00294 
 
322
<a name="l00295"></a>00295      <span class="comment">// --------------------------------------------</span>
 
323
<a name="l00296"></a>00296      <span class="comment">//</span>
 
324
<a name="l00297"></a>00297      <span class="comment">// Here we combine two plain bitblocks </span>
 
325
<a name="l00298"></a>00298 
 
326
<a name="l00299"></a>00299      <span class="keyword">const</span> <a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>* blk_end;
 
327
<a name="l00300"></a>00300      <span class="comment">//const bm::word_t* arg_end;</span>
 
328
<a name="l00301"></a>00301 
 
329
<a name="l00302"></a>00302      blk_end = blk + (<a class="code" href="a00110.html#a91319dbc0d0e1bf3a3efc4d92bac7972">bm::set_block_size</a>);
 
330
<a name="l00303"></a>00303      <span class="comment">//arg_end = arg_blk + (bm::set_block_size);</span>
 
331
<a name="l00304"></a>00304 
 
332
<a name="l00305"></a>00305 
 
333
<a name="l00306"></a>00306      <span class="keywordflow">for</span> (<a class="code" href="a00060.html" title="Distance metric descriptor, holds metric code and result.">distance_metric_descriptor</a>* it = dmit; it &lt; dmit_end; ++it)
 
334
<a name="l00307"></a>00307      {
 
335
<a name="l00308"></a>00308          <a class="code" href="a00060.html" title="Distance metric descriptor, holds metric code and result.">distance_metric_descriptor</a>&amp; dmd = *it;
 
336
<a name="l00309"></a>00309         <a class="code" href="a00110.html#ad93f96a77f223240b8c6b8f81c5db840">bit_operation_count_func_type</a> gfunc = 
 
337
<a name="l00310"></a>00310             <a class="code" href="a00076.html#a4fc04066445af644759bf65ebf765760">operation_functions&lt;true&gt;::bit_operation_count</a>(dmd.<a class="code" href="a00060.html#a3ece2ccdb7a6616f06a5a15679ccabb1">metric</a>);
 
338
<a name="l00311"></a>00311         <span class="keywordflow">if</span> (gfunc)
 
339
<a name="l00312"></a>00312         {
 
340
<a name="l00313"></a>00313             dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += (*gfunc)(blk, blk_end, arg_blk);
 
341
<a name="l00314"></a>00314         }
 
342
<a name="l00315"></a>00315         <span class="keywordflow">else</span>
 
343
<a name="l00316"></a>00316         {
 
344
<a name="l00317"></a>00317             <span class="keywordflow">switch</span> (dmd.<a class="code" href="a00060.html#a3ece2ccdb7a6616f06a5a15679ccabb1">metric</a>)
 
345
<a name="l00318"></a>00318             {
 
346
<a name="l00319"></a>00319             <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abaac7947d53eb3acf81251ee4130e6a4a2" title="A.count().">bm::COUNT_A</a>:
 
347
<a name="l00320"></a>00320                 <span class="keywordflow">if</span> (blk)
 
348
<a name="l00321"></a>00321                     dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += <a class="code" href="a00115.html#gab30df14a61f036d690c091878feaff1c" title="Bitcount for bit string.">bit_block_calc_count</a>(blk, blk_end);
 
349
<a name="l00322"></a>00322                 <span class="keywordflow">break</span>;
 
350
<a name="l00323"></a>00323             <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abac6dbadf2ab9405daa47dc0f10d082516" title="B.count().">bm::COUNT_B</a>:
 
351
<a name="l00324"></a>00324                 <span class="keywordflow">if</span> (arg_blk)
 
352
<a name="l00325"></a>00325                     dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += 
 
353
<a name="l00326"></a>00326                         <a class="code" href="a00115.html#gab30df14a61f036d690c091878feaff1c" title="Bitcount for bit string.">bit_block_calc_count</a>(arg_blk, 
 
354
<a name="l00327"></a>00327                                              arg_blk + <a class="code" href="a00110.html#a91319dbc0d0e1bf3a3efc4d92bac7972">bm::set_block_size</a>);
 
355
<a name="l00328"></a>00328                 <span class="keywordflow">break</span>;
 
356
<a name="l00329"></a>00329             <span class="keywordflow">default</span>:
 
357
<a name="l00330"></a>00330                 <a class="code" href="a00089.html#aa44515fab0ace8928d1cb82009a95bf8">BM_ASSERT</a>(0);
 
358
<a name="l00331"></a>00331             } <span class="comment">// switch</span>
 
359
<a name="l00332"></a>00332         }
 
360
<a name="l00333"></a>00333 
 
361
<a name="l00334"></a>00334      } <span class="comment">// for it</span>
 
362
<a name="l00335"></a>00335 }
 
363
<a name="l00336"></a>00336 <span class="comment"></span>
 
364
<a name="l00337"></a>00337 <span class="comment">/*!</span>
 
365
<a name="l00338"></a>00338 <span class="comment">    \brief Internal function computes different existense of distance metric.</span>
 
366
<a name="l00339"></a>00339 <span class="comment">    \internal </span>
 
367
<a name="l00340"></a>00340 <span class="comment">    \ingroup  distance</span>
 
368
<a name="l00341"></a>00341 <span class="comment">*/</span>
 
369
<a name="l00342"></a>00342 <span class="keyword">inline</span>
 
370
<a name="l00343"></a><a class="code" href="a00110.html#a24069ced9ea689034ff51246ae707ecc">00343</a> <span class="keywordtype">void</span> <a class="code" href="a00110.html#a24069ced9ea689034ff51246ae707ecc" title="Internal function computes different existense of distance metric.">combine_any_operation_with_block</a>(<span class="keyword">const</span> <a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>* blk,
 
371
<a name="l00344"></a>00344                                       <span class="keywordtype">unsigned</span> gap,
 
372
<a name="l00345"></a>00345                                       <span class="keyword">const</span> <a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>* arg_blk,
 
373
<a name="l00346"></a>00346                                       <span class="keywordtype">int</span> arg_gap,
 
374
<a name="l00347"></a>00347                                       <a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>* temp_blk,
 
375
<a name="l00348"></a>00348                                       <a class="code" href="a00060.html" title="Distance metric descriptor, holds metric code and result.">distance_metric_descriptor</a>* dmit,
 
376
<a name="l00349"></a>00349                                       <a class="code" href="a00060.html" title="Distance metric descriptor, holds metric code and result.">distance_metric_descriptor</a>* dmit_end)
 
377
<a name="l00350"></a>00350                                             
 
378
<a name="l00351"></a>00351 {
 
379
<a name="l00352"></a>00352      <a class="code" href="a00110.html#ac654d6319039a86546d235a236fc7cf6">gap_word_t</a>* res=0;
 
380
<a name="l00353"></a>00353      
 
381
<a name="l00354"></a>00354      <a class="code" href="a00110.html#ac654d6319039a86546d235a236fc7cf6">gap_word_t</a>* g1 = <a class="code" href="a00089.html#a6a7c8b8ee3f3b60ab907c1699acb7aa0">BMGAP_PTR</a>(blk);
 
382
<a name="l00355"></a>00355      <a class="code" href="a00110.html#ac654d6319039a86546d235a236fc7cf6">gap_word_t</a>* g2 = <a class="code" href="a00089.html#a6a7c8b8ee3f3b60ab907c1699acb7aa0">BMGAP_PTR</a>(arg_blk);
 
383
<a name="l00356"></a>00356      
 
384
<a name="l00357"></a>00357      <span class="keywordflow">if</span> (gap) <span class="comment">// first block GAP-type</span>
 
385
<a name="l00358"></a>00358      {
 
386
<a name="l00359"></a>00359          <span class="keywordflow">if</span> (arg_gap)  <span class="comment">// both blocks GAP-type</span>
 
387
<a name="l00360"></a>00360          {
 
388
<a name="l00361"></a>00361              <a class="code" href="a00110.html#ac654d6319039a86546d235a236fc7cf6">gap_word_t</a> tmp_buf[<a class="code" href="a00110.html#aa5e01dfb650d168f9be0525e042af647">bm::gap_max_buff_len</a> * 3]; <span class="comment">// temporary result</span>
 
389
<a name="l00362"></a>00362              
 
390
<a name="l00363"></a>00363              <span class="keywordflow">for</span> (<a class="code" href="a00060.html" title="Distance metric descriptor, holds metric code and result.">distance_metric_descriptor</a>* it = dmit;it &lt; dmit_end; ++it)
 
391
<a name="l00364"></a>00364              {
 
392
<a name="l00365"></a>00365                  <a class="code" href="a00060.html" title="Distance metric descriptor, holds metric code and result.">distance_metric_descriptor</a>&amp; dmd = *it;
 
393
<a name="l00366"></a>00366                  <span class="keywordflow">if</span> (dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a>)
 
394
<a name="l00367"></a>00367                  {
 
395
<a name="l00368"></a>00368                      <span class="keywordflow">continue</span>;
 
396
<a name="l00369"></a>00369                  }
 
397
<a name="l00370"></a>00370                  res = 0;
 
398
<a name="l00371"></a>00371                  <span class="keywordtype">unsigned</span> dsize = 0;
 
399
<a name="l00372"></a>00372                  <span class="keywordflow">switch</span> (dmd.<a class="code" href="a00060.html#a3ece2ccdb7a6616f06a5a15679ccabb1">metric</a>)
 
400
<a name="l00373"></a>00373                  {
 
401
<a name="l00374"></a>00374                  <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abacb39376469ba778e9a9099ddbae5e7ce" title="(A &amp;amp; B).count()">bm::COUNT_AND</a>:
 
402
<a name="l00375"></a>00375                      dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += <a class="code" href="a00114.html#gafb24a1e2588c5670df6facc537594d9d" title="GAP AND operation test.">gap_operation_any_and</a>(g1, g2);
 
403
<a name="l00376"></a>00376                      <span class="keywordflow">break</span>;
 
404
<a name="l00377"></a>00377                  <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abad0bd2d56c8ebd03f55c01b3cc6faaaeb" title="(A | B).count()">bm::COUNT_OR</a>:
 
405
<a name="l00378"></a>00378                      res = <a class="code" href="a00114.html#gacda280af8910ae5fde37731a3a7a1226" title="GAP OR operation.">gap_operation_or</a>(g1, g2, tmp_buf, dsize);
 
406
<a name="l00379"></a>00379                      <span class="keywordflow">break</span>;
 
407
<a name="l00380"></a>00380                  <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40aba9c101dab8904c0432f72ccce0a207e62" title="(A - B).count()">bm::COUNT_SUB_AB</a>:
 
408
<a name="l00381"></a>00381                      dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += <a class="code" href="a00114.html#gae0b1d4aca0ddfa58d83e4b089a4f35d9" title="GAP SUB operation test.">gap_operation_any_sub</a>(g1, g2); 
 
409
<a name="l00382"></a>00382                      <span class="keywordflow">break</span>;
 
410
<a name="l00383"></a>00383                  <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abafa036fb9d54bc659ed3c9e4185ccf400" title="(B - A).count()">bm::COUNT_SUB_BA</a>:
 
411
<a name="l00384"></a>00384                      dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += <a class="code" href="a00114.html#gae0b1d4aca0ddfa58d83e4b089a4f35d9" title="GAP SUB operation test.">gap_operation_any_sub</a>(g2, g1); 
 
412
<a name="l00385"></a>00385                      <span class="keywordflow">break</span>;
 
413
<a name="l00386"></a>00386                  <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40aba3e4861dde6e1179457ee0d3502ae8061" title="(A ^ B).count()">bm::COUNT_XOR</a>:
 
414
<a name="l00387"></a>00387                     dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += <a class="code" href="a00114.html#gab46833bf0d7813f868a1608f70db12de" title="GAP XOR operation test.">gap_operation_any_xor</a>(g1, g2); 
 
415
<a name="l00388"></a>00388                     <span class="keywordflow">break</span>;
 
416
<a name="l00389"></a>00389                  <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abaac7947d53eb3acf81251ee4130e6a4a2" title="A.count().">bm::COUNT_A</a>:
 
417
<a name="l00390"></a>00390                     res = g1;
 
418
<a name="l00391"></a>00391                     <span class="keywordflow">break</span>;
 
419
<a name="l00392"></a>00392                  <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abac6dbadf2ab9405daa47dc0f10d082516" title="B.count().">bm::COUNT_B</a>:
 
420
<a name="l00393"></a>00393                     res = g2;
 
421
<a name="l00394"></a>00394                     <span class="keywordflow">break</span>;
 
422
<a name="l00395"></a>00395                  } <span class="comment">// switch</span>
 
423
<a name="l00396"></a>00396                 <span class="keywordflow">if</span> (res)
 
424
<a name="l00397"></a>00397                     dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += !<a class="code" href="a00114.html#ga690ff7c8b16e1821a77663b7194267e7" title="Temporary inverts all bits in the GAP buffer.">gap_is_all_zero</a>(res, <a class="code" href="a00110.html#ad0b8714080144ac70197840ff96752b7">bm::gap_max_bits</a>);
 
425
<a name="l00398"></a>00398                                      
 
426
<a name="l00399"></a>00399              } <span class="comment">// for it</span>
 
427
<a name="l00400"></a>00400              
 
428
<a name="l00401"></a>00401              <span class="keywordflow">return</span>;
 
429
<a name="l00402"></a>00402 
 
430
<a name="l00403"></a>00403          }
 
431
<a name="l00404"></a>00404          <span class="keywordflow">else</span> <span class="comment">// first block - GAP, argument - BITSET</span>
 
432
<a name="l00405"></a>00405          {
 
433
<a name="l00406"></a>00406              <span class="keywordflow">for</span> (<a class="code" href="a00060.html" title="Distance metric descriptor, holds metric code and result.">distance_metric_descriptor</a>* it = dmit;it &lt; dmit_end; ++it)
 
434
<a name="l00407"></a>00407              {
 
435
<a name="l00408"></a>00408                  <a class="code" href="a00060.html" title="Distance metric descriptor, holds metric code and result.">distance_metric_descriptor</a>&amp; dmd = *it;
 
436
<a name="l00409"></a>00409                  <span class="keywordflow">if</span> (dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a>)
 
437
<a name="l00410"></a>00410                  {
 
438
<a name="l00411"></a>00411                      <span class="keywordflow">continue</span>;
 
439
<a name="l00412"></a>00412                  }
 
440
<a name="l00413"></a>00413                  
 
441
<a name="l00414"></a>00414                  <span class="keywordflow">switch</span> (dmd.<a class="code" href="a00060.html#a3ece2ccdb7a6616f06a5a15679ccabb1">metric</a>)
 
442
<a name="l00415"></a>00415                  {
 
443
<a name="l00416"></a>00416                  <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abacb39376469ba778e9a9099ddbae5e7ce" title="(A &amp;amp; B).count()">bm::COUNT_AND</a>:
 
444
<a name="l00417"></a>00417                      <span class="keywordflow">if</span> (arg_blk)
 
445
<a name="l00418"></a>00418                         dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += <a class="code" href="a00115.html#gad6e40898b8836ae1923b06a3d028fcaa" title="Bitcount test of bit block AND masked by GAP block.">gap_bitset_and_any</a>(arg_blk, g1);
 
446
<a name="l00419"></a>00419                      <span class="keywordflow">break</span>;
 
447
<a name="l00420"></a>00420                  <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abad0bd2d56c8ebd03f55c01b3cc6faaaeb" title="(A | B).count()">bm::COUNT_OR</a>:
 
448
<a name="l00421"></a>00421                      <span class="keywordflow">if</span> (!arg_blk)
 
449
<a name="l00422"></a>00422                         dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += !<a class="code" href="a00114.html#ga690ff7c8b16e1821a77663b7194267e7" title="Temporary inverts all bits in the GAP buffer.">gap_is_all_zero</a>(g1, <a class="code" href="a00110.html#ad0b8714080144ac70197840ff96752b7">bm::gap_max_bits</a>);
 
450
<a name="l00423"></a>00423                      <span class="keywordflow">else</span>
 
451
<a name="l00424"></a>00424                         dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += <a class="code" href="a00115.html#gad15f1b92c70752cd3b97fa9e0c585f00" title="Compute bitcount test of bit block OR masked by GAP block.">gap_bitset_or_any</a>(arg_blk, g1); 
 
452
<a name="l00425"></a>00425                      <span class="keywordflow">break</span>;
 
453
<a name="l00426"></a>00426                  <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40aba9c101dab8904c0432f72ccce0a207e62" title="(A - B).count()">bm::COUNT_SUB_AB</a>:
 
454
<a name="l00427"></a>00427                      <a class="code" href="a00114.html#ga4862f4dcdcb7c0575e2e2db9e5f2a849" title="GAP block to bitblock conversion.">gap_convert_to_bitset</a>((<a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>*) temp_blk, g1);
 
455
<a name="l00428"></a>00428                      dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += 
 
456
<a name="l00429"></a>00429                        <a class="code" href="a00115.html#ga847d5a84673b284be984f0db583e2723" title="Performs bitblock test of SUB operation.">bit_operation_sub_any</a>((<a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>*)temp_blk, 
 
457
<a name="l00430"></a>00430                           ((<a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>*)temp_blk) + <a class="code" href="a00110.html#a91319dbc0d0e1bf3a3efc4d92bac7972">bm::set_block_size</a>,
 
458
<a name="l00431"></a>00431                            arg_blk);
 
459
<a name="l00432"></a>00432                  
 
460
<a name="l00433"></a>00433                      <span class="keywordflow">break</span>;
 
461
<a name="l00434"></a>00434                  <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abafa036fb9d54bc659ed3c9e4185ccf400" title="(B - A).count()">bm::COUNT_SUB_BA</a>:
 
462
<a name="l00435"></a>00435                      dmd.<a class="code" href="a00060.html#a3ece2ccdb7a6616f06a5a15679ccabb1">metric</a> = <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40aba9c101dab8904c0432f72ccce0a207e62" title="(A - B).count()">bm::COUNT_SUB_AB</a>; <span class="comment">// recursive call to SUB_AB</span>
 
463
<a name="l00436"></a>00436                      <a class="code" href="a00110.html#a24069ced9ea689034ff51246ae707ecc" title="Internal function computes different existense of distance metric.">combine_any_operation_with_block</a>(arg_blk,
 
464
<a name="l00437"></a>00437                                                       arg_gap,
 
465
<a name="l00438"></a>00438                                                       blk,
 
466
<a name="l00439"></a>00439                                                       gap,
 
467
<a name="l00440"></a>00440                                                       temp_blk,
 
468
<a name="l00441"></a>00441                                                       it, it+1);
 
469
<a name="l00442"></a>00442                      dmd.<a class="code" href="a00060.html#a3ece2ccdb7a6616f06a5a15679ccabb1">metric</a> = <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abafa036fb9d54bc659ed3c9e4185ccf400" title="(B - A).count()">bm::COUNT_SUB_BA</a>; <span class="comment">// restore status quo</span>
 
470
<a name="l00443"></a>00443                      <span class="keywordflow">break</span>;
 
471
<a name="l00444"></a>00444                  <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40aba3e4861dde6e1179457ee0d3502ae8061" title="(A ^ B).count()">bm::COUNT_XOR</a>:
 
472
<a name="l00445"></a>00445                      <span class="keywordflow">if</span> (!arg_blk)
 
473
<a name="l00446"></a>00446                         dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += !<a class="code" href="a00114.html#ga690ff7c8b16e1821a77663b7194267e7" title="Temporary inverts all bits in the GAP buffer.">gap_is_all_zero</a>(g1, <a class="code" href="a00110.html#ad0b8714080144ac70197840ff96752b7">bm::gap_max_bits</a>);
 
474
<a name="l00447"></a>00447                      <span class="keywordflow">else</span>
 
475
<a name="l00448"></a>00448                         dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += <a class="code" href="a00115.html#gad0f7ee00f84ea357d55e6a2f507c8918" title="Compute bitcount test of bit block XOR masked by GAP block.">gap_bitset_xor_any</a>(arg_blk, g1);
 
476
<a name="l00449"></a>00449                      <span class="keywordflow">break</span>;
 
477
<a name="l00450"></a>00450                  <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abaac7947d53eb3acf81251ee4130e6a4a2" title="A.count().">bm::COUNT_A</a>:
 
478
<a name="l00451"></a>00451                     <span class="keywordflow">if</span> (g1)
 
479
<a name="l00452"></a>00452                         dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += !<a class="code" href="a00114.html#ga690ff7c8b16e1821a77663b7194267e7" title="Temporary inverts all bits in the GAP buffer.">gap_is_all_zero</a>(g1, <a class="code" href="a00110.html#ad0b8714080144ac70197840ff96752b7">bm::gap_max_bits</a>);
 
480
<a name="l00453"></a>00453                     <span class="keywordflow">break</span>;
 
481
<a name="l00454"></a>00454                  <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abac6dbadf2ab9405daa47dc0f10d082516" title="B.count().">bm::COUNT_B</a>:
 
482
<a name="l00455"></a>00455                     <span class="keywordflow">if</span> (arg_blk)
 
483
<a name="l00456"></a>00456                     {
 
484
<a name="l00457"></a>00457                         dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += 
 
485
<a name="l00458"></a>00458                           !<a class="code" href="a00115.html#gac6cfb9f92e4df6bb4c76f6efb2382860" title="Returns &amp;quot;true&amp;quot; if all bits in the block are 0.">bit_is_all_zero</a>((<a class="code" href="a00110.html#a7176bf7817550ca24cb6612bd8d7957d">bm::wordop_t</a>*)arg_blk, 
 
486
<a name="l00459"></a>00459                                            (<a class="code" href="a00110.html#a7176bf7817550ca24cb6612bd8d7957d">bm::wordop_t</a>*)(arg_blk + <a class="code" href="a00110.html#a91319dbc0d0e1bf3a3efc4d92bac7972">bm::set_block_size</a>));
 
487
<a name="l00460"></a>00460                     }
 
488
<a name="l00461"></a>00461                     <span class="keywordflow">break</span>;
 
489
<a name="l00462"></a>00462                  } <span class="comment">// switch</span>
 
490
<a name="l00463"></a>00463                                      
 
491
<a name="l00464"></a>00464              } <span class="comment">// for it</span>
 
492
<a name="l00465"></a>00465              
 
493
<a name="l00466"></a>00466              <span class="keywordflow">return</span>;
 
494
<a name="l00467"></a>00467          
 
495
<a name="l00468"></a>00468          }
 
496
<a name="l00469"></a>00469      } 
 
497
<a name="l00470"></a>00470      <span class="keywordflow">else</span> <span class="comment">// first block is BITSET-type</span>
 
498
<a name="l00471"></a>00471      {     
 
499
<a name="l00472"></a>00472          <span class="keywordflow">if</span> (arg_gap) <span class="comment">// second argument block is GAP-type</span>
 
500
<a name="l00473"></a>00473          {
 
501
<a name="l00474"></a>00474              <span class="keywordflow">for</span> (<a class="code" href="a00060.html" title="Distance metric descriptor, holds metric code and result.">distance_metric_descriptor</a>* it = dmit;it &lt; dmit_end; ++it)
 
502
<a name="l00475"></a>00475              {
 
503
<a name="l00476"></a>00476                  <a class="code" href="a00060.html" title="Distance metric descriptor, holds metric code and result.">distance_metric_descriptor</a>&amp; dmd = *it;
 
504
<a name="l00477"></a>00477                  <span class="keywordflow">if</span> (dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a>)
 
505
<a name="l00478"></a>00478                  {
 
506
<a name="l00479"></a>00479                      <span class="keywordflow">continue</span>;
 
507
<a name="l00480"></a>00480                  }
 
508
<a name="l00481"></a>00481                  
 
509
<a name="l00482"></a>00482                  <span class="keywordflow">switch</span> (dmd.<a class="code" href="a00060.html#a3ece2ccdb7a6616f06a5a15679ccabb1">metric</a>)
 
510
<a name="l00483"></a>00483                  {
 
511
<a name="l00484"></a>00484                  <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abacb39376469ba778e9a9099ddbae5e7ce" title="(A &amp;amp; B).count()">bm::COUNT_AND</a>:
 
512
<a name="l00485"></a>00485                      <span class="keywordflow">if</span> (blk) 
 
513
<a name="l00486"></a>00486                         dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += <a class="code" href="a00115.html#gad6e40898b8836ae1923b06a3d028fcaa" title="Bitcount test of bit block AND masked by GAP block.">gap_bitset_and_any</a>(blk, g2);                         
 
514
<a name="l00487"></a>00487                      <span class="keywordflow">break</span>;
 
515
<a name="l00488"></a>00488                  <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abad0bd2d56c8ebd03f55c01b3cc6faaaeb" title="(A | B).count()">bm::COUNT_OR</a>:
 
516
<a name="l00489"></a>00489                      <span class="keywordflow">if</span> (!blk)
 
517
<a name="l00490"></a>00490                         dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += !<a class="code" href="a00114.html#ga690ff7c8b16e1821a77663b7194267e7" title="Temporary inverts all bits in the GAP buffer.">gap_is_all_zero</a>(g2, <a class="code" href="a00110.html#ad0b8714080144ac70197840ff96752b7">bm::gap_max_bits</a>);
 
518
<a name="l00491"></a>00491                      <span class="keywordflow">else</span>
 
519
<a name="l00492"></a>00492                         dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += <a class="code" href="a00115.html#gad15f1b92c70752cd3b97fa9e0c585f00" title="Compute bitcount test of bit block OR masked by GAP block.">gap_bitset_or_any</a>(blk, g2);
 
520
<a name="l00493"></a>00493                      <span class="keywordflow">break</span>;
 
521
<a name="l00494"></a>00494                  <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40aba9c101dab8904c0432f72ccce0a207e62" title="(A - B).count()">bm::COUNT_SUB_AB</a>:
 
522
<a name="l00495"></a>00495                      <span class="keywordflow">if</span> (blk)
 
523
<a name="l00496"></a>00496                         dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += <a class="code" href="a00115.html#gaab7c711122e8f189555dffd83a21111c" title="Compute bitcount test of bit block SUB masked by GAP block.">gap_bitset_sub_any</a>(blk, g2);
 
524
<a name="l00497"></a>00497                      <span class="keywordflow">break</span>;
 
525
<a name="l00498"></a>00498                  <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abafa036fb9d54bc659ed3c9e4185ccf400" title="(B - A).count()">bm::COUNT_SUB_BA</a>:
 
526
<a name="l00499"></a>00499                      dmd.<a class="code" href="a00060.html#a3ece2ccdb7a6616f06a5a15679ccabb1">metric</a> = <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40aba9c101dab8904c0432f72ccce0a207e62" title="(A - B).count()">bm::COUNT_SUB_AB</a>; <span class="comment">// recursive call to SUB_AB</span>
 
527
<a name="l00500"></a>00500                      <a class="code" href="a00110.html#a24069ced9ea689034ff51246ae707ecc" title="Internal function computes different existense of distance metric.">combine_any_operation_with_block</a>(arg_blk,
 
528
<a name="l00501"></a>00501                                                       arg_gap,
 
529
<a name="l00502"></a>00502                                                       blk,
 
530
<a name="l00503"></a>00503                                                       gap,
 
531
<a name="l00504"></a>00504                                                       temp_blk,
 
532
<a name="l00505"></a>00505                                                       it, it+1);
 
533
<a name="l00506"></a>00506                      dmd.<a class="code" href="a00060.html#a3ece2ccdb7a6616f06a5a15679ccabb1">metric</a> = <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abafa036fb9d54bc659ed3c9e4185ccf400" title="(B - A).count()">bm::COUNT_SUB_BA</a>; <span class="comment">// restore status quo</span>
 
534
<a name="l00507"></a>00507                      <span class="keywordflow">break</span>;
 
535
<a name="l00508"></a>00508                  <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40aba3e4861dde6e1179457ee0d3502ae8061" title="(A ^ B).count()">bm::COUNT_XOR</a>:
 
536
<a name="l00509"></a>00509                      <span class="keywordflow">if</span> (!blk)
 
537
<a name="l00510"></a>00510                         dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += !<a class="code" href="a00114.html#ga690ff7c8b16e1821a77663b7194267e7" title="Temporary inverts all bits in the GAP buffer.">gap_is_all_zero</a>(g2, <a class="code" href="a00110.html#ad0b8714080144ac70197840ff96752b7">bm::gap_max_bits</a>);
 
538
<a name="l00511"></a>00511                      <span class="keywordflow">else</span>
 
539
<a name="l00512"></a>00512                         dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += <a class="code" href="a00115.html#gad0f7ee00f84ea357d55e6a2f507c8918" title="Compute bitcount test of bit block XOR masked by GAP block.">gap_bitset_xor_any</a>(blk, g2); 
 
540
<a name="l00513"></a>00513                     <span class="keywordflow">break</span>;
 
541
<a name="l00514"></a>00514                  <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abaac7947d53eb3acf81251ee4130e6a4a2" title="A.count().">bm::COUNT_A</a>:
 
542
<a name="l00515"></a>00515                     <span class="keywordflow">if</span> (blk)
 
543
<a name="l00516"></a>00516                     {
 
544
<a name="l00517"></a>00517                         dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a>+=
 
545
<a name="l00518"></a>00518                             !<a class="code" href="a00115.html#gac6cfb9f92e4df6bb4c76f6efb2382860" title="Returns &amp;quot;true&amp;quot; if all bits in the block are 0.">bit_is_all_zero</a>((<a class="code" href="a00110.html#a7176bf7817550ca24cb6612bd8d7957d">bm::wordop_t</a>*)blk, 
 
546
<a name="l00519"></a>00519                                               (<a class="code" href="a00110.html#a7176bf7817550ca24cb6612bd8d7957d">bm::wordop_t</a>*)blk + <a class="code" href="a00110.html#a91319dbc0d0e1bf3a3efc4d92bac7972">bm::set_block_size</a>);
 
547
<a name="l00520"></a>00520                     }
 
548
<a name="l00521"></a>00521                     <span class="keywordflow">break</span>;
 
549
<a name="l00522"></a>00522                  <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abac6dbadf2ab9405daa47dc0f10d082516" title="B.count().">bm::COUNT_B</a>:
 
550
<a name="l00523"></a>00523                     <span class="keywordflow">if</span> (g2)
 
551
<a name="l00524"></a>00524                         dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += !<a class="code" href="a00114.html#ga690ff7c8b16e1821a77663b7194267e7" title="Temporary inverts all bits in the GAP buffer.">gap_is_all_zero</a>(g2, <a class="code" href="a00110.html#ad0b8714080144ac70197840ff96752b7">bm::gap_max_bits</a>);
 
552
<a name="l00525"></a>00525                     <span class="keywordflow">break</span>;
 
553
<a name="l00526"></a>00526                  } <span class="comment">// switch</span>
 
554
<a name="l00527"></a>00527                                      
 
555
<a name="l00528"></a>00528              } <span class="comment">// for it</span>
 
556
<a name="l00529"></a>00529              
 
557
<a name="l00530"></a>00530              <span class="keywordflow">return</span>;
 
558
<a name="l00531"></a>00531          }
 
559
<a name="l00532"></a>00532      }
 
560
<a name="l00533"></a>00533 
 
561
<a name="l00534"></a>00534      <span class="comment">// --------------------------------------------</span>
 
562
<a name="l00535"></a>00535      <span class="comment">//</span>
 
563
<a name="l00536"></a>00536      <span class="comment">// Here we combine two plain bitblocks </span>
 
564
<a name="l00537"></a>00537 
 
565
<a name="l00538"></a>00538      <span class="keyword">const</span> <a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>* blk_end;
 
566
<a name="l00539"></a>00539      <span class="keyword">const</span> <a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>* arg_end;
 
567
<a name="l00540"></a>00540 
 
568
<a name="l00541"></a>00541      blk_end = blk + (<a class="code" href="a00110.html#a91319dbc0d0e1bf3a3efc4d92bac7972">bm::set_block_size</a>);
 
569
<a name="l00542"></a>00542      arg_end = arg_blk + (<a class="code" href="a00110.html#a91319dbc0d0e1bf3a3efc4d92bac7972">bm::set_block_size</a>);
 
570
<a name="l00543"></a>00543 
 
571
<a name="l00544"></a>00544      <span class="keywordflow">for</span> (<a class="code" href="a00060.html" title="Distance metric descriptor, holds metric code and result.">distance_metric_descriptor</a>* it = dmit; it &lt; dmit_end; ++it)
 
572
<a name="l00545"></a>00545      {
 
573
<a name="l00546"></a>00546         <a class="code" href="a00060.html" title="Distance metric descriptor, holds metric code and result.">distance_metric_descriptor</a>&amp; dmd = *it;
 
574
<a name="l00547"></a>00547         <span class="keywordflow">if</span> (dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a>)
 
575
<a name="l00548"></a>00548         {
 
576
<a name="l00549"></a>00549             <span class="keywordflow">continue</span>;
 
577
<a name="l00550"></a>00550         }
 
578
<a name="l00551"></a>00551 
 
579
<a name="l00552"></a>00552         <span class="keywordflow">switch</span> (dmd.<a class="code" href="a00060.html#a3ece2ccdb7a6616f06a5a15679ccabb1">metric</a>)
 
580
<a name="l00553"></a>00553         {
 
581
<a name="l00554"></a>00554         <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abacb39376469ba778e9a9099ddbae5e7ce" title="(A &amp;amp; B).count()">bm::COUNT_AND</a>:
 
582
<a name="l00555"></a>00555             dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += 
 
583
<a name="l00556"></a>00556             <a class="code" href="a00115.html#ga0e7995f7d6c791f6ff27a8dd21d324e5" title="Performs bitblock AND operation test.">bit_operation_and_any</a>(blk, blk_end, arg_blk);
 
584
<a name="l00557"></a>00557             <span class="keywordflow">break</span>;
 
585
<a name="l00558"></a>00558         <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abad0bd2d56c8ebd03f55c01b3cc6faaaeb" title="(A | B).count()">bm::COUNT_OR</a>:
 
586
<a name="l00559"></a>00559             dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += 
 
587
<a name="l00560"></a>00560             <a class="code" href="a00115.html#ga6d26742bdc373074474a6932eab4f388" title="Performs bitblock OR operation test.">bit_operation_or_any</a>(blk, blk_end, arg_blk);
 
588
<a name="l00561"></a>00561             <span class="keywordflow">break</span>;
 
589
<a name="l00562"></a>00562         <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40aba9c101dab8904c0432f72ccce0a207e62" title="(A - B).count()">bm::COUNT_SUB_AB</a>:
 
590
<a name="l00563"></a>00563             dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += 
 
591
<a name="l00564"></a>00564             <a class="code" href="a00115.html#ga847d5a84673b284be984f0db583e2723" title="Performs bitblock test of SUB operation.">bit_operation_sub_any</a>(blk, blk_end, arg_blk);
 
592
<a name="l00565"></a>00565             <span class="keywordflow">break</span>;
 
593
<a name="l00566"></a>00566         <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abafa036fb9d54bc659ed3c9e4185ccf400" title="(B - A).count()">bm::COUNT_SUB_BA</a>:
 
594
<a name="l00567"></a>00567             dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += 
 
595
<a name="l00568"></a>00568             <a class="code" href="a00115.html#ga847d5a84673b284be984f0db583e2723" title="Performs bitblock test of SUB operation.">bit_operation_sub_any</a>(arg_blk, arg_end, blk);
 
596
<a name="l00569"></a>00569             <span class="keywordflow">break</span>;
 
597
<a name="l00570"></a>00570         <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40aba3e4861dde6e1179457ee0d3502ae8061" title="(A ^ B).count()">bm::COUNT_XOR</a>:
 
598
<a name="l00571"></a>00571             dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += 
 
599
<a name="l00572"></a>00572             <a class="code" href="a00115.html#gaa86561b6d11c3f01dd772563c692f732" title="Performs bitblock XOR operation test.">bit_operation_xor_any</a>(blk, blk_end, arg_blk);
 
600
<a name="l00573"></a>00573             <span class="keywordflow">break</span>;
 
601
<a name="l00574"></a>00574         <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abaac7947d53eb3acf81251ee4130e6a4a2" title="A.count().">bm::COUNT_A</a>:
 
602
<a name="l00575"></a>00575             <span class="keywordflow">if</span> (blk)
 
603
<a name="l00576"></a>00576                 dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += !<a class="code" href="a00115.html#gac6cfb9f92e4df6bb4c76f6efb2382860" title="Returns &amp;quot;true&amp;quot; if all bits in the block are 0.">bit_is_all_zero</a>((<a class="code" href="a00110.html#a7176bf7817550ca24cb6612bd8d7957d">bm::wordop_t</a>*)blk, 
 
604
<a name="l00577"></a>00577                                                (<a class="code" href="a00110.html#a7176bf7817550ca24cb6612bd8d7957d">bm::wordop_t</a>*)blk_end);
 
605
<a name="l00578"></a>00578             <span class="keywordflow">break</span>;
 
606
<a name="l00579"></a>00579         <span class="keywordflow">case</span> <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abac6dbadf2ab9405daa47dc0f10d082516" title="B.count().">bm::COUNT_B</a>:
 
607
<a name="l00580"></a>00580             <span class="keywordflow">if</span> (arg_blk)
 
608
<a name="l00581"></a>00581                 dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a> += !<a class="code" href="a00115.html#gac6cfb9f92e4df6bb4c76f6efb2382860" title="Returns &amp;quot;true&amp;quot; if all bits in the block are 0.">bit_is_all_zero</a>((<a class="code" href="a00110.html#a7176bf7817550ca24cb6612bd8d7957d">bm::wordop_t</a>*)arg_blk, 
 
609
<a name="l00582"></a>00582                                                (<a class="code" href="a00110.html#a7176bf7817550ca24cb6612bd8d7957d">bm::wordop_t</a>*)arg_end);
 
610
<a name="l00583"></a>00583             <span class="keywordflow">break</span>;
 
611
<a name="l00584"></a>00584         } <span class="comment">// switch</span>
 
612
<a name="l00585"></a>00585 
 
613
<a name="l00586"></a>00586      } <span class="comment">// for it</span>
 
614
<a name="l00587"></a>00587 }
 
615
<a name="l00588"></a>00588 
 
616
<a name="l00589"></a>00589 
 
617
<a name="l00590"></a>00590 <span class="comment"></span>
 
618
<a name="l00591"></a>00591 <span class="comment">/*!</span>
 
619
<a name="l00592"></a>00592 <span class="comment">    Convenience internal function to compute combine count for one metric</span>
 
620
<a name="l00593"></a>00593 <span class="comment">    \internal</span>
 
621
<a name="l00594"></a>00594 <span class="comment">    \ingroup  distance</span>
 
622
<a name="l00595"></a>00595 <span class="comment">*/</span>
 
623
<a name="l00596"></a>00596 <span class="keyword">inline</span>
 
624
<a name="l00597"></a><a class="code" href="a00110.html#a2f81b8ce3d389973b4f867b0fcc98e7a">00597</a> <span class="keywordtype">unsigned</span> <a class="code" href="a00110.html#abecd5b24d5e394fd46a9db514cfa659a" title="Internal function computes different distance metrics.">combine_count_operation_with_block</a>(<span class="keyword">const</span> <a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>* blk,
 
625
<a name="l00598"></a>00598                                             <span class="keywordtype">unsigned</span> gap,
 
626
<a name="l00599"></a>00599                                             <span class="keyword">const</span> <a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>* arg_blk,
 
627
<a name="l00600"></a>00600                                             <span class="keywordtype">int</span> arg_gap,
 
628
<a name="l00601"></a>00601                                             <a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>* temp_blk,
 
629
<a name="l00602"></a>00602                                             <a class="code" href="a00120.html#gac38d64c8b27b652413a664cddd4d40ab" title="Distance metrics codes defined for vectors A and B.">distance_metric</a> metric)
 
630
<a name="l00603"></a>00603 {
 
631
<a name="l00604"></a>00604     <a class="code" href="a00060.html" title="Distance metric descriptor, holds metric code and result.">distance_metric_descriptor</a> dmd(metric);
 
632
<a name="l00605"></a>00605     <a class="code" href="a00110.html#abecd5b24d5e394fd46a9db514cfa659a" title="Internal function computes different distance metrics.">combine_count_operation_with_block</a>(blk, gap, 
 
633
<a name="l00606"></a>00606                                        arg_blk, arg_gap, 
 
634
<a name="l00607"></a>00607                                        temp_blk,
 
635
<a name="l00608"></a>00608                                        &amp;dmd, &amp;dmd+1);
 
636
<a name="l00609"></a>00609     <span class="keywordflow">return</span> dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a>;
 
637
<a name="l00610"></a>00610 }
 
638
<a name="l00611"></a>00611 
 
639
<a name="l00612"></a>00612 <span class="comment"></span>
 
640
<a name="l00613"></a>00613 <span class="comment">/*!</span>
 
641
<a name="l00614"></a>00614 <span class="comment">    Convenience internal function to compute combine any for one metric</span>
 
642
<a name="l00615"></a>00615 <span class="comment">    \internal</span>
 
643
<a name="l00616"></a>00616 <span class="comment">    \ingroup  distance</span>
 
644
<a name="l00617"></a>00617 <span class="comment">*/</span>
 
645
<a name="l00618"></a>00618 <span class="keyword">inline</span>
 
646
<a name="l00619"></a><a class="code" href="a00110.html#a093f2dadce40f42a184928c9d1456592">00619</a> <span class="keywordtype">unsigned</span> <a class="code" href="a00110.html#a24069ced9ea689034ff51246ae707ecc" title="Internal function computes different existense of distance metric.">combine_any_operation_with_block</a>(<span class="keyword">const</span> <a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>* blk,
 
647
<a name="l00620"></a>00620                                           <span class="keywordtype">unsigned</span> gap,
 
648
<a name="l00621"></a>00621                                           <span class="keyword">const</span> <a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>* arg_blk,
 
649
<a name="l00622"></a>00622                                           <span class="keywordtype">int</span> arg_gap,
 
650
<a name="l00623"></a>00623                                           <a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>* temp_blk,
 
651
<a name="l00624"></a>00624                                           <a class="code" href="a00120.html#gac38d64c8b27b652413a664cddd4d40ab" title="Distance metrics codes defined for vectors A and B.">distance_metric</a> metric)
 
652
<a name="l00625"></a>00625 {
 
653
<a name="l00626"></a>00626     <a class="code" href="a00060.html" title="Distance metric descriptor, holds metric code and result.">distance_metric_descriptor</a> dmd(metric);
 
654
<a name="l00627"></a>00627     <a class="code" href="a00110.html#a24069ced9ea689034ff51246ae707ecc" title="Internal function computes different existense of distance metric.">combine_any_operation_with_block</a>(blk, gap, 
 
655
<a name="l00628"></a>00628                                      arg_blk, arg_gap, 
 
656
<a name="l00629"></a>00629                                      temp_blk,
 
657
<a name="l00630"></a>00630                                      &amp;dmd, &amp;dmd+1);
 
658
<a name="l00631"></a>00631     <span class="keywordflow">return</span> dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a>;
 
659
<a name="l00632"></a>00632 }
 
660
<a name="l00633"></a>00633 <span class="comment"></span>
 
661
<a name="l00634"></a>00634 <span class="comment">/*!</span>
 
662
<a name="l00635"></a>00635 <span class="comment">    \brief Staging function for distance operation</span>
 
663
<a name="l00636"></a>00636 <span class="comment"></span>
 
664
<a name="l00637"></a>00637 <span class="comment">    \return temp block allocated (or NULL)</span>
 
665
<a name="l00638"></a>00638 <span class="comment"></span>
 
666
<a name="l00639"></a>00639 <span class="comment">    \internal</span>
 
667
<a name="l00640"></a>00640 <span class="comment">*/</span>
 
668
<a name="l00641"></a>00641 <span class="keyword">template</span>&lt;<span class="keyword">class</span> BV&gt;
 
669
<a name="l00642"></a><a class="code" href="a00110.html#ad47cf2dce876dcbc25aef4c7a222c66f">00642</a> <a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>* <a class="code" href="a00110.html#ad47cf2dce876dcbc25aef4c7a222c66f" title="Staging function for distance operation.">distance_stage</a>(<span class="keyword">const</span> BV&amp;                         bv1,
 
670
<a name="l00643"></a>00643                            <span class="keyword">const</span> <a class="code" href="a00060.html" title="Distance metric descriptor, holds metric code and result.">distance_metric_descriptor</a>* dmit,
 
671
<a name="l00644"></a>00644                            <span class="keyword">const</span> <a class="code" href="a00060.html" title="Distance metric descriptor, holds metric code and result.">distance_metric_descriptor</a>* dmit_end,
 
672
<a name="l00645"></a>00645                            <span class="keywordtype">bool</span>*                             is_all_and)
 
673
<a name="l00646"></a>00646 {
 
674
<a name="l00647"></a>00647     <a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>* temp_blk = 0;
 
675
<a name="l00648"></a>00648     <span class="keywordflow">for</span> (<span class="keyword">const</span> <a class="code" href="a00060.html" title="Distance metric descriptor, holds metric code and result.">distance_metric_descriptor</a>* it = dmit; it &lt; dmit_end; ++it)
 
676
<a name="l00649"></a>00649     {
 
677
<a name="l00650"></a>00650         <span class="comment">// allocate temp block when necessary</span>
 
678
<a name="l00651"></a>00651         <span class="keywordflow">if</span> (temp_blk == 0)
 
679
<a name="l00652"></a>00652         {
 
680
<a name="l00653"></a>00653             <span class="keywordflow">if</span> (it-&gt;metric == <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40aba9c101dab8904c0432f72ccce0a207e62" title="(A - B).count()">bm::COUNT_SUB_AB</a> || 
 
681
<a name="l00654"></a>00654                 it-&gt;metric == <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abafa036fb9d54bc659ed3c9e4185ccf400" title="(B - A).count()">bm::COUNT_SUB_BA</a>)
 
682
<a name="l00655"></a>00655             {
 
683
<a name="l00656"></a>00656                 temp_blk = bv1.allocate_tempblock();
 
684
<a name="l00657"></a>00657             }
 
685
<a name="l00658"></a>00658         }
 
686
<a name="l00659"></a>00659         <span class="keywordflow">if</span> (it-&gt;metric != <a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abacb39376469ba778e9a9099ddbae5e7ce" title="(A &amp;amp; B).count()">bm::COUNT_AND</a>)
 
687
<a name="l00660"></a>00660         {
 
688
<a name="l00661"></a>00661             *is_all_and = <span class="keyword">false</span>;
 
689
<a name="l00662"></a>00662         } 
 
690
<a name="l00663"></a>00663     } <span class="comment">// for</span>
 
691
<a name="l00664"></a>00664     <span class="keywordflow">return</span> temp_blk;
 
692
<a name="l00665"></a>00665 }
 
693
<a name="l00666"></a>00666 <span class="comment"></span>
 
694
<a name="l00667"></a>00667 <span class="comment">/*!</span>
 
695
<a name="l00668"></a>00668 <span class="comment">    \brief Distance computing template function.</span>
 
696
<a name="l00669"></a>00669 <span class="comment"></span>
 
697
<a name="l00670"></a>00670 <span class="comment">    Function receives two bitvectors and an array of distance metrics</span>
 
698
<a name="l00671"></a>00671 <span class="comment">    (metrics pipeline). Function computes all metrics saves result into</span>
 
699
<a name="l00672"></a>00672 <span class="comment">    corresponding pipeline results (distance_metric_descriptor::result)</span>
 
700
<a name="l00673"></a>00673 <span class="comment">    An important detail is that function reuses metric descriptors, </span>
 
701
<a name="l00674"></a>00674 <span class="comment">    incrementing received values. It allows you to accumulate results </span>
 
702
<a name="l00675"></a>00675 <span class="comment">    from different calls in the pipeline.</span>
 
703
<a name="l00676"></a>00676 <span class="comment">    </span>
 
704
<a name="l00677"></a>00677 <span class="comment">    \param bv1      - argument bitvector 1 (A)</span>
 
705
<a name="l00678"></a>00678 <span class="comment">    \param bv2      - argument bitvector 2 (B)</span>
 
706
<a name="l00679"></a>00679 <span class="comment">    \param dmit     - pointer to first element of metric descriptors array</span>
 
707
<a name="l00680"></a>00680 <span class="comment">                      Input-Output parameter, receives metric code as input,</span>
 
708
<a name="l00681"></a>00681 <span class="comment">                      computation is added to &quot;result&quot; field</span>
 
709
<a name="l00682"></a>00682 <span class="comment">    \param dmit_end - pointer to (last+1) element of metric descriptors array</span>
 
710
<a name="l00683"></a>00683 <span class="comment">    \ingroup  distance</span>
 
711
<a name="l00684"></a>00684 <span class="comment">    </span>
 
712
<a name="l00685"></a>00685 <span class="comment">*/</span>
 
713
<a name="l00686"></a>00686 
 
714
<a name="l00687"></a>00687 <span class="keyword">template</span>&lt;<span class="keyword">class</span> BV&gt;
 
715
<a name="l00688"></a><a class="code" href="a00120.html#ga815fef76f02576ab9ab58de0a45d8a4b">00688</a> <span class="keywordtype">void</span> <a class="code" href="a00120.html#ga815fef76f02576ab9ab58de0a45d8a4b" title="Distance computing template function.">distance_operation</a>(<span class="keyword">const</span> BV&amp; bv1, 
 
716
<a name="l00689"></a>00689                         <span class="keyword">const</span> BV&amp; bv2, 
 
717
<a name="l00690"></a>00690                         <a class="code" href="a00060.html" title="Distance metric descriptor, holds metric code and result.">distance_metric_descriptor</a>* dmit,
 
718
<a name="l00691"></a>00691                         <a class="code" href="a00060.html" title="Distance metric descriptor, holds metric code and result.">distance_metric_descriptor</a>* dmit_end)
 
719
<a name="l00692"></a>00692 {
 
720
<a name="l00693"></a>00693     <span class="keyword">const</span> <span class="keyword">typename</span> BV::blocks_manager_type&amp; bman1 = bv1.get_blocks_manager();
 
721
<a name="l00694"></a>00694     <span class="keyword">const</span> <span class="keyword">typename</span> BV::blocks_manager_type&amp; bman2 = bv2.get_blocks_manager();
 
722
<a name="l00695"></a>00695 
 
723
<a name="l00696"></a>00696     <span class="keywordtype">bool</span> is_all_and = <span class="keyword">true</span>; <span class="comment">// flag is distance operation is just COUNT_AND</span>
 
724
<a name="l00697"></a>00697     <a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>* temp_blk = <a class="code" href="a00110.html#ad47cf2dce876dcbc25aef4c7a222c66f" title="Staging function for distance operation.">distance_stage</a>(bv1, dmit, dmit_end, &amp;is_all_and);
 
725
<a name="l00698"></a>00698 
 
726
<a name="l00699"></a>00699     <a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>*** blk_root = bman1.get_rootblock();
 
727
<a name="l00700"></a>00700     <span class="keywordtype">unsigned</span> block_idx = 0;
 
728
<a name="l00701"></a>00701     <span class="keywordtype">unsigned</span> i, j;
 
729
<a name="l00702"></a>00702     
 
730
<a name="l00703"></a>00703     <span class="keyword">const</span> <a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>* blk;
 
731
<a name="l00704"></a>00704     <span class="keyword">const</span> <a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>* arg_blk;
 
732
<a name="l00705"></a>00705     <span class="keywordtype">bool</span>  blk_gap;
 
733
<a name="l00706"></a>00706     <span class="keywordtype">bool</span>  arg_gap;
 
734
<a name="l00707"></a>00707 
 
735
<a name="l00708"></a>00708     <a class="code" href="a00089.html#a7e6f87ba3230dece2125af5c32e84b05">BM_SET_MMX_GUARD</a>
 
736
<a name="l00709"></a>00709 
 
737
<a name="l00710"></a>00710     <span class="keywordtype">unsigned</span> effective_top_block_size = bman1.effective_top_block_size();
 
738
<a name="l00711"></a>00711     <span class="keywordtype">unsigned</span> ebs2 = bman2.effective_top_block_size();
 
739
<a name="l00712"></a>00712     <span class="keywordflow">if</span> (ebs2 &gt; effective_top_block_size)
 
740
<a name="l00713"></a>00713         effective_top_block_size = ebs2;
 
741
<a name="l00714"></a>00714 
 
742
<a name="l00715"></a>00715     <span class="keywordflow">for</span> (i = 0; i &lt; effective_top_block_size; ++i)
 
743
<a name="l00716"></a>00716     {
 
744
<a name="l00717"></a>00717         <a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>** blk_blk = blk_root[i];
 
745
<a name="l00718"></a>00718 
 
746
<a name="l00719"></a>00719         <span class="keywordflow">if</span> (blk_blk == 0) <span class="comment">// not allocated</span>
 
747
<a name="l00720"></a>00720         {
 
748
<a name="l00721"></a>00721             <span class="comment">// AND operation requested - we can skip this portion here </span>
 
749
<a name="l00722"></a>00722             <span class="keywordflow">if</span> (is_all_and)
 
750
<a name="l00723"></a>00723             {
 
751
<a name="l00724"></a>00724                 block_idx += <a class="code" href="a00110.html#a40ad34d6c46a2fb20ba2baa7f95d80b4">bm::set_array_size</a>;
 
752
<a name="l00725"></a>00725                 <span class="keywordflow">continue</span>;
 
753
<a name="l00726"></a>00726             }
 
754
<a name="l00727"></a>00727             <span class="keyword">const</span> <a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>* <span class="keyword">const</span>* bvbb = bman2.get_topblock(i);
 
755
<a name="l00728"></a>00728             <span class="keywordflow">if</span> (bvbb == 0) 
 
756
<a name="l00729"></a>00729             {
 
757
<a name="l00730"></a>00730                 block_idx += <a class="code" href="a00110.html#a40ad34d6c46a2fb20ba2baa7f95d80b4">bm::set_array_size</a>;
 
758
<a name="l00731"></a>00731                 <span class="keywordflow">continue</span>;
 
759
<a name="l00732"></a>00732             }
 
760
<a name="l00733"></a>00733 
 
761
<a name="l00734"></a>00734             blk = 0;
 
762
<a name="l00735"></a>00735             blk_gap = <span class="keyword">false</span>;
 
763
<a name="l00736"></a>00736 
 
764
<a name="l00737"></a>00737             <span class="keywordflow">for</span> (j = 0; j &lt; <a class="code" href="a00110.html#a40ad34d6c46a2fb20ba2baa7f95d80b4">bm::set_array_size</a>; ++j,++block_idx)
 
765
<a name="l00738"></a>00738             {                
 
766
<a name="l00739"></a>00739                 arg_blk = bman2.get_block(i, j);
 
767
<a name="l00740"></a>00740                 arg_gap = <a class="code" href="a00089.html#a862d6f92b4de3ddb94fd367a800512eb">BM_IS_GAP</a>(bman2, arg_blk, block_idx);
 
768
<a name="l00741"></a>00741 
 
769
<a name="l00742"></a>00742                 <span class="keywordflow">if</span> (!arg_blk) 
 
770
<a name="l00743"></a>00743                     <span class="keywordflow">continue</span>;
 
771
<a name="l00744"></a>00744                 <a class="code" href="a00110.html#abecd5b24d5e394fd46a9db514cfa659a" title="Internal function computes different distance metrics.">combine_count_operation_with_block</a>(blk, blk_gap,
 
772
<a name="l00745"></a>00745                                                    arg_blk, arg_gap,
 
773
<a name="l00746"></a>00746                                                    temp_blk,
 
774
<a name="l00747"></a>00747                                                    dmit, dmit_end);
 
775
<a name="l00748"></a>00748             } <span class="comment">// for j</span>
 
776
<a name="l00749"></a>00749             <span class="keywordflow">continue</span>;
 
777
<a name="l00750"></a>00750         }
 
778
<a name="l00751"></a>00751 
 
779
<a name="l00752"></a>00752         <span class="keywordflow">for</span> (j = 0; j &lt; <a class="code" href="a00110.html#a40ad34d6c46a2fb20ba2baa7f95d80b4">bm::set_array_size</a>; ++j, ++block_idx)
 
780
<a name="l00753"></a>00753         {
 
781
<a name="l00754"></a>00754             blk = blk_blk[j];
 
782
<a name="l00755"></a>00755             <span class="keywordflow">if</span> (blk == 0 &amp;&amp; is_all_and)
 
783
<a name="l00756"></a>00756                 <span class="keywordflow">continue</span>;
 
784
<a name="l00757"></a>00757 
 
785
<a name="l00758"></a>00758             arg_blk = bman2.get_block(i, j);
 
786
<a name="l00759"></a>00759 
 
787
<a name="l00760"></a>00760             <span class="keywordflow">if</span> (blk == 0 &amp;&amp; arg_blk == 0)
 
788
<a name="l00761"></a>00761                 <span class="keywordflow">continue</span>;
 
789
<a name="l00762"></a>00762                 
 
790
<a name="l00763"></a>00763             arg_gap = <a class="code" href="a00089.html#a862d6f92b4de3ddb94fd367a800512eb">BM_IS_GAP</a>(bman2, arg_blk, block_idx);
 
791
<a name="l00764"></a>00764             blk_gap = <a class="code" href="a00089.html#a862d6f92b4de3ddb94fd367a800512eb">BM_IS_GAP</a>(bman1, blk, block_idx);
 
792
<a name="l00765"></a>00765             
 
793
<a name="l00766"></a>00766             <a class="code" href="a00110.html#abecd5b24d5e394fd46a9db514cfa659a" title="Internal function computes different distance metrics.">combine_count_operation_with_block</a>(blk, blk_gap,
 
794
<a name="l00767"></a>00767                                                arg_blk, arg_gap,
 
795
<a name="l00768"></a>00768                                                temp_blk,
 
796
<a name="l00769"></a>00769                                                dmit, dmit_end);
 
797
<a name="l00770"></a>00770             
 
798
<a name="l00771"></a>00771 
 
799
<a name="l00772"></a>00772         } <span class="comment">// for j</span>
 
800
<a name="l00773"></a>00773 
 
801
<a name="l00774"></a>00774     } <span class="comment">// for i</span>
 
802
<a name="l00775"></a>00775     
 
803
<a name="l00776"></a>00776     <span class="keywordflow">if</span> (temp_blk)
 
804
<a name="l00777"></a>00777     {
 
805
<a name="l00778"></a>00778         bv1.free_tempblock(temp_blk);
 
806
<a name="l00779"></a>00779     }
 
807
<a name="l00780"></a>00780 
 
808
<a name="l00781"></a>00781 }
 
809
<a name="l00782"></a>00782 
 
810
<a name="l00783"></a>00783 
 
811
<a name="l00784"></a>00784 <span class="comment"></span>
 
812
<a name="l00785"></a>00785 <span class="comment">/*!</span>
 
813
<a name="l00786"></a>00786 <span class="comment">    \brief Distance screening template function.</span>
 
814
<a name="l00787"></a>00787 <span class="comment"></span>
 
815
<a name="l00788"></a>00788 <span class="comment">    Function receives two bitvectors and an array of distance metrics</span>
 
816
<a name="l00789"></a>00789 <span class="comment">    (metrics pipeline). Function computes possybility of a metric(any bit) </span>
 
817
<a name="l00790"></a>00790 <span class="comment">    saves result into corresponding pipeline results </span>
 
818
<a name="l00791"></a>00791 <span class="comment">    (distance_metric_descriptor::result)</span>
 
819
<a name="l00792"></a>00792 <span class="comment">    An important detail is that function reuses metric descriptors, </span>
 
820
<a name="l00793"></a>00793 <span class="comment">    incrementing received values. It allows you to accumulate results </span>
 
821
<a name="l00794"></a>00794 <span class="comment">    from different calls in the pipeline.</span>
 
822
<a name="l00795"></a>00795 <span class="comment">    </span>
 
823
<a name="l00796"></a>00796 <span class="comment">    \param bv1      - argument bitvector 1 (A)</span>
 
824
<a name="l00797"></a>00797 <span class="comment">    \param bv2      - argument bitvector 2 (B)</span>
 
825
<a name="l00798"></a>00798 <span class="comment">    \param dmit     - pointer to first element of metric descriptors array</span>
 
826
<a name="l00799"></a>00799 <span class="comment">                      Input-Output parameter, receives metric code as input,</span>
 
827
<a name="l00800"></a>00800 <span class="comment">                      computation is added to &quot;result&quot; field</span>
 
828
<a name="l00801"></a>00801 <span class="comment">    \param dmit_end - pointer to (last+1) element of metric descriptors array</span>
 
829
<a name="l00802"></a>00802 <span class="comment">    \ingroup  distance</span>
 
830
<a name="l00803"></a>00803 <span class="comment">    </span>
 
831
<a name="l00804"></a>00804 <span class="comment">*/</span>
 
832
<a name="l00805"></a>00805 
 
833
<a name="l00806"></a>00806 <span class="keyword">template</span>&lt;<span class="keyword">class</span> BV&gt;
 
834
<a name="l00807"></a><a class="code" href="a00120.html#gaa66525fd7a3f823d73678252a235982e">00807</a> <span class="keywordtype">void</span> <a class="code" href="a00120.html#gaa66525fd7a3f823d73678252a235982e" title="Distance screening template function.">distance_operation_any</a>(<span class="keyword">const</span> BV&amp; bv1, 
 
835
<a name="l00808"></a>00808                             <span class="keyword">const</span> BV&amp; bv2, 
 
836
<a name="l00809"></a>00809                             <a class="code" href="a00060.html" title="Distance metric descriptor, holds metric code and result.">distance_metric_descriptor</a>* dmit,
 
837
<a name="l00810"></a>00810                             <a class="code" href="a00060.html" title="Distance metric descriptor, holds metric code and result.">distance_metric_descriptor</a>* dmit_end)
 
838
<a name="l00811"></a>00811 {
 
839
<a name="l00812"></a>00812     <span class="keyword">const</span> <span class="keyword">typename</span> BV::blocks_manager_type&amp; bman1 = bv1.get_blocks_manager();
 
840
<a name="l00813"></a>00813     <span class="keyword">const</span> <span class="keyword">typename</span> BV::blocks_manager_type&amp; bman2 = bv2.get_blocks_manager();
 
841
<a name="l00814"></a>00814     
 
842
<a name="l00815"></a>00815     <span class="keywordtype">bool</span> is_all_and = <span class="keyword">true</span>; <span class="comment">// flag is distance operation is just COUNT_AND</span>
 
843
<a name="l00816"></a>00816     <a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>* temp_blk = <a class="code" href="a00110.html#ad47cf2dce876dcbc25aef4c7a222c66f" title="Staging function for distance operation.">distance_stage</a>(bv1, dmit, dmit_end, &amp;is_all_and);
 
844
<a name="l00817"></a>00817   
 
845
<a name="l00818"></a>00818     <a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>*** blk_root = bman1.get_rootblock();
 
846
<a name="l00819"></a>00819     <span class="keywordtype">unsigned</span> block_idx = 0;
 
847
<a name="l00820"></a>00820     <span class="keywordtype">unsigned</span> i, j;
 
848
<a name="l00821"></a>00821     
 
849
<a name="l00822"></a>00822     <span class="keyword">const</span> <a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>* blk;
 
850
<a name="l00823"></a>00823     <span class="keyword">const</span> <a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>* arg_blk;
 
851
<a name="l00824"></a>00824     <span class="keywordtype">bool</span>  blk_gap;
 
852
<a name="l00825"></a>00825     <span class="keywordtype">bool</span>  arg_gap;
 
853
<a name="l00826"></a>00826 
 
854
<a name="l00827"></a>00827     <a class="code" href="a00089.html#a7e6f87ba3230dece2125af5c32e84b05">BM_SET_MMX_GUARD</a>
 
855
<a name="l00828"></a>00828 
 
856
<a name="l00829"></a>00829     <span class="keywordtype">unsigned</span> effective_top_block_size = bman1.effective_top_block_size();
 
857
<a name="l00830"></a>00830     <span class="keywordtype">unsigned</span> ebs2 = bman2.effective_top_block_size();
 
858
<a name="l00831"></a>00831     <span class="keywordflow">if</span> (ebs2 &gt; effective_top_block_size)
 
859
<a name="l00832"></a>00832         effective_top_block_size = ebs2;
 
860
<a name="l00833"></a>00833 
 
861
<a name="l00834"></a>00834     <span class="keywordflow">for</span> (i = 0; i &lt; effective_top_block_size; ++i)
 
862
<a name="l00835"></a>00835     {
 
863
<a name="l00836"></a>00836         <a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>** blk_blk = blk_root[i];
 
864
<a name="l00837"></a>00837 
 
865
<a name="l00838"></a>00838         <span class="keywordflow">if</span> (blk_blk == 0) <span class="comment">// not allocated</span>
 
866
<a name="l00839"></a>00839         {
 
867
<a name="l00840"></a>00840             <span class="comment">// AND operation requested - we can skip this portion here </span>
 
868
<a name="l00841"></a>00841             <span class="keywordflow">if</span> (is_all_and)
 
869
<a name="l00842"></a>00842             {
 
870
<a name="l00843"></a>00843                 block_idx += <a class="code" href="a00110.html#a40ad34d6c46a2fb20ba2baa7f95d80b4">bm::set_array_size</a>;
 
871
<a name="l00844"></a>00844                 <span class="keywordflow">continue</span>;
 
872
<a name="l00845"></a>00845             }
 
873
<a name="l00846"></a>00846 
 
874
<a name="l00847"></a>00847             <span class="keyword">const</span> <a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>* <span class="keyword">const</span>* bvbb = bman2.get_topblock(i);
 
875
<a name="l00848"></a>00848             <span class="keywordflow">if</span> (bvbb == 0) 
 
876
<a name="l00849"></a>00849             {
 
877
<a name="l00850"></a>00850                 block_idx += <a class="code" href="a00110.html#a40ad34d6c46a2fb20ba2baa7f95d80b4">bm::set_array_size</a>;
 
878
<a name="l00851"></a>00851                 <span class="keywordflow">continue</span>;
 
879
<a name="l00852"></a>00852             }
 
880
<a name="l00853"></a>00853 
 
881
<a name="l00854"></a>00854             blk = 0;
 
882
<a name="l00855"></a>00855             blk_gap = <span class="keyword">false</span>;
 
883
<a name="l00856"></a>00856 
 
884
<a name="l00857"></a>00857             <span class="keywordflow">for</span> (j = 0; j &lt; <a class="code" href="a00110.html#a40ad34d6c46a2fb20ba2baa7f95d80b4">bm::set_array_size</a>; ++j,++block_idx)
 
885
<a name="l00858"></a>00858             {                
 
886
<a name="l00859"></a>00859                 arg_blk = bman2.get_block(i, j);
 
887
<a name="l00860"></a>00860                 arg_gap = <a class="code" href="a00089.html#a862d6f92b4de3ddb94fd367a800512eb">BM_IS_GAP</a>(bman2, arg_blk, block_idx);
 
888
<a name="l00861"></a>00861 
 
889
<a name="l00862"></a>00862                 <span class="keywordflow">if</span> (!arg_blk) 
 
890
<a name="l00863"></a>00863                     <span class="keywordflow">continue</span>;
 
891
<a name="l00864"></a>00864                 <a class="code" href="a00110.html#a24069ced9ea689034ff51246ae707ecc" title="Internal function computes different existense of distance metric.">combine_any_operation_with_block</a>(blk, blk_gap,
 
892
<a name="l00865"></a>00865                                                  arg_blk, arg_gap,
 
893
<a name="l00866"></a>00866                                                  temp_blk,
 
894
<a name="l00867"></a>00867                                                  dmit, dmit_end);
 
895
<a name="l00868"></a>00868 
 
896
<a name="l00869"></a>00869                 <span class="comment">// check if all distance requests alredy resolved</span>
 
897
<a name="l00870"></a>00870                 <span class="keywordtype">bool</span> all_resolved = <span class="keyword">false</span>;
 
898
<a name="l00871"></a>00871                 <a class="code" href="a00060.html" title="Distance metric descriptor, holds metric code and result.">distance_metric_descriptor</a>* it=dmit;
 
899
<a name="l00872"></a>00872                 <span class="keywordflow">do</span>
 
900
<a name="l00873"></a>00873                 {
 
901
<a name="l00874"></a>00874                     <span class="keywordflow">if</span> (!it-&gt;<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a>)
 
902
<a name="l00875"></a>00875                     {
 
903
<a name="l00876"></a>00876                         all_resolved = <span class="keyword">false</span>;
 
904
<a name="l00877"></a>00877                         <span class="keywordflow">break</span>;
 
905
<a name="l00878"></a>00878                     }
 
906
<a name="l00879"></a>00879                     ++it;
 
907
<a name="l00880"></a>00880                 } <span class="keywordflow">while</span> (it &lt; dmit_end);
 
908
<a name="l00881"></a>00881                 <span class="keywordflow">if</span> (all_resolved)
 
909
<a name="l00882"></a>00882                     <span class="keywordflow">goto</span> return_proc;
 
910
<a name="l00883"></a>00883             } <span class="comment">// for j</span>
 
911
<a name="l00884"></a>00884 
 
912
<a name="l00885"></a>00885             <span class="keywordflow">continue</span>;
 
913
<a name="l00886"></a>00886         }
 
914
<a name="l00887"></a>00887 
 
915
<a name="l00888"></a>00888         <span class="keywordflow">for</span> (j = 0; j &lt; <a class="code" href="a00110.html#a40ad34d6c46a2fb20ba2baa7f95d80b4">bm::set_array_size</a>; ++j, ++block_idx)
 
916
<a name="l00889"></a>00889         {
 
917
<a name="l00890"></a>00890             blk = blk_blk[j];
 
918
<a name="l00891"></a>00891             <span class="keywordflow">if</span> (blk == 0 &amp;&amp; is_all_and)
 
919
<a name="l00892"></a>00892                 <span class="keywordflow">continue</span>;
 
920
<a name="l00893"></a>00893 
 
921
<a name="l00894"></a>00894             arg_blk = bman2.get_block(i, j);
 
922
<a name="l00895"></a>00895 
 
923
<a name="l00896"></a>00896             <span class="keywordflow">if</span> (blk == 0 &amp;&amp; arg_blk == 0)
 
924
<a name="l00897"></a>00897                 <span class="keywordflow">continue</span>;
 
925
<a name="l00898"></a>00898                 
 
926
<a name="l00899"></a>00899             arg_gap = <a class="code" href="a00089.html#a862d6f92b4de3ddb94fd367a800512eb">BM_IS_GAP</a>(bman2, arg_blk, block_idx);
 
927
<a name="l00900"></a>00900             blk_gap = <a class="code" href="a00089.html#a862d6f92b4de3ddb94fd367a800512eb">BM_IS_GAP</a>(bman1, blk, block_idx);
 
928
<a name="l00901"></a>00901             
 
929
<a name="l00902"></a>00902             <a class="code" href="a00110.html#a24069ced9ea689034ff51246ae707ecc" title="Internal function computes different existense of distance metric.">combine_any_operation_with_block</a>(blk, blk_gap,
 
930
<a name="l00903"></a>00903                                              arg_blk, arg_gap,
 
931
<a name="l00904"></a>00904                                              temp_blk,
 
932
<a name="l00905"></a>00905                                              dmit, dmit_end);
 
933
<a name="l00906"></a>00906             
 
934
<a name="l00907"></a>00907             <span class="comment">// check if all distance requests alredy resolved</span>
 
935
<a name="l00908"></a>00908             <span class="keywordtype">bool</span> all_resolved = <span class="keyword">false</span>;
 
936
<a name="l00909"></a>00909             <a class="code" href="a00060.html" title="Distance metric descriptor, holds metric code and result.">distance_metric_descriptor</a>* it=dmit;
 
937
<a name="l00910"></a>00910             <span class="keywordflow">do</span>
 
938
<a name="l00911"></a>00911             {
 
939
<a name="l00912"></a>00912                 <span class="keywordflow">if</span> (!it-&gt;<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a>)
 
940
<a name="l00913"></a>00913                 {
 
941
<a name="l00914"></a>00914                     all_resolved = <span class="keyword">false</span>;
 
942
<a name="l00915"></a>00915                     <span class="keywordflow">break</span>;
 
943
<a name="l00916"></a>00916                 }
 
944
<a name="l00917"></a>00917                 ++it;
 
945
<a name="l00918"></a>00918             } <span class="keywordflow">while</span> (it &lt; dmit_end);
 
946
<a name="l00919"></a>00919             <span class="keywordflow">if</span> (all_resolved)
 
947
<a name="l00920"></a>00920                 <span class="keywordflow">goto</span> return_proc;
 
948
<a name="l00921"></a>00921 
 
949
<a name="l00922"></a>00922         } <span class="comment">// for j</span>
 
950
<a name="l00923"></a>00923 
 
951
<a name="l00924"></a>00924     } <span class="comment">// for i</span>
 
952
<a name="l00925"></a>00925 return_proc:    
 
953
<a name="l00926"></a>00926     <span class="keywordflow">if</span> (temp_blk)
 
954
<a name="l00927"></a>00927     {
 
955
<a name="l00928"></a>00928         bv1.free_tempblock(temp_blk);
 
956
<a name="l00929"></a>00929     }
 
957
<a name="l00930"></a>00930 
 
958
<a name="l00931"></a>00931 }
 
959
<a name="l00932"></a>00932 
 
960
<a name="l00933"></a>00933 
 
961
<a name="l00934"></a>00934 <span class="comment"></span>
 
962
<a name="l00935"></a>00935 <span class="comment">/*!</span>
 
963
<a name="l00936"></a>00936 <span class="comment">   \brief Computes bitcount of AND operation of two bitsets</span>
 
964
<a name="l00937"></a>00937 <span class="comment">   \param bv1 - Argument bit-vector.</span>
 
965
<a name="l00938"></a>00938 <span class="comment">   \param bv2 - Argument bit-vector.</span>
 
966
<a name="l00939"></a>00939 <span class="comment">   \return bitcount of the result</span>
 
967
<a name="l00940"></a>00940 <span class="comment">   \ingroup  distance</span>
 
968
<a name="l00941"></a>00941 <span class="comment">*/</span>
 
969
<a name="l00942"></a>00942 <span class="keyword">template</span>&lt;<span class="keyword">class</span> BV&gt;
 
970
<a name="l00943"></a><a class="code" href="a00120.html#gae451cb4b87e8c0859b0614d2ffb99737">00943</a> <a class="code" href="a00110.html#aa3824d882a037396370b16f2f0a8bf37">bm::id_t</a> <a class="code" href="a00120.html#gae451cb4b87e8c0859b0614d2ffb99737" title="Computes bitcount of AND operation of two bitsets.">count_and</a>(<span class="keyword">const</span> BV&amp; bv1, <span class="keyword">const</span> BV&amp; bv2)
 
971
<a name="l00944"></a>00944 {
 
972
<a name="l00945"></a>00945     <a class="code" href="a00060.html" title="Distance metric descriptor, holds metric code and result.">distance_metric_descriptor</a> dmd(<a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abacb39376469ba778e9a9099ddbae5e7ce" title="(A &amp;amp; B).count()">bm::COUNT_AND</a>);
 
973
<a name="l00946"></a>00946     
 
974
<a name="l00947"></a>00947     <a class="code" href="a00120.html#ga815fef76f02576ab9ab58de0a45d8a4b" title="Distance computing template function.">distance_operation</a>(bv1, bv2, &amp;dmd, &amp;dmd+1);
 
975
<a name="l00948"></a>00948     <span class="keywordflow">return</span> dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a>;
 
976
<a name="l00949"></a>00949 }
 
977
<a name="l00950"></a>00950 <span class="comment"></span>
 
978
<a name="l00951"></a>00951 <span class="comment">/*!</span>
 
979
<a name="l00952"></a>00952 <span class="comment">   \brief Computes if there is any bit in AND operation of two bitsets</span>
 
980
<a name="l00953"></a>00953 <span class="comment">   \param bv1 - Argument bit-vector.</span>
 
981
<a name="l00954"></a>00954 <span class="comment">   \param bv2 - Argument bit-vector.</span>
 
982
<a name="l00955"></a>00955 <span class="comment">   \return non zero value if there is any bit</span>
 
983
<a name="l00956"></a>00956 <span class="comment">   \ingroup  distance</span>
 
984
<a name="l00957"></a>00957 <span class="comment">*/</span>
 
985
<a name="l00958"></a>00958 <span class="keyword">template</span>&lt;<span class="keyword">class</span> BV&gt;
 
986
<a name="l00959"></a><a class="code" href="a00120.html#ga2d5393e05bcfc540840a4cee67fb771f">00959</a> <a class="code" href="a00110.html#aa3824d882a037396370b16f2f0a8bf37">bm::id_t</a> <a class="code" href="a00120.html#ga2d5393e05bcfc540840a4cee67fb771f" title="Computes if there is any bit in AND operation of two bitsets.">any_and</a>(<span class="keyword">const</span> BV&amp; bv1, <span class="keyword">const</span> BV&amp; bv2)
 
987
<a name="l00960"></a>00960 {
 
988
<a name="l00961"></a>00961     <a class="code" href="a00060.html" title="Distance metric descriptor, holds metric code and result.">distance_metric_descriptor</a> dmd(<a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abacb39376469ba778e9a9099ddbae5e7ce" title="(A &amp;amp; B).count()">bm::COUNT_AND</a>);
 
989
<a name="l00962"></a>00962     
 
990
<a name="l00963"></a>00963     <a class="code" href="a00120.html#gaa66525fd7a3f823d73678252a235982e" title="Distance screening template function.">distance_operation_any</a>(bv1, bv2, &amp;dmd, &amp;dmd+1);
 
991
<a name="l00964"></a>00964     <span class="keywordflow">return</span> dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a>;
 
992
<a name="l00965"></a>00965 }
 
993
<a name="l00966"></a>00966 
 
994
<a name="l00967"></a>00967 
 
995
<a name="l00968"></a>00968 <span class="comment"></span>
 
996
<a name="l00969"></a>00969 <span class="comment">/*!</span>
 
997
<a name="l00970"></a>00970 <span class="comment">   \brief Computes bitcount of XOR operation of two bitsets</span>
 
998
<a name="l00971"></a>00971 <span class="comment">   \param bv1 - Argument bit-vector.</span>
 
999
<a name="l00972"></a>00972 <span class="comment">   \param bv2 - Argument bit-vector.</span>
 
1000
<a name="l00973"></a>00973 <span class="comment">   \return bitcount of the result</span>
 
1001
<a name="l00974"></a>00974 <span class="comment">   \ingroup  distance</span>
 
1002
<a name="l00975"></a>00975 <span class="comment">*/</span>
 
1003
<a name="l00976"></a>00976 <span class="keyword">template</span>&lt;<span class="keyword">class</span> BV&gt;
 
1004
<a name="l00977"></a><a class="code" href="a00120.html#gafc64a082dcaee07f70f7faf3e24f844e">00977</a> <a class="code" href="a00110.html#aa3824d882a037396370b16f2f0a8bf37">bm::id_t</a> <a class="code" href="a00120.html#gafc64a082dcaee07f70f7faf3e24f844e" title="Computes bitcount of XOR operation of two bitsets.">count_xor</a>(<span class="keyword">const</span> BV&amp; bv1, <span class="keyword">const</span> BV&amp; bv2)
 
1005
<a name="l00978"></a>00978 {
 
1006
<a name="l00979"></a>00979     <a class="code" href="a00060.html" title="Distance metric descriptor, holds metric code and result.">distance_metric_descriptor</a> dmd(<a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40aba3e4861dde6e1179457ee0d3502ae8061" title="(A ^ B).count()">bm::COUNT_XOR</a>);
 
1007
<a name="l00980"></a>00980     
 
1008
<a name="l00981"></a>00981     <a class="code" href="a00120.html#ga815fef76f02576ab9ab58de0a45d8a4b" title="Distance computing template function.">distance_operation</a>(bv1, bv2, &amp;dmd, &amp;dmd+1);
 
1009
<a name="l00982"></a>00982     <span class="keywordflow">return</span> dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a>;
 
1010
<a name="l00983"></a>00983 }
 
1011
<a name="l00984"></a>00984 <span class="comment"></span>
 
1012
<a name="l00985"></a>00985 <span class="comment">/*!</span>
 
1013
<a name="l00986"></a>00986 <span class="comment">   \brief Computes if there is any bit in XOR operation of two bitsets</span>
 
1014
<a name="l00987"></a>00987 <span class="comment">   \param bv1 - Argument bit-vector.</span>
 
1015
<a name="l00988"></a>00988 <span class="comment">   \param bv2 - Argument bit-vector.</span>
 
1016
<a name="l00989"></a>00989 <span class="comment">   \return non zero value if there is any bit</span>
 
1017
<a name="l00990"></a>00990 <span class="comment">   \ingroup  distance</span>
 
1018
<a name="l00991"></a>00991 <span class="comment">*/</span>
 
1019
<a name="l00992"></a>00992 <span class="keyword">template</span>&lt;<span class="keyword">class</span> BV&gt;
 
1020
<a name="l00993"></a><a class="code" href="a00120.html#ga2d63f41244b82d233acb53d88b326b82">00993</a> <a class="code" href="a00110.html#aa3824d882a037396370b16f2f0a8bf37">bm::id_t</a> <a class="code" href="a00120.html#ga2d63f41244b82d233acb53d88b326b82" title="Computes if there is any bit in XOR operation of two bitsets.">any_xor</a>(<span class="keyword">const</span> BV&amp; bv1, <span class="keyword">const</span> BV&amp; bv2)
 
1021
<a name="l00994"></a>00994 {
 
1022
<a name="l00995"></a>00995     <a class="code" href="a00060.html" title="Distance metric descriptor, holds metric code and result.">distance_metric_descriptor</a> dmd(<a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40aba3e4861dde6e1179457ee0d3502ae8061" title="(A ^ B).count()">bm::COUNT_XOR</a>);
 
1023
<a name="l00996"></a>00996     
 
1024
<a name="l00997"></a>00997     <a class="code" href="a00120.html#gaa66525fd7a3f823d73678252a235982e" title="Distance screening template function.">distance_operation_any</a>(bv1, bv2, &amp;dmd, &amp;dmd+1);
 
1025
<a name="l00998"></a>00998     <span class="keywordflow">return</span> dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a>;
 
1026
<a name="l00999"></a>00999 }
 
1027
<a name="l01000"></a>01000 
 
1028
<a name="l01001"></a>01001 
 
1029
<a name="l01002"></a>01002 <span class="comment"></span>
 
1030
<a name="l01003"></a>01003 <span class="comment">/*!</span>
 
1031
<a name="l01004"></a>01004 <span class="comment">   \brief Computes bitcount of SUB operation of two bitsets</span>
 
1032
<a name="l01005"></a>01005 <span class="comment">   \param bv1 - Argument bit-vector.</span>
 
1033
<a name="l01006"></a>01006 <span class="comment">   \param bv2 - Argument bit-vector.</span>
 
1034
<a name="l01007"></a>01007 <span class="comment">   \return bitcount of the result</span>
 
1035
<a name="l01008"></a>01008 <span class="comment">   \ingroup  distance</span>
 
1036
<a name="l01009"></a>01009 <span class="comment">*/</span>
 
1037
<a name="l01010"></a>01010 <span class="keyword">template</span>&lt;<span class="keyword">class</span> BV&gt;
 
1038
<a name="l01011"></a><a class="code" href="a00120.html#ga902d8c1cd1f8a2538cd47d47f5d8d605">01011</a> <a class="code" href="a00110.html#aa3824d882a037396370b16f2f0a8bf37">bm::id_t</a> <a class="code" href="a00120.html#ga902d8c1cd1f8a2538cd47d47f5d8d605" title="Computes bitcount of SUB operation of two bitsets.">count_sub</a>(<span class="keyword">const</span> BV&amp; bv1, <span class="keyword">const</span> BV&amp; bv2)
 
1039
<a name="l01012"></a>01012 {
 
1040
<a name="l01013"></a>01013     <a class="code" href="a00060.html" title="Distance metric descriptor, holds metric code and result.">distance_metric_descriptor</a> dmd(<a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40aba9c101dab8904c0432f72ccce0a207e62" title="(A - B).count()">bm::COUNT_SUB_AB</a>);
 
1041
<a name="l01014"></a>01014     
 
1042
<a name="l01015"></a>01015     <a class="code" href="a00120.html#ga815fef76f02576ab9ab58de0a45d8a4b" title="Distance computing template function.">distance_operation</a>(bv1, bv2, &amp;dmd, &amp;dmd+1);
 
1043
<a name="l01016"></a>01016     <span class="keywordflow">return</span> dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a>;
 
1044
<a name="l01017"></a>01017 }
 
1045
<a name="l01018"></a>01018 
 
1046
<a name="l01019"></a>01019 <span class="comment"></span>
 
1047
<a name="l01020"></a>01020 <span class="comment">/*!</span>
 
1048
<a name="l01021"></a>01021 <span class="comment">   \brief Computes if there is any bit in SUB operation of two bitsets</span>
 
1049
<a name="l01022"></a>01022 <span class="comment">   \param bv1 - Argument bit-vector.</span>
 
1050
<a name="l01023"></a>01023 <span class="comment">   \param bv2 - Argument bit-vector.</span>
 
1051
<a name="l01024"></a>01024 <span class="comment">   \return non zero value if there is any bit</span>
 
1052
<a name="l01025"></a>01025 <span class="comment">   \ingroup  distance</span>
 
1053
<a name="l01026"></a>01026 <span class="comment">*/</span>
 
1054
<a name="l01027"></a>01027 <span class="keyword">template</span>&lt;<span class="keyword">class</span> BV&gt;
 
1055
<a name="l01028"></a><a class="code" href="a00120.html#gabde2e210b9b1edd190e1f5a9ff22344c">01028</a> <a class="code" href="a00110.html#aa3824d882a037396370b16f2f0a8bf37">bm::id_t</a> <a class="code" href="a00120.html#gabde2e210b9b1edd190e1f5a9ff22344c" title="Computes if there is any bit in SUB operation of two bitsets.">any_sub</a>(<span class="keyword">const</span> BV&amp; bv1, <span class="keyword">const</span> BV&amp; bv2)
 
1056
<a name="l01029"></a>01029 {
 
1057
<a name="l01030"></a>01030     <a class="code" href="a00060.html" title="Distance metric descriptor, holds metric code and result.">distance_metric_descriptor</a> dmd(<a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40aba9c101dab8904c0432f72ccce0a207e62" title="(A - B).count()">bm::COUNT_SUB_AB</a>);
 
1058
<a name="l01031"></a>01031     
 
1059
<a name="l01032"></a>01032     <a class="code" href="a00120.html#gaa66525fd7a3f823d73678252a235982e" title="Distance screening template function.">distance_operation_any</a>(bv1, bv2, &amp;dmd, &amp;dmd+1);
 
1060
<a name="l01033"></a>01033     <span class="keywordflow">return</span> dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a>;
 
1061
<a name="l01034"></a>01034 }
 
1062
<a name="l01035"></a>01035 
 
1063
<a name="l01036"></a>01036 <span class="comment"></span>
 
1064
<a name="l01037"></a>01037 <span class="comment">/*!    </span>
 
1065
<a name="l01038"></a>01038 <span class="comment">   \brief Computes bitcount of OR operation of two bitsets</span>
 
1066
<a name="l01039"></a>01039 <span class="comment">   \param bv1 - Argument bit-vector.</span>
 
1067
<a name="l01040"></a>01040 <span class="comment">   \param bv2 - Argument bit-vector.</span>
 
1068
<a name="l01041"></a>01041 <span class="comment">   \return bitcount of the result</span>
 
1069
<a name="l01042"></a>01042 <span class="comment">   \ingroup  distance</span>
 
1070
<a name="l01043"></a>01043 <span class="comment">*/</span>
 
1071
<a name="l01044"></a>01044 <span class="keyword">template</span>&lt;<span class="keyword">class</span> BV&gt;
 
1072
<a name="l01045"></a><a class="code" href="a00120.html#ga803c564668703fc3bf80067570c2c905">01045</a> <a class="code" href="a00110.html#aa3824d882a037396370b16f2f0a8bf37">bm::id_t</a> <a class="code" href="a00120.html#ga803c564668703fc3bf80067570c2c905" title="Computes bitcount of OR operation of two bitsets.">count_or</a>(<span class="keyword">const</span> BV&amp; bv1, <span class="keyword">const</span> BV&amp; bv2)
 
1073
<a name="l01046"></a>01046 {
 
1074
<a name="l01047"></a>01047     <a class="code" href="a00060.html" title="Distance metric descriptor, holds metric code and result.">distance_metric_descriptor</a> dmd(<a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abad0bd2d56c8ebd03f55c01b3cc6faaaeb" title="(A | B).count()">bm::COUNT_OR</a>);
 
1075
<a name="l01048"></a>01048     
 
1076
<a name="l01049"></a>01049     <a class="code" href="a00120.html#ga815fef76f02576ab9ab58de0a45d8a4b" title="Distance computing template function.">distance_operation</a>(bv1, bv2, &amp;dmd, &amp;dmd+1);
 
1077
<a name="l01050"></a>01050     <span class="keywordflow">return</span> dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a>;
 
1078
<a name="l01051"></a>01051 }
 
1079
<a name="l01052"></a>01052 <span class="comment"></span>
 
1080
<a name="l01053"></a>01053 <span class="comment">/*!</span>
 
1081
<a name="l01054"></a>01054 <span class="comment">   \brief Computes if there is any bit in OR operation of two bitsets</span>
 
1082
<a name="l01055"></a>01055 <span class="comment">   \param bv1 - Argument bit-vector.</span>
 
1083
<a name="l01056"></a>01056 <span class="comment">   \param bv2 - Argument bit-vector.</span>
 
1084
<a name="l01057"></a>01057 <span class="comment">   \return non zero value if there is any bit</span>
 
1085
<a name="l01058"></a>01058 <span class="comment">   \ingroup  distance</span>
 
1086
<a name="l01059"></a>01059 <span class="comment">*/</span>
 
1087
<a name="l01060"></a>01060 <span class="keyword">template</span>&lt;<span class="keyword">class</span> BV&gt;
 
1088
<a name="l01061"></a><a class="code" href="a00120.html#gaeda4f0cf54aa464cec09e740100caa79">01061</a> <a class="code" href="a00110.html#aa3824d882a037396370b16f2f0a8bf37">bm::id_t</a> <a class="code" href="a00120.html#gaeda4f0cf54aa464cec09e740100caa79" title="Computes if there is any bit in OR operation of two bitsets.">any_or</a>(<span class="keyword">const</span> BV&amp; bv1, <span class="keyword">const</span> BV&amp; bv2)
 
1089
<a name="l01062"></a>01062 {
 
1090
<a name="l01063"></a>01063     <a class="code" href="a00060.html" title="Distance metric descriptor, holds metric code and result.">distance_metric_descriptor</a> dmd(<a class="code" href="a00120.html#ggac38d64c8b27b652413a664cddd4d40abad0bd2d56c8ebd03f55c01b3cc6faaaeb" title="(A | B).count()">bm::COUNT_OR</a>);
 
1091
<a name="l01064"></a>01064     
 
1092
<a name="l01065"></a>01065     <a class="code" href="a00120.html#gaa66525fd7a3f823d73678252a235982e" title="Distance screening template function.">distance_operation_any</a>(bv1, bv2, &amp;dmd, &amp;dmd+1);
 
1093
<a name="l01066"></a>01066     <span class="keywordflow">return</span> dmd.<a class="code" href="a00060.html#a94c955fe1ac46589d6edc8df7fd35cf6">result</a>;
 
1094
<a name="l01067"></a>01067 }
 
1095
<a name="l01068"></a>01068 
 
1096
<a name="l01069"></a>01069 <span class="comment"></span>
 
1097
<a name="l01070"></a>01070 <span class="comment">/**</span>
 
1098
<a name="l01071"></a>01071 <span class="comment">    \brief Internal algorithms scans the input for the block range limit</span>
 
1099
<a name="l01072"></a>01072 <span class="comment">    \internal</span>
 
1100
<a name="l01073"></a>01073 <span class="comment">*/</span>
 
1101
<a name="l01074"></a>01074 <span class="keyword">template</span>&lt;<span class="keyword">class</span> It&gt;
 
1102
<a name="l01075"></a><a class="code" href="a00110.html#a86d5d5ccdb79d2b2ad552bd1caf34b2f">01075</a> It <a class="code" href="a00110.html#a86d5d5ccdb79d2b2ad552bd1caf34b2f" title="Internal algorithms scans the input for the block range limit.">block_range_scan</a>(It  first, It last, <span class="keywordtype">unsigned</span> nblock, <span class="keywordtype">unsigned</span>* max_id)
 
1103
<a name="l01076"></a>01076 {
 
1104
<a name="l01077"></a>01077     It right;
 
1105
<a name="l01078"></a>01078     <span class="keywordflow">for</span> (right = first; right != last; ++right)
 
1106
<a name="l01079"></a>01079     {
 
1107
<a name="l01080"></a>01080         <span class="keywordtype">unsigned</span> v = unsigned(*right);
 
1108
<a name="l01081"></a>01081         <a class="code" href="a00089.html#aa44515fab0ace8928d1cb82009a95bf8">BM_ASSERT</a>(v &lt; <a class="code" href="a00110.html#a104b924a1df81542db2a6296fbf26a65">bm::id_max</a>);
 
1109
<a name="l01082"></a>01082         <span class="keywordflow">if</span> (v &gt;= *max_id)
 
1110
<a name="l01083"></a>01083             *max_id = v;
 
1111
<a name="l01084"></a>01084         <span class="keywordtype">unsigned</span> nb = v &gt;&gt; <a class="code" href="a00110.html#ad8723fbeea6290d3daa8917ea7ce9bb2">bm::set_block_shift</a>;
 
1112
<a name="l01085"></a>01085         <span class="keywordflow">if</span> (nb != nblock)
 
1113
<a name="l01086"></a>01086             <span class="keywordflow">break</span>;
 
1114
<a name="l01087"></a>01087     }
 
1115
<a name="l01088"></a>01088     <span class="keywordflow">return</span> right;
 
1116
<a name="l01089"></a>01089 }
 
1117
<a name="l01090"></a>01090 <span class="comment"></span>
 
1118
<a name="l01091"></a>01091 <span class="comment">/**</span>
 
1119
<a name="l01092"></a>01092 <span class="comment">    \brief OR Combine bitvector and the iterable sequence </span>
 
1120
<a name="l01093"></a>01093 <span class="comment"></span>
 
1121
<a name="l01094"></a>01094 <span class="comment">    Algorithm combines bvector with sequence of integers </span>
 
1122
<a name="l01095"></a>01095 <span class="comment">    (represents another set). When the agrument set is sorted </span>
 
1123
<a name="l01096"></a>01096 <span class="comment">    this method can give serious increase in performance.</span>
 
1124
<a name="l01097"></a>01097 <span class="comment">    </span>
 
1125
<a name="l01098"></a>01098 <span class="comment">    \param bv     - destination bitvector</span>
 
1126
<a name="l01099"></a>01099 <span class="comment">    \param first  - first element of the iterated sequence</span>
 
1127
<a name="l01100"></a>01100 <span class="comment">    \param last   - last element of the iterated sequence</span>
 
1128
<a name="l01101"></a>01101 <span class="comment">    </span>
 
1129
<a name="l01102"></a>01102 <span class="comment">    \ingroup setalgo</span>
 
1130
<a name="l01103"></a>01103 <span class="comment">*/</span>
 
1131
<a name="l01104"></a>01104 <span class="keyword">template</span>&lt;<span class="keyword">class</span> BV, <span class="keyword">class</span> It&gt;
 
1132
<a name="l01105"></a><a class="code" href="a00119.html#ga54ff78528c99ae3ca443eb99ba44785b">01105</a> <span class="keywordtype">void</span> <a class="code" href="a00119.html#ga54ff78528c99ae3ca443eb99ba44785b" title="OR Combine bitvector and the iterable sequence.">combine_or</a>(BV&amp; bv, It  first, It last)
 
1133
<a name="l01106"></a>01106 {
 
1134
<a name="l01107"></a>01107     <span class="keyword">typename</span> BV::blocks_manager_type&amp; bman = bv.get_blocks_manager();
 
1135
<a name="l01108"></a>01108     <span class="keywordtype">unsigned</span> max_id = 0;
 
1136
<a name="l01109"></a>01109 
 
1137
<a name="l01110"></a>01110     <span class="keywordflow">while</span> (first &lt; last)
 
1138
<a name="l01111"></a>01111     {
 
1139
<a name="l01112"></a>01112         <span class="keywordtype">unsigned</span> nblock = unsigned((*first) &gt;&gt; <a class="code" href="a00110.html#ad8723fbeea6290d3daa8917ea7ce9bb2">bm::set_block_shift</a>);     
 
1140
<a name="l01113"></a>01113         It right = <a class="code" href="a00110.html#a86d5d5ccdb79d2b2ad552bd1caf34b2f" title="Internal algorithms scans the input for the block range limit.">block_range_scan</a>(first, last, nblock, &amp;max_id);
 
1141
<a name="l01114"></a>01114 
 
1142
<a name="l01115"></a>01115         <span class="keywordflow">if</span> (max_id &gt;= bv.size())
 
1143
<a name="l01116"></a>01116         {
 
1144
<a name="l01117"></a>01117             <a class="code" href="a00089.html#aa44515fab0ace8928d1cb82009a95bf8">BM_ASSERT</a>(max_id &lt; <a class="code" href="a00110.html#a104b924a1df81542db2a6296fbf26a65">bm::id_max</a>);
 
1145
<a name="l01118"></a>01118             bv.resize(max_id + 1);
 
1146
<a name="l01119"></a>01119         }
 
1147
<a name="l01120"></a>01120 
 
1148
<a name="l01121"></a>01121         <span class="comment">// now we have one in-block array of bits to set</span>
 
1149
<a name="l01122"></a>01122         
 
1150
<a name="l01123"></a>01123         label1:
 
1151
<a name="l01124"></a>01124         
 
1152
<a name="l01125"></a>01125         <span class="keywordtype">int</span> block_type;
 
1153
<a name="l01126"></a>01126         <a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>* blk = 
 
1154
<a name="l01127"></a>01127             bman.check_allocate_block(nblock, 
 
1155
<a name="l01128"></a>01128                                       <span class="keyword">true</span>, 
 
1156
<a name="l01129"></a>01129                                       bv.get_new_blocks_strat(), 
 
1157
<a name="l01130"></a>01130                                       &amp;block_type);
 
1158
<a name="l01131"></a>01131         <span class="keywordflow">if</span> (!blk) 
 
1159
<a name="l01132"></a>01132             <span class="keywordflow">continue</span>;
 
1160
<a name="l01133"></a>01133                         
 
1161
<a name="l01134"></a>01134         <span class="keywordflow">if</span> (block_type == 1) <span class="comment">// gap</span>
 
1162
<a name="l01135"></a>01135         {            
 
1163
<a name="l01136"></a>01136             <a class="code" href="a00110.html#ac654d6319039a86546d235a236fc7cf6">bm::gap_word_t</a>* gap_blk = <a class="code" href="a00089.html#a6a7c8b8ee3f3b60ab907c1699acb7aa0">BMGAP_PTR</a>(blk);
 
1164
<a name="l01137"></a>01137             <span class="keywordtype">unsigned</span> threshold = <a class="code" href="a00114.html#ga94a5371b5dc6a1560d95d7c2dde88815" title="Returs GAP block capacity limit.">bm::gap_limit</a>(gap_blk, bman.glen());
 
1165
<a name="l01138"></a>01138             
 
1166
<a name="l01139"></a>01139             <span class="keywordflow">for</span> (; first &lt; right; ++first)
 
1167
<a name="l01140"></a>01140             {
 
1168
<a name="l01141"></a>01141                 <span class="keywordtype">unsigned</span> is_set;
 
1169
<a name="l01142"></a>01142                 <span class="keywordtype">unsigned</span> nbit   = (*first) &amp; <a class="code" href="a00110.html#a201fb8b1f81b7487f1c1c129fc3d6557">bm::set_block_mask</a>; 
 
1170
<a name="l01143"></a>01143                 
 
1171
<a name="l01144"></a>01144                 <span class="keywordtype">unsigned</span> new_block_len =
 
1172
<a name="l01145"></a>01145                     <a class="code" href="a00114.html#ga69186bd13bda27e04b3e33683ff884c2" title="Abstract distance(similarity) operation for GAP buffers. Receives functor F as a...">gap_set_value</a>(<span class="keyword">true</span>, gap_blk, nbit, &amp;is_set);
 
1173
<a name="l01146"></a>01146                 <span class="keywordflow">if</span> (new_block_len &gt; threshold) 
 
1174
<a name="l01147"></a>01147                 {
 
1175
<a name="l01148"></a>01148                     bman.extend_gap_block(nblock, gap_blk);
 
1176
<a name="l01149"></a>01149                     ++first;
 
1177
<a name="l01150"></a>01150                     <span class="keywordflow">goto</span> label1;  <span class="comment">// block pointer changed - goto reset</span>
 
1178
<a name="l01151"></a>01151                 }
 
1179
<a name="l01152"></a>01152             }
 
1180
<a name="l01153"></a>01153         }
 
1181
<a name="l01154"></a>01154         <span class="keywordflow">else</span> <span class="comment">// bit block</span>
 
1182
<a name="l01155"></a>01155         {
 
1183
<a name="l01156"></a>01156             <span class="keywordflow">for</span> (; first &lt; right; ++first)
 
1184
<a name="l01157"></a>01157             {
 
1185
<a name="l01158"></a>01158                 <span class="keywordtype">unsigned</span> nbit   = unsigned(*first &amp; <a class="code" href="a00110.html#a201fb8b1f81b7487f1c1c129fc3d6557">bm::set_block_mask</a>); 
 
1186
<a name="l01159"></a>01159                 <span class="keywordtype">unsigned</span> nword  = unsigned(nbit &gt;&gt; <a class="code" href="a00110.html#a83d76bccf6fe3770f32d5ba11d2a37ad">bm::set_word_shift</a>); 
 
1187
<a name="l01160"></a>01160                 nbit &amp;= <a class="code" href="a00110.html#addbf345be3733d5e4575d71733ed1da8">bm::set_word_mask</a>;
 
1188
<a name="l01161"></a>01161                 blk[nword] |= (<a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>)1 &lt;&lt; nbit;
 
1189
<a name="l01162"></a>01162             } <span class="comment">// for</span>
 
1190
<a name="l01163"></a>01163         }
 
1191
<a name="l01164"></a>01164     } <span class="comment">// while</span>
 
1192
<a name="l01165"></a>01165     
 
1193
<a name="l01166"></a>01166     bv.forget_count();
 
1194
<a name="l01167"></a>01167 }
 
1195
<a name="l01168"></a>01168 
 
1196
<a name="l01169"></a>01169 <span class="comment"></span>
 
1197
<a name="l01170"></a>01170 <span class="comment">/**</span>
 
1198
<a name="l01171"></a>01171 <span class="comment">    \brief XOR Combine bitvector and the iterable sequence </span>
 
1199
<a name="l01172"></a>01172 <span class="comment"></span>
 
1200
<a name="l01173"></a>01173 <span class="comment">    Algorithm combines bvector with sequence of integers </span>
 
1201
<a name="l01174"></a>01174 <span class="comment">    (represents another set). When the agrument set is sorted </span>
 
1202
<a name="l01175"></a>01175 <span class="comment">    this method can give serious increase in performance.</span>
 
1203
<a name="l01176"></a>01176 <span class="comment">    </span>
 
1204
<a name="l01177"></a>01177 <span class="comment">    \param bv     - destination bitvector</span>
 
1205
<a name="l01178"></a>01178 <span class="comment">    \param first  - first element of the iterated sequence</span>
 
1206
<a name="l01179"></a>01179 <span class="comment">    \param last   - last element of the iterated sequence</span>
 
1207
<a name="l01180"></a>01180 <span class="comment">    </span>
 
1208
<a name="l01181"></a>01181 <span class="comment">    \ingroup setalgo</span>
 
1209
<a name="l01182"></a>01182 <span class="comment">*/</span>
 
1210
<a name="l01183"></a>01183 <span class="keyword">template</span>&lt;<span class="keyword">class</span> BV, <span class="keyword">class</span> It&gt;
 
1211
<a name="l01184"></a><a class="code" href="a00119.html#ga3cb362aee03de6a321495100ae5c8375">01184</a> <span class="keywordtype">void</span> <a class="code" href="a00119.html#ga3cb362aee03de6a321495100ae5c8375" title="XOR Combine bitvector and the iterable sequence.">combine_xor</a>(BV&amp; bv, It  first, It last)
 
1212
<a name="l01185"></a>01185 {
 
1213
<a name="l01186"></a>01186     <span class="keyword">typename</span> BV::blocks_manager_type&amp; bman = bv.get_blocks_manager();
 
1214
<a name="l01187"></a>01187     <span class="keywordtype">unsigned</span> max_id = 0;
 
1215
<a name="l01188"></a>01188 
 
1216
<a name="l01189"></a>01189     <span class="keywordflow">while</span> (first &lt; last)
 
1217
<a name="l01190"></a>01190     {
 
1218
<a name="l01191"></a>01191         <span class="keywordtype">unsigned</span> nblock = unsigned((*first) &gt;&gt; <a class="code" href="a00110.html#ad8723fbeea6290d3daa8917ea7ce9bb2">bm::set_block_shift</a>);     
 
1219
<a name="l01192"></a>01192         It right = <a class="code" href="a00110.html#a86d5d5ccdb79d2b2ad552bd1caf34b2f" title="Internal algorithms scans the input for the block range limit.">block_range_scan</a>(first, last, nblock, &amp;max_id);
 
1220
<a name="l01193"></a>01193 
 
1221
<a name="l01194"></a>01194         <span class="keywordflow">if</span> (max_id &gt;= bv.size())
 
1222
<a name="l01195"></a>01195         {
 
1223
<a name="l01196"></a>01196             <a class="code" href="a00089.html#aa44515fab0ace8928d1cb82009a95bf8">BM_ASSERT</a>(max_id &lt; <a class="code" href="a00110.html#a104b924a1df81542db2a6296fbf26a65">bm::id_max</a>);
 
1224
<a name="l01197"></a>01197             bv.resize(max_id + 1);
 
1225
<a name="l01198"></a>01198         }
 
1226
<a name="l01199"></a>01199 
 
1227
<a name="l01200"></a>01200         <span class="comment">// now we have one in-block array of bits to set</span>
 
1228
<a name="l01201"></a>01201         
 
1229
<a name="l01202"></a>01202         label1:
 
1230
<a name="l01203"></a>01203         
 
1231
<a name="l01204"></a>01204         <span class="keywordtype">int</span> block_type;
 
1232
<a name="l01205"></a>01205         <a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>* blk = 
 
1233
<a name="l01206"></a>01206             bman.check_allocate_block(nblock, 
 
1234
<a name="l01207"></a>01207                                       <span class="keyword">true</span>, 
 
1235
<a name="l01208"></a>01208                                       bv.get_new_blocks_strat(), 
 
1236
<a name="l01209"></a>01209                                       &amp;block_type,
 
1237
<a name="l01210"></a>01210                                       <span class="keyword">false</span> <span class="comment">/* no null return */</span>);
 
1238
<a name="l01211"></a>01211         <a class="code" href="a00089.html#aa44515fab0ace8928d1cb82009a95bf8">BM_ASSERT</a>(blk); 
 
1239
<a name="l01212"></a>01212                         
 
1240
<a name="l01213"></a>01213         <span class="keywordflow">if</span> (block_type == 1) <span class="comment">// gap</span>
 
1241
<a name="l01214"></a>01214         {
 
1242
<a name="l01215"></a>01215             <a class="code" href="a00110.html#ac654d6319039a86546d235a236fc7cf6">bm::gap_word_t</a>* gap_blk = <a class="code" href="a00089.html#a6a7c8b8ee3f3b60ab907c1699acb7aa0">BMGAP_PTR</a>(blk);
 
1243
<a name="l01216"></a>01216             <span class="keywordtype">unsigned</span> threshold = <a class="code" href="a00114.html#ga94a5371b5dc6a1560d95d7c2dde88815" title="Returs GAP block capacity limit.">bm::gap_limit</a>(gap_blk, bman.glen());
 
1244
<a name="l01217"></a>01217             
 
1245
<a name="l01218"></a>01218             <span class="keywordflow">for</span> (; first &lt; right; ++first)
 
1246
<a name="l01219"></a>01219             {
 
1247
<a name="l01220"></a>01220                 <span class="keywordtype">unsigned</span> is_set;
 
1248
<a name="l01221"></a>01221                 <span class="keywordtype">unsigned</span> nbit   = (*first) &amp; <a class="code" href="a00110.html#a201fb8b1f81b7487f1c1c129fc3d6557">bm::set_block_mask</a>; 
 
1249
<a name="l01222"></a>01222                 
 
1250
<a name="l01223"></a>01223                 is_set = <a class="code" href="a00114.html#ga866352ef5986a7d2b709795d127b666b" title="Tests if bit = pos is true.">gap_test</a>(gap_blk, nbit);
 
1251
<a name="l01224"></a>01224                 <a class="code" href="a00089.html#aa44515fab0ace8928d1cb82009a95bf8">BM_ASSERT</a>(is_set &lt;= 1);
 
1252
<a name="l01225"></a>01225                 is_set ^= 1; 
 
1253
<a name="l01226"></a>01226                 
 
1254
<a name="l01227"></a>01227                 <span class="keywordtype">unsigned</span> new_block_len =
 
1255
<a name="l01228"></a>01228                     <a class="code" href="a00114.html#ga69186bd13bda27e04b3e33683ff884c2" title="Abstract distance(similarity) operation for GAP buffers. Receives functor F as a...">gap_set_value</a>(is_set, gap_blk, nbit, &amp;is_set);
 
1256
<a name="l01229"></a>01229                 <span class="keywordflow">if</span> (new_block_len &gt; threshold) 
 
1257
<a name="l01230"></a>01230                 {
 
1258
<a name="l01231"></a>01231                     bman.extend_gap_block(nblock, gap_blk);
 
1259
<a name="l01232"></a>01232                     ++first;
 
1260
<a name="l01233"></a>01233                     <span class="keywordflow">goto</span> label1;  <span class="comment">// block pointer changed - goto reset</span>
 
1261
<a name="l01234"></a>01234                 }
 
1262
<a name="l01235"></a>01235             }
 
1263
<a name="l01236"></a>01236         }
 
1264
<a name="l01237"></a>01237         <span class="keywordflow">else</span> <span class="comment">// bit block</span>
 
1265
<a name="l01238"></a>01238         {
 
1266
<a name="l01239"></a>01239             <span class="keywordflow">for</span> (; first &lt; right; ++first)
 
1267
<a name="l01240"></a>01240             {
 
1268
<a name="l01241"></a>01241                 <span class="keywordtype">unsigned</span> nbit   = unsigned(*first &amp; <a class="code" href="a00110.html#a201fb8b1f81b7487f1c1c129fc3d6557">bm::set_block_mask</a>); 
 
1269
<a name="l01242"></a>01242                 <span class="keywordtype">unsigned</span> nword  = unsigned(nbit &gt;&gt; <a class="code" href="a00110.html#a83d76bccf6fe3770f32d5ba11d2a37ad">bm::set_word_shift</a>); 
 
1270
<a name="l01243"></a>01243                 nbit &amp;= <a class="code" href="a00110.html#addbf345be3733d5e4575d71733ed1da8">bm::set_word_mask</a>;
 
1271
<a name="l01244"></a>01244                 blk[nword] ^= (<a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>)1 &lt;&lt; nbit;
 
1272
<a name="l01245"></a>01245             } <span class="comment">// for</span>
 
1273
<a name="l01246"></a>01246         }
 
1274
<a name="l01247"></a>01247     } <span class="comment">// while</span>
 
1275
<a name="l01248"></a>01248     
 
1276
<a name="l01249"></a>01249     bv.forget_count();
 
1277
<a name="l01250"></a>01250 }
 
1278
<a name="l01251"></a>01251 
 
1279
<a name="l01252"></a>01252 
 
1280
<a name="l01253"></a>01253 <span class="comment"></span>
 
1281
<a name="l01254"></a>01254 <span class="comment">/**</span>
 
1282
<a name="l01255"></a>01255 <span class="comment">    \brief SUB Combine bitvector and the iterable sequence </span>
 
1283
<a name="l01256"></a>01256 <span class="comment"></span>
 
1284
<a name="l01257"></a>01257 <span class="comment">    Algorithm combines bvector with sequence of integers </span>
 
1285
<a name="l01258"></a>01258 <span class="comment">    (represents another set). When the agrument set is sorted </span>
 
1286
<a name="l01259"></a>01259 <span class="comment">    this method can give serious increase in performance.</span>
 
1287
<a name="l01260"></a>01260 <span class="comment">    </span>
 
1288
<a name="l01261"></a>01261 <span class="comment">    \param bv     - destination bitvector</span>
 
1289
<a name="l01262"></a>01262 <span class="comment">    \param first  - first element of the iterated sequence</span>
 
1290
<a name="l01263"></a>01263 <span class="comment">    \param last   - last element of the iterated sequence</span>
 
1291
<a name="l01264"></a>01264 <span class="comment">    </span>
 
1292
<a name="l01265"></a>01265 <span class="comment">    \ingroup setalgo</span>
 
1293
<a name="l01266"></a>01266 <span class="comment">*/</span>
 
1294
<a name="l01267"></a>01267 <span class="keyword">template</span>&lt;<span class="keyword">class</span> BV, <span class="keyword">class</span> It&gt;
 
1295
<a name="l01268"></a><a class="code" href="a00119.html#gab88c5bf51484323e0139aa789d7f0b98">01268</a> <span class="keywordtype">void</span> <a class="code" href="a00119.html#gab88c5bf51484323e0139aa789d7f0b98" title="SUB Combine bitvector and the iterable sequence.">combine_sub</a>(BV&amp; bv, It  first, It last)
 
1296
<a name="l01269"></a>01269 {
 
1297
<a name="l01270"></a>01270     <span class="keyword">typename</span> BV::blocks_manager_type&amp; bman = bv.get_blocks_manager();
 
1298
<a name="l01271"></a>01271     <span class="keywordtype">unsigned</span> max_id = 0;
 
1299
<a name="l01272"></a>01272 
 
1300
<a name="l01273"></a>01273     <span class="keywordflow">while</span> (first &lt; last)
 
1301
<a name="l01274"></a>01274     {
 
1302
<a name="l01275"></a>01275         <span class="keywordtype">unsigned</span> nblock = unsigned((*first) &gt;&gt; <a class="code" href="a00110.html#ad8723fbeea6290d3daa8917ea7ce9bb2">bm::set_block_shift</a>);     
 
1303
<a name="l01276"></a>01276         It right = <a class="code" href="a00110.html#a86d5d5ccdb79d2b2ad552bd1caf34b2f" title="Internal algorithms scans the input for the block range limit.">block_range_scan</a>(first, last, nblock, &amp;max_id);
 
1304
<a name="l01277"></a>01277 
 
1305
<a name="l01278"></a>01278         <span class="keywordflow">if</span> (max_id &gt;= bv.size())
 
1306
<a name="l01279"></a>01279         {
 
1307
<a name="l01280"></a>01280             <a class="code" href="a00089.html#aa44515fab0ace8928d1cb82009a95bf8">BM_ASSERT</a>(max_id &lt; <a class="code" href="a00110.html#a104b924a1df81542db2a6296fbf26a65">bm::id_max</a>);
 
1308
<a name="l01281"></a>01281             bv.resize(max_id + 1);
 
1309
<a name="l01282"></a>01282         }
 
1310
<a name="l01283"></a>01283 
 
1311
<a name="l01284"></a>01284         <span class="comment">// now we have one in-block array of bits to set</span>
 
1312
<a name="l01285"></a>01285         
 
1313
<a name="l01286"></a>01286         label1:
 
1314
<a name="l01287"></a>01287         
 
1315
<a name="l01288"></a>01288         <span class="keywordtype">int</span> block_type;
 
1316
<a name="l01289"></a>01289         <a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>* blk = 
 
1317
<a name="l01290"></a>01290             bman.check_allocate_block(nblock, 
 
1318
<a name="l01291"></a>01291                                       <span class="keyword">false</span>, 
 
1319
<a name="l01292"></a>01292                                       bv.get_new_blocks_strat(), 
 
1320
<a name="l01293"></a>01293                                       &amp;block_type);
 
1321
<a name="l01294"></a>01294 
 
1322
<a name="l01295"></a>01295         <span class="keywordflow">if</span> (!blk)
 
1323
<a name="l01296"></a>01296             <span class="keywordflow">continue</span>;
 
1324
<a name="l01297"></a>01297                         
 
1325
<a name="l01298"></a>01298         <span class="keywordflow">if</span> (block_type == 1) <span class="comment">// gap</span>
 
1326
<a name="l01299"></a>01299         {
 
1327
<a name="l01300"></a>01300             <a class="code" href="a00110.html#ac654d6319039a86546d235a236fc7cf6">bm::gap_word_t</a>* gap_blk = <a class="code" href="a00089.html#a6a7c8b8ee3f3b60ab907c1699acb7aa0">BMGAP_PTR</a>(blk);
 
1328
<a name="l01301"></a>01301             <span class="keywordtype">unsigned</span> threshold = <a class="code" href="a00114.html#ga94a5371b5dc6a1560d95d7c2dde88815" title="Returs GAP block capacity limit.">bm::gap_limit</a>(gap_blk, bman.glen());
 
1329
<a name="l01302"></a>01302             
 
1330
<a name="l01303"></a>01303             <span class="keywordflow">for</span> (; first &lt; right; ++first)
 
1331
<a name="l01304"></a>01304             {
 
1332
<a name="l01305"></a>01305                 <span class="keywordtype">unsigned</span> is_set;
 
1333
<a name="l01306"></a>01306                 <span class="keywordtype">unsigned</span> nbit   = (*first) &amp; <a class="code" href="a00110.html#a201fb8b1f81b7487f1c1c129fc3d6557">bm::set_block_mask</a>; 
 
1334
<a name="l01307"></a>01307                 
 
1335
<a name="l01308"></a>01308                 is_set = <a class="code" href="a00114.html#ga866352ef5986a7d2b709795d127b666b" title="Tests if bit = pos is true.">gap_test</a>(gap_blk, nbit);
 
1336
<a name="l01309"></a>01309                 <span class="keywordflow">if</span> (!is_set)
 
1337
<a name="l01310"></a>01310                     <span class="keywordflow">continue</span>;
 
1338
<a name="l01311"></a>01311                 
 
1339
<a name="l01312"></a>01312                 <span class="keywordtype">unsigned</span> new_block_len =
 
1340
<a name="l01313"></a>01313                     <a class="code" href="a00114.html#ga69186bd13bda27e04b3e33683ff884c2" title="Abstract distance(similarity) operation for GAP buffers. Receives functor F as a...">gap_set_value</a>(<span class="keyword">false</span>, gap_blk, nbit, &amp;is_set);
 
1341
<a name="l01314"></a>01314                 <span class="keywordflow">if</span> (new_block_len &gt; threshold) 
 
1342
<a name="l01315"></a>01315                 {
 
1343
<a name="l01316"></a>01316                     bman.extend_gap_block(nblock, gap_blk);
 
1344
<a name="l01317"></a>01317                     ++first;
 
1345
<a name="l01318"></a>01318                     <span class="keywordflow">goto</span> label1;  <span class="comment">// block pointer changed - goto reset</span>
 
1346
<a name="l01319"></a>01319                 }
 
1347
<a name="l01320"></a>01320             }
 
1348
<a name="l01321"></a>01321         }
 
1349
<a name="l01322"></a>01322         <span class="keywordflow">else</span> <span class="comment">// bit block</span>
 
1350
<a name="l01323"></a>01323         {
 
1351
<a name="l01324"></a>01324             <span class="keywordflow">for</span> (; first &lt; right; ++first)
 
1352
<a name="l01325"></a>01325             {
 
1353
<a name="l01326"></a>01326                 <span class="keywordtype">unsigned</span> nbit   = unsigned(*first &amp; <a class="code" href="a00110.html#a201fb8b1f81b7487f1c1c129fc3d6557">bm::set_block_mask</a>); 
 
1354
<a name="l01327"></a>01327                 <span class="keywordtype">unsigned</span> nword  = unsigned(nbit &gt;&gt; <a class="code" href="a00110.html#a83d76bccf6fe3770f32d5ba11d2a37ad">bm::set_word_shift</a>); 
 
1355
<a name="l01328"></a>01328                 nbit &amp;= <a class="code" href="a00110.html#addbf345be3733d5e4575d71733ed1da8">bm::set_word_mask</a>;
 
1356
<a name="l01329"></a>01329                 blk[nword] &amp;= ~((<a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>)1 &lt;&lt; nbit);
 
1357
<a name="l01330"></a>01330             } <span class="comment">// for</span>
 
1358
<a name="l01331"></a>01331         }
 
1359
<a name="l01332"></a>01332     } <span class="comment">// while</span>
 
1360
<a name="l01333"></a>01333     
 
1361
<a name="l01334"></a>01334     bv.forget_count();
 
1362
<a name="l01335"></a>01335 }
 
1363
<a name="l01336"></a>01336 <span class="comment"></span>
 
1364
<a name="l01337"></a>01337 <span class="comment">/**</span>
 
1365
<a name="l01338"></a>01338 <span class="comment">    \brief AND Combine bitvector and the iterable sequence </span>
 
1366
<a name="l01339"></a>01339 <span class="comment"></span>
 
1367
<a name="l01340"></a>01340 <span class="comment">    Algorithm combines bvector with sorted sequence of integers </span>
 
1368
<a name="l01341"></a>01341 <span class="comment">    (represents another set).</span>
 
1369
<a name="l01342"></a>01342 <span class="comment">    </span>
 
1370
<a name="l01343"></a>01343 <span class="comment">    \param bv     - destination bitvector</span>
 
1371
<a name="l01344"></a>01344 <span class="comment">    \param first  - first element of the iterated sequence</span>
 
1372
<a name="l01345"></a>01345 <span class="comment">    \param last   - last element of the iterated sequence</span>
 
1373
<a name="l01346"></a>01346 <span class="comment">    </span>
 
1374
<a name="l01347"></a>01347 <span class="comment">    \ingroup setalgo</span>
 
1375
<a name="l01348"></a>01348 <span class="comment">*/</span>
 
1376
<a name="l01349"></a>01349 <span class="keyword">template</span>&lt;<span class="keyword">class</span> BV, <span class="keyword">class</span> It&gt;
 
1377
<a name="l01350"></a><a class="code" href="a00119.html#ga22922f71bd1eec8a5b663dc77b90cf6c">01350</a> <span class="keywordtype">void</span> <a class="code" href="a00119.html#ga22922f71bd1eec8a5b663dc77b90cf6c" title="AND Combine bitvector and the iterable sequence.">combine_and_sorted</a>(BV&amp; bv, It  first, It last)
 
1378
<a name="l01351"></a>01351 {
 
1379
<a name="l01352"></a>01352     <a class="code" href="a00110.html#aa3824d882a037396370b16f2f0a8bf37">bm::id_t</a> prev = 0;
 
1380
<a name="l01353"></a>01353     <span class="keywordflow">for</span> ( ;first &lt; last; ++first)
 
1381
<a name="l01354"></a>01354     {
 
1382
<a name="l01355"></a>01355         <a class="code" href="a00110.html#aa3824d882a037396370b16f2f0a8bf37">bm::id_t</a> <span class="keywordtype">id</span> = *first;
 
1383
<a name="l01356"></a>01356         <a class="code" href="a00089.html#aa44515fab0ace8928d1cb82009a95bf8">BM_ASSERT</a>(<span class="keywordtype">id</span> &gt;= prev); <span class="comment">// make sure it&apos;s sorted</span>
 
1384
<a name="l01357"></a>01357         bv.set_bit_and(<span class="keywordtype">id</span>, <span class="keyword">true</span>);
 
1385
<a name="l01358"></a>01358         <span class="keywordflow">if</span> (++prev &lt; <span class="keywordtype">id</span>) 
 
1386
<a name="l01359"></a>01359         {
 
1387
<a name="l01360"></a>01360             bv.set_range(prev, <span class="keywordtype">id</span>-1, <span class="keyword">false</span>);
 
1388
<a name="l01361"></a>01361         }
 
1389
<a name="l01362"></a>01362         prev = id;
 
1390
<a name="l01363"></a>01363     }
 
1391
<a name="l01364"></a>01364 }
 
1392
<a name="l01365"></a>01365 
 
1393
<a name="l01366"></a>01366 <span class="comment"></span>
 
1394
<a name="l01367"></a>01367 <span class="comment">/**</span>
 
1395
<a name="l01368"></a>01368 <span class="comment">    \brief AND Combine bitvector and the iterable sequence </span>
 
1396
<a name="l01369"></a>01369 <span class="comment"></span>
 
1397
<a name="l01370"></a>01370 <span class="comment">    Algorithm combines bvector with sequence of integers </span>
 
1398
<a name="l01371"></a>01371 <span class="comment">    (represents another set). When the agrument set is sorted </span>
 
1399
<a name="l01372"></a>01372 <span class="comment">    this method can give serious increase in performance.</span>
 
1400
<a name="l01373"></a>01373 <span class="comment">    </span>
 
1401
<a name="l01374"></a>01374 <span class="comment">    \param bv     - destination bitvector</span>
 
1402
<a name="l01375"></a>01375 <span class="comment">    \param first  - first element of the iterated sequence</span>
 
1403
<a name="l01376"></a>01376 <span class="comment">    \param last   - last element of the iterated sequence</span>
 
1404
<a name="l01377"></a>01377 <span class="comment">    </span>
 
1405
<a name="l01378"></a>01378 <span class="comment">    \ingroup setalgo</span>
 
1406
<a name="l01379"></a>01379 <span class="comment">    \sa combine_and_sorted</span>
 
1407
<a name="l01380"></a>01380 <span class="comment">*/</span>
 
1408
<a name="l01381"></a>01381 <span class="keyword">template</span>&lt;<span class="keyword">class</span> BV, <span class="keyword">class</span> It&gt;
 
1409
<a name="l01382"></a><a class="code" href="a00119.html#ga819bdab57a624a08456ea79161b9c5d2">01382</a> <span class="keywordtype">void</span> <a class="code" href="a00119.html#ga819bdab57a624a08456ea79161b9c5d2" title="AND Combine bitvector and the iterable sequence.">combine_and</a>(BV&amp; bv, It  first, It last)
 
1410
<a name="l01383"></a>01383 {
 
1411
<a name="l01384"></a>01384     BV bv_tmp;
 
1412
<a name="l01385"></a>01385     <a class="code" href="a00119.html#ga54ff78528c99ae3ca443eb99ba44785b" title="OR Combine bitvector and the iterable sequence.">combine_or</a>(bv_tmp, first, last);
 
1413
<a name="l01386"></a>01386     bv &amp;= bv_tmp;
 
1414
<a name="l01387"></a>01387 }
 
1415
<a name="l01388"></a>01388 <span class="comment"></span>
 
1416
<a name="l01389"></a>01389 <span class="comment">/*!</span>
 
1417
<a name="l01390"></a>01390 <span class="comment">    \brief Compute number of bit intervals (GAPs) in the bitvector</span>
 
1418
<a name="l01391"></a>01391 <span class="comment">    </span>
 
1419
<a name="l01392"></a>01392 <span class="comment">    Algorithm traverses bit vector and count number of uninterrupted</span>
 
1420
<a name="l01393"></a>01393 <span class="comment">    intervals of 1s and 0s.</span>
 
1421
<a name="l01394"></a>01394 <span class="comment">    &lt;pre&gt;</span>
 
1422
<a name="l01395"></a>01395 <span class="comment">    For example: </span>
 
1423
<a name="l01396"></a>01396 <span class="comment">      00001111100000 - gives us 3 intervals</span>
 
1424
<a name="l01397"></a>01397 <span class="comment">      10001111100000 - 4 intervals</span>
 
1425
<a name="l01398"></a>01398 <span class="comment">      00000000000000 - 1 interval</span>
 
1426
<a name="l01399"></a>01399 <span class="comment">      11111111111111 - 1 interval</span>
 
1427
<a name="l01400"></a>01400 <span class="comment">    &lt;/pre&gt;</span>
 
1428
<a name="l01401"></a>01401 <span class="comment">    \return Number of intervals</span>
 
1429
<a name="l01402"></a>01402 <span class="comment">    \ingroup setalgo</span>
 
1430
<a name="l01403"></a>01403 <span class="comment">*/</span>
 
1431
<a name="l01404"></a>01404 <span class="keyword">template</span>&lt;<span class="keyword">class</span> BV&gt;
 
1432
<a name="l01405"></a><a class="code" href="a00119.html#gac7a59d3bc266310ec127cb3efadb0d33">01405</a> <a class="code" href="a00110.html#aa3824d882a037396370b16f2f0a8bf37">bm::id_t</a> <a class="code" href="a00119.html#gac7a59d3bc266310ec127cb3efadb0d33" title="Compute number of bit intervals (GAPs) in the bitvector.">count_intervals</a>(<span class="keyword">const</span> BV&amp; bv)
 
1433
<a name="l01406"></a>01406 {
 
1434
<a name="l01407"></a>01407     <span class="keyword">const</span> <span class="keyword">typename</span> BV::blocks_manager_type&amp; bman = bv.get_blocks_manager();
 
1435
<a name="l01408"></a>01408 
 
1436
<a name="l01409"></a>01409     <a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>*** blk_root = bman.get_rootblock();
 
1437
<a name="l01410"></a>01410     <span class="keyword">typename</span> BV::blocks_manager_type::block_count_change_func func(bman);
 
1438
<a name="l01411"></a>01411     <a class="code" href="a00110.html#a86742a3e17527be5a9743f26b36a7691">for_each_block</a>(blk_root, bman.top_block_size(), <a class="code" href="a00110.html#a40ad34d6c46a2fb20ba2baa7f95d80b4">bm::set_array_size</a>, func);
 
1439
<a name="l01412"></a>01412 
 
1440
<a name="l01413"></a>01413     <span class="keywordflow">return</span> func.count();        
 
1441
<a name="l01414"></a>01414 }
 
1442
<a name="l01415"></a>01415 <span class="comment"></span>
 
1443
<a name="l01416"></a>01416 <span class="comment">/*!</span>
 
1444
<a name="l01417"></a>01417 <span class="comment">    \brief Export bitset from an array of binary data representing</span>
 
1445
<a name="l01418"></a>01418 <span class="comment">    the bit vector. </span>
 
1446
<a name="l01419"></a>01419 <span class="comment"></span>
 
1447
<a name="l01420"></a>01420 <span class="comment">    Input array can be array of ints, chars or other native C types.</span>
 
1448
<a name="l01421"></a>01421 <span class="comment">    Method works with iterators, which makes it compatible with </span>
 
1449
<a name="l01422"></a>01422 <span class="comment">    STL containers and C arrays</span>
 
1450
<a name="l01423"></a>01423 <span class="comment"></span>
 
1451
<a name="l01424"></a>01424 <span class="comment">    \param bv     - destination bitvector</span>
 
1452
<a name="l01425"></a>01425 <span class="comment">    \param first  - first element of the iterated sequence</span>
 
1453
<a name="l01426"></a>01426 <span class="comment">    \param last   - last element of the iterated sequence</span>
 
1454
<a name="l01427"></a>01427 <span class="comment"></span>
 
1455
<a name="l01428"></a>01428 <span class="comment">    \ingroup setalgo</span>
 
1456
<a name="l01429"></a>01429 <span class="comment">*/</span>
 
1457
<a name="l01430"></a>01430 <span class="keyword">template</span>&lt;<span class="keyword">class</span> BV, <span class="keyword">class</span> It&gt;
 
1458
<a name="l01431"></a><a class="code" href="a00119.html#gacd88ed9539553dd93419b7029e8a4584">01431</a> <span class="keywordtype">void</span> <a class="code" href="a00119.html#gacd88ed9539553dd93419b7029e8a4584" title="Export bitset from an array of binary data representing the bit vector.">export_array</a>(BV&amp; bv, It first, It last)
 
1459
<a name="l01432"></a>01432 {
 
1460
<a name="l01433"></a>01433     <span class="keyword">typename</span> BV::blocks_manager_type&amp; bman = bv.get_blocks_manager();
 
1461
<a name="l01434"></a>01434     <span class="keywordtype">unsigned</span> inp_word_size = <span class="keyword">sizeof</span>(*first);
 
1462
<a name="l01435"></a>01435     <span class="keywordtype">size_t</span> array_size = last - first;
 
1463
<a name="l01436"></a>01436     <span class="keywordtype">size_t</span> bit_cnt = array_size * inp_word_size * 8;
 
1464
<a name="l01437"></a>01437     <span class="keywordtype">int</span> block_type;
 
1465
<a name="l01438"></a>01438     <a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a> tmp;
 
1466
<a name="l01439"></a>01439     <span class="keywordtype">unsigned</span> b1, b2, b3, b4;
 
1467
<a name="l01440"></a>01440 
 
1468
<a name="l01441"></a>01441     <span class="keywordflow">if</span> (bit_cnt &gt;= bv.size())
 
1469
<a name="l01442"></a>01442         bv.resize((<a class="code" href="a00110.html#aa3824d882a037396370b16f2f0a8bf37">bm::id_t</a>)bit_cnt + 1);
 
1470
<a name="l01443"></a>01443     <span class="keywordflow">else</span> 
 
1471
<a name="l01444"></a>01444         bv.set_range((<a class="code" href="a00110.html#aa3824d882a037396370b16f2f0a8bf37">bm::id_t</a>)bit_cnt, bv.size() - 1, <span class="keyword">false</span>);
 
1472
<a name="l01445"></a>01445     
 
1473
<a name="l01446"></a>01446     <span class="keywordflow">switch</span> (inp_word_size)
 
1474
<a name="l01447"></a>01447     {
 
1475
<a name="l01448"></a>01448     <span class="keywordflow">case</span> 1:
 
1476
<a name="l01449"></a>01449         {
 
1477
<a name="l01450"></a>01450             <span class="keywordtype">size_t</span> word_cnt = array_size / 4;
 
1478
<a name="l01451"></a>01451             <span class="keywordflow">for</span> (<span class="keywordtype">unsigned</span> i = 0; i &lt; <a class="code" href="a00110.html#a505011007f54598794e0b9477c0b0b11">bm::set_total_blocks</a>; ++i)
 
1479
<a name="l01452"></a>01452             {
 
1480
<a name="l01453"></a>01453                 <a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>* blk = 
 
1481
<a name="l01454"></a>01454                     bman.check_allocate_block(i, 
 
1482
<a name="l01455"></a>01455                                               <span class="keyword">false</span>, 
 
1483
<a name="l01456"></a>01456                                               <a class="code" href="a00113.html#ggad0b87b3b7292383a864d27feaf1c9effa40920ae0ef7b4411d60463d8f576b5ba" title="No GAP compression strategy. All new blocks are bit blocks.">BM_BIT</a>, 
 
1484
<a name="l01457"></a>01457                                               &amp;block_type,
 
1485
<a name="l01458"></a>01458                                               <span class="keyword">false</span> <span class="comment">/*no NULL ret*/</span>);
 
1486
<a name="l01459"></a>01459                 <span class="keywordflow">if</span> (block_type == 1) <span class="comment">// gap</span>
 
1487
<a name="l01460"></a>01460                 {
 
1488
<a name="l01461"></a>01461                     blk = bman.convert_gap2bitset(i, <a class="code" href="a00089.html#a6a7c8b8ee3f3b60ab907c1699acb7aa0">BMGAP_PTR</a>(blk));
 
1489
<a name="l01462"></a>01462                 }
 
1490
<a name="l01463"></a>01463                 
 
1491
<a name="l01464"></a>01464                 <a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>* wrd_ptr = blk;
 
1492
<a name="l01465"></a>01465                 <span class="keywordflow">if</span> (word_cnt &gt;= <a class="code" href="a00110.html#a91319dbc0d0e1bf3a3efc4d92bac7972">bm::set_block_size</a>) {
 
1493
<a name="l01466"></a>01466                     <a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>* wrd_end = blk + <a class="code" href="a00110.html#a91319dbc0d0e1bf3a3efc4d92bac7972">bm::set_block_size</a>;
 
1494
<a name="l01467"></a>01467                     <span class="keywordflow">do</span> {
 
1495
<a name="l01468"></a>01468                         b1 = *first++; b2 = *first++;
 
1496
<a name="l01469"></a>01469                         b3 = *first++; b4 = *first++;
 
1497
<a name="l01470"></a>01470                         tmp = b1 | (b2 &lt;&lt; 8) | (b3 &lt;&lt; 16) | (b4 &lt;&lt; 24);
 
1498
<a name="l01471"></a>01471                         *wrd_ptr++ = tmp;
 
1499
<a name="l01472"></a>01472                     } <span class="keywordflow">while</span> (wrd_ptr &lt; wrd_end);
 
1500
<a name="l01473"></a>01473                     word_cnt -= bm::set_block_size;
 
1501
<a name="l01474"></a>01474                 } 
 
1502
<a name="l01475"></a>01475                 <span class="keywordflow">else</span> 
 
1503
<a name="l01476"></a>01476                 {
 
1504
<a name="l01477"></a>01477                     <span class="keywordtype">size_t</span> to_convert = last - first;
 
1505
<a name="l01478"></a>01478                     <span class="keywordflow">for</span> (<span class="keywordtype">size_t</span> j = 0; j &lt; to_convert / 4; ++j)
 
1506
<a name="l01479"></a>01479                     {
 
1507
<a name="l01480"></a>01480                         b1 = *first++; b2 = *first++;
 
1508
<a name="l01481"></a>01481                         b3 = *first++; b4 = *first++;
 
1509
<a name="l01482"></a>01482                         tmp = b1 | (b2 &lt;&lt; 8) | (b3 &lt;&lt; 16) | (b4 &lt;&lt; 24);
 
1510
<a name="l01483"></a>01483                         *wrd_ptr++ = tmp;
 
1511
<a name="l01484"></a>01484                     }
 
1512
<a name="l01485"></a>01485                     <span class="keywordflow">while</span> (1)
 
1513
<a name="l01486"></a>01486                     {
 
1514
<a name="l01487"></a>01487                         <span class="keywordflow">if</span> (first == last) <span class="keywordflow">break</span>;
 
1515
<a name="l01488"></a>01488                         *wrd_ptr = *first++;
 
1516
<a name="l01489"></a>01489                         <span class="keywordflow">if</span> (first == last) <span class="keywordflow">break</span>;
 
1517
<a name="l01490"></a>01490                         *wrd_ptr |= (*first++) &lt;&lt; 8;
 
1518
<a name="l01491"></a>01491                         <span class="keywordflow">if</span> (first == last) <span class="keywordflow">break</span>;
 
1519
<a name="l01492"></a>01492                         *wrd_ptr |= (*first++) &lt;&lt; 16;
 
1520
<a name="l01493"></a>01493                         <span class="keywordflow">if</span> (first == last) <span class="keywordflow">break</span>;
 
1521
<a name="l01494"></a>01494                         *wrd_ptr |= (*first++) &lt;&lt; 24;
 
1522
<a name="l01495"></a>01495                         ++wrd_ptr;
 
1523
<a name="l01496"></a>01496                     }
 
1524
<a name="l01497"></a>01497                 }
 
1525
<a name="l01498"></a>01498                 <span class="keywordflow">if</span> (first == last) <span class="keywordflow">break</span>;
 
1526
<a name="l01499"></a>01499             } <span class="comment">// for</span>
 
1527
<a name="l01500"></a>01500         }
 
1528
<a name="l01501"></a>01501         <span class="keywordflow">break</span>;
 
1529
<a name="l01502"></a>01502     <span class="keywordflow">case</span> 2:
 
1530
<a name="l01503"></a>01503         {
 
1531
<a name="l01504"></a>01504             <span class="keywordtype">size_t</span> word_cnt = array_size / 2;
 
1532
<a name="l01505"></a>01505             <span class="keywordflow">for</span> (<span class="keywordtype">unsigned</span> i = 0; i &lt; <a class="code" href="a00110.html#a505011007f54598794e0b9477c0b0b11">bm::set_total_blocks</a>; ++i)
 
1533
<a name="l01506"></a>01506             {
 
1534
<a name="l01507"></a>01507                 <a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>* blk = 
 
1535
<a name="l01508"></a>01508                     bman.check_allocate_block(i, 
 
1536
<a name="l01509"></a>01509                                               <span class="keyword">false</span>, 
 
1537
<a name="l01510"></a>01510                                               <a class="code" href="a00113.html#ggad0b87b3b7292383a864d27feaf1c9effa40920ae0ef7b4411d60463d8f576b5ba" title="No GAP compression strategy. All new blocks are bit blocks.">BM_BIT</a>, 
 
1538
<a name="l01511"></a>01511                                               &amp;block_type,
 
1539
<a name="l01512"></a>01512                                               <span class="keyword">false</span> <span class="comment">/*no NULL ret*/</span>);
 
1540
<a name="l01513"></a>01513                 <span class="keywordflow">if</span> (block_type == 1) <span class="comment">// gap</span>
 
1541
<a name="l01514"></a>01514                 {
 
1542
<a name="l01515"></a>01515                     blk = bman.convert_gap2bitset(i, <a class="code" href="a00089.html#a6a7c8b8ee3f3b60ab907c1699acb7aa0">BMGAP_PTR</a>(blk));
 
1543
<a name="l01516"></a>01516                 }
 
1544
<a name="l01517"></a>01517                 
 
1545
<a name="l01518"></a>01518                 <a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>* wrd_ptr = blk;
 
1546
<a name="l01519"></a>01519                 <span class="keywordflow">if</span> (word_cnt &gt;= <a class="code" href="a00110.html#a91319dbc0d0e1bf3a3efc4d92bac7972">bm::set_block_size</a>) {
 
1547
<a name="l01520"></a>01520                     <a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>* wrd_end = blk + <a class="code" href="a00110.html#a91319dbc0d0e1bf3a3efc4d92bac7972">bm::set_block_size</a>;
 
1548
<a name="l01521"></a>01521                     <span class="keywordflow">do</span> {
 
1549
<a name="l01522"></a>01522                         b1 = *first++; b2 = *first++;
 
1550
<a name="l01523"></a>01523                         tmp = b1 | (b2 &lt;&lt; 16);
 
1551
<a name="l01524"></a>01524                         *wrd_ptr++ = tmp;
 
1552
<a name="l01525"></a>01525                     } <span class="keywordflow">while</span> (wrd_ptr &lt; wrd_end);
 
1553
<a name="l01526"></a>01526                     word_cnt -= bm::set_block_size;
 
1554
<a name="l01527"></a>01527                 } 
 
1555
<a name="l01528"></a>01528                 <span class="keywordflow">else</span> 
 
1556
<a name="l01529"></a>01529                 {
 
1557
<a name="l01530"></a>01530                     <span class="keywordtype">size_t</span> to_convert = last - first;
 
1558
<a name="l01531"></a>01531                     <span class="keywordflow">for</span> (<span class="keywordtype">unsigned</span> j = 0; j &lt; to_convert / 2; ++j)
 
1559
<a name="l01532"></a>01532                     {
 
1560
<a name="l01533"></a>01533                         b1 = *first++; b2 = *first++;
 
1561
<a name="l01534"></a>01534                         tmp = b1 | (b2 &lt;&lt; 16);
 
1562
<a name="l01535"></a>01535                         *wrd_ptr++ = tmp;
 
1563
<a name="l01536"></a>01536                     }
 
1564
<a name="l01537"></a>01537                     <span class="keywordflow">while</span> (1)
 
1565
<a name="l01538"></a>01538                     {
 
1566
<a name="l01539"></a>01539                         <span class="keywordflow">if</span> (first == last) <span class="keywordflow">break</span>;
 
1567
<a name="l01540"></a>01540                         *wrd_ptr = *first++;
 
1568
<a name="l01541"></a>01541                         <span class="keywordflow">if</span> (first == last) <span class="keywordflow">break</span>;
 
1569
<a name="l01542"></a>01542                         *wrd_ptr |= (*first++) &lt;&lt; 16;
 
1570
<a name="l01543"></a>01543                         ++wrd_ptr;
 
1571
<a name="l01544"></a>01544                     }
 
1572
<a name="l01545"></a>01545                 }
 
1573
<a name="l01546"></a>01546                 <span class="keywordflow">if</span> (first == last) <span class="keywordflow">break</span>;
 
1574
<a name="l01547"></a>01547             } <span class="comment">// for</span>
 
1575
<a name="l01548"></a>01548         }
 
1576
<a name="l01549"></a>01549         <span class="keywordflow">break</span>;
 
1577
<a name="l01550"></a>01550     <span class="keywordflow">case</span> 4:
 
1578
<a name="l01551"></a>01551         {
 
1579
<a name="l01552"></a>01552             <span class="keywordtype">size_t</span> word_cnt = array_size;
 
1580
<a name="l01553"></a>01553             <span class="keywordflow">for</span> (<span class="keywordtype">unsigned</span> i = 0; i &lt; <a class="code" href="a00110.html#a505011007f54598794e0b9477c0b0b11">bm::set_total_blocks</a>; ++i)
 
1581
<a name="l01554"></a>01554             {
 
1582
<a name="l01555"></a>01555                 <a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>* blk = 
 
1583
<a name="l01556"></a>01556                     bman.check_allocate_block(i, 
 
1584
<a name="l01557"></a>01557                                               <span class="keyword">false</span>, 
 
1585
<a name="l01558"></a>01558                                               <a class="code" href="a00113.html#ggad0b87b3b7292383a864d27feaf1c9effa40920ae0ef7b4411d60463d8f576b5ba" title="No GAP compression strategy. All new blocks are bit blocks.">BM_BIT</a>, 
 
1586
<a name="l01559"></a>01559                                               &amp;block_type,
 
1587
<a name="l01560"></a>01560                                               <span class="keyword">false</span> <span class="comment">/*no NULL ret*/</span>);
 
1588
<a name="l01561"></a>01561                 <span class="keywordflow">if</span> (block_type == 1) <span class="comment">// gap</span>
 
1589
<a name="l01562"></a>01562                 {
 
1590
<a name="l01563"></a>01563                     blk = bman.convert_gap2bitset(i, <a class="code" href="a00089.html#a6a7c8b8ee3f3b60ab907c1699acb7aa0">BMGAP_PTR</a>(blk));
 
1591
<a name="l01564"></a>01564                 }
 
1592
<a name="l01565"></a>01565                 
 
1593
<a name="l01566"></a>01566                 <a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>* wrd_ptr = blk;
 
1594
<a name="l01567"></a>01567                 <span class="keywordflow">if</span> (word_cnt &gt;= <a class="code" href="a00110.html#a91319dbc0d0e1bf3a3efc4d92bac7972">bm::set_block_size</a>) {
 
1595
<a name="l01568"></a>01568                     <a class="code" href="a00110.html#a17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a>* wrd_end = blk + <a class="code" href="a00110.html#a91319dbc0d0e1bf3a3efc4d92bac7972">bm::set_block_size</a>;
 
1596
<a name="l01569"></a>01569                     <span class="keywordflow">do</span> {
 
1597
<a name="l01570"></a>01570                         *wrd_ptr++ = *first++;
 
1598
<a name="l01571"></a>01571                     } <span class="keywordflow">while</span> (wrd_ptr &lt; wrd_end);
 
1599
<a name="l01572"></a>01572                     word_cnt -= bm::set_block_size;
 
1600
<a name="l01573"></a>01573                 } 
 
1601
<a name="l01574"></a>01574                 <span class="keywordflow">else</span> 
 
1602
<a name="l01575"></a>01575                 {
 
1603
<a name="l01576"></a>01576                     <span class="keywordflow">while</span> (1)
 
1604
<a name="l01577"></a>01577                     {
 
1605
<a name="l01578"></a>01578                         <span class="keywordflow">if</span> (first == last) <span class="keywordflow">break</span>;
 
1606
<a name="l01579"></a>01579                         *wrd_ptr = *first++;
 
1607
<a name="l01580"></a>01580                         ++wrd_ptr;
 
1608
<a name="l01581"></a>01581                     }
 
1609
<a name="l01582"></a>01582                 }
 
1610
<a name="l01583"></a>01583                 <span class="keywordflow">if</span> (first == last) <span class="keywordflow">break</span>;
 
1611
<a name="l01584"></a>01584             } <span class="comment">// for</span>
 
1612
<a name="l01585"></a>01585         }
 
1613
<a name="l01586"></a>01586         <span class="keywordflow">break</span>;
 
1614
<a name="l01587"></a>01587     <span class="keywordflow">default</span>:
 
1615
<a name="l01588"></a>01588         <a class="code" href="a00089.html#aa44515fab0ace8928d1cb82009a95bf8">BM_ASSERT</a>(0);
 
1616
<a name="l01589"></a>01589     } <span class="comment">// switch</span>
 
1617
<a name="l01590"></a>01590 
 
1618
<a name="l01591"></a>01591 }
 
1619
<a name="l01592"></a>01592 
 
1620
<a name="l01593"></a>01593 } <span class="comment">// namespace bm</span>
 
1621
<a name="l01594"></a>01594 
 
1622
<a name="l01595"></a>01595 <span class="preprocessor">#ifdef _MSC_VER</span>
 
1623
<a name="l01596"></a>01596 <span class="preprocessor"></span><span class="preprocessor">#pragma warning( default : 4311 4312)</span>
 
1624
<a name="l01597"></a>01597 <span class="preprocessor"></span><span class="preprocessor">#endif</span>
 
1625
<a name="l01598"></a>01598 <span class="preprocessor"></span>
 
1626
<a name="l01599"></a>01599 <span class="preprocessor">#endif</span>
189
1627
</pre></div></div>
190
 
<hr size="1"><address style="text-align: right;"><small>Generated on Sat Aug 8 12:21:27 2009 for BitMagic by&nbsp;
 
1628
<hr size="1"/><address style="text-align: right;"><small>Generated on Sun Nov 22 10:49:35 2009 for BitMagic by&nbsp;
191
1629
<a href="http://www.doxygen.org/index.html">
192
 
<img src="doxygen.png" alt="doxygen" align="middle" border="0"></a> 1.5.9 </small></address>
 
1630
<img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.6.1 </small></address>
193
1631
</body>
194
1632
</html>