2003-02-25 04:25:13 +08:00
|
|
|
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
2007-02-07 22:56:24 +08:00
|
|
|
* Copyright by The HDF Group. *
|
2003-02-25 04:25:13 +08:00
|
|
|
* Copyright by the Board of Trustees of the University of Illinois. *
|
|
|
|
* All rights reserved. *
|
|
|
|
* *
|
|
|
|
* This file is part of HDF5. The full HDF5 copyright notice, including *
|
|
|
|
* terms governing use, modification, and redistribution, is contained in *
|
2017-04-18 03:32:16 +08:00
|
|
|
* the COPYING file, which can be found at the root of the source code *
|
2021-02-17 22:52:04 +08:00
|
|
|
* distribution tree, or in https://www.hdfgroup.org/licenses. *
|
2017-04-18 03:32:16 +08:00
|
|
|
* If you do not have access to either file, you may request a copy from *
|
|
|
|
* help@hdfgroup.org. *
|
2003-02-25 04:25:13 +08:00
|
|
|
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
|
|
|
|
|
|
|
/*
|
|
|
|
Test HDF Heap routines.
|
|
|
|
|
|
|
|
REMARKS
|
|
|
|
|
|
|
|
DESIGN
|
|
|
|
|
|
|
|
BUGS/LIMITATIONS
|
|
|
|
|
|
|
|
EXPORTED ROUTINES
|
|
|
|
|
|
|
|
AUTHOR
|
|
|
|
Quincey Koziol
|
|
|
|
|
|
|
|
MODIFICATION HISTORY
|
|
|
|
2/18/03 - Started coding
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "testhdf5.h"
|
|
|
|
#include "H5HPprivate.h"
|
|
|
|
|
|
|
|
/* The number of elements in testing arrays */
|
2020-09-30 22:27:10 +08:00
|
|
|
#define NUM_ELEMS 1000
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Objects for testing in heaps */
|
|
|
|
typedef struct test_obj {
|
2020-09-30 22:27:10 +08:00
|
|
|
H5HP_info_t heap_info; /* Information required for heap. _MUST_ be first */
|
|
|
|
int val; /* Actual information for object */
|
2003-02-25 04:25:13 +08:00
|
|
|
} test_obj;
|
|
|
|
|
|
|
|
/* Array of random element values */
|
2016-09-28 01:29:16 +08:00
|
|
|
static test_obj *rand_num;
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Array of random elements values, sorted in increasing order */
|
2016-09-28 01:29:16 +08:00
|
|
|
static test_obj *inc_sort_num;
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Array of random elements values, sorted in decreasing order */
|
2016-09-28 01:29:16 +08:00
|
|
|
static test_obj *dec_sort_num;
|
2003-02-25 04:25:13 +08:00
|
|
|
|
2020-09-30 22:27:10 +08:00
|
|
|
static int
|
|
|
|
tst_dec_sort(const void *_i1, const void *_i2)
|
2003-02-25 04:25:13 +08:00
|
|
|
{
|
2020-09-30 22:27:10 +08:00
|
|
|
const test_obj *i1 = (const test_obj *)_i1;
|
|
|
|
const test_obj *i2 = (const test_obj *)_i2;
|
|
|
|
|
|
|
|
if (i1->val < i2->val)
|
|
|
|
return (1);
|
|
|
|
else if (i1->val > i2->val)
|
|
|
|
return (-1);
|
|
|
|
return (0);
|
2003-02-25 04:25:13 +08:00
|
|
|
}
|
|
|
|
|
2020-09-30 22:27:10 +08:00
|
|
|
static int
|
|
|
|
tst_inc_sort(const void *_i1, const void *_i2)
|
2003-02-25 04:25:13 +08:00
|
|
|
{
|
2020-09-30 22:27:10 +08:00
|
|
|
const test_obj *i1 = (const test_obj *)_i1;
|
|
|
|
const test_obj *i2 = (const test_obj *)_i2;
|
|
|
|
|
|
|
|
if (i1->val < i2->val)
|
|
|
|
return (-1);
|
|
|
|
else if (i1->val > i2->val)
|
|
|
|
return (1);
|
|
|
|
return (0);
|
2003-02-25 04:25:13 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/****************************************************************
|
|
|
|
**
|
|
|
|
** test_heap_init(): Test H5HP (heap) code.
|
|
|
|
** Initialize data for Heap testing
|
2005-08-14 04:53:35 +08:00
|
|
|
**
|
2003-02-25 04:25:13 +08:00
|
|
|
****************************************************************/
|
2005-08-14 04:53:35 +08:00
|
|
|
static void
|
2003-02-25 04:25:13 +08:00
|
|
|
test_heap_init(void)
|
|
|
|
{
|
2020-09-30 22:27:10 +08:00
|
|
|
time_t curr_time; /* Current time, for seeding random number generator */
|
|
|
|
size_t u; /* Local index variables */
|
2003-02-25 04:25:13 +08:00
|
|
|
|
2016-09-28 01:29:16 +08:00
|
|
|
/* Allocate arrays */
|
|
|
|
rand_num = (test_obj *)HDmalloc(sizeof(test_obj) * NUM_ELEMS);
|
2017-11-27 10:13:18 +08:00
|
|
|
CHECK_PTR(rand_num, "HDmalloc");
|
2016-09-28 01:29:16 +08:00
|
|
|
inc_sort_num = (test_obj *)HDmalloc(sizeof(test_obj) * NUM_ELEMS);
|
2017-11-27 10:13:18 +08:00
|
|
|
CHECK_PTR(inc_sort_num, "HDmalloc");
|
2016-09-28 01:29:16 +08:00
|
|
|
dec_sort_num = (test_obj *)HDmalloc(sizeof(test_obj) * NUM_ELEMS);
|
2017-11-27 10:13:18 +08:00
|
|
|
CHECK_PTR(dec_sort_num, "HDmalloc");
|
2016-09-28 01:29:16 +08:00
|
|
|
|
2003-02-25 04:25:13 +08:00
|
|
|
/* Create randomized set of numbers */
|
2016-09-28 01:29:16 +08:00
|
|
|
curr_time = HDtime(NULL);
|
[svn-r17980] Description:
Bring Coverity changes into the trunk: (also other minor cleanups)
r17955:
Fix Coverity item 24. Add missing error condition to
H5AC_ext_config_2_int_config.
r17956:
Fix Coverity item 24. Improve error checking in H5A_compact_build_table_cb.
r17957:
Fix Coverity item 150. Fix warning in H5A_compact_build_table_cb.
r17958:
Fix Coverity item 117. Fix error handling in H5B_shared_new.
r17959:
Fix Coverity item 209. Added an assertion for leaf->shared in
H5B2_cache_leaf_dest.
r17960:
Fix Coverity item 208. Added an assertion for internal->shared in
H5B2_cache_internal_dest.
r17961:
Fix Coverity item 89. Reworked the code to avoid array overrun in
H5C__autoadjust__ageout__insert_new_marker.
r17962:
Fix for coverity Resource_leak 195,203,204,205.
r17963:
Fix Coverity item 44. Prevented potential NULL dereference in H5D_btree_debug.
r17964:
Fix Coverity issues #197, 198 & 199: memory not being released. (Also
clean up other resource leaks in nearby and/or similar code).
r17965:
Fix Coverity issue #151: release resources on error
r17966:
Fix Coverity issue #187: Remove leftover code remnant from prior bugfix
which was causing resource leak of open files.
r17967:
Fixed Coverity issues # 193 & 194. Removed unnecessary memory allocation and
added comparison of length of path parameter to the size of the destination
buffer in h5import.h/h5import.c.
r17968:
Fix Coverity item 144. Fixed memory leak on error in H5D_chunk_copy.
r17969:
Fix for coverity Resource_leak #196.
r17970:
Coverity 167-173:
Initialized pointer of buffers.
In error handling, closed types and free memory.
Tested on:
FreeBSD/32 6.3 (duty) in debug mode
FreeBSD/64 6.3 (liberty) w/C++ & FORTRAN, in debug mode
Linux/32 2.6 (jam) w/PGI compilers, w/default API=1.8.x,
w/C++ & FORTRAN, w/threadsafe, in debug mode
Linux/64-amd64 2.6 (smirom) w/Intel compilers, w/default API=1.6.x,
w/C++ & FORTRAN, in production mode
Solaris/32 2.10 (linew) w/deprecated symbols disabled, w/C++ & FORTRAN,
w/szip filter, in production mode
Linux/64-ia64 2.6 (cobalt) w/Intel compilers, w/C++ & FORTRAN,
in production mode
Linux/64-ia64 2.4 (tg-login3) w/parallel, w/FORTRAN, in debug mode
Linux/64-amd64 2.6 (abe) w/parallel, w/FORTRAN, in production mode
Mac OS X/32 10.6.2 (amazon) in debug mode
Mac OS X/32 10.6.2 (amazon) w/C++ & FORTRAN, w/threadsafe,
in production mode
2009-12-10 20:36:56 +08:00
|
|
|
HDsrandom((unsigned)curr_time);
|
2020-09-30 22:27:10 +08:00
|
|
|
for (u = 0; u < NUM_ELEMS; u++)
|
2003-02-25 04:25:13 +08:00
|
|
|
/* Generate random numbers from -1000 to 1000 */
|
2016-09-28 01:29:16 +08:00
|
|
|
rand_num[u].val = (int)(HDrandom() % 2001) - 1001;
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Sort random numbers into increasing order */
|
2016-09-28 01:29:16 +08:00
|
|
|
HDmemcpy(inc_sort_num, rand_num, sizeof(test_obj) * NUM_ELEMS);
|
2006-10-30 23:58:46 +08:00
|
|
|
HDqsort(inc_sort_num, (size_t)NUM_ELEMS, sizeof(test_obj), tst_inc_sort);
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Sort random numbers into decreasing order */
|
2016-09-28 01:29:16 +08:00
|
|
|
HDmemcpy(dec_sort_num, rand_num, sizeof(test_obj) * NUM_ELEMS);
|
2006-10-30 23:58:46 +08:00
|
|
|
HDqsort(dec_sort_num, (size_t)NUM_ELEMS, sizeof(test_obj), tst_dec_sort);
|
2016-09-28 01:29:16 +08:00
|
|
|
} /* end test_heap_init() */
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/****************************************************************
|
|
|
|
**
|
|
|
|
** test_heap_create(): Test basic H5HP (heap) code.
|
|
|
|
** Tests creating and closing heaps.
|
2005-08-14 04:53:35 +08:00
|
|
|
**
|
2003-02-25 04:25:13 +08:00
|
|
|
****************************************************************/
|
2005-08-14 04:53:35 +08:00
|
|
|
static void
|
2003-02-25 04:25:13 +08:00
|
|
|
test_heap_create(void)
|
|
|
|
{
|
2020-09-30 22:27:10 +08:00
|
|
|
H5HP_t *heap; /* Heap created */
|
|
|
|
herr_t ret; /* Generic return value */
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Output message about test being performed */
|
|
|
|
MESSAGE(6, ("Testing Creating & Closing Heaps\n"));
|
|
|
|
|
|
|
|
/* Try creating a maximum Heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
heap = H5HP_create(H5HP_MAX_HEAP);
|
2017-11-27 10:13:18 +08:00
|
|
|
CHECK_PTR(heap, "H5HP_create");
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Try closing the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_close(heap);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_close");
|
|
|
|
|
|
|
|
/* Try creating a minimum Heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
heap = H5HP_create(H5HP_MIN_HEAP);
|
2017-11-27 10:13:18 +08:00
|
|
|
CHECK_PTR(heap, "H5HP_create");
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Try closing the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_close(heap);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_close");
|
|
|
|
|
|
|
|
} /* end test_heap_create() */
|
|
|
|
|
|
|
|
/****************************************************************
|
|
|
|
**
|
|
|
|
** test_heap_insert_min(): Test H5HP (heap) code.
|
|
|
|
** Tests basic inserting objects into minimum heaps.
|
2005-08-14 04:53:35 +08:00
|
|
|
**
|
2003-02-25 04:25:13 +08:00
|
|
|
****************************************************************/
|
2005-08-14 04:53:35 +08:00
|
|
|
static void
|
2003-02-25 04:25:13 +08:00
|
|
|
test_heap_insert_min(void)
|
|
|
|
{
|
2020-09-30 22:27:10 +08:00
|
|
|
H5HP_t * heap; /* Heap created */
|
|
|
|
ssize_t num; /* Number of elements in heap */
|
|
|
|
int val; /* Value of object on heap */
|
|
|
|
test_obj obj1, obj2, obj3; /* Test objects to insert */
|
|
|
|
herr_t ret; /* Generic return value */
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Output message about test being performed */
|
|
|
|
MESSAGE(7, ("Testing Inserting Into Minimum Heaps\n"));
|
|
|
|
|
|
|
|
/* Create a Heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
heap = H5HP_create(H5HP_MIN_HEAP);
|
2017-11-27 10:13:18 +08:00
|
|
|
CHECK_PTR(heap, "H5HP_create");
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Check that the heap has no elements */
|
2020-09-30 22:27:10 +08:00
|
|
|
num = H5HP_count(heap);
|
2003-02-25 04:25:13 +08:00
|
|
|
VERIFY(num, 0, "H5HP_count");
|
|
|
|
|
|
|
|
/* Insert an object into the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
obj1.val = 100;
|
|
|
|
ret = H5HP_insert(heap, 10, &obj1);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_insert");
|
|
|
|
|
|
|
|
/* Check that the heap has one element */
|
2020-09-30 22:27:10 +08:00
|
|
|
num = H5HP_count(heap);
|
2003-02-25 04:25:13 +08:00
|
|
|
VERIFY(num, 1, "H5HP_count");
|
|
|
|
|
|
|
|
/* Check the minimum value on the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_top(heap, &val);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_top");
|
|
|
|
VERIFY(val, 10, "H5HP_top");
|
|
|
|
|
|
|
|
/* Insert another object into the heap, with value less than top element */
|
2020-09-30 22:27:10 +08:00
|
|
|
obj2.val = 50;
|
|
|
|
ret = H5HP_insert(heap, 5, &obj2);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_insert");
|
|
|
|
|
|
|
|
/* Check that the heap has two elements */
|
2020-09-30 22:27:10 +08:00
|
|
|
num = H5HP_count(heap);
|
2003-02-25 04:25:13 +08:00
|
|
|
VERIFY(num, 2, "H5HP_count");
|
|
|
|
|
|
|
|
/* Check the minimum value on the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_top(heap, &val);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_top");
|
|
|
|
VERIFY(val, 5, "H5HP_top");
|
|
|
|
|
|
|
|
/* Insert third object into the heap, with value greater than top element */
|
2020-09-30 22:27:10 +08:00
|
|
|
obj3.val = 200;
|
|
|
|
ret = H5HP_insert(heap, 20, &obj3);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_insert");
|
|
|
|
|
|
|
|
/* Check that the heap has three elements */
|
2020-09-30 22:27:10 +08:00
|
|
|
num = H5HP_count(heap);
|
2003-02-25 04:25:13 +08:00
|
|
|
VERIFY(num, 3, "H5HP_count");
|
|
|
|
|
|
|
|
/* Check the minimum value on the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_top(heap, &val);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_top");
|
|
|
|
VERIFY(val, 5, "H5HP_top");
|
|
|
|
|
|
|
|
/* Close the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_close(heap);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_close");
|
|
|
|
|
|
|
|
} /* end test_heap_insert_min() */
|
|
|
|
|
|
|
|
/****************************************************************
|
|
|
|
**
|
|
|
|
** test_heap_insert(): Test H5HP (heap) code.
|
|
|
|
** Tests basic inserting objects into maximum heaps.
|
2005-08-14 04:53:35 +08:00
|
|
|
**
|
2003-02-25 04:25:13 +08:00
|
|
|
****************************************************************/
|
2005-08-14 04:53:35 +08:00
|
|
|
static void
|
2003-02-25 04:25:13 +08:00
|
|
|
test_heap_insert_max(void)
|
|
|
|
{
|
2020-09-30 22:27:10 +08:00
|
|
|
H5HP_t * heap; /* Heap created */
|
|
|
|
ssize_t num; /* Number of elements in heap */
|
|
|
|
int val; /* Value of object on heap */
|
|
|
|
test_obj obj1, obj2, obj3; /* Test objects to insert */
|
|
|
|
herr_t ret; /* Generic return value */
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Output message about test being performed */
|
|
|
|
MESSAGE(7, ("Testing Inserting Into Maximum Heaps\n"));
|
|
|
|
|
|
|
|
/* Create a Heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
heap = H5HP_create(H5HP_MAX_HEAP);
|
2017-11-27 10:13:18 +08:00
|
|
|
CHECK_PTR(heap, "H5HP_create");
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Check that the heap has no elements */
|
2020-09-30 22:27:10 +08:00
|
|
|
num = H5HP_count(heap);
|
2003-02-25 04:25:13 +08:00
|
|
|
VERIFY(num, 0, "H5HP_count");
|
|
|
|
|
|
|
|
/* Insert an object into the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
obj1.val = 100;
|
|
|
|
ret = H5HP_insert(heap, 10, &obj1);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_insert");
|
|
|
|
|
|
|
|
/* Check that the heap has one element */
|
2020-09-30 22:27:10 +08:00
|
|
|
num = H5HP_count(heap);
|
2003-02-25 04:25:13 +08:00
|
|
|
VERIFY(num, 1, "H5HP_count");
|
|
|
|
|
|
|
|
/* Check the maximum value on the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_top(heap, &val);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_top");
|
|
|
|
VERIFY(val, 10, "H5HP_top");
|
|
|
|
|
|
|
|
/* Insert another object into the heap, with value less than top element */
|
2020-09-30 22:27:10 +08:00
|
|
|
obj2.val = 50;
|
|
|
|
ret = H5HP_insert(heap, 5, &obj2);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_insert");
|
|
|
|
|
|
|
|
/* Check that the heap has two elements */
|
2020-09-30 22:27:10 +08:00
|
|
|
num = H5HP_count(heap);
|
2003-02-25 04:25:13 +08:00
|
|
|
VERIFY(num, 2, "H5HP_count");
|
|
|
|
|
|
|
|
/* Check the maximum value on the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_top(heap, &val);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_top");
|
|
|
|
VERIFY(val, 10, "H5HP_top");
|
|
|
|
|
|
|
|
/* Insert third object into the heap, with value greater than top element */
|
2020-09-30 22:27:10 +08:00
|
|
|
obj3.val = 200;
|
|
|
|
ret = H5HP_insert(heap, 20, &obj3);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_insert");
|
|
|
|
|
|
|
|
/* Check that the heap has three elements */
|
2020-09-30 22:27:10 +08:00
|
|
|
num = H5HP_count(heap);
|
2003-02-25 04:25:13 +08:00
|
|
|
VERIFY(num, 3, "H5HP_count");
|
|
|
|
|
|
|
|
/* Check the maximum value on the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_top(heap, &val);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_top");
|
|
|
|
VERIFY(val, 20, "H5HP_top");
|
|
|
|
|
|
|
|
/* Close the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_close(heap);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_close");
|
|
|
|
|
|
|
|
} /* end test_heap_insert_max() */
|
|
|
|
|
|
|
|
/****************************************************************
|
|
|
|
**
|
|
|
|
** test_heap_insert(): Test H5HP (heap) code.
|
|
|
|
** Tests basic inserting objects into heaps.
|
2005-08-14 04:53:35 +08:00
|
|
|
**
|
2003-02-25 04:25:13 +08:00
|
|
|
****************************************************************/
|
2005-08-14 04:53:35 +08:00
|
|
|
static void
|
2003-02-25 04:25:13 +08:00
|
|
|
test_heap_insert(void)
|
|
|
|
{
|
|
|
|
/* Output message about test being performed */
|
|
|
|
MESSAGE(6, ("Testing Inserting Into Heaps\n"));
|
|
|
|
|
|
|
|
/* Test insertions into minimum & maximum heaps */
|
|
|
|
test_heap_insert_max();
|
|
|
|
test_heap_insert_min();
|
|
|
|
} /* end test_heap_insert() */
|
|
|
|
|
|
|
|
/****************************************************************
|
|
|
|
**
|
|
|
|
** test_heap_insert_many_core (): Tests H5HP (heap) code.
|
|
|
|
** "Core" routine called by test_heap_insert_many() routine.
|
2005-08-14 04:53:35 +08:00
|
|
|
**
|
2003-02-25 04:25:13 +08:00
|
|
|
****************************************************************/
|
2006-10-30 23:58:46 +08:00
|
|
|
static void
|
|
|
|
test_heap_insert_many_core(H5HP_type_t heap_type, test_obj *arr, size_t nelem, int top_val)
|
2003-02-25 04:25:13 +08:00
|
|
|
{
|
2020-09-30 22:27:10 +08:00
|
|
|
H5HP_t *heap; /* Heap created */
|
|
|
|
ssize_t num; /* Number of elements in heap */
|
|
|
|
int val; /* Value of object on heap */
|
|
|
|
size_t u; /* Local index variable */
|
|
|
|
herr_t ret; /* Generic return value */
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Create a Heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
heap = H5HP_create(heap_type);
|
2017-11-27 10:13:18 +08:00
|
|
|
CHECK_PTR(heap, "H5HP_create");
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Check that the heap has no elements */
|
2020-09-30 22:27:10 +08:00
|
|
|
num = H5HP_count(heap);
|
2003-02-25 04:25:13 +08:00
|
|
|
VERIFY(num, 0, "H5HP_count");
|
|
|
|
|
|
|
|
/* Insert the array elements into the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
for (u = 0; u < nelem; u++) {
|
|
|
|
ret = H5HP_insert(heap, arr[u].val, &arr[u]);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_insert");
|
|
|
|
} /* end for */
|
|
|
|
|
|
|
|
/* Check that the heap has correct number of elements */
|
2020-09-30 22:27:10 +08:00
|
|
|
num = H5HP_count(heap);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(num, FAIL, "H5HP_count");
|
|
|
|
VERIFY((size_t)num, nelem, "H5HP_count");
|
|
|
|
|
|
|
|
/* Check the maximum value on the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_top(heap, &val);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_top");
|
|
|
|
VERIFY(val, top_val, "H5HP_top");
|
|
|
|
|
|
|
|
/* Close the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_close(heap);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_close");
|
|
|
|
} /* end test_heap_insert_many_core() */
|
|
|
|
|
|
|
|
/****************************************************************
|
|
|
|
**
|
|
|
|
** test_heap_insert_many (): Test H5HP (heap) code.
|
|
|
|
** Tests inserting many objects into heaps.
|
2005-08-14 04:53:35 +08:00
|
|
|
**
|
2003-02-25 04:25:13 +08:00
|
|
|
****************************************************************/
|
2005-08-14 04:53:35 +08:00
|
|
|
static void
|
2003-02-25 04:25:13 +08:00
|
|
|
test_heap_insert_many(void)
|
|
|
|
{
|
|
|
|
/* Output message about test being performed */
|
|
|
|
MESSAGE(6, ("Testing Inserting Many Objects Into Heaps\n"));
|
|
|
|
|
|
|
|
/* Test creating a heap from random elements */
|
2006-10-30 23:58:46 +08:00
|
|
|
test_heap_insert_many_core(H5HP_MAX_HEAP, rand_num, (size_t)NUM_ELEMS, dec_sort_num[0].val);
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Test creating a heap from elements in increasing order */
|
2006-10-30 23:58:46 +08:00
|
|
|
test_heap_insert_many_core(H5HP_MAX_HEAP, inc_sort_num, (size_t)NUM_ELEMS, dec_sort_num[0].val);
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Test creating a heap from elements in decreasing order */
|
2006-10-30 23:58:46 +08:00
|
|
|
test_heap_insert_many_core(H5HP_MAX_HEAP, dec_sort_num, (size_t)NUM_ELEMS, dec_sort_num[0].val);
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Test creating a heap from random elements */
|
2006-10-30 23:58:46 +08:00
|
|
|
test_heap_insert_many_core(H5HP_MIN_HEAP, rand_num, (size_t)NUM_ELEMS, inc_sort_num[0].val);
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Test creating a heap from elements in increasing order */
|
2006-10-30 23:58:46 +08:00
|
|
|
test_heap_insert_many_core(H5HP_MIN_HEAP, inc_sort_num, (size_t)NUM_ELEMS, inc_sort_num[0].val);
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Test creating a heap from elements in decreasing order */
|
2006-10-30 23:58:46 +08:00
|
|
|
test_heap_insert_many_core(H5HP_MIN_HEAP, dec_sort_num, (size_t)NUM_ELEMS, inc_sort_num[0].val);
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
} /* end test_heap_insert_many() */
|
|
|
|
|
|
|
|
/****************************************************************
|
|
|
|
**
|
|
|
|
** test_heap_remove_min(): Test H5HP (heap) code.
|
|
|
|
** Tests basic removal of objects from minimum heaps.
|
2005-08-14 04:53:35 +08:00
|
|
|
**
|
2003-02-25 04:25:13 +08:00
|
|
|
****************************************************************/
|
2005-08-14 04:53:35 +08:00
|
|
|
static void
|
2003-02-25 04:25:13 +08:00
|
|
|
test_heap_remove_min(void)
|
|
|
|
{
|
2020-09-30 22:27:10 +08:00
|
|
|
H5HP_t * heap; /* Heap created */
|
|
|
|
ssize_t num; /* Number of elements in heap */
|
|
|
|
int val; /* Value of object on heap */
|
|
|
|
void * ptr; /* Pointer for object on heap */
|
|
|
|
test_obj obj1, obj2, obj3; /* Test objects to insert */
|
|
|
|
herr_t ret; /* Generic return value */
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Output message about test being performed */
|
|
|
|
MESSAGE(7, ("Testing Removing From Minimum Heaps\n"));
|
|
|
|
|
|
|
|
/* Create a Heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
heap = H5HP_create(H5HP_MIN_HEAP);
|
2017-11-27 10:13:18 +08:00
|
|
|
CHECK_PTR(heap, "H5HP_create");
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Check that the heap has no elements */
|
2020-09-30 22:27:10 +08:00
|
|
|
num = H5HP_count(heap);
|
2003-02-25 04:25:13 +08:00
|
|
|
VERIFY(num, 0, "H5HP_count");
|
|
|
|
|
|
|
|
/* Try removing an object from an empty heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_remove(heap, &val, &ptr);
|
2003-02-25 04:25:13 +08:00
|
|
|
VERIFY(ret, FAIL, "H5HP_remove");
|
|
|
|
|
|
|
|
/* Insert an object into the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
obj1.val = 100;
|
|
|
|
ret = H5HP_insert(heap, 10, &obj1);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_insert");
|
|
|
|
|
|
|
|
/* Insert another object into the heap, with value less than top element */
|
2020-09-30 22:27:10 +08:00
|
|
|
obj2.val = 50;
|
|
|
|
ret = H5HP_insert(heap, 5, &obj2);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_insert");
|
|
|
|
|
|
|
|
/* Insert third object into the heap, with value greater than top element */
|
2020-09-30 22:27:10 +08:00
|
|
|
obj3.val = 200;
|
|
|
|
ret = H5HP_insert(heap, 20, &obj3);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_insert");
|
|
|
|
|
|
|
|
/* Remove first maximum value from heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_remove(heap, &val, &ptr);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_remove");
|
|
|
|
VERIFY(val, 5, "H5HP_remove");
|
2017-11-28 00:57:26 +08:00
|
|
|
CHECK_PTR_EQ(ptr, &obj2, "H5HP_remove");
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Remove second maximum value from heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_remove(heap, &val, &ptr);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_remove");
|
|
|
|
VERIFY(val, 10, "H5HP_remove");
|
2017-11-28 00:57:26 +08:00
|
|
|
CHECK_PTR_EQ(ptr, &obj1, "H5HP_remove");
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Remove third maximum value from heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_remove(heap, &val, &ptr);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_remove");
|
|
|
|
VERIFY(val, 20, "H5HP_remove");
|
2017-11-28 00:57:26 +08:00
|
|
|
CHECK_PTR_EQ(ptr, &obj3, "H5HP_remove");
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Try removing an object from an empty heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_remove(heap, &val, &ptr);
|
2003-02-25 04:25:13 +08:00
|
|
|
VERIFY(ret, FAIL, "H5HP_remove");
|
|
|
|
|
|
|
|
/* Close the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_close(heap);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_close");
|
|
|
|
|
|
|
|
} /* end test_heap_remove_min() */
|
|
|
|
|
|
|
|
/****************************************************************
|
|
|
|
**
|
|
|
|
** test_heap_remove_max(): Test H5HP (heap) code.
|
|
|
|
** Tests basic removal of objects from maximum heaps.
|
2005-08-14 04:53:35 +08:00
|
|
|
**
|
2003-02-25 04:25:13 +08:00
|
|
|
****************************************************************/
|
2005-08-14 04:53:35 +08:00
|
|
|
static void
|
2003-02-25 04:25:13 +08:00
|
|
|
test_heap_remove_max(void)
|
|
|
|
{
|
2020-09-30 22:27:10 +08:00
|
|
|
H5HP_t * heap; /* Heap created */
|
|
|
|
ssize_t num; /* Number of elements in heap */
|
|
|
|
int val; /* Value of object on heap */
|
|
|
|
void * ptr; /* Pointer for object on heap */
|
|
|
|
test_obj obj1, obj2, obj3; /* Test objects to insert */
|
|
|
|
herr_t ret; /* Generic return value */
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Output message about test being performed */
|
|
|
|
MESSAGE(7, ("Testing Removing From Maximum Heaps\n"));
|
|
|
|
|
|
|
|
/* Create a Heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
heap = H5HP_create(H5HP_MAX_HEAP);
|
2017-11-27 10:13:18 +08:00
|
|
|
CHECK_PTR(heap, "H5HP_create");
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Check that the heap has no elements */
|
2020-09-30 22:27:10 +08:00
|
|
|
num = H5HP_count(heap);
|
2003-02-25 04:25:13 +08:00
|
|
|
VERIFY(num, 0, "H5HP_count");
|
|
|
|
|
|
|
|
/* Try removing an object from an empty heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_remove(heap, &val, &ptr);
|
2003-02-25 04:25:13 +08:00
|
|
|
VERIFY(ret, FAIL, "H5HP_remove");
|
|
|
|
|
|
|
|
/* Insert an object into the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
obj1.val = 100;
|
|
|
|
ret = H5HP_insert(heap, 10, &obj1);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_insert");
|
|
|
|
|
|
|
|
/* Insert another object into the heap, with value less than top element */
|
2020-09-30 22:27:10 +08:00
|
|
|
obj2.val = 50;
|
|
|
|
ret = H5HP_insert(heap, 5, &obj2);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_insert");
|
|
|
|
|
|
|
|
/* Insert third object into the heap, with value greater than top element */
|
2020-09-30 22:27:10 +08:00
|
|
|
obj3.val = 200;
|
|
|
|
ret = H5HP_insert(heap, 20, &obj3);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_insert");
|
|
|
|
|
|
|
|
/* Remove first maximum value from heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_remove(heap, &val, &ptr);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_remove");
|
|
|
|
VERIFY(val, 20, "H5HP_remove");
|
2017-11-28 00:57:26 +08:00
|
|
|
CHECK_PTR_EQ(ptr, &obj3, "H5HP_remove");
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Remove second maximum value from heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_remove(heap, &val, &ptr);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_remove");
|
|
|
|
VERIFY(val, 10, "H5HP_remove");
|
2017-11-28 00:57:26 +08:00
|
|
|
CHECK_PTR_EQ(ptr, &obj1, "H5HP_remove");
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Remove third maximum value from heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_remove(heap, &val, &ptr);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_remove");
|
|
|
|
VERIFY(val, 5, "H5HP_remove");
|
2017-11-28 00:57:26 +08:00
|
|
|
CHECK_PTR_EQ(ptr, &obj2, "H5HP_remove");
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Try removing an object from an empty heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_remove(heap, &val, &ptr);
|
2003-02-25 04:25:13 +08:00
|
|
|
VERIFY(ret, FAIL, "H5HP_remove");
|
|
|
|
|
|
|
|
/* Close the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_close(heap);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_close");
|
|
|
|
|
|
|
|
} /* end test_heap_remove_max() */
|
|
|
|
|
|
|
|
/****************************************************************
|
|
|
|
**
|
|
|
|
** test_heap_remove(): Test H5HP (heap) code.
|
|
|
|
** Tests basic removal of objects from minimum & maximum heaps.
|
2005-08-14 04:53:35 +08:00
|
|
|
**
|
2003-02-25 04:25:13 +08:00
|
|
|
****************************************************************/
|
2005-08-14 04:53:35 +08:00
|
|
|
static void
|
2003-02-25 04:25:13 +08:00
|
|
|
test_heap_remove(void)
|
|
|
|
{
|
|
|
|
/* Output message about test being performed */
|
|
|
|
MESSAGE(6, ("Testing Removing From Heaps\n"));
|
|
|
|
|
|
|
|
/* Test removals from minimum & maximum heaps */
|
|
|
|
test_heap_remove_max();
|
|
|
|
test_heap_remove_min();
|
|
|
|
} /* end test_heap_remove() */
|
|
|
|
|
|
|
|
/****************************************************************
|
|
|
|
**
|
|
|
|
** test_heap_remove_many_core (): Tests H5HP (heap) code.
|
|
|
|
** "Core" routine called by test_heap_remove_many() routine.
|
2005-08-14 04:53:35 +08:00
|
|
|
**
|
2003-02-25 04:25:13 +08:00
|
|
|
****************************************************************/
|
2020-09-30 22:27:10 +08:00
|
|
|
static void
|
|
|
|
test_heap_remove_many_core(H5HP_type_t heap_type, test_obj *arr, size_t nelem)
|
2003-02-25 04:25:13 +08:00
|
|
|
{
|
2020-09-30 22:27:10 +08:00
|
|
|
H5HP_t * heap; /* Heap created */
|
|
|
|
ssize_t num; /* Number of elements in heap */
|
|
|
|
int last_val; /* Last value from the heap */
|
|
|
|
int val; /* Value of object on heap */
|
2003-02-25 04:25:13 +08:00
|
|
|
test_obj *ptr; /* Pointer for object on heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
size_t u; /* Local index variable */
|
|
|
|
herr_t ret; /* Generic return value */
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Create a Heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
heap = H5HP_create(heap_type);
|
2017-11-27 10:13:18 +08:00
|
|
|
CHECK_PTR(heap, "H5HP_create");
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Check that the heap has no elements */
|
2020-09-30 22:27:10 +08:00
|
|
|
num = H5HP_count(heap);
|
2003-02-25 04:25:13 +08:00
|
|
|
VERIFY(num, 0, "H5HP_count");
|
|
|
|
|
|
|
|
/* Insert the array elements into the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
for (u = 0; u < nelem; u++) {
|
|
|
|
ret = H5HP_insert(heap, arr[u].val, &arr[u]);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_insert");
|
|
|
|
} /* end for */
|
|
|
|
|
|
|
|
/* Check that the heap has correct number of elements */
|
2020-09-30 22:27:10 +08:00
|
|
|
num = H5HP_count(heap);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(num, FAIL, "H5HP_count");
|
|
|
|
VERIFY((size_t)num, nelem, "H5HP_count");
|
|
|
|
|
|
|
|
/* Set an appropriate starting value for the "last" value from heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
if (heap_type == H5HP_MAX_HEAP)
|
|
|
|
last_val = INT_MAX;
|
2003-02-25 04:25:13 +08:00
|
|
|
else
|
2020-09-30 22:27:10 +08:00
|
|
|
last_val = INT_MIN;
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Remove the objects from the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
for (u = 0; u < nelem; u++) {
|
|
|
|
ret = H5HP_remove(heap, &val, (void **)&ptr);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_remove");
|
|
|
|
VERIFY(val, ptr->val, "H5HP_remove");
|
|
|
|
|
|
|
|
/* Check that the value is correct, based on the heap type */
|
2020-09-30 22:27:10 +08:00
|
|
|
if (heap_type == H5HP_MAX_HEAP) {
|
|
|
|
if (val > last_val)
|
|
|
|
TestErrPrintf("Error on line %d: incorrect value from heap=%d, last_val=%d\n", __LINE__, val,
|
|
|
|
last_val);
|
2003-02-25 04:25:13 +08:00
|
|
|
} /* end if */
|
|
|
|
else {
|
2020-09-30 22:27:10 +08:00
|
|
|
if (val < last_val)
|
|
|
|
TestErrPrintf("Error on line %d: incorrect value from heap=%d, last_val=%d\n", __LINE__, val,
|
|
|
|
last_val);
|
2003-02-25 04:25:13 +08:00
|
|
|
} /* end else */
|
|
|
|
|
|
|
|
/* Update last value */
|
2020-09-30 22:27:10 +08:00
|
|
|
last_val = val;
|
2003-02-25 04:25:13 +08:00
|
|
|
} /* end for */
|
|
|
|
|
|
|
|
/* Check that the heap has no elements */
|
2020-09-30 22:27:10 +08:00
|
|
|
num = H5HP_count(heap);
|
2003-02-25 04:25:13 +08:00
|
|
|
VERIFY(num, 0, "H5HP_count");
|
|
|
|
|
2020-09-30 22:27:10 +08:00
|
|
|
/* Insert & remove again, to check that completely empty heaps can be added again */
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Set an appropriate starting value for the "last" value from heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
if (heap_type == H5HP_MAX_HEAP)
|
|
|
|
last_val = INT_MAX;
|
2003-02-25 04:25:13 +08:00
|
|
|
else
|
2020-09-30 22:27:10 +08:00
|
|
|
last_val = INT_MIN;
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Insert the array elements into the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
for (u = 0; u < nelem; u++) {
|
|
|
|
ret = H5HP_insert(heap, arr[u].val, &arr[u]);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_insert");
|
|
|
|
} /* end for */
|
|
|
|
|
|
|
|
/* Check that the heap has correct number of elements */
|
2020-09-30 22:27:10 +08:00
|
|
|
num = H5HP_count(heap);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(num, FAIL, "H5HP_count");
|
|
|
|
VERIFY((size_t)num, nelem, "H5HP_count");
|
|
|
|
|
|
|
|
/* Remove the objects from the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
for (u = 0; u < nelem; u++) {
|
|
|
|
ret = H5HP_remove(heap, &val, (void **)&ptr);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_remove");
|
|
|
|
VERIFY(val, ptr->val, "H5HP_remove");
|
|
|
|
|
|
|
|
/* Check that the value is correct, based on the heap type */
|
2020-09-30 22:27:10 +08:00
|
|
|
if (heap_type == H5HP_MAX_HEAP) {
|
|
|
|
if (val > last_val)
|
|
|
|
TestErrPrintf("Error on line %d: incorrect value from heap=%d, last_val=%d\n", __LINE__, val,
|
|
|
|
last_val);
|
2003-02-25 04:25:13 +08:00
|
|
|
} /* end if */
|
|
|
|
else {
|
2020-09-30 22:27:10 +08:00
|
|
|
if (val < last_val)
|
|
|
|
TestErrPrintf("Error on line %d: incorrect value from heap=%d, last_val=%d\n", __LINE__, val,
|
|
|
|
last_val);
|
2003-02-25 04:25:13 +08:00
|
|
|
} /* end else */
|
|
|
|
|
|
|
|
/* Update last value */
|
2020-09-30 22:27:10 +08:00
|
|
|
last_val = val;
|
2003-02-25 04:25:13 +08:00
|
|
|
} /* end for */
|
|
|
|
|
|
|
|
/* Check that the heap has no elements */
|
2020-09-30 22:27:10 +08:00
|
|
|
num = H5HP_count(heap);
|
2003-02-25 04:25:13 +08:00
|
|
|
VERIFY(num, 0, "H5HP_count");
|
|
|
|
|
|
|
|
/* Close the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_close(heap);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_close");
|
|
|
|
} /* end test_heap_remove_many_core() */
|
|
|
|
|
|
|
|
/****************************************************************
|
|
|
|
**
|
|
|
|
** test_heap_remove_many (): Test H5HP (heap) code.
|
|
|
|
** Tests removing many objects into heaps.
|
2005-08-14 04:53:35 +08:00
|
|
|
**
|
2003-02-25 04:25:13 +08:00
|
|
|
****************************************************************/
|
2005-08-14 04:53:35 +08:00
|
|
|
static void
|
2003-02-25 04:25:13 +08:00
|
|
|
test_heap_remove_many(void)
|
|
|
|
{
|
|
|
|
/* Output message about test being performed */
|
|
|
|
MESSAGE(6, ("Testing Removing Many Objects From Heaps\n"));
|
|
|
|
|
|
|
|
/* Test removing objects from maximum heap with random elements */
|
2006-10-30 23:58:46 +08:00
|
|
|
test_heap_remove_many_core(H5HP_MAX_HEAP, rand_num, (size_t)NUM_ELEMS);
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Test removing objects from maximum heap with elements already sorted in increasing order */
|
2006-10-30 23:58:46 +08:00
|
|
|
test_heap_remove_many_core(H5HP_MAX_HEAP, inc_sort_num, (size_t)NUM_ELEMS);
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Test removing objects from maximum heap with elements already sorted in decreasing order */
|
2006-10-30 23:58:46 +08:00
|
|
|
test_heap_remove_many_core(H5HP_MAX_HEAP, dec_sort_num, (size_t)NUM_ELEMS);
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Test removing objects from minimum heap with random elements */
|
2006-10-30 23:58:46 +08:00
|
|
|
test_heap_remove_many_core(H5HP_MIN_HEAP, rand_num, (size_t)NUM_ELEMS);
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Test removing objects from minimum heap with elements already sorted in increasing order */
|
2006-10-30 23:58:46 +08:00
|
|
|
test_heap_remove_many_core(H5HP_MIN_HEAP, inc_sort_num, (size_t)NUM_ELEMS);
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Test removing objects from minimum heap with elements already sorted in decreasing order */
|
2006-10-30 23:58:46 +08:00
|
|
|
test_heap_remove_many_core(H5HP_MIN_HEAP, dec_sort_num, (size_t)NUM_ELEMS);
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
} /* end test_heap_remove_many() */
|
|
|
|
|
|
|
|
/****************************************************************
|
|
|
|
**
|
|
|
|
** test_heap_change_min (): Test H5HP (heap) code.
|
|
|
|
** Tests changing the priority of an object in a minimum heap
|
2005-08-14 04:53:35 +08:00
|
|
|
**
|
2003-02-25 04:25:13 +08:00
|
|
|
****************************************************************/
|
2005-08-14 04:53:35 +08:00
|
|
|
static void
|
2003-02-25 04:25:13 +08:00
|
|
|
test_heap_change_min(void)
|
|
|
|
{
|
2020-09-30 22:27:10 +08:00
|
|
|
H5HP_t * heap; /* Heap created */
|
|
|
|
ssize_t num; /* Number of elements in heap */
|
|
|
|
int val; /* Value of object on heap */
|
|
|
|
test_obj obj1, obj2, obj3; /* Test objects to insert */
|
|
|
|
herr_t ret; /* Generic return value */
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Output message about test being performed */
|
|
|
|
MESSAGE(7, ("Testing Changing Priority of Objects in Minimum Heaps\n"));
|
|
|
|
|
|
|
|
/* Create a Heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
heap = H5HP_create(H5HP_MIN_HEAP);
|
2017-11-27 10:13:18 +08:00
|
|
|
CHECK_PTR(heap, "H5HP_create");
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Check that the heap has no elements */
|
2020-09-30 22:27:10 +08:00
|
|
|
num = H5HP_count(heap);
|
2003-02-25 04:25:13 +08:00
|
|
|
VERIFY(num, 0, "H5HP_count");
|
|
|
|
|
|
|
|
/* Insert an object into the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
obj1.val = 100;
|
|
|
|
ret = H5HP_insert(heap, 10, &obj1);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_insert");
|
|
|
|
|
|
|
|
/* Insert another object into the heap, with value less than top element */
|
2020-09-30 22:27:10 +08:00
|
|
|
obj2.val = 50;
|
|
|
|
ret = H5HP_insert(heap, 5, &obj2);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_insert");
|
|
|
|
|
|
|
|
/* Insert third object into the heap, with value greater than top element */
|
2020-09-30 22:27:10 +08:00
|
|
|
obj3.val = 200;
|
|
|
|
ret = H5HP_insert(heap, 20, &obj3);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_insert");
|
|
|
|
|
|
|
|
/* Change priority of first object on heap in way which shouldn't affect heap order */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_change(heap, 11, &obj1);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_change");
|
|
|
|
|
|
|
|
/* Check the minimum value on the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_top(heap, &val);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_top");
|
|
|
|
VERIFY(val, 5, "H5HP_top");
|
|
|
|
|
|
|
|
/* Change priority of first object on heap to be the top object on the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_change(heap, 3, &obj1);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_change");
|
|
|
|
|
|
|
|
/* Check the maximum value on the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_top(heap, &val);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_top");
|
|
|
|
VERIFY(val, 3, "H5HP_top");
|
|
|
|
|
|
|
|
/* Change priority of first object on heap to not be the top object on the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_change(heap, 10, &obj1);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_change");
|
|
|
|
|
|
|
|
/* Check the maximum value on the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_top(heap, &val);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_top");
|
|
|
|
VERIFY(val, 5, "H5HP_top");
|
|
|
|
|
|
|
|
/* Close the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_close(heap);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_close");
|
|
|
|
|
|
|
|
} /* end test_heap_change_min() */
|
|
|
|
|
|
|
|
/****************************************************************
|
|
|
|
**
|
|
|
|
** test_heap_change_max (): Test H5HP (heap) code.
|
|
|
|
** Tests changing the priority of an object in a maximumheap
|
2005-08-14 04:53:35 +08:00
|
|
|
**
|
2003-02-25 04:25:13 +08:00
|
|
|
****************************************************************/
|
2005-08-14 04:53:35 +08:00
|
|
|
static void
|
2003-02-25 04:25:13 +08:00
|
|
|
test_heap_change_max(void)
|
|
|
|
{
|
2020-09-30 22:27:10 +08:00
|
|
|
H5HP_t * heap; /* Heap created */
|
|
|
|
ssize_t num; /* Number of elements in heap */
|
|
|
|
int val; /* Value of object on heap */
|
|
|
|
test_obj obj1, obj2, obj3; /* Test objects to insert */
|
|
|
|
herr_t ret; /* Generic return value */
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Output message about test being performed */
|
|
|
|
MESSAGE(7, ("Testing Changing Priority of Objects in Maximum Heaps\n"));
|
|
|
|
|
|
|
|
/* Create a Heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
heap = H5HP_create(H5HP_MAX_HEAP);
|
2017-11-27 10:13:18 +08:00
|
|
|
CHECK_PTR(heap, "H5HP_create");
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Check that the heap has no elements */
|
2020-09-30 22:27:10 +08:00
|
|
|
num = H5HP_count(heap);
|
2003-02-25 04:25:13 +08:00
|
|
|
VERIFY(num, 0, "H5HP_count");
|
|
|
|
|
|
|
|
/* Insert an object into the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
obj1.val = 100;
|
|
|
|
ret = H5HP_insert(heap, 10, &obj1);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_insert");
|
|
|
|
|
|
|
|
/* Insert another object into the heap, with value less than top element */
|
2020-09-30 22:27:10 +08:00
|
|
|
obj2.val = 50;
|
|
|
|
ret = H5HP_insert(heap, 5, &obj2);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_insert");
|
|
|
|
|
|
|
|
/* Insert third object into the heap, with value greater than top element */
|
2020-09-30 22:27:10 +08:00
|
|
|
obj3.val = 200;
|
|
|
|
ret = H5HP_insert(heap, 20, &obj3);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_insert");
|
|
|
|
|
|
|
|
/* Change priority of first object on heap in way which shouldn't affect heap order */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_change(heap, 11, &obj1);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_change");
|
|
|
|
|
|
|
|
/* Check the maximum value on the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_top(heap, &val);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_top");
|
|
|
|
VERIFY(val, 20, "H5HP_top");
|
|
|
|
|
|
|
|
/* Change priority of first object on heap to be the top object on the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_change(heap, 21, &obj1);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_change");
|
|
|
|
|
|
|
|
/* Check the maximum value on the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_top(heap, &val);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_top");
|
|
|
|
VERIFY(val, 21, "H5HP_top");
|
|
|
|
|
|
|
|
/* Change priority of first object on heap to not be the top object on the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_change(heap, 10, &obj1);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_change");
|
|
|
|
|
|
|
|
/* Check the maximum value on the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_top(heap, &val);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_top");
|
|
|
|
VERIFY(val, 20, "H5HP_top");
|
|
|
|
|
|
|
|
/* Close the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_close(heap);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_close");
|
|
|
|
|
|
|
|
} /* end test_heap_change() */
|
|
|
|
|
|
|
|
/****************************************************************
|
|
|
|
**
|
|
|
|
** test_heap_change (): Test H5HP (heap) code.
|
|
|
|
** Tests changing the priority of an object in maximum & minimum heaps
|
2005-08-14 04:53:35 +08:00
|
|
|
**
|
2003-02-25 04:25:13 +08:00
|
|
|
****************************************************************/
|
2005-08-14 04:53:35 +08:00
|
|
|
static void
|
2003-02-25 04:25:13 +08:00
|
|
|
test_heap_change(void)
|
|
|
|
{
|
|
|
|
/* Output message about test being performed */
|
|
|
|
MESSAGE(6, ("Testing Changing Priority of Objects in Heaps\n"));
|
|
|
|
|
|
|
|
/* Test removals from minimum & maximum heaps */
|
|
|
|
test_heap_change_max();
|
|
|
|
test_heap_change_min();
|
|
|
|
} /* end test_heap_change() */
|
|
|
|
|
|
|
|
/****************************************************************
|
|
|
|
**
|
|
|
|
** test_heap_incdec_min (): Test H5HP (heap) code.
|
|
|
|
** Tests incrementing & decrementing priority of objects on
|
|
|
|
** a minimum heap.
|
2005-08-14 04:53:35 +08:00
|
|
|
**
|
2003-02-25 04:25:13 +08:00
|
|
|
****************************************************************/
|
2005-08-14 04:53:35 +08:00
|
|
|
static void
|
2003-02-25 04:25:13 +08:00
|
|
|
test_heap_incdec_min(void)
|
|
|
|
{
|
2020-09-30 22:27:10 +08:00
|
|
|
H5HP_t * heap; /* Heap created */
|
|
|
|
ssize_t num; /* Number of elements in heap */
|
|
|
|
int val; /* Value of object on heap */
|
|
|
|
test_obj obj1, obj2, obj3; /* Test objects to insert */
|
|
|
|
herr_t ret; /* Generic return value */
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Output message about test being performed */
|
|
|
|
MESSAGE(7, ("Testing Incrementing & Decrementing Priority of Objects in Minimum Heaps\n"));
|
|
|
|
|
|
|
|
/* Create a Heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
heap = H5HP_create(H5HP_MIN_HEAP);
|
2017-11-27 10:13:18 +08:00
|
|
|
CHECK_PTR(heap, "H5HP_create");
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Check that the heap has no elements */
|
2020-09-30 22:27:10 +08:00
|
|
|
num = H5HP_count(heap);
|
2003-02-25 04:25:13 +08:00
|
|
|
VERIFY(num, 0, "H5HP_count");
|
|
|
|
|
|
|
|
/* Insert an object into the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
obj1.val = 100;
|
|
|
|
ret = H5HP_insert(heap, 6, &obj1);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_insert");
|
|
|
|
|
|
|
|
/* Insert another object into the heap, with value less than top element */
|
2020-09-30 22:27:10 +08:00
|
|
|
obj2.val = 50;
|
|
|
|
ret = H5HP_insert(heap, 5, &obj2);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_insert");
|
|
|
|
|
|
|
|
/* Insert third object into the heap, with value greater than top element */
|
2020-09-30 22:27:10 +08:00
|
|
|
obj3.val = 200;
|
|
|
|
ret = H5HP_insert(heap, 20, &obj3);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_insert");
|
|
|
|
|
|
|
|
/* Decrement object one's priority by two to put it on top of the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_decr(heap, 2, &obj1);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_change");
|
|
|
|
|
|
|
|
/* Check the minimum value on the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_top(heap, &val);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_top");
|
|
|
|
VERIFY(val, 4, "H5HP_top");
|
|
|
|
|
|
|
|
/* Decrement object two's priority by two to put it back on top of the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_decr(heap, 2, &obj2);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_change");
|
|
|
|
|
|
|
|
/* Check the minimum value on the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_top(heap, &val);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_top");
|
|
|
|
VERIFY(val, 3, "H5HP_top");
|
|
|
|
|
|
|
|
/* Increment object two's priority by two to return object one to the top */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_incr(heap, 2, &obj2);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_change");
|
|
|
|
|
|
|
|
/* Check the minimum value on the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_top(heap, &val);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_top");
|
|
|
|
VERIFY(val, 4, "H5HP_top");
|
|
|
|
|
|
|
|
/* Close the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_close(heap);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_close");
|
|
|
|
|
|
|
|
} /* end test_heap_incdec_min() */
|
|
|
|
|
|
|
|
/****************************************************************
|
|
|
|
**
|
|
|
|
** test_heap_incdec_max (): Test H5HP (heap) code.
|
|
|
|
** Tests incrementing & decrementing priority of objects on
|
|
|
|
** a maximum heap.
|
2005-08-14 04:53:35 +08:00
|
|
|
**
|
2003-02-25 04:25:13 +08:00
|
|
|
****************************************************************/
|
2005-08-14 04:53:35 +08:00
|
|
|
static void
|
2003-02-25 04:25:13 +08:00
|
|
|
test_heap_incdec_max(void)
|
|
|
|
{
|
2020-09-30 22:27:10 +08:00
|
|
|
H5HP_t * heap; /* Heap created */
|
|
|
|
ssize_t num; /* Number of elements in heap */
|
|
|
|
int val; /* Value of object on heap */
|
|
|
|
test_obj obj1, obj2, obj3; /* Test objects to insert */
|
|
|
|
herr_t ret; /* Generic return value */
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Output message about test being performed */
|
|
|
|
MESSAGE(7, ("Testing Incrementing & Decrementing Priority of Objects in Maximum Heaps\n"));
|
|
|
|
|
|
|
|
/* Create a Heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
heap = H5HP_create(H5HP_MAX_HEAP);
|
2017-11-27 10:13:18 +08:00
|
|
|
CHECK_PTR(heap, "H5HP_create");
|
2003-02-25 04:25:13 +08:00
|
|
|
|
|
|
|
/* Check that the heap has no elements */
|
2020-09-30 22:27:10 +08:00
|
|
|
num = H5HP_count(heap);
|
2003-02-25 04:25:13 +08:00
|
|
|
VERIFY(num, 0, "H5HP_count");
|
|
|
|
|
|
|
|
/* Insert an object into the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
obj1.val = 100;
|
|
|
|
ret = H5HP_insert(heap, 19, &obj1);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_insert");
|
|
|
|
|
|
|
|
/* Insert another object into the heap, with value less than top element */
|
2020-09-30 22:27:10 +08:00
|
|
|
obj2.val = 50;
|
|
|
|
ret = H5HP_insert(heap, 5, &obj2);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_insert");
|
|
|
|
|
|
|
|
/* Insert third object into the heap, with value greater than top element */
|
2020-09-30 22:27:10 +08:00
|
|
|
obj3.val = 200;
|
|
|
|
ret = H5HP_insert(heap, 20, &obj3);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_insert");
|
|
|
|
|
|
|
|
/* Increment object one's priority by two to put it on top of the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_incr(heap, 2, &obj1);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_change");
|
|
|
|
|
|
|
|
/* Check the maximum value on the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_top(heap, &val);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_top");
|
|
|
|
VERIFY(val, 21, "H5HP_top");
|
|
|
|
|
|
|
|
/* Increment object three's priority by two to put it back on top of the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_incr(heap, 2, &obj3);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_change");
|
|
|
|
|
|
|
|
/* Check the maximum value on the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_top(heap, &val);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_top");
|
|
|
|
VERIFY(val, 22, "H5HP_top");
|
|
|
|
|
|
|
|
/* Decrement object three's priority by two to return object one to the top */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_decr(heap, 2, &obj3);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_change");
|
|
|
|
|
|
|
|
/* Check the maximum value on the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_top(heap, &val);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_top");
|
|
|
|
VERIFY(val, 21, "H5HP_top");
|
|
|
|
|
|
|
|
/* Close the heap */
|
2020-09-30 22:27:10 +08:00
|
|
|
ret = H5HP_close(heap);
|
2003-02-25 04:25:13 +08:00
|
|
|
CHECK(ret, FAIL, "H5HP_close");
|
|
|
|
|
|
|
|
} /* end test_heap_incdec_max() */
|
|
|
|
|
|
|
|
/****************************************************************
|
|
|
|
**
|
|
|
|
** test_heap_incdec (): Test H5HP (heap) code.
|
|
|
|
** Tests incrementing & decrementing priority of objects on
|
|
|
|
** maximum & minimum heaps.
|
2005-08-14 04:53:35 +08:00
|
|
|
**
|
2003-02-25 04:25:13 +08:00
|
|
|
****************************************************************/
|
2005-08-14 04:53:35 +08:00
|
|
|
static void
|
2003-02-25 04:25:13 +08:00
|
|
|
test_heap_incdec(void)
|
|
|
|
{
|
|
|
|
/* Output message about test being performed */
|
|
|
|
MESSAGE(6, ("Testing Incrementing & Decrementing Priority of Objects in Heaps\n"));
|
|
|
|
|
|
|
|
/* Test increments & decrements in minimum & maximum heaps */
|
|
|
|
test_heap_incdec_max();
|
|
|
|
test_heap_incdec_min();
|
|
|
|
} /* end test_heap_incdec() */
|
|
|
|
|
2016-09-28 01:29:16 +08:00
|
|
|
/****************************************************************
|
|
|
|
**
|
|
|
|
** test_heap_term(): Test H5HP (heap) code.
|
|
|
|
** Release data for Heap testing
|
|
|
|
**
|
|
|
|
****************************************************************/
|
|
|
|
static void
|
|
|
|
test_heap_term(void)
|
|
|
|
{
|
|
|
|
/* Release arrays */
|
2020-09-30 22:27:10 +08:00
|
|
|
if (rand_num)
|
2016-09-30 04:17:55 +08:00
|
|
|
HDfree(rand_num);
|
2020-09-30 22:27:10 +08:00
|
|
|
if (inc_sort_num)
|
2016-09-30 04:17:55 +08:00
|
|
|
HDfree(inc_sort_num);
|
2020-09-30 22:27:10 +08:00
|
|
|
if (dec_sort_num)
|
2016-09-30 04:17:55 +08:00
|
|
|
HDfree(dec_sort_num);
|
2021-03-30 10:32:52 +08:00
|
|
|
} /* end test_heap_term() */
|
2016-09-28 01:29:16 +08:00
|
|
|
|
2003-02-25 04:25:13 +08:00
|
|
|
/****************************************************************
|
|
|
|
**
|
|
|
|
** test_heap(): Main H5HP testing routine.
|
2005-08-14 04:53:35 +08:00
|
|
|
**
|
2003-02-25 04:25:13 +08:00
|
|
|
****************************************************************/
|
|
|
|
void
|
|
|
|
test_heap(void)
|
|
|
|
{
|
|
|
|
/* Output message about test being performed */
|
|
|
|
MESSAGE(5, ("Testing Heaps\n"));
|
|
|
|
|
|
|
|
/* Initialize Heap testing data */
|
|
|
|
test_heap_init();
|
|
|
|
|
|
|
|
/* Actual Heap tests */
|
2020-09-30 22:27:10 +08:00
|
|
|
test_heap_create(); /* Test Heap creation */
|
|
|
|
test_heap_insert(); /* Test basic Heap insertion */
|
|
|
|
test_heap_insert_many(); /* Test Heap insertion of many items */
|
|
|
|
test_heap_remove(); /* Test basic Heap removal */
|
|
|
|
test_heap_remove_many(); /* Test Heap removal of many items */
|
|
|
|
test_heap_change(); /* Test changing priority of objects on Heap */
|
|
|
|
test_heap_incdec(); /* Test incrementing & decrementing priority of objects on Heap */
|
2003-02-25 04:25:13 +08:00
|
|
|
|
2016-09-28 01:29:16 +08:00
|
|
|
/* Release Heap testing data */
|
|
|
|
test_heap_term();
|
|
|
|
|
2020-09-30 22:27:10 +08:00
|
|
|
} /* end test_heap() */
|