-
Notifications
You must be signed in to change notification settings - Fork 52
/
Copy pathretrieve.py
42 lines (36 loc) · 1.21 KB
/
retrieve.py
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
from utils import *
sys_p = """
Assess the similarity of the two provided summaries and return a rating from these options: 'very similar', 'similar', 'general', 'not similar', 'totally not similar'. Provide only the rating.
"""
def seq_ret(n4j, sumq):
rating_list = []
sumk = []
gids = []
sum_query = """
MATCH (s:Summary)
RETURN s.content, s.gid
"""
res = n4j.query(sum_query)
for r in res:
sumk.append(r['s.content'])
gids.append(r['s.gid'])
for sk in sumk:
sk = sk[0]
rate = call_llm(sys_p, "The two summaries for comparison are: \n Summary 1: " + sk + "\n Summary 2: " + sumq[0])
if "totally not similar" in rate:
rating_list.append(0)
elif "not similar" in rate:
rating_list.append(1)
elif "general" in rate:
rating_list.append(2)
elif "very similar" in rate:
rating_list.append(4)
elif "similar" in rate:
rating_list.append(3)
else:
print("llm returns no relevant rate")
rating_list.append(-1)
ind = find_index_of_largest(rating_list)
# print('ind is', ind)
gid = gids[ind]
return gid