ultimatepp/benchmarks/Sort2/Sort2.cpp
cxl dc23d485c1 .benchmarks
git-svn-id: svn://ultimatepp.org/upp/trunk@15353 f0d560ea-af0d-0410-9eb7-867de7ffcac7
2020-11-04 09:00:00 +00:00

100 lines
2.1 KiB
C++

#include <Core/Core.h>
using namespace Upp;
#ifdef _DEBUG
const int N = 1000;
#else
const int N = 1000000;
#endif
// M. D. MCILROY
// Appendix. An adversary for
// qsort
#include <stdlib.h>
int *val; /* item values */
int ncmp; /* number of comparisons */
int nsolid; /* number of solid items */
int candidate; /* pivot candidate */
int gas; /* gas value */
#define freeze(x) val[x] = nsolid++
int cmp(const void *px, const void *py) /* per C standard */
{
const int x = *(const int*)px;
const int y = *(const int*)py;
ncmp++;
if(val[x]==gas && val[y]==gas)
if(x == candidate)
freeze(x);
else
freeze(y);
if(val[x] == gas)
candidate = x;
else if(val[y] == gas)
candidate = y;
return val[x] - val[y]; /* only the sign matters */
}
int antiqsort(int n, int *a)
{
int i;
int *ptr = (int *)malloc(n*sizeof(*ptr));
val = a;
gas = n - 1;
nsolid = ncmp = candidate = 0;
for(i=0; i<n; i++) {
ptr[i] = i;
val[i] = gas;
}
qsort(ptr, n, sizeof(*ptr), cmp);
free(ptr);
return ncmp;
}
CONSOLE_APP_MAIN
{
StdLogSetup(LOG_COUT|LOG_FILE);
// -3 Sorted
// -2 Valley pattern
// -1 Reverse sorted
// 0 Max Random values
// >0 - number of random values
for(int n = -3; n <= 10; n++) {
Vector<String> h;
for(int i = 0; i < N; i++)
if(n == -3)
h.Add(Format("%06d", i));
else
if(n == -2)
h.Add(Format("%06d", 2 * abs(N / 2 - i) + (i > N / 2)));
else
if(n == -1)
h.Add(Format("%06d", N - i));
else
if(n)
h.Add(AsString(Random(n)));
else
h.Add(AsString(Random()));
DUMP(h);
TimeStop tm;
Sort(h);
double t = tm.Seconds();
RLOG(n << " " << t << " s");
}
/*
Buffer<int> aq(N);
RLOG("Generating antiqsort");
antiqsort(N, aq);
Vector<String> h;
for(int i = 0; i < N; i++)
h.Add(AsString(aq[i]));
RLOG("Now sorting");
TimeStop tm;
Sort(h);
double t = tm.Seconds();
RLOG("antiqsort " << t << " s");
*/
}