Skip to content

Commit

Permalink
Easy-rag: allow to specify minScore through configuration
Browse files Browse the repository at this point in the history
  • Loading branch information
edeandrea committed Oct 31, 2024
1 parent 92c2aa5 commit 80003ee
Show file tree
Hide file tree
Showing 3 changed files with 16 additions and 7 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -2,9 +2,11 @@

import static io.quarkus.runtime.annotations.ConfigPhase.RUN_TIME;

import io.quarkiverse.langchain4j.easyrag.EasyRagManualIngestion;
import java.util.OptionalDouble;

import io.quarkus.runtime.annotations.ConfigGroup;
import io.quarkus.runtime.annotations.ConfigRoot;

import io.smallrye.config.ConfigMapping;
import io.smallrye.config.WithDefault;

Expand Down Expand Up @@ -52,6 +54,11 @@ public interface EasyRagConfig {
@WithDefault("5")
Integer maxResults();

/**
* The minimum score for results to return when querying the retrieval augmentor.
*/
OptionalDouble minScore();

/**
* The strategy to decide whether document ingestion into the store
* should happen at startup or not. The default is ON. Changing to OFF
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -72,7 +72,7 @@ public RetrievalAugmentor apply(SyntheticCreationalContext<RetrievalAugmentor> c
EmbeddingModel model = context.getInjectedReference(EmbeddingModel.class, Default.Literal.INSTANCE);
EmbeddingStore<TextSegment> store = context.getInjectedReference(EmbeddingStore.class,
Default.Literal.INSTANCE);
return new EasyRetrievalAugmentor(config.maxResults(), model, store);
return new EasyRetrievalAugmentor(config, model, store);
}
};
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -16,14 +16,16 @@ public class EasyRetrievalAugmentor implements RetrievalAugmentor {

private DefaultRetrievalAugmentor delegate;

public EasyRetrievalAugmentor(Integer maxResults, EmbeddingModel embeddingModel, EmbeddingStore embeddingStore) {
EmbeddingStoreContentRetriever contentRetriever = EmbeddingStoreContentRetriever.builder()
public EasyRetrievalAugmentor(EasyRagConfig config, EmbeddingModel embeddingModel, EmbeddingStore embeddingStore) {
var contentRetrieverBuilder = EmbeddingStoreContentRetriever.builder()
.embeddingModel(embeddingModel)
.embeddingStore(embeddingStore)
.maxResults(maxResults)
.build();
.maxResults(config.maxResults());

config.minScore().ifPresent(contentRetrieverBuilder::minScore);

delegate = DefaultRetrievalAugmentor.builder()
.contentRetriever(contentRetriever).build();
.contentRetriever(contentRetrieverBuilder.build()).build();
}

@Override
Expand Down

0 comments on commit 80003ee

Please sign in to comment.