rhubarb-lip-sync/rhubarb/lib/sphinxbase-rev13216/include/sphinxbase/bitvec.h

156 lines
4.5 KiB
C

/* -*- c-basic-offset: 4; indent-tabs-mode: nil -*- */
/* ====================================================================
* Copyright (c) 1999-2004 Carnegie Mellon University. All rights
* reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
*
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
*
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in
* the documentation and/or other materials provided with the
* distribution.
*
* This work was supported in part by funding from the Defense Advanced
* Research Projects Agency and the National Science Foundation of the
* United States of America, and the CMU Sphinx Speech Consortium.
*
* THIS SOFTWARE IS PROVIDED BY CARNEGIE MELLON UNIVERSITY ``AS IS'' AND
* ANY EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
* THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL CARNEGIE MELLON UNIVERSITY
* NOR ITS EMPLOYEES BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
* ====================================================================
*
*/
#ifndef _LIBUTIL_BITVEC_H_
#define _LIBUTIL_BITVEC_H_
#include <string.h>
/* Win32/WinCE DLL gunk */
#include <sphinxbase/sphinxbase_export.h>
#include <sphinxbase/prim_type.h>
#include <sphinxbase/ckd_alloc.h>
/**
* @file bitvec.h
* @brief An implementation of bit vectors.
*
* Implementation of basic operations of bit vectors.
*/
#ifdef __cplusplus
extern "C" {
#endif
#if 0
/* Fool Emacs. */
}
#endif
#define BITVEC_BITS 32
typedef uint32 bitvec_t;
/**
* Number of bitvec_t in a bit vector
*/
#define bitvec_size(n) (((n)+BITVEC_BITS-1)/BITVEC_BITS)
/**
* Allocate a bit vector, all bits are clear
*/
#define bitvec_alloc(n) ckd_calloc(bitvec_size(n), sizeof(bitvec_t))
/**
* Resize a bit vector, clear the remaining bits
*/
SPHINXBASE_EXPORT
bitvec_t *bitvec_realloc(bitvec_t *vec, /* In: Bit vector to search */
size_t old_len, /* In: Old length */
size_t new_len); /* In: New lenght of above bit vector */
/**
* Free a bit vector.
*/
#define bitvec_free(v) ckd_free(v)
/**
* Set the b-th bit of bit vector v
* @param v is a vector
* @param b is the bit which will be set
*/
#define bitvec_set(v,b) (v[(b)/BITVEC_BITS] |= (1UL << ((b) & (BITVEC_BITS-1))))
/**
* Set all n bits in bit vector v
* @param v is a vector
* @param n is the number of bits
*/
#define bitvec_set_all(v,n) memset(v, (bitvec_t)-1, \
(((n)+BITVEC_BITS-1)/BITVEC_BITS) * \
sizeof(bitvec_t))
/**
* Clear the b-th bit of bit vector v
* @param v is a vector
* @param b is the bit which will be set
*/
#define bitvec_clear(v,b) (v[(b)/BITVEC_BITS] &= ~(1UL << ((b) & (BITVEC_BITS-1))))
/**
* Clear all n bits in bit vector v
* @param v is a vector
* @param n is the number of bits
*/
#define bitvec_clear_all(v,n) memset(v, 0, (((n)+BITVEC_BITS-1)/BITVEC_BITS) * \
sizeof(bitvec_t))
/**
* Check whether the b-th bit is set in vector v
* @param v is a vector
* @param b is the bit which will be checked
*/
#define bitvec_is_set(v,b) (v[(b)/BITVEC_BITS] & (1UL << ((b) & (BITVEC_BITS-1))))
/**
* Check whether the b-th bit is cleared in vector v
* @param v is a vector
* @param b is the bit which will be checked
*/
#define bitvec_is_clear(v,b) (! (bitvec_is_set(v,b)))
/**
* Return the number of bits set in the given bitvector.
*
* @param vec is the bit vector
* @param len is the length of bit vector <code>vec</code>
* @return the number of bits being set in vector <code>vec</code>
*/
SPHINXBASE_EXPORT
size_t bitvec_count_set(bitvec_t *vec, /* In: Bit vector to search */
size_t len); /* In: Lenght of above bit vector */
#ifdef __cplusplus
}
#endif
#endif