diff options
Diffstat (limited to 'src/boost/libs/dynamic_bitset/example')
-rw-r--r-- | src/boost/libs/dynamic_bitset/example/Jamfile | 26 | ||||
-rw-r--r-- | src/boost/libs/dynamic_bitset/example/example1.cpp | 35 | ||||
-rw-r--r-- | src/boost/libs/dynamic_bitset/example/example2.cpp | 32 | ||||
-rw-r--r-- | src/boost/libs/dynamic_bitset/example/example3.cpp | 71 | ||||
-rw-r--r-- | src/boost/libs/dynamic_bitset/example/timing_tests.cpp | 142 |
5 files changed, 306 insertions, 0 deletions
diff --git a/src/boost/libs/dynamic_bitset/example/Jamfile b/src/boost/libs/dynamic_bitset/example/Jamfile new file mode 100644 index 00000000..6b4b0f3e --- /dev/null +++ b/src/boost/libs/dynamic_bitset/example/Jamfile @@ -0,0 +1,26 @@ +# ----------------------------------------------------------- +# Copyright (c) 2002 Gennaro Prota +# +# Distributed under the Boost Software License, Version 1.0. +# (See accompanying file LICENSE_1_0.txt or copy at +# http://www.boost.org/LICENSE_1_0.txt) +# +# ----------------------------------------------------------- + +exe timing_tests + : timing_tests.cpp + ../../timer/build//boost_timer + ; + +exe example1 + : example1.cpp + ; + +exe example2 + : example2.cpp + ; + +exe example3 + : example3.cpp + ; + diff --git a/src/boost/libs/dynamic_bitset/example/example1.cpp b/src/boost/libs/dynamic_bitset/example/example1.cpp new file mode 100644 index 00000000..5a03602b --- /dev/null +++ b/src/boost/libs/dynamic_bitset/example/example1.cpp @@ -0,0 +1,35 @@ +// (C) Copyright Jeremy Siek 2001. +// Distributed under the Boost Software License, Version 1.0. (See +// accompanying file LICENSE_1_0.txt or copy at +// http://www.boost.org/LICENSE_1_0.txt) + + + +// An example of setting and reading some bits. Note that operator[] +// goes from the least-significant bit at 0 to the most significant +// bit at size()-1. The operator<< for dynamic_bitset prints the +// bitset from most-significant to least-significant, since that is +// the format most people are used to reading. +// +// The output is: +// +// 11001 +// 10011 +// --------------------------------------------------------------------- + +#include <iostream> +#include <boost/dynamic_bitset.hpp> + +int main() +{ + boost::dynamic_bitset<> x(5); // all 0's by default + x[0] = 1; + x[1] = 1; + x[4] = 1; + for (boost::dynamic_bitset<>::size_type i = 0; i < x.size(); ++i) + std::cout << x[i]; + std::cout << "\n"; + std::cout << x << "\n"; + + return 0; +} diff --git a/src/boost/libs/dynamic_bitset/example/example2.cpp b/src/boost/libs/dynamic_bitset/example/example2.cpp new file mode 100644 index 00000000..151aa337 --- /dev/null +++ b/src/boost/libs/dynamic_bitset/example/example2.cpp @@ -0,0 +1,32 @@ +// (C) Copyright Jeremy Siek 2001. +// Distributed under the Boost Software License, Version 1.0. (See +// accompanying file LICENSE_1_0.txt or copy at +// http://www.boost.org/LICENSE_1_0.txt) +// +// Sample output: +// +// bits(0) = 00 +// bits(1) = 01 +// bits(2) = 10 +// bits(3) = 11 + + +#include <iostream> +#include <boost/dynamic_bitset.hpp> + +int main() +{ + const boost::dynamic_bitset<> b0(2, 0ul); + std::cout << "bits(0) = " << b0 << std::endl; + + const boost::dynamic_bitset<> b1(2, 1ul); + std::cout << "bits(1) = " << b1 << std::endl; + + const boost::dynamic_bitset<> b2(2, 2ul); + std::cout << "bits(2) = " << b2 << std::endl; + + const boost::dynamic_bitset<> b3(2, 3ul); + std::cout << "bits(3) = " << b3 << std::endl; + + return 0; +} diff --git a/src/boost/libs/dynamic_bitset/example/example3.cpp b/src/boost/libs/dynamic_bitset/example/example3.cpp new file mode 100644 index 00000000..e78a2cd9 --- /dev/null +++ b/src/boost/libs/dynamic_bitset/example/example3.cpp @@ -0,0 +1,71 @@ +// Copyright (c) 2001 Jeremy Siek +// Copyright (c) 2008 Gennaro Prota +// Distributed under the Boost Software License, Version 1.0. (See +// accompanying file LICENSE_1_0.txt or copy at +// http://www.boost.org/LICENSE_1_0.txt) +// +// Sample run: +// +// mask = 101010101010 +// x.size() = 0 +// Enter a bitset in binary: x = 100100010 +// +// Input number: 100100010 +// x.size() is now: 9 +// As unsigned long: 290 +// Mask (possibly resized): 010101010 +// And with mask: 000100010 +// Or with mask: 110101010 +// Shifted left by 1: 001000100 +// Shifted right by 1: 010010001 + + + +#include "boost/dynamic_bitset.hpp" + +#include <ostream> +#include <iostream> + +int main() +{ + boost::dynamic_bitset<> mask(12, 2730ul); + std::cout << "mask = " << mask << std::endl; + + boost::dynamic_bitset<> x; + std::cout << "x.size() = " << x.size() << std::endl; + + std::cout << "Enter a bitset in binary: x = " << std::flush; + if (std::cin >> x) { + const std::size_t sz = x.size(); + std::cout << std::endl; + std::cout << "Input number: " << x << std::endl; + std::cout << "x.size() is now: " << sz << std::endl; + + bool fits_in_ulong = true; + unsigned long ul = 0; + try { + ul = x.to_ulong(); + } catch(std::overflow_error &) { + fits_in_ulong = false; + } + + std::cout << "As unsigned long: "; + if(fits_in_ulong) { + std::cout << ul; + } else { + std::cout << "(overflow exception)"; + } + + std::cout << std::endl; + + mask.resize(sz); + + std::cout << "Mask (possibly resized): " << mask << std::endl; + + std::cout << "And with mask: " << (x & mask) << std::endl; + std::cout << "Or with mask: " << (x | mask) << std::endl; + std::cout << "Shifted left by 1: " << (x << 1) << std::endl; + std::cout << "Shifted right by 1: " << (x >> 1) << std::endl; + } + return 0; +} diff --git a/src/boost/libs/dynamic_bitset/example/timing_tests.cpp b/src/boost/libs/dynamic_bitset/example/timing_tests.cpp new file mode 100644 index 00000000..0e96bf43 --- /dev/null +++ b/src/boost/libs/dynamic_bitset/example/timing_tests.cpp @@ -0,0 +1,142 @@ +// ----------------------------------------------------------- +// +// Copyright (c) 2003-2004 Gennaro Prota +// +// Distributed under the Boost Software License, Version 1.0. +// (See accompanying file LICENSE_1_0.txt or copy at +// http://www.boost.org/LICENSE_1_0.txt) +// +// ----------------------------------------------------------- + +// boost::dynamic_bitset timing tests +// +// NOTE: +// ~~~~~ +// This is a preliminary, incomplete version. +// +// If you are interested in having more benchmarks please make a +// request on the boost list, which could encourage me to continue +// this work. + +// Also, if you use boost::dynamic_bitset on a platform where +// CHAR_BIT >= 9 I suggest experimenting with the size of the count +// table in detail/dynamic_bitset.hpp and report any interesting +// discovery on the list as well. + +// You might also want to try both counting methods (by_bytes vs. +// by_blocks) to see if the one that is selected automatically is +// actually the fastest on your system. + +// +// +// -----------------------------------------------------------------------// + + +#include "boost/config.hpp" + +#if defined (__STL_CONFIG_H) && !defined (__STL_USE_NEW_IOSTREAMS) + // for pre 3.0 versions of libstdc++ +# define BOOST_OLD_IOSTREAMS +#endif +// ------------------------------------------------- // + +#include <typeinfo> +#include <iostream> +#if !defined(BOOST_OLD_IOSTREAMS) +# include <ostream> +#endif + + +#include "boost/cstdlib.hpp" +#include "boost/version.hpp" +#include "boost/timer/timer.hpp" +#include "boost/dynamic_bitset.hpp" + + +namespace { + + // the m_ prefixes, below, are mainly to avoid problems with g++: + // see http://gcc.gnu.org/ml/gcc-bugs/1999-03n/msg00884.html + // + class boost_version { + int m_major; + int m_minor; + int m_subminor; + + public: + boost_version(unsigned long v = BOOST_VERSION): + m_major(v / 100000), m_minor(v / 100 % 1000), m_subminor(v % 100) {} + + friend std::ostream & operator<<(std::ostream &, const boost_version &); + }; + + + // give up using basic_ostream, to avoid headaches with old libraries + std::ostream& operator<<(std::ostream& os, const boost_version & v) { + return os << v.m_major << '.' << v.m_minor << '.' << v.m_subminor; + } + +} + + +void prologue() +{ + std::cout << '\n'; + std::cout << "Compiler: " << BOOST_COMPILER << '\n'; + std::cout << "Std lib : " << BOOST_STDLIB << '\n'; + std::cout << "Boost v.: " << boost_version() << '\n'; + + std::cout << '\n'; +} + + + +template <typename T> +void timing_test(T* = 0) // dummy parameter to workaround VC6 +{ +#ifndef BOOST_NO_STRESS_TEST + const unsigned long num = 30 * 100000; +#else + const unsigned long num = 30 * 1000; +#endif + + + // This variable is printed at the end of the test, + // to prevent the optimizer from removing the call to + // count() in the loop below. + typename boost::dynamic_bitset<T>::size_type dummy = 0; + + std::cout << "\nTimings for dynamic_bitset<" << typeid(T).name() + << "> [" << num << " iterations]\n"; + std::cout << "--------------------------------------------------\n"; + + { + boost::timer::auto_cpu_timer time; + + const typename boost::dynamic_bitset<T>::size_type sz = 5000; + for (unsigned long i = 0; i < num; ++i) { + boost::dynamic_bitset<T> bs(sz, i); + dummy += bs.count(); + } + } + + std::cout << "(total count: " << dummy << ")\n\n"; +} + + + +int main() +{ + prologue(); + + timing_test<unsigned char>(); + timing_test<unsigned short>(); + timing_test<unsigned int>(); + timing_test<unsigned long>(); +# ifdef BOOST_HAS_LONG_LONG + timing_test< ::boost::ulong_long_type>(); +# endif + + return boost::exit_success; +} + |