source code
/* The Computer Language Benchmarks Game
* https://salsa.debian.org/benchmarksgame-team/benchmarksgame/
*
* Contributed by Eckehard Berns
* Based on code by Kevin Carson
* *reset*
*/
#include <stdlib.h>
#include <stdio.h>
#include <pthread.h>
typedef struct node {
struct node *left, *right;
} node;
static node *
new_node(node *left, node *right)
{
node *ret;
ret = malloc(sizeof(node));
ret->left = left;
ret->right = right;
return ret;
}
static long
item_check(node *tree)
{
if (tree->left == NULL)
return 1;
else
return 1 + item_check(tree->left) +
item_check(tree->right);
}
static node *
bottom_up_tree(int depth)
{
if (depth > 0)
return new_node(bottom_up_tree(depth - 1),
bottom_up_tree(depth - 1));
else
return new_node(NULL, NULL);
}
static void
delete_tree(node *tree)
{
if (tree->left != NULL) {
delete_tree(tree->left);
delete_tree(tree->right);
}
free(tree);
}
struct worker_args {
long iter, check;
int depth;
pthread_t id;
struct worker_args *next;
};
static void *
check_tree_of_depth(void *_args)
{
struct worker_args *args = _args;
long i, iter, check, depth;
node *tmp;
iter = args->iter;
depth = args->depth;
check = 0;
for (i = 1; i <= iter; i++) {
tmp = bottom_up_tree(depth);
check += item_check(tmp);
delete_tree(tmp);
}
args->check = check;
return NULL;
}
int
main(int ac, char **av)
{
node *stretch, *longlived;
struct worker_args *args, *targs, *hargs;
int n, depth, mindepth, maxdepth, stretchdepth;
n = ac > 1 ? atoi(av[1]) : 10;
if (n < 1) {
fprintf(stderr, "Wrong argument.\n");
exit(1);
}
mindepth = 4;
maxdepth = mindepth + 2 > n ? mindepth + 2 : n;
stretchdepth = maxdepth + 1;
stretch = bottom_up_tree(stretchdepth);
printf("stretch tree of depth %u\t check: %li\n", stretchdepth,
item_check(stretch));
delete_tree(stretch);
longlived = bottom_up_tree(maxdepth);
hargs = NULL;
targs = NULL;
for (depth = mindepth; depth <= maxdepth; depth += 2) {
args = malloc(sizeof(struct worker_args));
args->iter = 1 << (maxdepth - depth + mindepth);
args->depth = depth;
args->next = NULL;
if (targs == NULL) {
hargs = args;
targs = args;
} else {
targs->next = args;
targs = args;
}
pthread_create(&args->id, NULL, check_tree_of_depth, args);
}
while (hargs != NULL) {
args = hargs;
pthread_join(args->id, NULL);
printf("%ld\t trees of depth %d\t check: %ld\n",
args->iter, args->depth, args->check);
hargs = args->next;
free(args);
}
printf("long lived tree of depth %d\t check: %ld\n", maxdepth,
item_check(longlived));
/* not in original C version: */
delete_tree(longlived);
return 0;
}
notes, command-line, and program output
NOTES:
64-bit Ubuntu quad core
Ubuntu clang version 18.1.8 (11)
Wed, 23 Oct 2024 01:08:45 GMT
MAKE:
/usr/bin/clang -pipe -Wall -O3 -fomit-frame-pointer -march=ivybridge -pthread binarytrees.clang-5.c -o binarytrees.clang-5.clang_run
rm binarytrees.clang-5.c
5.65s to complete and log all make actions
COMMAND LINE:
./binarytrees.clang-5.clang_run 21
PROGRAM OUTPUT:
stretch tree of depth 22 check: 8388607
2097152 trees of depth 4 check: 65011712
524288 trees of depth 6 check: 66584576
131072 trees of depth 8 check: 66977792
32768 trees of depth 10 check: 67076096
8192 trees of depth 12 check: 67100672
2048 trees of depth 14 check: 67106816
512 trees of depth 16 check: 67108352
128 trees of depth 18 check: 67108736
32 trees of depth 20 check: 67108832
long lived tree of depth 21 check: 4194303