63 std::cout <<
"<EMPTY SET>";
65 for (; first != last; ++first)
66 std::cout << *first <<
";";
67 std::cout << std::endl;
73 std::vector<bm_size_type> &v2,
74 std::vector<bm_size_type> &v3)
154 std::vector<bm_size_type> &v2,
155 std::vector<bm_size_type> &v3)
170 std::vector<bm_size_type> &v2,
171 std::vector<bm_size_type> &v3)
212 for (
unsigned i = 0; i <
sizeof(bits) /
sizeof(bits[0]); ++i)
214 bool b = bv1.set_bit(bits[i],
true);
217 std::cout <<
"Number of bits changed:" << cnt << std::endl;
224 b = bv1.set_bit_conditional(5,
true,
false);
225 std::cout <<
"Bit 5 set:" << (b ?
" yes " :
" no ") << std::endl;
227 b = bv1.set_bit_conditional(256,
true,
false);
228 std::cout <<
"Bit 256 set:" << (b ?
" yes " :
" no ") << std::endl;
230 b = bv1.set_bit_conditional(256,
true,
true);
231 std::cout <<
"Bit 256 set:" << (b ?
" yes " :
" no ") << std::endl;
238 bv1.set_range(10, 15,
true);
241 bv1.set_range(10, 12,
false);
246 b = bv1.clear_bit(13);
247 std::cout <<
"Bit 13 set:" << (b ?
" yes " :
" no ") << std::endl;
257 bm::combine_or(bv1, &bits[0], &bits[0] + (
sizeof(bits) /
sizeof(bits[0])));
277 for (p = bv2.extract_next(p); p != 0; p = bv2.extract_next(p))
279 std::cout <<
"Extracted p = " << p << std::endl;
288 bv3.set_bit_no_check(10);
289 bv3.set_bit_no_check(100);
290 bv3.set_bit_no_check(1000);
295 std::vector<bm_size_type> v1, v2, v3;
298 for (
unsigned k = 0; k < 1000; ++k)
303 for (i = 0; i < v1.size(); ++i)
304 s = s + s* v1[i] + i;
305 for (i = 0; i < v2.size(); ++i)
306 s = s + s* v2[i] + i;
307 std::cout << s <<
"\r";
310 std::cout << std::endl <<
"Running benchmarks..." << std::endl;
319 std::cout << std::endl;
322 catch(std::exception& ex)
324 std::cerr << ex.what() << std::endl;