1
0
mirror of https://git.savannah.gnu.org/git/gnulib.git synced 2025-08-08 17:22:05 +03:00

Improve name: "count-one-bits" is better than "popcount".

* MODULES.html.sh: Update name.
* lib/popcount.h: Renamed lib/count-one-bits.h.
(popcount): Renamed count_one_bits.
(popcountl): Renamed count_one_bits_l.
(popcountll): Renamed count_one_bits_ll.
* m4/popcount.m4: Renamed m4/count-one-bits.m4.
* modules/popcount: Renamed module/count-one-bits.
* modules/popcount-tests: Renamed module/count-one-bits-tests.
* tests/test-popcount.c: Renamed tests/test-count-one-bits.c.
This commit is contained in:
Ben Pfaff
2007-07-25 03:13:19 +00:00
parent 27699186ce
commit e9cfd9f2d0
8 changed files with 61 additions and 51 deletions

View File

@@ -1,3 +1,16 @@
2007-07-24 Ben Pfaff <blp@gnu.org>
Improve name: "count-one-bits" is better than "popcount".
* MODULES.html.sh: Update name.
* lib/popcount.h: Renamed lib/count-one-bits.h.
(popcount): Renamed count_one_bits.
(popcountl): Renamed count_one_bits_l.
(popcountll): Renamed count_one_bits_ll.
* m4/popcount.m4: Renamed m4/count-one-bits.m4.
* modules/popcount: Renamed module/count-one-bits.
* modules/popcount-tests: Renamed module/count-one-bits-tests.
* tests/test-popcount.c: Renamed tests/test-count-one-bits.c.
2007-07-23 Ben Pfaff <blp@gnu.org> 2007-07-23 Ben Pfaff <blp@gnu.org>
* lib/popcount.h (popcount32): Reduce size of constants, to allow * lib/popcount.h (popcount32): Reduce size of constants, to allow

View File

@@ -1609,9 +1609,9 @@ func_all_modules ()
func_echo "$element" func_echo "$element"
func_begin_table func_begin_table
func_module count-one-bits
func_module gcd func_module gcd
func_module minmax func_module minmax
func_module popcount
func_end_table func_end_table
element="Environment variables <stdlib.h>" element="Environment variables <stdlib.h>"

View File

@@ -1,4 +1,4 @@
/* popcount.h -- population count /* count-one-bits.h -- counts the number of 1-bits in a word.
Copyright (C) 2007 Free Software Foundation, Inc. Copyright (C) 2007 Free Software Foundation, Inc.
This program is free software; you can redistribute it and/or modify This program is free software; you can redistribute it and/or modify
@@ -17,29 +17,28 @@
/* Written by Ben Pfaff. */ /* Written by Ben Pfaff. */
#ifndef POPCOUNT_H #ifndef COUNT_ONE_BITS_H
# define POPCOUNT_H 1 # define COUNT_ONE_BITS_H 1
#include <limits.h> #include <limits.h>
#include <stdlib.h> #include <stdlib.h>
#include "verify.h" #include "verify.h"
#if __GNUC__ > 3 || (__GNUC__ == 3 && __GNUC_MINOR >= 4) #if __GNUC__ > 3 || (__GNUC__ == 3 && __GNUC_MINOR >= 4)
#define POPCOUNT_CALCULATION(NAME, TYPE) \ #define COUNT_ONE_BITS(BUILTIN, TYPE) \
return __builtin_##NAME (x); return BUILTIN (x);
#else #else
#define POPCOUNT_CALCULATION(NAME, TYPE) \ #define COUNT_ONE_BITS(BUILTIN, TYPE) \
int pop = popcount32 (x); \ int count = count_one_bits_32 (x); \
if (CHAR_BIT * sizeof (TYPE) > 32) \ if (CHAR_BIT * sizeof (TYPE) > 32) \
pop += popcount32 (x >> 31 >> 1); \ count += count_one_bits_32 (x >> 31 >> 1); \
(void) verify_true (CHAR_BIT * sizeof (TYPE) <= 64); \ (void) verify_true (CHAR_BIT * sizeof (TYPE) <= 64); \
return pop; return count;
/* Compute and return the population count of the low 32 bits of /* Compute and return the the number of 1-bits set in the least
X, that is, the number of 1-bits set in its least significant significant 32 bits of X. */
32 bits. */
static inline int static inline int
popcount32 (unsigned int x) count_one_bits_32 (unsigned int x)
{ {
x = ((x & 0xaaaaaaaaU) >> 1) + (x & 0x55555555U); x = ((x & 0xaaaaaaaaU) >> 1) + (x & 0x55555555U);
x = ((x & 0xccccccccU) >> 2) + (x & 0x33333333U); x = ((x & 0xccccccccU) >> 2) + (x & 0x33333333U);
@@ -49,30 +48,27 @@ popcount32 (unsigned int x)
} }
#endif #endif
/* Compute and return the population count of X, that is, the /* Compute and return the number of 1-bits set in X. */
number of 1-bits set in X. */
static inline int static inline int
popcount (unsigned int x) count_one_bits (unsigned int x)
{ {
POPCOUNT_CALCULATION (popcount, unsigned int); COUNT_ONE_BITS (__builtin_popcount, unsigned int);
} }
/* Compute and return the population count of X, that is, the /* Compute and return the number of 1-bits set in X. */
number of 1-bits set in X. */
static inline int static inline int
popcountl (unsigned long int x) count_one_bits_l (unsigned long int x)
{ {
POPCOUNT_CALCULATION (popcountl, unsigned long int); COUNT_ONE_BITS (__builtin_popcountl, unsigned long int);
} }
#if HAVE_UNSIGNED_LONG_LONG_INT #if HAVE_UNSIGNED_LONG_LONG_INT
/* Compute and return the population count of X, that is, the /* Compute and return the number of 1-bits set in X. */
number of 1-bits set in X. */
static inline int static inline int
popcountll (unsigned long long int x) count_one_bits_ll (unsigned long long int x)
{ {
POPCOUNT_CALCULATION (popcountll, unsigned long long int); COUNT_ONE_BITS (__builtin_popcountll, unsigned long long int);
} }
#endif #endif
#endif /* POPCOUNT_H */ #endif /* COUNT_ONE_BITS_H */

