Package org.apache.lucene.util.hnsw
Class BlockingFloatHeap
java.lang.Object
org.apache.lucene.util.hnsw.BlockingFloatHeap
A blocking bounded min heap that stores floats. The top element is the lowest value of the heap.
 
A primitive priority queue that maintains a partial ordering of its elements such that the
 least element can always be found in constant time. Implementation is based on LongHeap
- NOTE: This API is for internal purposes only and might change in incompatible ways in the next release.
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionfloatoffer(float value) Inserts a value into this heap.floatoffer(float[] values, int len) Inserts array of values into this heap.floatpeek()Retrieves, but does not remove, the head of this heap.floatpoll()Removes and returns the head of the heapintsize()Returns the number of elements in this heap.
- 
Constructor Details- 
BlockingFloatHeappublic BlockingFloatHeap(int maxSize) 
 
- 
- 
Method Details- 
offerpublic float offer(float value) Inserts a value into this heap.If the number of values would exceed the heap's maxSize, the least value is discarded - Parameters:
- value- the value to add
- Returns:
- the new 'top' element in the queue.
 
- 
offerpublic float offer(float[] values, int len) Inserts array of values into this heap.Values must be sorted in ascending order. - Parameters:
- values- a set of values to insert, must be sorted in ascending order
- len- number of values from the- valuesarray to insert
- Returns:
- the new 'top' element in the queue.
 
- 
pollpublic float poll()Removes and returns the head of the heap- Returns:
- the head of the heap, the smallest value
- Throws:
- IllegalStateException- if the heap is empty
 
- 
peekpublic float peek()Retrieves, but does not remove, the head of this heap.- Returns:
- the head of the heap, the smallest value
 
- 
sizepublic int size()Returns the number of elements in this heap.- Returns:
- the number of elements in this heap
 
 
-