-
Notifications
You must be signed in to change notification settings - Fork 17
/
Copy pathevaluate_summary.py
45 lines (34 loc) · 1.39 KB
/
evaluate_summary.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
import sys
sys.path.append('../')
import numpy as np
import os
from ref_free_metrics.supert import Supert
from utils.data_reader import CorpusReader
from utils.evaluator import evaluate_summary_rouge, add_result
if __name__ == '__main__':
# pseudo-ref strategy:
# * top15 means the first 15 sentences from each input doc will be used to build the pseudo reference summary
pseudo_ref = 'top15'
# read source documents
reader = CorpusReader('data/topic_1')
source_docs = reader()
summaries = reader.readSummaries()
# get unsupervised metrics for the summaries
supert = Supert(source_docs, ref_metric=pseudo_ref)
scores = supert(summaries)
print('unsupervised metrics\n', scores)
# (Optional) compare the summaries against golden refs using ROUGE
if os.path.isdir('./rouge/ROUGE-RELEASE-1.5.5'):
refs = reader.readReferences() # make sure you have put the references in data/topic_1/references
summ_rouge_scores = []
for summ in summaries:
rouge_scores = {}
for ref in refs:
rs = evaluate_summary_rouge(summ, ref)
add_result(rouge_scores, rs)
summ_rouge_scores.append(rouge_scores)
mm = 'ROUGE-1'
rouge_scores = []
for rs in summ_rouge_scores:
rouge_scores.append( np.mean(rs[mm]) )
print('reference-based',mm,'\n',rouge_scores)