|
nsz |
7da660 |
#include <stdlib.h>
|
|
nsz |
7da660 |
#include <stdio.h>
|
|
nsz |
7da660 |
#include <string.h>
|
|
nsz |
7da660 |
#include "test.h"
|
|
nsz |
7da660 |
|
|
nsz |
7da660 |
static int scmp(const void *a, const void *b)
|
|
nsz |
7da660 |
{
|
|
nsz |
7da660 |
return strcmp(*(char **)a, *(char **)b);
|
|
nsz |
7da660 |
}
|
|
nsz |
7da660 |
|
|
nsz |
7da660 |
static int icmp(const void *a, const void *b)
|
|
nsz |
7da660 |
{
|
|
nsz |
7da660 |
return *(int*)a - *(int*)b;
|
|
nsz |
7da660 |
}
|
|
nsz |
7da660 |
|
|
nsz |
7da660 |
/* 26 items -- even */
|
|
nsz |
7da660 |
static char *s[] = {
|
|
nsz |
7da660 |
"Bob", "Alice", "John", "Ceres",
|
|
nsz |
7da660 |
"Helga", "Drepper", "Emeralda", "Zoran",
|
|
nsz |
7da660 |
"Momo", "Frank", "Pema", "Xavier",
|
|
nsz |
7da660 |
"Yeva", "Gedun", "Irina", "Nono",
|
|
nsz |
7da660 |
"Wiener", "Vincent", "Tsering", "Karnica",
|
|
nsz |
7da660 |
"Lulu", "Quincy", "Osama", "Riley",
|
|
nsz |
7da660 |
"Ursula", "Sam"
|
|
nsz |
7da660 |
};
|
|
nsz |
7da660 |
/* 23 items -- odd, prime */
|
|
nsz |
7da660 |
static int n[] = {
|
|
nsz |
7da660 |
879045, 394, 99405644, 33434, 232323, 4334, 5454,
|
|
nsz |
7da660 |
343, 45545, 454, 324, 22, 34344, 233, 45345, 343,
|
|
nsz |
7da660 |
848405, 3434, 3434344, 3535, 93994, 2230404, 4334
|
|
nsz |
7da660 |
};
|
|
nsz |
7da660 |
|
|
nsz |
7da660 |
void test_qsort(void) {
|
|
nsz |
7da660 |
int i;
|
|
nsz |
7da660 |
|
|
nsz |
7da660 |
qsort(s, sizeof(s)/sizeof(char *), sizeof(char *), scmp);
|
|
nsz |
7da660 |
for (i=0; i
|
|
nsz |
7da660 |
if (strcmp(s[i], s[i+1]) > 0) {
|
|
nsz |
7da660 |
error("string sort failed at index %d\n", i);
|
|
nsz |
7da660 |
for (i=0; i
|
|
nsz |
7da660 |
fprintf(stderr, "\t%d\t%s\n", i, s[i]);
|
|
nsz |
7da660 |
break;
|
|
nsz |
7da660 |
}
|
|
nsz |
7da660 |
}
|
|
nsz |
7da660 |
|
|
nsz |
7da660 |
qsort(n, sizeof(n)/sizeof(int), sizeof(int), icmp);
|
|
nsz |
7da660 |
for (i=0; i
|
|
nsz |
7da660 |
if (n[i] > n[i+1]) {
|
|
nsz |
7da660 |
error("integer sort failed at index %d\n", i);
|
|
nsz |
7da660 |
for (i=0; i
|
|
nsz |
7da660 |
fprintf(stderr, "\t%d\t%d\n", i, n[i]);
|
|
nsz |
7da660 |
break;
|
|
nsz |
7da660 |
}
|
|
nsz |
7da660 |
}
|
|
nsz |
7da660 |
}
|
|
nsz |
7da660 |
|
|
nsz |
7da660 |
void bench_qsort_small(int N) {
|
|
nsz |
7da660 |
int i;
|
|
nsz |
7da660 |
int *a = malloc(sizeof n);
|
|
nsz |
7da660 |
|
|
nsz |
7da660 |
for (i = 0; i < N; i++) {
|
|
nsz |
7da660 |
memcpy(a, n, sizeof n);
|
|
nsz |
7da660 |
qsort(a, sizeof n/sizeof *n, sizeof *a, icmp);
|
|
nsz |
7da660 |
}
|
|
nsz |
7da660 |
free(a);
|
|
nsz |
7da660 |
}
|
|
nsz |
7da660 |
|
|
nsz |
7da660 |
void bench_qsort_large(int N) {
|
|
nsz |
7da660 |
int i,j;
|
|
nsz |
7da660 |
int len = 100000;
|
|
nsz |
7da660 |
int *a = malloc(len * sizeof *a);
|
|
nsz |
7da660 |
|
|
nsz |
7da660 |
for (i = 0; i < N; i++) {
|
|
nsz |
7da660 |
srand(13);
|
|
nsz |
7da660 |
for (j = 0; j < len; j++)
|
|
nsz |
7da660 |
a[j] = rand();
|
|
nsz |
7da660 |
qsort(a, len, sizeof *a, icmp);
|
|
nsz |
7da660 |
}
|
|
nsz |
7da660 |
free(a);
|
|
nsz |
7da660 |
}
|