* src/bddop.c, src/bddx.h, src/cache.c, src/cache.h, src/kernel.c, src/kernel.h, src/prime.c, src/prime.h, src/reorder.c: Use power of two for the sizes of all hash tables, in order to reduce the amount of divisions performed. Also allow bddhash to be smaller than bddnodes.
84 lines
2.9 KiB
C
84 lines
2.9 KiB
C
/*========================================================================
|
|
Copyright (C) 1996-2002 by Jorn Lind-Nielsen
|
|
All rights reserved
|
|
|
|
Permission is hereby granted, without written agreement and without
|
|
license or royalty fees, to use, reproduce, prepare derivative
|
|
works, distribute, and display this software and its documentation
|
|
for any purpose, provided that (1) the above copyright notice and
|
|
the following two paragraphs appear in all copies of the source code
|
|
and (2) redistributions, including without limitation binaries,
|
|
reproduce these notices in the supporting documentation. Substantial
|
|
modifications to this software may be copyrighted by their authors
|
|
and need not follow the licensing terms described here, provided
|
|
that the new terms are clearly indicated in all files where they apply.
|
|
|
|
IN NO EVENT SHALL JORN LIND-NIELSEN, OR DISTRIBUTORS OF THIS
|
|
SOFTWARE BE LIABLE TO ANY PARTY FOR DIRECT, INDIRECT, SPECIAL,
|
|
INCIDENTAL, OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OF THIS
|
|
SOFTWARE AND ITS DOCUMENTATION, EVEN IF THE AUTHORS OR ANY OF THE
|
|
ABOVE PARTIES HAVE BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
JORN LIND-NIELSEN SPECIFICALLY DISCLAIM ANY WARRANTIES, INCLUDING,
|
|
BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
|
|
FITNESS FOR A PARTICULAR PURPOSE. THE SOFTWARE PROVIDED HEREUNDER IS
|
|
ON AN "AS IS" BASIS, AND THE AUTHORS AND DISTRIBUTORS HAVE NO
|
|
OBLIGATION TO PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR
|
|
MODIFICATIONS.
|
|
========================================================================*/
|
|
|
|
/*************************************************************************
|
|
$Header: /Volumes/CVS/repository/spot/spot/buddy/src/cache.c,v 1.2 2003/05/05 13:45:05 aduret Exp $
|
|
FILE: cache.c
|
|
DESCR: Cache class for caching apply/exist etc. results in BDD package
|
|
AUTH: Jorn Lind
|
|
DATE: (C) june 1997
|
|
*************************************************************************/
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
#include <limits.h>
|
|
#include "kernel.h"
|
|
#include "cache.h"
|
|
#include "prime.h"
|
|
|
|
/*************************************************************************
|
|
*************************************************************************/
|
|
|
|
void BddCache_reset(BddCache *cache)
|
|
{
|
|
int n;
|
|
for (n = 0; n < cache->tablesize; n++)
|
|
cache->table[n].i.a = -1;
|
|
}
|
|
|
|
|
|
int BddCache_init(BddCache *cache, int size)
|
|
{
|
|
size = bdd_nextpower(size);
|
|
|
|
if ((cache->table=NEW(BddCacheData,size)) == NULL)
|
|
return bdd_error(BDD_MEMORY);
|
|
|
|
cache->tablesize = size;
|
|
BddCache_reset(cache);
|
|
return 0;
|
|
}
|
|
|
|
|
|
void BddCache_done(BddCache *cache)
|
|
{
|
|
free(cache->table);
|
|
cache->table = NULL;
|
|
cache->tablesize = 0;
|
|
}
|
|
|
|
|
|
int BddCache_resize(BddCache *cache, int newsize)
|
|
{
|
|
free(cache->table);
|
|
return BddCache_init(cache, newsize);
|
|
}
|
|
|
|
|
|
|
|
/* EOF */
|