aboutsummaryrefslogtreecommitdiffstats
path: root/chilbert
diff options
context:
space:
mode:
Diffstat (limited to 'chilbert')
-rw-r--r--chilbert/BigBitVec.hpp6
-rw-r--r--chilbert/FixBitVec.hpp6
-rw-r--r--chilbert/Operations.hpp45
3 files changed, 36 insertions, 21 deletions
diff --git a/chilbert/BigBitVec.hpp b/chilbert/BigBitVec.hpp
index c3fe957..8d073b5 100644
--- a/chilbert/BigBitVec.hpp
+++ b/chilbert/BigBitVec.hpp
@@ -490,6 +490,12 @@ private:
};
template <>
+struct is_bitvec<CBigBitVec>
+{
+ constexpr static bool value = true;
+};
+
+template <>
void
grayCode(CBigBitVec& value)
{
diff --git a/chilbert/FixBitVec.hpp b/chilbert/FixBitVec.hpp
index f9ce94a..f782723 100644
--- a/chilbert/FixBitVec.hpp
+++ b/chilbert/FixBitVec.hpp
@@ -402,6 +402,12 @@ private:
};
template <>
+struct is_bitvec<CFixBitVec>
+{
+ constexpr static bool value = true;
+};
+
+template <>
void
grayCode(CFixBitVec& value)
{
diff --git a/chilbert/Operations.hpp b/chilbert/Operations.hpp
index 3b9dd53..d80a994 100644
--- a/chilbert/Operations.hpp
+++ b/chilbert/Operations.hpp
@@ -27,13 +27,16 @@
namespace chilbert {
-/// IntegralIndex<T> only exists if T is integral
-template <typename T>
-using IntegralIndex = std::enable_if_t<std::is_integral<T>::value, size_t>;
+/// Member `value` is true iff T is a chilbert bitset
+template <class T>
+struct is_bitvec
+{
+ static constexpr bool value = false;
+};
-/// BitsetIndex<T> only exists if T is not integral (must be a bitset)
-template <typename T>
-using BitsetIndex = std::enable_if_t<!std::is_integral<T>::value, size_t>;
+/// True iff T is a chilbert bitset
+template <class T>
+static constexpr bool is_bitvec_v = is_bitvec<T>::value;
/// Reset all bits in `field`
template <typename T>
@@ -45,7 +48,7 @@ resetBits(T& field)
/// Reset all bits in `field`
template <typename T>
-std::enable_if_t<!std::is_integral<T>::value>
+std::enable_if_t<is_bitvec_v<T>>
resetBits(T& field)
{
field.reset();
@@ -53,8 +56,8 @@ resetBits(T& field)
/// Return the `index`th bit in `field`
template <typename T>
-bool
-testBit(const T& field, const IntegralIndex<T> index)
+std::enable_if_t<std::is_integral<T>::value, bool>
+testBit(const T& field, const size_t index)
{
assert(size_t(index) < sizeof(field) * CHAR_BIT);
return field & (T{1} << index);
@@ -62,16 +65,16 @@ testBit(const T& field, const IntegralIndex<T> index)
/// Return the `index`th bit in `field`
template <typename T>
-bool
-testBit(const T& field, const BitsetIndex<T> index)
+std::enable_if_t<is_bitvec_v<T>, bool>
+testBit(const T& field, const size_t index)
{
return field.test(index);
}
/// Set the `index`th bit in `field`
template <typename T>
-void
-setBit(T& field, const IntegralIndex<T> index)
+std::enable_if_t<std::is_integral<T>::value>
+setBit(T& field, const size_t index)
{
assert(size_t(index) < sizeof(field) * CHAR_BIT);
field |= (T{1} << index);
@@ -80,8 +83,8 @@ setBit(T& field, const IntegralIndex<T> index)
/// Set the `index`th bit in `field` to `value`
template <typename T>
-void
-setBit(T& field, const IntegralIndex<T> index, const bool value)
+std::enable_if_t<std::is_integral<T>::value>
+setBit(T& field, const size_t index, const bool value)
{
assert(size_t(index) < sizeof(field) * CHAR_BIT);
field ^= (-T{value} ^ field) & (T{1U} << index);
@@ -90,16 +93,16 @@ setBit(T& field, const IntegralIndex<T> index, const bool value)
/// Set the `index`th bit in `field`
template <typename T>
-void
-setBit(T& field, const BitsetIndex<T> index)
+std::enable_if_t<is_bitvec_v<T>>
+setBit(T& field, const size_t index)
{
field.set(index);
}
/// Set the `index`th bit in `field` to `value`
template <typename T>
-void
-setBit(T& field, const BitsetIndex<T> index, const bool value)
+std::enable_if_t<is_bitvec_v<T>>
+setBit(T& field, const size_t index, const bool value)
{
field.set(index, value);
}
@@ -142,7 +145,7 @@ ffs<unsigned long long>(const unsigned long long field)
/// Calculates the Gray Code of `value` in place
template <typename T>
-std::enable_if_t<!std::is_integral<T>::value> grayCode(T& value);
+std::enable_if_t<is_bitvec_v<T>> grayCode(T& value);
/// Implementation of grayCode for any integral type
template <typename T>
@@ -154,7 +157,7 @@ grayCode(T& value)
/// Calculates the inverse Gray Code of `value` in place
template <typename T>
-std::enable_if_t<!std::is_integral<T>::value> grayCodeInv(T& value);
+std::enable_if_t<is_bitvec_v<T>> grayCodeInv(T& value);
/// Implementation of grayCodeInv for any integral type
template <typename T>