Package org.apache.lucene.util.hnsw
Class OnHeapHnswGraph
java.lang.Object
org.apache.lucene.util.hnsw.HnswGraph
org.apache.lucene.util.hnsw.OnHeapHnswGraph
- All Implemented Interfaces:
- Accountable
An 
HnswGraph where all nodes and connections are held in memory. This class is used to
 construct the HNSW graph before it's written to the index.- 
Nested Class SummaryNested classes/interfaces inherited from class org.apache.lucene.util.hnsw.HnswGraphHnswGraph.ArrayNodesIterator, HnswGraph.CollectionNodesIterator, HnswGraph.NodesIterator
- 
Field SummaryFields inherited from class org.apache.lucene.util.hnsw.HnswGraphEMPTY, UNKNOWN_MAX_CONNFields inherited from interface org.apache.lucene.util.AccountableNULL_ACCOUNTABLE
- 
Method SummaryModifier and TypeMethodDescriptionvoidaddNode(int level, int node) Add node on the given level.intReturns the graph's current entry node on the top level shown as ordinals of the nodes on 0th levelgetNeighbors(int level, int node) Returns theNeighborQueueconnected to the given node.getNodesOnLevel(int level) WARN: calling this method will essentially iterate through all nodes at level 0 (even if you're not getting node at level 0), we have built some caching mechanism such that if graph is not changed only the first non-zero level call will pay the cost.intmaxConn()returns M, the maximum number of connections for a node.intWhen we initialize from another graph, the max node id is different fromsize(), because we will add nodes out of order, such that we need two method for eachintintIterates over the neighbor list.intReturns the current number of levels in the graphlongReturn the memory usage of this object in bytes.voidseek(int level, int targetNode) Move the pointer to exactly the givenlevel'starget.intsize()Returns the number of nodes in the graphtoString()booleantryPromoteNewEntryNode(int node, int level, int expectOldLevel) Try to promote the provided node to the entry nodebooleantrySetNewEntryNode(int node, int level) Try to set the entry node if the graph does not have oneMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface org.apache.lucene.util.AccountablegetChildResources
- 
Method Details- 
getNeighborsReturns theNeighborQueueconnected to the given node.- Parameters:
- level- level of the graph
- node- the node whose neighbors are returned, represented as an ordinal on the level 0.
 
- 
sizepublic int size()Description copied from class:HnswGraphReturns the number of nodes in the graph
- 
maxNodeIdpublic int maxNodeId()When we initialize from another graph, the max node id is different fromsize(), because we will add nodes out of order, such that we need two method for each
- 
addNodepublic void addNode(int level, int node) Add node on the given level. Nodes can be inserted out of order, but it requires that the nodes preceded by the node inserted out of order are eventually added.NOTE: You must add a node starting from the node's top level - Parameters:
- level- level to add a node on
- node- the node to add, represented as an ordinal on the level 0.
 
- 
seekpublic void seek(int level, int targetNode) Description copied from class:HnswGraphMove the pointer to exactly the givenlevel'starget. After this method returns, callHnswGraph.nextNeighbor()to return successive (ordered) connected node ordinals.- Specified by:
- seekin class- HnswGraph
- Parameters:
- level- level of the graph
- targetNode- ordinal of a node in the graph, must be ≥ 0 and <- KnnVectorValues.size().
 
- 
neighborCountpublic int neighborCount()- Specified by:
- neighborCountin class- HnswGraph
 
- 
nextNeighborpublic int nextNeighbor()Description copied from class:HnswGraphIterates over the neighbor list. It is illegal to call this method after it returns NO_MORE_DOCS without callingHnswGraph.seek(int, int), which resets the iterator.- Specified by:
- nextNeighborin class- HnswGraph
- Returns:
- a node ordinal in the graph, or NO_MORE_DOCS if the iteration is complete.
 
- 
numLevelspublic int numLevels()Returns the current number of levels in the graph
- 
entryNodepublic int entryNode()Returns the graph's current entry node on the top level shown as ordinals of the nodes on 0th level
- 
maxConnpublic int maxConn()Description copied from class:HnswGraphreturns M, the maximum number of connections for a node.
- 
trySetNewEntryNodepublic boolean trySetNewEntryNode(int node, int level) Try to set the entry node if the graph does not have one- Returns:
- True if the entry node is set to the provided node. False if the entry node already exists
 
- 
tryPromoteNewEntryNodepublic boolean tryPromoteNewEntryNode(int node, int level, int expectOldLevel) Try to promote the provided node to the entry node- Parameters:
- level- should be larger than expectedOldLevel
- expectOldLevel- is the old entry node level the caller expect to be, the actual graph level can be different due to concurrent modification
- Returns:
- True if the entry node is set to the provided node. False if expectOldLevel is not the same as the current entry node level. Even if the provided node's level is still higher than the current entry node level, the new entry node will not be set and false will be returned.
 
- 
getNodesOnLevelWARN: calling this method will essentially iterate through all nodes at level 0 (even if you're not getting node at level 0), we have built some caching mechanism such that if graph is not changed only the first non-zero level call will pay the cost. So it is highly NOT recommended to call this method while the graph is still building.NOTE: calling this method while the graph is still building is prohibited - Specified by:
- getNodesOnLevelin class- HnswGraph
- Parameters:
- level- level for which to get all nodes
- Returns:
- an iterator over nodes where nextIntreturns a next node on the level
 
- 
ramBytesUsedpublic long ramBytesUsed()Description copied from interface:AccountableReturn the memory usage of this object in bytes. Negative values are illegal.- Specified by:
- ramBytesUsedin interface- Accountable
 
- 
toString
 
-