diff options
Diffstat (limited to 'Hilbert/SetLocation.hpp')
-rw-r--r-- | Hilbert/SetLocation.hpp | 78 |
1 files changed, 10 insertions, 68 deletions
diff --git a/Hilbert/SetLocation.hpp b/Hilbert/SetLocation.hpp index 66e6459..4a2ba3d 100644 --- a/Hilbert/SetLocation.hpp +++ b/Hilbert/SetLocation.hpp @@ -1,4 +1,4 @@ -/* +/* Copyright (C) 2018 David Robillard <d@drobilla.net> * Copyright (C) 2006-2007 Chris Hamilton <chamilton@cs.dal.ca> * * This program is free software; you can redistribute it and/or modify @@ -19,77 +19,19 @@ #ifndef _SETLOCATION_HPP_ #define _SETLOCATION_HPP_ +#include <Hilbert/Operations.hpp> -#include <Hilbert/BigBitVec.hpp> +namespace Hilbert { - -namespace Hilbert +template <class P, class I> +inline void +setLocation(P* const p, const int n, const int i, const I& l) { - template <class P,class I> - inline - void - setLocation( - P *p, - int n, - int i, - const I &l - ) - { - // Easy to understand implementation - /*int j; - for ( j = 0; j < n; j++ ) - p[j].set(i,l.test(j)); - return;*/ - - // Much faster loop-unrolled implementation. - int ir, ib; - FBV_UINT im; - BBV_MODSPLIT(ir,ib,i); - im = (FBV1<<ib); - -#define SETBIT p->racks()[ir]|=im; if ((*lr&jm)==0) p->racks()[ir]^=im; jm<<=1; ++p; -#define SETBIT1(a) \ - case (a+1): SETBIT; -#define SETBIT2(a) \ - SETBIT1(a+1); \ - SETBIT1(a); -#define SETBIT4(a) \ - SETBIT2(a+2); \ - SETBIT2(a); -#define SETBIT8(a) \ - SETBIT4(a+4); \ - SETBIT4(a); -#define SETBIT16(a) \ - SETBIT8(a+8); \ - SETBIT8(a); -#define SETBIT32(a) \ - SETBIT16(a+16); \ - SETBIT16(a); - - int j = 0; - FBV_UINT jm = 1; - const FBV_UINT *lr = l.racks(); - while ( j < n ) - { - if ( jm == 0 ) - { - jm = 1; - ++lr; - } - - int dj = n - j; - switch ( n - j ) - { - default: dj = 32; - SETBIT32(0); - } - j += dj; - } - - return; + for (int j = 0; j < n; j++) { + setBit(p[j], i, testBit(l, j)); } +} -}; - +} // namespace Hilbert #endif |