Skip to content

Commit

Permalink
feat: add RAG exceptions (#171)
Browse files Browse the repository at this point in the history
Signed-off-by: Panos Vagenas <[email protected]>
  • Loading branch information
vagenas authored Mar 5, 2024
1 parent c83cbde commit 533e4c5
Showing 1 changed file with 25 additions and 2 deletions.
27 changes: 25 additions & 2 deletions deepsearch/cps/queries/results.py
Original file line number Diff line number Diff line change
Expand Up @@ -31,16 +31,37 @@ class RAGAnswerItem(BaseModel):
grounding: RAGGroundingInfo


class SemanticError(Exception):
pass


class GenerationError(SemanticError):
def __init__(self, msg="", *args, **kwargs):
err_msg = "There was an error during generation"
if msg:
err_msg += f": {msg}"
super().__init__(err_msg, *args, **kwargs)


class NoSearchResultsError(SemanticError):
def __init__(self, msg="Search returned no results", *args, **kwargs):
super().__init__(msg, *args, **kwargs)


class RAGResult(BaseModel):
answers: List[RAGAnswerItem]
search_result_items: List[SearchResultItem]

@classmethod
def from_api_output(cls, data: RunQueryResult):
def from_api_output(cls, data: RunQueryResult, raise_on_error=True):
answers: List[RAGAnswerItem] = []
try:
search_result_items = data.outputs["retrieval"]["items"]
if raise_on_error and len(search_result_items) == 0:
raise NoSearchResultsError()
for answer_item in data.outputs["answers"]:
if raise_on_error and (gen_err := answer_item.get("gen_err")):
raise GenerationError(gen_err)
answers.append(
RAGAnswerItem(
answer=answer_item["answer"],
Expand All @@ -64,9 +85,11 @@ class SearchResult(BaseModel):
search_result_items: List[SearchResultItem]

@classmethod
def from_api_output(cls, data: RunQueryResult):
def from_api_output(cls, data: RunQueryResult, raise_on_error=True):
try:
search_result_items = data.outputs["items"]
if raise_on_error and len(search_result_items) == 0:
raise NoSearchResultsError()
except KeyError:
raise ValueError("Unexpected input format.")
return SearchResult(
Expand Down

0 comments on commit 533e4c5

Please sign in to comment.