2013-02-07 10:34:27 +01:00
|
|
|
/*************** Csort H Declares Source Code File (.H) ****************/
|
|
|
|
/* Name: CSORT.H Version 1.2 */
|
|
|
|
/* */
|
|
|
|
/* (C) Copyright to the author Olivier BERTRAND 2000-2012 */
|
|
|
|
/* */
|
|
|
|
/* This file contains the CSORT class declares (not 64-bits ready) */
|
|
|
|
/* */
|
|
|
|
/* Note on use of this class: This class is meant to be used as a */
|
|
|
|
/* base class by the calling class. This is because the comparison */
|
|
|
|
/* routine must belong to both CSORT and the calling class. */
|
|
|
|
/* This avoids to pass explicitly to it the calling "this" pointer. */
|
|
|
|
/***********************************************************************/
|
|
|
|
#if !defined(CSORT_DEFINED)
|
|
|
|
#define CSORT_DEFINED
|
|
|
|
|
|
|
|
#include <math.h> /* Required for log function */
|
|
|
|
#undef DOMAIN // Was defined in math.h
|
|
|
|
|
|
|
|
/***********************************************************************/
|
|
|
|
/* Constant and external definitions. */
|
|
|
|
/***********************************************************************/
|
|
|
|
#define THRESH 4 /* Threshold for insertion (was 4) */
|
|
|
|
#define MTHRESH 6 /* Threshold for median */
|
|
|
|
|
2014-03-18 19:25:50 +01:00
|
|
|
//extern FILE *debug; /* Debug file */
|
2013-02-07 10:34:27 +01:00
|
|
|
|
|
|
|
typedef int* const CPINT;
|
|
|
|
|
|
|
|
/***********************************************************************/
|
|
|
|
/* This is the CSORT base class declaration. */
|
|
|
|
/***********************************************************************/
|
|
|
|
class DllExport CSORT {
|
|
|
|
public:
|
|
|
|
// Constructor
|
|
|
|
CSORT(bool cns, int th = THRESH, int mth = MTHRESH);
|
2023-02-07 12:57:20 +01:00
|
|
|
virtual ~CSORT() = default;
|
2013-02-07 10:34:27 +01:00
|
|
|
protected:
|
|
|
|
// Implementation
|
|
|
|
/*********************************************************************/
|
|
|
|
/* qsortx/qstx are NOT conservative but use less storage space. */
|
|
|
|
/* qsortc/qstc ARE conservative but use more storage space. */
|
|
|
|
/*********************************************************************/
|
|
|
|
int Qsortx(void); /* Index quick/insert sort */
|
|
|
|
void Qstx(int *base, int *max); /* Preliminary quick sort */
|
|
|
|
int Qsortc(void); /* Conservative q/ins sort */
|
|
|
|
void Qstc(int *base, int *max); /* Preliminary quick sort */
|
|
|
|
void Istc(int *base, int *hi, int *max); /* Insertion sort routine */
|
|
|
|
|
|
|
|
public:
|
|
|
|
// Methods
|
|
|
|
int Qsort(PGLOBAL g, int n); /* Sort calling routine */
|
2017-05-19 22:27:26 +02:00
|
|
|
//virtual void Printf(PGLOBAL g, FILE *f, uint n);
|
|
|
|
//virtual void Prints(PGLOBAL g, char *ps, uint z);
|
2013-02-07 10:34:27 +01:00
|
|
|
#ifdef DEBTRACE
|
|
|
|
int GetNcmp(void) {return num_comp;}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
protected:
|
|
|
|
// Overridable
|
|
|
|
virtual int Qcompare(int *, int *) = 0; /* Item compare routine */
|
|
|
|
#ifdef DEBTRACE
|
|
|
|
virtual void DebugSort(int ph, int n, int *base, int *mid, int *tmp);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
public:
|
|
|
|
// Utility
|
|
|
|
static void SetCmpNum(void)
|
|
|
|
{for (int i = 1; i < 1000; i++) Cpn[i] = Cmpnum(i); Limit = 1000;}
|
|
|
|
protected:
|
|
|
|
static size_t Cmpnum(int n)
|
|
|
|
#if defined(AIX)
|
|
|
|
{return (n < Limit) ? Cpn[n]
|
|
|
|
: (size_t)round(1.0 + (double)n * (log2((double)n) - 1.0));}
|
|
|
|
#else // !AIX
|
|
|
|
{return (n < Limit) ? Cpn[n]
|
|
|
|
: (size_t)(1.5 + (double)n * (log((double)n)/Lg2 - 1.0));}
|
|
|
|
#endif // !AIX
|
|
|
|
|
|
|
|
|
|
|
|
// Members
|
|
|
|
static int Limit; /* Size of precalculated array */
|
|
|
|
static size_t Cpn[1000]; /* Precalculated cmpnum values */
|
|
|
|
static double Lg2; /* Precalculated log(2) value */
|
|
|
|
PGLOBAL G;
|
|
|
|
PDBUSER Dup; /* Used for progress info */
|
|
|
|
bool Cons; /* true for conservative sort */
|
|
|
|
int Thresh; /* Threshold for using qsort */
|
|
|
|
int Mthresh; /* Threshold for median find */
|
|
|
|
int Nitem; /* Number of items to sort */
|
|
|
|
MBLOCK Index; /* Index allocation block */
|
|
|
|
MBLOCK Offset; /* Offset allocation block */
|
|
|
|
CPINT &Pex; /* Reference to sort index */
|
|
|
|
CPINT &Pof; /* Reference to offset array */
|
|
|
|
int *Swix; /* Pointer on EQ/GT work area */
|
|
|
|
int Savmax; /* Saved ProgMax value */
|
|
|
|
int Savcur; /* Saved ProgCur value */
|
|
|
|
LPCSTR Savstep; /* Saved progress step */
|
|
|
|
#ifdef DEBTRACE
|
|
|
|
int num_comp; /* Number of quick sort calls */
|
|
|
|
#endif
|
|
|
|
}; // end of class CSORT
|
|
|
|
|
|
|
|
#endif // CSORT_DEFINED
|
|
|
|
|