Newer
Older

Christian Godenschwager
committed
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
//======================================================================================================================
//
// This file is part of waLBerla. waLBerla is free software: you can
// redistribute it and/or modify it under the terms of the GNU General Public
// License as published by the Free Software Foundation, either version 3 of
// the License, or (at your option) any later version.
//
// waLBerla is distributed in the hope that it will be useful, but WITHOUT
// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
// FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
// for more details.
//
// You should have received a copy of the GNU General Public License along
// with waLBerla (see COPYING.txt). If not, see <http://www.gnu.org/licenses/>.
//
//! \file Conversion.cpp
//! \ingroup core
//! \author Sebastian Eibl <sebastian.eibl@fau.de>
//
//======================================================================================================================
//*************************************************************************************************
// Includes
//*************************************************************************************************
#include "Conversion.h"
namespace walberla {
void convert(const std::vector<bool> & from, std::vector<uint8_t> & to)
{
to.clear();
to.reserve( from.size() / 8 + 1);
auto it = from.begin();
while( it != from.end() )
{
uint8_t container = 0;
for( size_t bitPos = 0; bitPos < 8 && it != from.end(); ++bitPos, ++it )
container = numeric_cast<uint8_t>( container | numeric_cast<uint8_t>( ( static_cast<bool>( *it ) ? ( 1U << bitPos ) : 0U ) ) );
to.push_back(container);
}
}
void convert(const std::vector<uint8_t> & from, std::vector<bool> & to)
{
to.clear();
to.resize(from.size() * sizeof(uint8_t) * 8);

Christian Godenschwager
committed
auto unpackIt = from.begin();
auto it = to.begin();
while( it != to.end() )
{
uint8_t container;
container = *unpackIt;
++unpackIt;
for( size_t bitPos = 0; bitPos < 8 && it != to.end(); ++bitPos, ++it )
*it = ( container & ( static_cast<uint8_t>(1) << bitPos ) ) > 0U;
}
}
}