|
import json |
|
from core import register_solver, FactCheckerState, StandardTaskSolver |
|
|
|
|
|
''' |
|
{ |
|
'average_claim_level_factuality': 0.0, |
|
'average_response_level_factuality': 0.0, |
|
'detailed_information': [ |
|
{ |
|
'prompt': 'Introduce Graham Neubig', |
|
'response': 'Graham Neubig is a professor at MIT', |
|
'category': 'kbqa', |
|
'claims': [ |
|
{ |
|
'claim': 'Graham Neubig is a professor at MIT' |
|
} |
|
], |
|
'queries': [ |
|
[ 'Is Graham Neubig a professor at MIT?', 'Graham Neubig professorship' ] |
|
], |
|
'evidences': [ |
|
{ |
|
'evidence': [ 'I am an Associate Professor at the Carnegie Mellon University Language Technology Institute in the School of Computer Science, and work with a bunch of great ...', 'Missing: MIT? | Show results with:MIT?', 'EI Seminar - Graham Neubig - Learning to Explain and ...', 'Duration: 57:54', 'Posted: Feb 17, 2023', 'I am an Associate Professor at the Carnegie Mellon University Language Technology Institute in the School of Computer Science, and work with a bunch of great ...', 'My research is concerned with language and its role in human communication. In particular, my long-term research goal is to break down barriers in human-human ...', 'Graham Neubig. Associate Professor. Research Interests: Machine Translation · Natural Language Processing · Spoken Language Processing · Machine Learning. My ...', "I am an Associate Professor of Computer Science at Carnegie Mellon University and CEO of… | Learn more about Graham Neubig's work experience, education, ...", 'Graham Neubig received the B.E. degree from the University of Illinois, Urbana ... He is currently an Assistant Professor with Carnegie Mellon University ...' ], |
|
'source': [ 'http://www.phontron.com/', 'http://www.phontron.com/', 'https://youtube.com/watch?v=CtcP5bvODzY', 'https://youtube.com/watch?v=CtcP5bvODzY', 'https://youtube.com/watch?v=CtcP5bvODzY', 'http://www.phontron.com/', 'https://www.phontron.com/research.php', 'https://lti.cs.cmu.edu/people/222217661/graham-neubig', 'https://www.linkedin.com/in/graham-neubig-10b41616b', 'https://ieeexplore.ieee.org/author/37591106000' ] |
|
} |
|
], |
|
'claim_level_factuality': [ |
|
{ |
|
'reasoning': 'The given text is non-factual. Multiple pieces of evidence indicate that Graham Neubig is an Associate Professor at the Carnegie Mellon University Language Technology Institute in the School of Computer Science, not at MIT.', |
|
'error': 'Graham Neubig is not a professor at MIT.', |
|
'correction': 'Graham Neubig is a professor at Carnegie Mellon University.', |
|
'factuality': False, |
|
'claim': 'Graham Neubig is a professor at MIT' |
|
} |
|
], |
|
'response_level_factuality': False |
|
} |
|
] |
|
} |
|
''' |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@register_solver("factool_blackbox_post_editor", "claim_info", "claim_info") |
|
class FactoolBlackboxPostEditor(StandardTaskSolver): |
|
def __init__(self, args): |
|
super().__init__(args) |
|
self.path_save_analysis = args.get("path_save_analysis","factool_evidence_analysis.json") |
|
|
|
def __call__(self, state: FactCheckerState, *args, **kwargs): |
|
claim_info = state.get(self.input_name) |
|
|
|
|
|
edited_claims = '' |
|
for clf in claim_info['detailed_information'][0]['claim_level_factuality']: |
|
edited_claims += 'Claim: "' + clf['claim'] + '" => ' |
|
edited_claims += ('' if (clf['error'] == 'None' or len(clf['error']) == 0) else (clf['error'] + ' ')) |
|
edited_claims += ('' if (clf['reasoning'] == 'None' or len(clf['reasoning']) == 0) else clf['reasoning']) |
|
edited_claims += ((' ' + clf['claim']) if (clf['correction'] == 'None' or len(clf['correction']) == 0) else (' ' + clf['correction'])) |
|
edited_claims += '\n' |
|
edited_claims = edited_claims[:-1] |
|
new_claim_info = {} |
|
new_claim_info[claim_info['detailed_information'][0]['response']] = { |
|
"edited_claims": edited_claims |
|
} |
|
|
|
|
|
json_object = json.dumps(claim_info, indent=4) |
|
|
|
|
|
with open(self.path_save_analysis, "w") as outfile: |
|
outfile.write(json_object) |
|
|
|
state.set(self.output_name, new_claim_info) |
|
return True, state |
|
|