1 Star 0 Fork 45

cluo1989/课程资料以及代码

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
bleu_score.py 2.12 KB
一键复制 编辑 原始数据 按行查看 历史
zhaomingming 提交于 2020-06-21 16:27 . add week23
import sys, argparse
import nltk
def process_args(args):
parser = argparse.ArgumentParser(description='Evaluate text edit distance.')
parser.add_argument('--target-formulas', dest='target_file',
type=str, required=True,
help=(
'target formulas file'
))
parser.add_argument('--predicted-formulas', dest='predicted_file',
type=str, required=True,
help=(
'predicted formulas file'
))
parser.add_argument('--ngram', dest='ngram',
type=int, required=True,
help=(
'predicted formulas file'
))
parameters = parser.parse_args(args)
return parameters
def main(args):
parameters = process_args(args)
target_formulas_file = parameters.target_file
predicted_formulas_file = parameters.predicted_file
ngram = parameters.ngram
target_formulas = open(target_formulas_file).readlines()
predicted_formulas = open(predicted_formulas_file).readlines()
i = 0
total_bleu_score = 0
if len(target_formulas) != len(predicted_formulas):
print("number of formulas doesn't match")
return
n = len(target_formulas)
for tf, pf in zip(target_formulas, predicted_formulas):
i += 1
if i % 2000 == 0:
print("{}/{}".format(i, n))
tf_ = tf.strip()
pf_ = pf.strip()
true_token = tf_.split(' ')
predicted_tokens = pf_.split(' ')
l = min(ngram, len(true_token), len(predicted_tokens))
if l == 0:
print("Encountered formula with zero length")
bleu_score = nltk.translate.bleu_score.sentence_bleu([true_token], predicted_tokens,
weights=[1.0 / l for _ in range(l)])
total_bleu_score += bleu_score
print("{}/{}".format(n, n))
print('BLEU Score: %f' % (float(total_bleu_score) / n))
if __name__ == '__main__':
main(sys.argv[1:])
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Python
1
https://gitee.com/cluo1989/CourseMaterialsCodes.git
git@gitee.com:cluo1989/CourseMaterialsCodes.git
cluo1989
CourseMaterialsCodes
课程资料以及代码
master

搜索帮助