Skip to content

Commit

Permalink
Document priority queue, max heap. Fixes: #2901
Browse files Browse the repository at this point in the history
  • Loading branch information
LeStarch authored Nov 23, 2024
1 parent b6dca73 commit 67e5b12
Showing 1 changed file with 37 additions and 0 deletions.
37 changes: 37 additions & 0 deletions Os/Generic/docs/sdd.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
# Generic OSAL Implementations

This package provides generic implementations of various OSAL modules. These are implemented using generic data structures, other OSAL types, and C++ code. These specifically avoid calls down into any underlying operating system.

Available implementations:
1. [Os::PriorityQueue](#ospriority-queue-key-algorithms)


## Os::PriorityQueue

Os::PriorityQueue is an in-memory implementation of Os::Queue. It allows projects that desire in-memory queue support to use Os::Queues. Os::PriorityQueue allocates memory for its underlying data strctures using `new (nothrow)` and deallocates memory with `delete`. These actions are taken during `create` and object destruction. This implies that Os::PriorityQueue should be instantiated and initializated during system intitalization.

Check failure

Code scanning / check-spelling

Unrecognized Spelling Error documentation

strctures is not a recognized word. (unrecognized-spelling)

Check failure

Code scanning / check-spelling

Unrecognized Spelling Error documentation

initializated is not a recognized word. (unrecognized-spelling)

Check failure

Code scanning / check-spelling

Unrecognized Spelling Error documentation

intitalization is not a recognized word. (unrecognized-spelling)

For memory protection, Os::PriorityQueue delegates to Os::Mutex and Os::ConditionVariable.

### Os::PriorityQueue Key Algorithms

Os::PriorityQueue stores messages in a set of dynamically allocated unordered parallel arrays. These arrays store: message data, and message data size repsctively. There is also an index-free list that stores the indicies that are available for storage in the fixed size arrays.

Check failure

Code scanning / check-spelling

Unrecognized Spelling Error documentation

repsctively is not a recognized word. (unrecognized-spelling)

Check failure

Code scanning / check-spelling

Unrecognized Spelling Error documentation

indicies is not a recognized word. (unrecognized-spelling)

In order to prioritize messages, a [Types::MaxHeap](#typesmax-heap-data-structure) data structure is used.

When a message is received from a calling sender, `find_index` returns a free index from the free list. The data is copied into the message data array, and the size into the size array using this free index via `store_data`. The index is then inserted into the max heap strcture for prioritization. When the queue is full and the `BLOCKING` option was supplied, the sender will block on the `m_full` condition variable until notified of a dequeue.

Check failure

Code scanning / check-spelling

Unrecognized Spelling Error documentation

strcture is not a recognized word. (unrecognized-spelling)

When a message is dequeued, the highest priority index is removed from the max heap. The data is copied out from the data array, and the size from the size array using that index via `load_data` and sent to the calling receiver. The index is then returned to the free list via `return_index` to indicate that it may be reusued. When the queue is empty and the `BLOCKING` option was supplied, the receiver will block on the `m_empty` condition variable until notified of a dequeue.

Check failure

Code scanning / check-spelling

Unrecognized Spelling Error documentation

reusued is not a recognized word. (unrecognized-spelling)

If the queue is empty and data was received, the `m_empty` condition variable is notified to unblock waiting receivers. If the queue is full and data was dequeued, the `m_full` condition variable is notified to unblock waiting receivers.

### Types::MaxHeap Data Structure

The Types::MaxHeap data structure is used to prioritize a list of indicies using the given priority. This heap uses a dynamically allocated maximum-length array to back a binary tree storage structure. The first element is the root of the tree, left children are calculated using `2x + 1` and right children using `2x + 2`. A node's parent is at `(x - 1)/2`.

Check failure

Code scanning / check-spelling

Unrecognized Spelling Error documentation

indicies is not a recognized word. (unrecognized-spelling)

When an index is pushed into this structure, it starts at the first unused element (first free child of some node) and iteratively swaps with its parent as long as the new nodes priority is larger than the parent. This ensures that the higher-priority elements are closer to the root of the tree. Specifically, the root *is* the highest priority element.

When an index is pulled from this structure, the root is removed as it is the highest priority data structure. The last leaf of the tree is elivated to the root and `heapify` is then called to restore the max-heap invariant of the data structur.

Check failure

Code scanning / check-spelling

Unrecognized Spelling Error documentation

elivated is not a recognized word. (unrecognized-spelling)

Check failure

Code scanning / check-spelling

Unrecognized Spelling Error documentation

structur is not a recognized word. (unrecognized-spelling)

`heapify` starts at the newly ill-ordered root. It iteratively swaps this node with the highest-priority child until this node is the largest of the three (parent, left child, and right child) or until this node is swapped into a leaf position without children. The max-heap invariant is now restored.


0 comments on commit 67e5b12

Please sign in to comment.