Class CoherenceEmbeddingStore
java.lang.Object
dev.langchain4j.store.embedding.coherence.CoherenceEmbeddingStore
- All Implemented Interfaces:
EmbeddingStore<TextSegment>
An
EmbeddingStore backed by an Oracle Coherence NamedMap.-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionstatic classA builder to createCoherenceEmbeddingStoreinstances. -
Field Summary
FieldsModifier and TypeFieldDescriptionstatic final StringThe defaultNamedMapname.protected final com.tangosol.net.NamedMap<com.oracle.coherence.ai.DocumentChunk.Id, com.oracle.coherence.ai.DocumentChunk> TheNamedMapused to store thedocument chunks.protected final boolean -
Constructor Summary
ConstructorsModifierConstructorDescriptionprotectedCoherenceEmbeddingStore(com.tangosol.net.NamedMap<com.oracle.coherence.ai.DocumentChunk.Id, com.oracle.coherence.ai.DocumentChunk> namedMap, boolean normalizeEmbeddings) Create anCoherenceEmbeddingStore. -
Method Summary
Modifier and TypeMethodDescriptionAdds a given embedding to the store.add(Embedding embedding, TextSegment segment) Adds a given embedding and the corresponding content that has been embedded to the store.voidAdds a given embedding to the store.Adds multiple embeddings to the store.voidAdd multipleEmbeddinginstances to the repository.builder()Return aCoherenceEmbeddingStore.Builderto use to build aCoherenceEmbeddingStore.static CoherenceEmbeddingStorecreate()Create a defaultCoherenceEmbeddingStore.static CoherenceEmbeddingStorecreate(com.tangosol.net.NamedMap<com.oracle.coherence.ai.DocumentChunk.Id, com.oracle.coherence.ai.DocumentChunk> map) Create aCoherenceEmbeddingStorethat uses the specified CoherenceNamedMapname.static CoherenceEmbeddingStoreCreate aCoherenceEmbeddingStorethat uses the specified CoherenceNamedMapname.voidRemoves a single embedding from the store by ID.voidRemoves all embeddings from the store.voidRemoves all embeddings that match the specifiedFilterfrom the store.voidremoveAll(Collection<String> ids) Removes all embeddings that match the specified IDs from the store.search(EmbeddingSearchRequest request) Searches for the most similar (closest in the embedding space)Embeddings.Methods inherited from class Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface EmbeddingStore
addAll, generateIds
-
Field Details
-
DEFAULT_MAP_NAME
-
documentChunks
protected final com.tangosol.net.NamedMap<com.oracle.coherence.ai.DocumentChunk.Id, com.oracle.coherence.ai.DocumentChunk> documentChunksTheNamedMapused to store thedocument chunks. -
normalizeEmbeddings
protected final boolean normalizeEmbeddings
-
-
Constructor Details
-
CoherenceEmbeddingStore
protected CoherenceEmbeddingStore(com.tangosol.net.NamedMap<com.oracle.coherence.ai.DocumentChunk.Id, com.oracle.coherence.ai.DocumentChunk> namedMap, boolean normalizeEmbeddings) Create anCoherenceEmbeddingStore.This method is protected, instances of
CoherenceEmbeddingStoreare created using the builder.- Parameters:
namedMap- theNamedMapto contain thedocument chunksnormalizeEmbeddings-trueif thisCoherenceEmbeddingStoreshould callEmbedding.normalize()on embeddings when adding or searching
-
-
Method Details
-
add
Description copied from interface:EmbeddingStoreAdds a given embedding to the store.- Specified by:
addin interfaceEmbeddingStore<TextSegment>- Parameters:
embedding- The embedding to be added to the store.- Returns:
- The auto-generated ID associated with the added embedding.
-
add
Description copied from interface:EmbeddingStoreAdds a given embedding to the store.- Specified by:
addin interfaceEmbeddingStore<TextSegment>- Parameters:
id- The unique identifier for the embedding to be added.embedding- The embedding to be added to the store.
-
add
Description copied from interface:EmbeddingStoreAdds a given embedding and the corresponding content that has been embedded to the store.- Specified by:
addin interfaceEmbeddingStore<TextSegment>- Parameters:
embedding- The embedding to be added to the store.segment- Original content that was embedded.- Returns:
- The auto-generated ID associated with the added embedding.
-
addAll
Description copied from interface:EmbeddingStoreAdds multiple embeddings to the store.- Specified by:
addAllin interfaceEmbeddingStore<TextSegment>- Parameters:
embeddings- A list of embeddings to be added to the store.- Returns:
- A list of auto-generated IDs associated with the added embeddings.
-
remove
Description copied from interface:EmbeddingStoreRemoves a single embedding from the store by ID.- Specified by:
removein interfaceEmbeddingStore<TextSegment>- Parameters:
id- The unique ID of the embedding to be removed.
-
removeAll
Description copied from interface:EmbeddingStoreRemoves all embeddings that match the specified IDs from the store.- Specified by:
removeAllin interfaceEmbeddingStore<TextSegment>- Parameters:
ids- A collection of unique IDs of the embeddings to be removed.
-
removeAll
Description copied from interface:EmbeddingStoreRemoves all embeddings that match the specifiedFilterfrom the store.- Specified by:
removeAllin interfaceEmbeddingStore<TextSegment>- Parameters:
filter- The filter to be applied to theMetadataof theTextSegmentduring removal. Only embeddings whoseTextSegment'sMetadatamatch theFilterwill be removed.
-
removeAll
public void removeAll()Description copied from interface:EmbeddingStoreRemoves all embeddings from the store.- Specified by:
removeAllin interfaceEmbeddingStore<TextSegment>
-
search
Description copied from interface:EmbeddingStoreSearches for the most similar (closest in the embedding space)Embeddings.
All search criteria are defined inside theEmbeddingSearchRequest.
EmbeddingSearchRequest.filter()can be used to filter by various metadata entries (e.g., user/memory ID). Please note that not allEmbeddingStoreimplementations supportFiltering.- Specified by:
searchin interfaceEmbeddingStore<TextSegment>- Parameters:
request- A request to search in anEmbeddingStore. Contains all search criteria.- Returns:
- An
EmbeddingSearchResultcontaining all foundEmbeddings.
-
addAll
Add multipleEmbeddinginstances to the repository.- Specified by:
addAllin interfaceEmbeddingStore<TextSegment>- Parameters:
ids- the list of identifiers to use for each of theEmbeddingembeddings- theEmbeddingto addsegments- an optional list ofTextSegmentto add with the embeddings
-
create
Create a defaultCoherenceEmbeddingStore.- Returns:
- a default
CoherenceEmbeddingStore
-
create
Create aCoherenceEmbeddingStorethat uses the specified CoherenceNamedMapname.- Parameters:
name- the name of the CoherenceNamedMapused to store documents- Returns:
- a
CoherenceEmbeddingStore
-
create
public static CoherenceEmbeddingStore create(com.tangosol.net.NamedMap<com.oracle.coherence.ai.DocumentChunk.Id, com.oracle.coherence.ai.DocumentChunk> map) Create aCoherenceEmbeddingStorethat uses the specified CoherenceNamedMapname.- Parameters:
map- theNamedMapused to store documents- Returns:
- a
CoherenceEmbeddingStore
-
builder
Return aCoherenceEmbeddingStore.Builderto use to build aCoherenceEmbeddingStore.- Returns:
- a
CoherenceEmbeddingStore.Builderto use to build aCoherenceEmbeddingStore
-