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
Modifier and TypeClassDescriptionstatic class
A builder to createCoherenceEmbeddingStore
instances. -
Field Summary
Modifier and TypeFieldDescriptionstatic final String
The defaultNamedMap
name.protected final com.tangosol.net.NamedMap
<com.oracle.coherence.ai.DocumentChunk.Id, com.oracle.coherence.ai.DocumentChunk> TheNamedMap
used to store thedocument chunks
.protected final boolean
-
Constructor Summary
ModifierConstructorDescriptionprotected
CoherenceEmbeddingStore
(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.void
Adds a given embedding to the store.Adds multiple embeddings to the store.void
Add multipleEmbedding
instances to the repository.builder()
Return aCoherenceEmbeddingStore.Builder
to use to build aCoherenceEmbeddingStore
.static CoherenceEmbeddingStore
create()
Create a defaultCoherenceEmbeddingStore
.static CoherenceEmbeddingStore
create
(com.tangosol.net.NamedMap<com.oracle.coherence.ai.DocumentChunk.Id, com.oracle.coherence.ai.DocumentChunk> map) Create aCoherenceEmbeddingStore
that uses the specified CoherenceNamedMap
name.static CoherenceEmbeddingStore
Create aCoherenceEmbeddingStore
that uses the specified CoherenceNamedMap
name.void
Removes a single embedding from the store by ID.void
Removes all embeddings from the store.void
Removes all embeddings that match the specifiedFilter
from the store.void
removeAll
(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)Embedding
s.Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
Methods inherited from interface dev.langchain4j.store.embedding.EmbeddingStore
addAll, findRelevant, findRelevant, findRelevant, findRelevant, generateIds
-
Field Details
-
DEFAULT_MAP_NAME
The defaultNamedMap
name.- See Also:
-
documentChunks
protected final com.tangosol.net.NamedMap<com.oracle.coherence.ai.DocumentChunk.Id,com.oracle.coherence.ai.DocumentChunk> documentChunksTheNamedMap
used 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
CoherenceEmbeddingStore
are created using the builder.- Parameters:
namedMap
- theNamedMap
to contain thedocument chunks
normalizeEmbeddings
-true
if thisCoherenceEmbeddingStore
should callEmbedding.normalize()
on embeddings when adding or searching
-
-
Method Details
-
add
Description copied from interface:EmbeddingStore
Adds a given embedding to the store.- Specified by:
add
in 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:EmbeddingStore
Adds a given embedding to the store.- Specified by:
add
in 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:EmbeddingStore
Adds a given embedding and the corresponding content that has been embedded to the store.- Specified by:
add
in 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:EmbeddingStore
Adds multiple embeddings to the store.- Specified by:
addAll
in 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:EmbeddingStore
Removes a single embedding from the store by ID.- Specified by:
remove
in interfaceEmbeddingStore<TextSegment>
- Parameters:
id
- The unique ID of the embedding to be removed.
-
removeAll
Description copied from interface:EmbeddingStore
Removes all embeddings that match the specified IDs from the store.- Specified by:
removeAll
in interfaceEmbeddingStore<TextSegment>
- Parameters:
ids
- A collection of unique IDs of the embeddings to be removed.
-
removeAll
Description copied from interface:EmbeddingStore
Removes all embeddings that match the specifiedFilter
from the store.- Specified by:
removeAll
in interfaceEmbeddingStore<TextSegment>
- Parameters:
filter
- The filter to be applied to theMetadata
of theTextSegment
during removal. Only embeddings whoseTextSegment
'sMetadata
match theFilter
will be removed.
-
removeAll
public void removeAll()Description copied from interface:EmbeddingStore
Removes all embeddings from the store.- Specified by:
removeAll
in interfaceEmbeddingStore<TextSegment>
-
search
Description copied from interface:EmbeddingStore
Searches for the most similar (closest in the embedding space)Embedding
s.
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 allEmbeddingStore
implementations supportFilter
ing.- Specified by:
search
in interfaceEmbeddingStore<TextSegment>
- Parameters:
request
- A request to search in anEmbeddingStore
. Contains all search criteria.- Returns:
- An
EmbeddingSearchResult
containing all foundEmbedding
s.
-
addAll
Add multipleEmbedding
instances to the repository.- Specified by:
addAll
in interfaceEmbeddingStore<TextSegment>
- Parameters:
ids
- the list of identifiers to use for each of theEmbedding
embeddings
- theEmbedding
to addsegments
- an optional list ofTextSegment
to add with the embeddings
-
create
Create a defaultCoherenceEmbeddingStore
.- Returns:
- a default
CoherenceEmbeddingStore
-
create
Create aCoherenceEmbeddingStore
that uses the specified CoherenceNamedMap
name.- Parameters:
name
- the name of the CoherenceNamedMap
used 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 aCoherenceEmbeddingStore
that uses the specified CoherenceNamedMap
name.- Parameters:
map
- theNamedMap
used to store documents- Returns:
- a
CoherenceEmbeddingStore
-
builder
Return aCoherenceEmbeddingStore.Builder
to use to build aCoherenceEmbeddingStore
.- Returns:
- a
CoherenceEmbeddingStore.Builder
to use to build aCoherenceEmbeddingStore
-