fpc/utils/sim_pasc/aiso.spc

103 lines
3.3 KiB
Plaintext

/*
Module: Arbitrary-In Sorted-Out (AISO)
Author: dick@cs.vu.nl (Dick Grune @ Vrije Universiteit, Amsterdam)
Version: Tue Aug 23 12:54:22 1988
Description:
This is the specification of a generic module that builds an
arbitrary-in sorted-out data structure, to be used as a heap, a
priority queue, etc. Elements can be inserted, the first element
extracted and the set scanned at any moment.
Instantiation:
The module is instantiated as follows.
Create a file M.h for some M, which contains at least:
- a definition of AISO_TYPE, the type of the object to be stored
- a possible definition of AISO_EXTRACTOR; see below
- a possible definition of AISO_ITERATOR; see below
- #include "aiso.spc"
This file M.h is to be included in all files that use the aiso
package.
Create a file M.c which contains at least:
- #include "M.h"
- a definition of a routine
int AISO_BEFORE(AISO_TYPE v, AISO_TYPE w)
which yields non-zero if v is to be sorted before w
- #include "aiso.bdy"
This file compiles into the module object.
Specification:
The module always supplies:
int InsertAiso(AISO_TYPE value)
inserts value in its proper place; fails if out of memory
If AISO_EXTRACTOR is defined, the module will also supply:
int ExtractAiso(AISO_TYPE *value)
yields the first value in the aiso and removes it;
fails if empty
If AISO_ITERATOR is defined, the module also supplies a type AisoIter
which declares an iterator, i.e., a structure that records a position
in the ordered set, plus routines for manipulating the iterator, thus
enabling the user to scan the ordered set. The iterator should be
declared as:
AisoIter iter;
and is manipulated by the following commands:
void OpenIter(AisoIter *iter)
opens the iterator for scanning the existing set in order
int GetAisoItem(AisoIter *iter, AISO_TYPE *value)
yields the next value in the iterator; fails if exhausted
void CloseIter(AisoIter *iter)
closes the iterator
If AISO_DEBUG is defined the module will also supply:
void PrintAisoTree(void)
prints the AISO tree; requires AISO_FORMAT, to be set to
a format suitable to print a value of type AISO_TYPE
Implementation:
The AISO implementation is based on a self-adjusting binary tree.
Degenerate behaviour of the tree is avoided by shaking the tree
every 'ln aiso_size' node accesses. This guarantees ln aiso_size
behaviour in the long run, though it is possible for a single
operation to take aiso_size node accesses.
The iterator is implemented as an additional linear linked list
through the tree. This is simpler than and at least as efficient as
clever tree-wiring.
Restrictions:
Due to built-in fixed names, there can only be one AISO per program.
*/
struct aiso_node {
struct aiso_node *an_left;
struct aiso_node *an_right;
#ifdef AISO_ITERATOR
struct aiso_node *an_next;
#endif /* AISO_ITERATOR */
AISO_TYPE an_value;
};
extern int InsertAiso(AISO_TYPE value);
#ifdef AISO_EXTRACTOR
extern int ExtractAiso(AISO_TYPE *value);
#endif /* AISO_EXTRACTOR */
#ifdef AISO_ITERATOR
typedef struct aiso_node *AisoIter;
extern void OpenIter(AisoIter *iter);
extern int GetAisoItem(AisoIter *iter, AISO_TYPE *value);
extern void CloseIter(AisoIter *iter);
#endif /* AISO_ITERATOR */
#ifdef AISO_DEBUG
extern void PrintAisoTree(void);
#endif /* AISO_ITERATOR */