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: bvector serialization</title>
4
<link href="doxygen.css" rel="stylesheet" type="text/css">
5
<link href="tabs.css" rel="stylesheet" type="text/css">
7
<!-- Generated by Doxygen 1.5.5 -->
8
<div class="navigation" id="top">
11
<li><a href="index.html"><span>Main Page</span></a></li>
12
<li><a href="modules.html"><span>Modules</span></a></li>
13
<li><a href="namespaces.html"><span>Namespaces</span></a></li>
14
<li><a href="classes.html"><span>Data Structures</span></a></li>
15
<li><a href="files.html"><span>Files</span></a></li>
16
<li><a href="examples.html"><span>Examples</span></a></li>
20
<div class="contents">
21
<h1>bvector serialization<br>
23
[<a class="el" href="a00108.html">BitMagic C++ Library</a>]</small>
26
<div class="dynheader">
27
Collaboration diagram for bvector serialization:</div>
28
<div class="dynsection">
29
<center><table><tr><td><img src="a00116.png" border="0" alt="" usemap="#a00184_map">
30
<map name="a00184_map">
31
<area shape="rect" id="node1" href="a00108.html" title="For more information please visit: http://bmagic.sourceforge.net." alt="" coords="5,5,149,33">
b'</map></td></tr></table></center>'
33
<table border="0" cellpadding="0" cellspacing="0">
35
<tr><td colspan="2"><br><h2>Data Structures</h2></td></tr>
36
<tr><td class="memItemLeft" nowrap align="right" valign="top">class </td><td class="memItemRight" valign="bottom"><a class="el" href="a00079.html">bm::serializer< BV ></a></td></tr>
38
<tr><td class="mdescLeft"> </td><td class="mdescRight">Bit-vector serialization class. <a href="a00079.html#_details">More...</a><br></td></tr>
39
<tr><td class="memItemLeft" nowrap align="right" valign="top">class </td><td class="memItemRight" valign="bottom"><a class="el" href="a00078.html">bm::serial_stream_iterator< DEC ></a></td></tr>
41
<tr><td class="mdescLeft"> </td><td class="mdescRight">Serialization stream iterator. <a href="a00078.html#_details">More...</a><br></td></tr>
42
<tr><td class="memItemLeft" nowrap align="right" valign="top">class </td><td class="memItemRight" valign="bottom"><a class="el" href="a00075.html">bm::operation_deserializer< BV ></a></td></tr>
44
<tr><td class="mdescLeft"> </td><td class="mdescRight">Class <a class="el" href="a00061.html" title="Class deserializer.">deserializer</a>, can perform logical operation on bit-vector and serialized bit-vector. <a href="a00075.html#_details">More...</a><br></td></tr>
45
<tr><td class="memItemLeft" nowrap align="right" valign="top">class </td><td class="memItemRight" valign="bottom"><a class="el" href="a00061.html">bm::deserializer< BV, DEC ></a></td></tr>
47
<tr><td class="mdescLeft"> </td><td class="mdescRight">Class <a class="el" href="a00061.html" title="Class deserializer.">deserializer</a>. <a href="a00061.html#_details">More...</a><br></td></tr>
48
<tr><td colspan="2"><br><h2>Enumerations</h2></td></tr>
49
<tr><td class="memItemLeft" nowrap align="right" valign="top">enum </td><td class="memItemRight" valign="bottom"><a class="el" href="a00116.html#g537dfe6318f1f1fe18d86dac312be978">bm::serialization_flags</a> { <a class="el" href="a00116.html#gg537dfe6318f1f1fe18d86dac312be978cdd8c071c079589388c3ca7bd4f367c8">bm::BM_NO_BYTE_ORDER</a> = 1,
50
<a class="el" href="a00116.html#gg537dfe6318f1f1fe18d86dac312be9785521473081d341bc32ac59538e6a8096">bm::BM_NO_GAP_LENGTH</a> = (1 << 1)
53
<tr><td class="mdescLeft"> </td><td class="mdescRight">Bit mask flags for serialization algorithm. <a href="a00116.html#g537dfe6318f1f1fe18d86dac312be978">More...</a><br></td></tr>
54
<tr><td colspan="2"><br><h2>Functions</h2></td></tr>
55
<tr><td class="memTemplParams" nowrap colspan="2">template<class BV> </td></tr>
56
<tr><td class="memTemplItemLeft" nowrap align="right" valign="top">unsigned </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="a00116.html#g5210c3bda57254ef2e8c71e23306cc88">bm::serialize</a> (const BV &bv, unsigned char *buf, <a class="el" href="a00106.html#17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a> *temp_block, unsigned serialization_flags=0)</td></tr>
58
<tr><td class="mdescLeft"> </td><td class="mdescRight">Saves bitvector into memory. <a href="#g5210c3bda57254ef2e8c71e23306cc88"></a><br></td></tr>
59
<tr><td class="memTemplParams" nowrap colspan="2">template<class BV> </td></tr>
60
<tr><td class="memTemplItemLeft" nowrap align="right" valign="top">unsigned </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="a00116.html#g213033b5cc6add74aa4bd1d614b56192">bm::serialize</a> (BV &bv, unsigned char *buf, unsigned serialization_flags=0)</td></tr>
62
<tr><td class="mdescLeft"> </td><td class="mdescRight">Saves bitvector into memory. Allocates temporary memory block for <a class="el" href="a00040.html" title="bitvector with runtime compression of bits.">bvector</a>. <a href="#g213033b5cc6add74aa4bd1d614b56192"></a><br></td></tr>
63
<tr><td class="memTemplParams" nowrap colspan="2">template<class BV> </td></tr>
64
<tr><td class="memTemplItemLeft" nowrap align="right" valign="top">unsigned </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="a00116.html#gfbe633db8da3d867f098468269fd8d3d">bm::deserialize</a> (BV &bv, const unsigned char *buf, <a class="el" href="a00106.html#17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a> *temp_block=0)</td></tr>
66
<tr><td class="mdescLeft"> </td><td class="mdescRight">Bitvector deserialization from memory. <a href="#gfbe633db8da3d867f098468269fd8d3d"></a><br></td></tr>
68
<hr><a name="_details"></a><h2>Detailed Description</h2>
69
bvector serialization <hr><h2>Enumeration Type Documentation</h2>
70
<a class="anchor" name="g537dfe6318f1f1fe18d86dac312be978"></a><!-- doxytag: member="bm::serialization_flags" ref="g537dfe6318f1f1fe18d86dac312be978" args="" -->
72
<div class="memproto">
73
<table class="memname">
75
<td class="memname">enum <a class="el" href="a00116.html#g537dfe6318f1f1fe18d86dac312be978">bm::serialization_flags</a> </td>
82
Bit mask flags for serialization algorithm.
84
<dl compact><dt><b>Enumerator: </b></dt><dd>
85
<table border="0" cellspacing="2" cellpadding="0">
86
<tr><td valign="top"><em><a class="anchor" name="gg537dfe6318f1f1fe18d86dac312be978cdd8c071c079589388c3ca7bd4f367c8"></a><!-- doxytag: member="BM_NO_BYTE_ORDER" ref="gg537dfe6318f1f1fe18d86dac312be978cdd8c071c079589388c3ca7bd4f367c8" args="" -->BM_NO_BYTE_ORDER</em> </td><td>
87
save no byte-order info (save some space) </td></tr>
88
<tr><td valign="top"><em><a class="anchor" name="gg537dfe6318f1f1fe18d86dac312be9785521473081d341bc32ac59538e6a8096"></a><!-- doxytag: member="BM_NO_GAP_LENGTH" ref="gg537dfe6318f1f1fe18d86dac312be9785521473081d341bc32ac59538e6a8096" args="" -->BM_NO_GAP_LENGTH</em> </td><td>
89
save no GAP info (save some space) </td></tr>
93
<p>Definition at line <a class="el" href="a00136.html#l00739">739</a> of file <a class="el" href="a00136.html">bmserial.h</a>.</p>
97
<hr><h2>Function Documentation</h2>
98
<a class="anchor" name="gfbe633db8da3d867f098468269fd8d3d"></a><!-- doxytag: member="bm::deserialize" ref="gfbe633db8da3d867f098468269fd8d3d" args="(BV &bv, const unsigned char *buf, bm::word_t *temp_block=0)" -->
100
<div class="memproto">
101
<div class="memtemplate">
102
template<class BV> </div>
103
<table class="memname">
105
<td class="memname">unsigned bm::deserialize </td>
107
<td class="paramtype">BV & </td>
108
<td class="paramname"> <em>bv</em>, </td>
111
<td class="paramkey"></td>
113
<td class="paramtype">const unsigned char * </td>
114
<td class="paramname"> <em>buf</em>, </td>
117
<td class="paramkey"></td>
119
<td class="paramtype"><a class="el" href="a00106.html#17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a> * </td>
120
<td class="paramname"> <em>temp_block</em> = <code>0</code></td><td> </td>
125
<td></td><td></td><td width="100%"><code> [inline]</code></td>
132
Bitvector deserialization from memory.
134
<dl compact><dt><b>Parameters:</b></dt><dd>
135
<table border="0" cellspacing="2" cellpadding="0">
136
<tr><td valign="top"></td><td valign="top"><em>buf</em> </td><td>- pointer on memory which keeps serialized <a class="el" href="a00040.html" title="bitvector with runtime compression of bits.">bvector</a> </td></tr>
137
<tr><td valign="top"></td><td valign="top"><em>temp_block</em> </td><td>- pointer on temporary block, if NULL <a class="el" href="a00040.html" title="bitvector with runtime compression of bits.">bvector</a> allocates own. </td></tr>
140
<dl class="return" compact><dt><b>Returns:</b></dt><dd>Number of bytes consumed by <a class="el" href="a00061.html" title="Class deserializer.">deserializer</a>.</dd></dl>
141
Function desrializes bitvector from memory block containig results of previous serialization. Function does not remove bits which are currently set. Effectively it means OR logical operation between current bitset and previously serialized one. <dl compact><dt><b>Examples: </b></dt><dd>
142
<a class="el" href="a00004.html#a16">sample4.cpp</a>.</dl>
143
<p>Definition at line <a class="el" href="a00136.html#l01064">1064</a> of file <a class="el" href="a00136.html">bmserial.h</a>.</p>
145
<p>References <a class="el" href="a00134.html#l00395">bm::BigEndian</a>, <a class="el" href="a00133.html#l00041">BM_ASSERT</a>, <a class="el" href="a00136.html#l00097">bm::BM_HM_NO_BO</a>, <a class="el" href="a00136.html#l01351">bm::deserializer< BV, DEC >::deserialize()</a>, <a class="el" href="a00142.html#l00080">bm::decoder_base::get_8()</a>, and <a class="el" href="a00134.html#l00396">bm::LittleEndian</a>.</p>
147
<p>Referenced by <a class="el" href="a00136.html#l02784">bm::operation_deserializer< BV >::deserialize()</a>, and <a class="el" href="a00122.html#l00107">main()</a>.</p>
151
<a class="anchor" name="g213033b5cc6add74aa4bd1d614b56192"></a><!-- doxytag: member="bm::serialize" ref="g213033b5cc6add74aa4bd1d614b56192" args="(BV &bv, unsigned char *buf, unsigned serialization_flags=0)" -->
152
<div class="memitem">
153
<div class="memproto">
154
<div class="memtemplate">
155
template<class BV> </div>
156
<table class="memname">
158
<td class="memname">unsigned bm::serialize </td>
160
<td class="paramtype">BV & </td>
161
<td class="paramname"> <em>bv</em>, </td>
164
<td class="paramkey"></td>
166
<td class="paramtype">unsigned char * </td>
167
<td class="paramname"> <em>buf</em>, </td>
170
<td class="paramkey"></td>
172
<td class="paramtype">unsigned </td>
173
<td class="paramname"> <em>serialization_flags</em> = <code>0</code></td><td> </td>
178
<td></td><td></td><td width="100%"><code> [inline]</code></td>
185
Saves bitvector into memory. Allocates temporary memory block for <a class="el" href="a00040.html" title="bitvector with runtime compression of bits.">bvector</a>.
188
<p>Definition at line <a class="el" href="a00136.html#l00812">812</a> of file <a class="el" href="a00136.html">bmserial.h</a>.</p>
190
<p>References <a class="el" href="a00136.html#l00740">bm::BM_NO_BYTE_ORDER</a>, <a class="el" href="a00136.html#l00741">bm::BM_NO_GAP_LENGTH</a>, <a class="el" href="a00136.html#l00281">bm::serializer< BV >::byte_order_serialization()</a>, <a class="el" href="a00136.html#l00275">bm::serializer< BV >::gap_length_serialization()</a>, <a class="el" href="a00136.html#l00529">bm::serializer< BV >::serialize()</a>, and <a class="el" href="a00136.html#l00256">bm::serializer< BV >::set_compression_level()</a>.</p>
194
<a class="anchor" name="g5210c3bda57254ef2e8c71e23306cc88"></a><!-- doxytag: member="bm::serialize" ref="g5210c3bda57254ef2e8c71e23306cc88" args="(const BV &bv, unsigned char *buf, bm::word_t *temp_block, unsigned serialization_flags=0)" -->
195
<div class="memitem">
196
<div class="memproto">
197
<div class="memtemplate">
198
template<class BV> </div>
199
<table class="memname">
201
<td class="memname">unsigned bm::serialize </td>
203
<td class="paramtype">const BV & </td>
204
<td class="paramname"> <em>bv</em>, </td>
207
<td class="paramkey"></td>
209
<td class="paramtype">unsigned char * </td>
210
<td class="paramname"> <em>buf</em>, </td>
213
<td class="paramkey"></td>
215
<td class="paramtype"><a class="el" href="a00106.html#17fd5ba52db3ddda05e6f8dd5000a1a4">bm::word_t</a> * </td>
216
<td class="paramname"> <em>temp_block</em>, </td>
219
<td class="paramkey"></td>
221
<td class="paramtype">unsigned </td>
222
<td class="paramname"> <em>serialization_flags</em> = <code>0</code></td><td> </td>
227
<td></td><td></td><td width="100%"><code> [inline]</code></td>
234
Saves bitvector into memory.
236
Function serializes content of the bitvector into memory. Serialization adaptively uses compression(variation of GAP encoding) when it is benefitial.<p>
237
<dl compact><dt><b>Parameters:</b></dt><dd>
238
<table border="0" cellspacing="2" cellpadding="0">
239
<tr><td valign="top"></td><td valign="top"><em>buf</em> </td><td>- pointer on target memory area. No range checking in the function. It is responsibility of programmer to allocate sufficient amount of memory using information from calc_stat function.</td></tr>
240
<tr><td valign="top"></td><td valign="top"><em>temp_block</em> </td><td>- pointer on temporary memory block. Cannot be 0; If you want to save memory across multiple bvectors allocate temporary block using allocate_tempblock and pass it to serialize. (Of course serialize does not deallocate temp_block.)</td></tr>
241
<tr><td valign="top"></td><td valign="top"><em>serialization_flags</em> </td><td>Flags controlling serilization (bit-mask) (use OR-ed serialization flags)</td></tr>
244
<dl class="return" compact><dt><b>Returns:</b></dt><dd>Size of serialization block. </dd></dl>
245
<dl class="see" compact><dt><b>See also:</b></dt><dd>calc_stat, <a class="el" href="a00116.html#g537dfe6318f1f1fe18d86dac312be978" title="Bit mask flags for serialization algorithm.">serialization_flags</a> </dd></dl>
247
<p>Definition at line <a class="el" href="a00136.html#l00786">786</a> of file <a class="el" href="a00136.html">bmserial.h</a>.</p>
249
<p>References <a class="el" href="a00136.html#l00740">bm::BM_NO_BYTE_ORDER</a>, <a class="el" href="a00136.html#l00741">bm::BM_NO_GAP_LENGTH</a>, <a class="el" href="a00136.html#l00281">bm::serializer< BV >::byte_order_serialization()</a>, <a class="el" href="a00136.html#l00275">bm::serializer< BV >::gap_length_serialization()</a>, <a class="el" href="a00136.html#l00529">bm::serializer< BV >::serialize()</a>, and <a class="el" href="a00136.html#l00256">bm::serializer< BV >::set_compression_level()</a>.</p>
254
<hr size="1"><address style="text-align: right;"><small>Generated on Mon Oct 12 12:16:57 2009 for BitMagic by
255
<a href="http://www.doxygen.org/index.html">
256
<img src="doxygen.png" alt="doxygen" align="middle" border="0"></a> 1.5.5 </small></address>