Search code examples
c++booststdbitset

Concatenate boost::dynamic_bitset or std::bitset


what is the best way to concatenate 2 bitsets?

For example i've got

boost::dynamic_bitset<> test1( std::string("1111") );
boost::dynamic_bitset<> test2( std::string("00") );

they should be concatenated into a thrid Bitset test3 which then holds

111100 

Solutions should use boost::dynamic_bitset. If the solution works with std::bitset, it would be nice too. There should be a focus on performance when concatenating the bits.

UPDATE: I've compared both methods (stringmethod from me and Neil and shiftmethod from messenger) and the stringmethod was a lot faster (factor 10++). Code here: http://pastebin.com/HfpfYfy8

I hope Pastebin is ok for posting long code-listings. If there is a better way please contact me.


Solution

  • For the standard bitset, something like:

    #include <bitset>
    #include <string>
    #include <iostream>
    using namespace std;
    
    template <size_t N1, size_t N2 >
    bitset <N1 + N2> concat( const bitset <N1> & b1, const bitset <N2> & b2 ) {
        string s1 = b1.to_string();
        string s2 = b2.to_string();
        return bitset <N1 + N2>( s1 + s2 );
    }
    
    int main() {
        bitset <4> a( string("1010") );
        bitset <2> b( string("11") );
        cout << concat( a, b ) << endl;
    }