tejastake commited on
Commit
3a2a3ef
·
verified ·
1 Parent(s): a55c1bd

Upload 3 files

Browse files
Files changed (3) hide show
  1. Dockerfile +20 -0
  2. app.py +23 -0
  3. requirements.txt +4 -0
Dockerfile ADDED
@@ -0,0 +1,20 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ FROM python:3.9
2
+
3
+ WORKDIR /code
4
+
5
+ COPY ./requirements.txt /code/requirements.txt
6
+
7
+ RUN pip install --no-cache-dir --upgrade -r /code/requirements.txt
8
+
9
+ RUN useradd -m -u 1000 user
10
+
11
+ USER user
12
+
13
+ ENV HOME=/home/user \
14
+ PATH=/home/user/.local/bin:$PATH
15
+
16
+ WORKDIR $HOME/app
17
+
18
+ COPY --chown=user . $HOME/app
19
+
20
+ CMD ["uvicorn", "app:app", "--host", "0.0.0.0", "--port", "7860"]
app.py ADDED
@@ -0,0 +1,23 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ from fastapi import FastAPI, HTTPException
2
+ from pydantic import BaseModel
3
+ from FlagEmbedding import FlagReranker
4
+
5
+ # Initialize FastAPI app
6
+ app = FastAPI(title="BGE-Reranker API")
7
+
8
+ # Load the reranker model once during startup
9
+ reranker = FlagReranker('BAAI/bge-reranker-v2-m3', use_fp16=True)
10
+
11
+ # Define the request body schema
12
+ class RerankRequest(BaseModel):
13
+ query: str
14
+ passage: str
15
+
16
+ # Define the API endpoint
17
+ @app.post("/rerank")
18
+ def rerank_score(request: RerankRequest):
19
+ try:
20
+ score = reranker.compute_score([request.query, request.passage], normalize=True)
21
+ return {"score": score}
22
+ except Exception as e:
23
+ raise HTTPException(status_code=500, detail=str(e))
requirements.txt ADDED
@@ -0,0 +1,4 @@
 
 
 
 
 
1
+ fastapi
2
+ uvicorn
3
+ FlagEmbedding
4
+