#include <vtkPriorityQueue.h>
vtkPriorityQueue is a general object for creating and manipulating lists of object ids (e.g., point or cell ids). Object ids are sorted according to a user-specified priority, where entries at the top of the queue have the smallest values.
This implementation provides a feature beyond the usual ability to insert and retrieve (or pop) values from the queue. It is also possible to pop any item in the queue given its id number. This allows you to delete entries in the queue which can useful for reinserting an item into the queue.
Definition at line 44 of file vtkPriorityQueue.h.
Public Types | |
typedef vtkObject | Superclass |
Public Member Functions | |
virtual const char * | GetClassName () |
virtual int | IsA (const char *type) |
void | PrintSelf (ostream &os, vtkIndent indent) |
void | Allocate (const vtkIdType sz, const vtkIdType ext=1000) |
void | Insert (double priority, vtkIdType id) |
vtkIdType | Pop (vtkIdType location=0) |
vtkIdType | Peek (vtkIdType location=0) |
double | DeleteId (vtkIdType id) |
double | GetPriority (vtkIdType id) |
vtkIdType | GetNumberOfItems () |
void | Reset () |
vtkIdType | Pop (vtkIdType location, double &priority) |
vtkIdType | Peek (vtkIdType location, double &priority) |
Static Public Member Functions | |
static vtkPriorityQueue * | New () |
static int | IsTypeOf (const char *type) |
static vtkPriorityQueue * | SafeDownCast (vtkObject *o) |
Protected Member Functions | |
vtkPriorityQueue () | |
~vtkPriorityQueue () | |
Item * | Resize (const vtkIdType sz) |
Protected Attributes | |
vtkIdTypeArray * | ItemLocation |
Item * | Array |
vtkIdType | Size |
vtkIdType | MaxId |
vtkIdType | Extend |
Classes | |
class | Item |
vtkPriorityQueue::vtkPriorityQueue | ( | ) | [protected] |
vtkPriorityQueue::~vtkPriorityQueue | ( | ) | [protected] |
static vtkPriorityQueue* vtkPriorityQueue::New | ( | ) | [static] |
Instantiate priority queue with default size and extension size of 1000.
Reimplemented from vtkObject.
virtual const char* vtkPriorityQueue::GetClassName | ( | ) | [virtual] |
Reimplemented from vtkObject.
static int vtkPriorityQueue::IsTypeOf | ( | const char * | name | ) | [static] |
Return 1 if this class type is the same type of (or a subclass of) the named class. Returns 0 otherwise. This method works in combination with vtkTypeMacro found in vtkSetGet.h.
Reimplemented from vtkObject.
virtual int vtkPriorityQueue::IsA | ( | const char * | name | ) | [virtual] |
Return 1 if this class is the same type of (or a subclass of) the named class. Returns 0 otherwise. This method works in combination with vtkTypeMacro found in vtkSetGet.h.
Reimplemented from vtkObject.
static vtkPriorityQueue* vtkPriorityQueue::SafeDownCast | ( | vtkObject * | o | ) | [static] |
Reimplemented from vtkObject.
void vtkPriorityQueue::PrintSelf | ( | ostream & | os, | |
vtkIndent | indent | |||
) | [virtual] |
Allocate initial space for priority queue.
void vtkPriorityQueue::Insert | ( | double | priority, | |
vtkIdType | id | |||
) |
Insert id with priority specified. The id is generally an index like a point id or cell id.
Removes item at specified location from tree; then reorders and balances tree. The location == 0 is the root of the tree. If queue is exhausted, then a value < 0 is returned. (Note: the location is not the same as deleting an id; id is mapped to location.)
Same as above but simplified for easier wrapping into interpreted languages.
Peek into the queue without actually removing anything. Returns the id and the priority.
Definition at line 152 of file vtkPriorityQueue.h.
Peek into the queue without actually removing anything. Returns the id.
Definition at line 165 of file vtkPriorityQueue.h.
double vtkPriorityQueue::DeleteId | ( | vtkIdType | id | ) | [inline] |
Delete entry in queue with specified id. Returns priority value associated with that id; or VTK_DOUBLE_MAX if not in queue.
Definition at line 127 of file vtkPriorityQueue.h.
double vtkPriorityQueue::GetPriority | ( | vtkIdType | id | ) | [inline] |
Get the priority of an entry in the queue with specified id. Returns priority value of that id or VTK_DOUBLE_MAX if not in queue.
Definition at line 140 of file vtkPriorityQueue.h.
vtkIdType vtkPriorityQueue::GetNumberOfItems | ( | ) | [inline] |
Return the number of items in this queue.
Definition at line 105 of file vtkPriorityQueue.h.
void vtkPriorityQueue::Reset | ( | ) |
Empty the queue but without releasing memory. This avoids the overhead of memory allocation/deletion.
vtkIdTypeArray* vtkPriorityQueue::ItemLocation [protected] |
Definition at line 117 of file vtkPriorityQueue.h.
Item* vtkPriorityQueue::Array [protected] |
Definition at line 118 of file vtkPriorityQueue.h.
vtkIdType vtkPriorityQueue::Size [protected] |
Definition at line 119 of file vtkPriorityQueue.h.
vtkIdType vtkPriorityQueue::MaxId [protected] |
Definition at line 120 of file vtkPriorityQueue.h.
vtkIdType vtkPriorityQueue::Extend [protected] |
Definition at line 121 of file vtkPriorityQueue.h.