|
import argparse |
|
import streamlit as st |
|
from streamlit_option_menu import option_menu |
|
|
|
from openfactcheck import OpenFactCheck |
|
from openfactcheck.lib import OpenFactCheckConfig |
|
from openfactcheck.app.sidebar import sidebar |
|
from openfactcheck.app.evaluate_response import evaluate_response |
|
from openfactcheck.app.evaluate_llm import evaluate_llm |
|
from openfactcheck.app.evaluate_factchecker import evaluate_factchecker |
|
from openfactcheck.app.utils import footer |
|
|
|
def parse_args(): |
|
parser = argparse.ArgumentParser(description='Initialize OpenFactCheck with custom configuration.') |
|
|
|
|
|
parser.add_argument("--config-path", |
|
type=str, |
|
help="Config File Path", |
|
default="config.json") |
|
|
|
|
|
args = parser.parse_args() |
|
return args |
|
|
|
class App: |
|
def __init__(self, config_path: str = "config.json"): |
|
@st.cache_resource(show_spinner=False) |
|
def init(config_path: str = "config.json"): |
|
|
|
config = OpenFactCheckConfig(config_path) |
|
ofc = OpenFactCheck(config) |
|
return ofc |
|
|
|
self.ofc = init(config_path) |
|
pass |
|
|
|
def run(self): |
|
|
|
st.set_page_config(page_title="OpenFactCheck Dashboard", |
|
page_icon=":bar_chart:", |
|
layout="wide", |
|
initial_sidebar_state="collapsed") |
|
|
|
|
|
|
|
|
|
|
|
sidebar() |
|
|
|
|
|
st.markdown("<h1 style='text-align: center;'>OpenFactCheck Dashboard</h1>", unsafe_allow_html=True) |
|
st.markdown("<h5 style='text-align: center;'>An Open-source Factuality Evaluation Demo for LLMs</h5>", unsafe_allow_html=True) |
|
|
|
|
|
selected = option_menu(None, ["Evaluate LLM Response", "Evaluate LLM", "Evaluate FactChecker", "Leaderboards", "About"], |
|
icons=['card-checklist', 'check-square', "check2-all", "trophy", "info-circle"], |
|
menu_icon="cast", |
|
default_index=0, |
|
orientation="horizontal" |
|
) |
|
|
|
st.info("Please provide OpenAI API Key, Serper API Key and Azure Search Key in the sidebar to evaluate LLM response.") |
|
|
|
|
|
if selected == "Evaluate LLM Response": |
|
evaluate_response(self.ofc) |
|
elif selected == "Evaluate LLM": |
|
evaluate_llm(self.ofc) |
|
elif selected == "Evaluate FactChecker": |
|
evaluate_factchecker(self.ofc) |
|
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == "__main__": |
|
args = parse_args() |
|
|
|
app = App(args.config_path) |
|
app.run() |