Skip to content

Latest commit

 

History

History
59 lines (41 loc) · 2.66 KB

README.md

File metadata and controls

59 lines (41 loc) · 2.66 KB

RAG Embedding Evaluation

Streamlit App

Overview

This project benchmark the performance of different text process techniques by evaluate it's ability to differentiate related and unrelated queries from document during embedding search.

Currently tested document process techniques:

Document side:

Query side:

Evaluation Method

  • For each case, multiple embeddings will be generated with each doc side and query side methods. Then cosine similarity is calculated accross 2 side embeddings.

  • Then Max similarity for each query of each <doc, query> side method pair is accumulated as a score for this 2 methods pair for this.

  • Then we calculate the average score for each positive query and negative query. And get the diff of average positive query to doc similarity to average negative query to doc similarity as the overall score for this <doc, query> method pair.

  • The score of origin doc embedding with origin query embedding, showed as <direct, direct> is reduced from each score. Since approach is expected to better differentiate related and unrelated queries.

How to use:

  • poetry install
  • poetry run streamlit run
  • add your own azure openai key and endpoint in streamlit app
  • select dataset
  • click run to run evaluation process. This will take a while. completed result will be store in results/ folder
  • click show cases to reveal current dataset
  • click show result to reveal previous eval result

Add or modify dataset

Each dataset is added to cases folder as a json file. The json file should contain a list of dict with following format:

{
    "topic": "topic name should be unique for each case",
    "content": "document content",
    "positive_queries": {
            "pq1 name": "query content",
            "pq2 name": "query content"
        },
    "negative_queries": {
        "nq1 name": "query content"
    }
}