View File

@@ -1,12 +1,12 @@
# popcount.m4 serial 1 # count-one-bits.m4 serial 1
dnl Copyright (C) 2007 Free Software Foundation, Inc. dnl Copyright (C) 2007 Free Software Foundation, Inc.
dnl This file is free software; the Free Software Foundation dnl This file is free software; the Free Software Foundation
dnl gives unlimited permission to copy and/or distribute it, dnl gives unlimited permission to copy and/or distribute it,
dnl with or without modifications, as long as this notice is preserved. dnl with or without modifications, as long as this notice is preserved.
AC_DEFUN([gl_POPCOUNT], AC_DEFUN([gl_COUNT_ONE_BITS],
[ [
dnl We don't need (and can't compile) popcountll dnl We don't need (and can't compile) count_one_bits_ll
dnl unless the type 'unsigned long long int' exists. dnl unless the type 'unsigned long long int' exists.
AC_REQUIRE([AC_TYPE_UNSIGNED_LONG_LONG_INT]) AC_REQUIRE([AC_TYPE_UNSIGNED_LONG_LONG_INT])
]) ])

View File

@@ -1,21 +1,21 @@
Description: Description:
Compute population count (number of 1-bits in a word). Counts the number of 1-bits in a word.
Files: Files:
lib/popcount.h lib/count-one-bits.h
m4/popcount.m4 m4/count-one-bits.m4
Depends-on: Depends-on:
inline inline
verify verify
configure.ac: configure.ac:
gl_POPCOUNT gl_COUNT_ONE_BITS
Makefile.am: Makefile.am:
Include: Include:
"popcount.h" "count-one-bits.h"
License: License:
GPL GPL

View File

@@ -0,0 +1,10 @@
Files:
tests/test-count-one-bits.c
Depends-on:
configure.ac:
Makefile.am:
TESTS += test-count-one-bits
check_PROGRAMS += test-count-one-bits

View File

@@ -1,10 +0,0 @@
Files:
tests/test-popcount.c
Depends-on:
configure.ac:
Makefile.am:
TESTS += test-popcount
check_PROGRAMS += test-popcount

View File

@@ -20,7 +20,7 @@
#include <config.h> #include <config.h>
#include "popcount.h" #include "count-one-bits.h"
#include <limits.h> #include <limits.h>
#include <stdio.h> #include <stdio.h>
@@ -52,7 +52,7 @@ main (int argc, char *argv[])
{ {
int i, j; int i, j;
#define TEST_POPCOUNT(FUNC, TYPE, BITS, MAX, ONE) \ #define TEST_COUNT_ONE_BITS(FUNC, TYPE, BITS, MAX, ONE) \
ASSERT (FUNC (0) == 0); \ ASSERT (FUNC (0) == 0); \
for (i = 0; i < BITS; i++) \ for (i = 0; i < BITS; i++) \
{ \ { \
@@ -70,11 +70,12 @@ main (int argc, char *argv[])
} \ } \
ASSERT (FUNC (MAX) == BITS); ASSERT (FUNC (MAX) == BITS);
TEST_POPCOUNT (popcount, unsigned int, UINT_BIT, UINT_MAX, 1U); TEST_COUNT_ONE_BITS (count_one_bits, unsigned int, UINT_BIT, UINT_MAX, 1U);
TEST_POPCOUNT (popcountl, unsigned long int, ULONG_BIT, ULONG_MAX, 1UL); TEST_COUNT_ONE_BITS (count_one_bits_l, unsigned long int,
ULONG_BIT, ULONG_MAX, 1UL);
#ifdef HAVE_UNSIGNED_LONG_LONG_INT #ifdef HAVE_UNSIGNED_LONG_LONG_INT
TEST_POPCOUNT (popcountll, TEST_COUNT_ONE_BITS (count_one_bits_ll,
unsigned long long int, ULLONG_BIT, ULLONG_MAX, 1ULL); unsigned long long int, ULLONG_BIT, ULLONG_MAX, 1ULL);
#endif #endif
return 0; return 0;