File size: 1,689 Bytes
08d2ea6
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
a6067aa
 
08d2ea6
a6067aa
 
 
08d2ea6
a6067aa
 
 
 
 
08d2ea6
13462fb
a6067aa
 
 
 
 
13462fb
 
a6067aa
 
13462fb
 
 
 
 
 
a6067aa
13462fb
 
 
 
 
08d2ea6
 
 
 
 
 
 
a6067aa
08d2ea6
 
 
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
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
import torch
from load_artifacts import load_artifacts


def predict_one(company_description):
    artifacts = load_artifacts()

    embedder = artifacts["embedder"]
    model = artifacts["model"]
    label_maps = artifacts["label_maps"]
    device = artifacts["device"]

    emb = embedder.encode(
        [company_description],
        convert_to_tensor=False,
        normalize_embeddings=True,
    )

    x = torch.tensor(emb, dtype=torch.float32).to(device)

    with torch.no_grad():
        logits = model(x)
        probs = torch.softmax(logits, dim=1)

    probs_np = probs[0].cpu().numpy()
    pred_idx = int(probs.argmax(dim=1)[0].cpu().item())
    pred_prob_y6 = float(torch.max(probs, dim=1).values[0].cpu().item())

    pred_y6 = label_maps["y6"]["to_value"][pred_idx]
    pred_y2 = pred_y6[:2]
    pred_y3 = pred_y6[:3]
    pred_y4 = pred_y6[:4]
    pred_y5 = pred_y6[:5]

    
    y6_title_lookup = artifacts["y6_title_lookup"]
    pred_y6_title = y6_title_lookup.get(pred_y6, "")

    top_idx = probs_np.argsort()[::-1]

    pred_top5_y6 = []
    for i in top_idx:
        prob = float(probs_np[i])

        if prob < 1e-6:
            continue

        code = label_maps["y6"]["to_value"][int(i)]
        pred_top5_y6.append({
            "code": code,
            "title": y6_title_lookup.get(code, ""),
            "prob": prob,
        })

        if len(pred_top5_y6) == 5:
            break

    return {
        "pred_y2": pred_y2,
        "pred_y3": pred_y3,
        "pred_y4": pred_y4,
        "pred_y5": pred_y5,
        "pred_y6": pred_y6,
        "pred_y6_title": pred_y6_title,
        "pred_prob_y6": pred_prob_y6,
        "pred_top5_y6": pred_top5_y6,
    }