|
import os |
|
import yaml |
|
|
|
from openfactcheck.core.state import FactCheckerState |
|
from openfactcheck.core.solver import StandardTaskSolver, Solver |
|
from .facttool_utils.chat_api import OpenAIChat |
|
|
|
@Solver.register("factool_verifier", "claims_with_evidences", "label") |
|
class FactoolVerifier(StandardTaskSolver): |
|
def __init__(self, args): |
|
super().__init__(args) |
|
self.gpt_model = self.global_config.get("factool_gpt_model", "gpt-3.5-turbo") |
|
self.gpt = OpenAIChat(self.gpt_model) |
|
self.verification_prompt = yaml.load( |
|
open( |
|
os.path.join( |
|
os.path.dirname(os.path.abspath(__file__)), |
|
"facttool_utils/prompts.yaml", |
|
), |
|
"r", |
|
), |
|
yaml.FullLoader, |
|
)["verification"] |
|
|
|
def __call__(self, state: FactCheckerState, *args, **kwargs): |
|
claims_with_evidences = state.get(self.input_name) |
|
results = self._verification(claims_with_evidences) |
|
for i, k in enumerate(list(claims_with_evidences.keys())): |
|
results[i]['claim'] = k |
|
results[i]['evidences'] = claims_with_evidences[k] |
|
state.set("detail", results) |
|
label = all(v['factuality'] for v in results) |
|
state.set(self.output_name, label) |
|
return True, state |
|
|
|
def _verification(self, claims_with_evidences): |
|
messages_list = [ |
|
[ |
|
{"role": "system", "content": self.verification_prompt['system']}, |
|
{"role": "user", "content": self.verification_prompt['user'].format(claim=claim, evidence=str( |
|
[e[1] for e in evidence]))}, |
|
] |
|
for claim, evidence in claims_with_evidences.items() |
|
] |
|
return self.gpt.run(messages_list, dict) |
|
|