File size: 984 Bytes
c26a43c
 
 
 
 
 
ef01036
c26a43c
 
ef01036
c26a43c
 
 
 
 
 
 
2535101
 
 
 
ef01036
 
c26a43c
ef01036
 
 
c26a43c
 
 
ef01036
c26a43c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
from typing import Dict, List, Any
from InstructorEmbedding import INSTRUCTOR


class EndpointHandler:
    def __init__(self, path=""):
        # load model on gpu
        self.model = INSTRUCTOR(path, device="cuda")

    def __call__(self, data: Dict[str, Any]) -> List[List[float]]:
        """
         data args:
              inputs (:obj: `str`)
        Return:
              A :obj:`list` | `dict`: will be serialized and returned
        """
        # get inputs
        inputs: dict = data.pop("inputs", data)
        texts = inputs.pop("texts", None)
        instruction = inputs.pop("instruction", None)

        if not texts or not instruction:
            raise ValueError("Please provide texts and instruction")

        # make sure texts is a list
        if not isinstance(texts, list):
            texts = [texts]

        instructions = [[instruction, text] for text in texts]
        embeddings = self.model.encode(instructions)

        return embeddings.tolist()