{ "cells": [ { "cell_type": "markdown", "metadata": {}, "source": [ "# ๐ŸŽฏ Long-Text Uncertainty Quantification\n", "\n", "
\n", "

\n", " Long-Text Uncertainty Quantification (LUQ) is a long-form adaptation of black-box uncertainty quantification. This approach generates multiple responses to the same prompt, decomposes those responses into granular units (sentences or claims), and scores those units by measuring whether sampled responses entail each unit. This demo provides an illustration \n", " of how to use the LUQ methods with uqlm. The available scorers and papers from which they are adapted are below:\n", "

\n", " \n", "* Long-text Uncertainty Quantification (LUQ) ([Zhang et al., 2024](https://arxiv.org/abs/2403.20279))\n", "* LUQ-Atomic ([Zhang et al., 2024](https://arxiv.org/abs/2403.20279))\n", "* LUQ-pair ([Zhang et al., 2024](https://arxiv.org/abs/2403.20279))\n", "* Generalized LUQ-pair ([Zhang et al., 2024](https://arxiv.org/abs/2403.20279))\n", "\n", "
\n", "\n", "## ๐Ÿ“Š What You'll Do in This Demo\n", "\n", "
\n", "
1
\n", "
\n", "

Set up LLM and prompts.

\n", "

Set up LLM instance and load example data prompts.

\n", "
\n", "
\n", "\n", "
\n", "
2
\n", "
\n", "

Generate LLM Responses and Confidence Scores

\n", "

Generate responses and compute claim-level confidence scores using the LongTextUQ() class.

\n", "
\n", "
\n", "\n", "
\n", "
3
\n", "
\n", "

Evaluate Hallucination Detection Performance

\n", "

Grade claims with `FactScoreGrader` class and evaluate claim-level hallucination detection.

\n", "
\n", "
\n", "\n", "## โš–๏ธ Advantages & Limitations\n", "\n", "
\n", "
\n", "

Pros

\n", " \n", "
\n", " \n", "
\n", "

Cons

\n", " \n", "
\n", "
" ] }, { "cell_type": "code", "execution_count": 1, "metadata": { "tags": [] }, "outputs": [], "source": [ "import numpy as np\n", "\n", "from uqlm import LongTextUQ\n", "from uqlm.utils import load_example_dataset, display_response_refinement, claims_dicts_to_lists, plot_model_accuracies\n", "from uqlm.longform import FactScoreGrader" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "## 1. Set up LLM and Prompts" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "In this demo, we will illustrate this approach using the [FactScore](https://github.com/shmsw25/FActScore/tree/main/factscore) longform QA dataset. To implement with your use case, simply **replace the example prompts with your data**. " ] }, { "cell_type": "code", "execution_count": 2, "metadata": { "tags": [] }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "Loading dataset - factscore...\n", "Processing dataset...\n", "Dataset ready!\n" ] }, { "data": { "text/html": [ "
\n", "\n", "\n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", "
promptwikipedia_text
0Tell me a bio of Suthida.\\nSuthida Bajrasudhabimalalakshana (Thai: เธชเธกเน€เธ”เน‡เธˆ...
1Tell me a bio of Miguel รngel Fรฉlix Gallardo.\\nMiguel รngel Fรฉlix Gallardo (born January 8, 1...
2Tell me a bio of Iggy Azalea.\\nAmethyst Amelia Kelly (born 7 June 1990), know...
3Tell me a bio of Fernando da Costa Novaes.\\nFernando da Costa Novaes (April 6, 1927 โ€“ Marc...
4Tell me a bio of Jan Zamoyski.\\nJan Sariusz Zamoyski (Latin: Ioannes Zamoyski ...
\n", "
" ], "text/plain": [ " prompt \\\n", "0 Tell me a bio of Suthida.\\n \n", "1 Tell me a bio of Miguel รngel Fรฉlix Gallardo.\\n \n", "2 Tell me a bio of Iggy Azalea.\\n \n", "3 Tell me a bio of Fernando da Costa Novaes.\\n \n", "4 Tell me a bio of Jan Zamoyski.\\n \n", "\n", " wikipedia_text \n", "0 Suthida Bajrasudhabimalalakshana (Thai: เธชเธกเน€เธ”เน‡เธˆ... \n", "1 Miguel รngel Fรฉlix Gallardo (born January 8, 1... \n", "2 Amethyst Amelia Kelly (born 7 June 1990), know... \n", "3 Fernando da Costa Novaes (April 6, 1927 โ€“ Marc... \n", "4 Jan Sariusz Zamoyski (Latin: Ioannes Zamoyski ... " ] }, "execution_count": 2, "metadata": {}, "output_type": "execute_result" } ], "source": [ "# Load example dataset (FactScore)\n", "factscore = load_example_dataset(\"factscore\", n=20)[[\"factscore_prompt\", \"wikipedia_text\"]].rename(columns={\"factscore_prompt\": \"prompt\"})\n", "factscore.head()" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "In this example, we use `AzureChatOpenAI` to instantiate our LLM, but any [LangChain Chat Model](https://js.langchain.com/docs/integrations/chat/) may be used. Be sure to **replace with your LLM of choice.**" ] }, { "cell_type": "code", "execution_count": 3, "metadata": { "tags": [] }, "outputs": [], "source": [ "# import sys\n", "# !{sys.executable} -m pip install langchain-openai\n", "\n", "## User to populate .env file with API credentials\n", "from dotenv import load_dotenv, find_dotenv\n", "from langchain_openai import AzureChatOpenAI\n", "\n", "load_dotenv(find_dotenv())\n", "llm = AzureChatOpenAI(\n", " deployment_name=\"gpt-4o\",\n", " openai_api_type=\"azure\",\n", " openai_api_version=\"2024-12-01-preview\",\n", " temperature=1, # User to set temperature\n", ")" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "## 2. Generate LLM Responses and Claim/Sentence-Level Confidence Scores" ] }, { "cell_type": "markdown", "metadata": { "tags": [] }, "source": [ "### `LongTextUQ()` - Generate long-text LLM responses, decompose into claims or sentences, and measure entailment among sampled responses.\n", "\n", "![Sample Image](https://raw.githubusercontent.com/cvs-health/uqlm/develop/assets/images/luq_example.png)\n", "\n", "#### ๐Ÿ“‹ Class Attributes\n", "\n", "\n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", "
ParameterType & DefaultDescription
llmBaseChatModel
default=None
A langchain llm `BaseChatModel`. User is responsible for specifying temperature and other relevant parameters to the constructor of the provided `llm` object.
granularitystr
default=\"claim\"
Specifies whether to decompose and score at claim or sentence level granularity. Must be either \"claim\" or \"sentence\".
modestr
default=\"unit_response\"
Specifies whether to implement unit-response (LUQ-style) scoring or matched-unit (LUQ-pair-style) scoring. Must be either \"unit_response\" (recommended) or \"matched_unit\".
scorersList[str]
default=None
Specifies which black box (consistency) scorers to include. subset of {\"entailment\", \"noncontradiction\", \"contrasted_entailment\", \"bert_score\", \"cosine_sim\"}. If None, defaults to [\"entailment\"].
aggregationstr
default=\"mean\"
Specifies how to aggregate claim/sentence-level scores to response-level scores. Must be one of 'min' or 'mean'.
response_refinementbool
default=False
Specifies whether to refine responses with uncertainty-aware decoding. This approach removes claims with confidence scores below the response_refinement_threshold and uses the claim_decomposition_llm to reconstruct the response from the retained claims. For more details, refer to Jiang et al., 2024: https://arxiv.org/abs/2410.20783
claim_filtering_scorerOptional[str]
default=None
Specifies which scorer to use to filter claims if response_refinement is True. If not provided, defaults to the first element of self.scorers.
claim_decomposition_llmBaseChatModel
default=None
A langchain llm `BaseChatModel` to be used for decomposing responses into individual claims. Also used for claim refinement. If granularity=\"claim\" and claim_decomposition_llm is None, the provided `llm` will be used for claim decomposition.
devicestr or torch.device
default=None
Specifies the device that NLI model use for prediction. If None, detects and returns the best available PyTorch device. Prioritizes CUDA (NVIDIA GPU), then MPS (macOS), then CPU.
system_promptstr or None
default=\"You are a helpful assistant.\"
Optional argument for user to provide custom system prompt for the LLM.
max_calls_per_minint
default=None
Specifies how many API calls to make per minute to avoid rate limit errors. By default, no limit is specified.
use_n_parambool
default=False
Specifies whether to use n parameter for BaseChatModel. Not compatible with all BaseChatModel classes. If used, it speeds up the generation process substantially when num_responses is large.
sampling_temperaturefloat
default=1
The 'temperature' parameter for LLM to use when generating sampled LLM responses. Must be greater than 0.
nli_model_namestr
default=\"microsoft/deberta-large-mnli\"
Specifies which NLI model to use. Must be acceptable input to AutoTokenizer.from_pretrained() and AutoModelForSequenceClassification.from_pretrained().
max_lengthint
default=2000
Specifies the maximum allowed string length for LLM responses for NLI computation. Responses longer than this value will be truncated in NLI computations to avoid OutOfMemoryError.
\n", "\n", "#### ๐Ÿ” Parameter Groups\n", "\n", "
\n", "
\n", "

๐Ÿง  LLM-Specific

\n", " \n", "
\n", "
\n", "

๐Ÿ“Š Confidence Scores

\n", " \n", "
\n", "
\n", "

๐Ÿ–ฅ๏ธ Hardware

\n", " \n", "
\n", "
\n", "

โšก Performance

\n", " \n", "
\n", "
\n", "\n", "```" ] }, { "cell_type": "code", "execution_count": 4, "metadata": { "tags": [] }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "claim_filtering_scorer is not specified for response_refinement. Defaulting to entailment.\n" ] } ], "source": [ "luq = LongTextUQ(\n", " llm=llm,\n", " granularity=\"claim\", # 'claim' recommended\n", " aggregation=\"mean\", # switch to 'min' for more conservative scoring\n", " response_refinement=True, # whether to filter out low-confidence claims\n", " max_calls_per_min=80,\n", " max_length=3000,\n", ")" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "### ๐Ÿ”„ Class Methods\n", "\n", "\n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", "
MethodDescription & Parameters
BlackBoxUQ.generate_and_score\n", "

Generate LLM responses, sampled LLM (candidate) responses, and compute confidence scores for the provided prompts.

\n", "

Parameters:

\n", "
    \n", "
  • prompts - (List[str] or List[List[BaseMessage]]) A list of input prompts for the model.
  • \n", "
  • num_responses - (int, default=5) The number of sampled responses used to compute consistency.
  • \n", "
  • response_refinement_threshold - (float, default=1/3) Threshold for uncertainty-aware filtering. Claims with confidence scores below this threshold are dropped from the refined response. Only used if response_refinement is True.
  • \n", "
  • show_progress_bars - (bool, default=True) If True, displays a progress bar while generating and scoring responses.
  • \n", "
\n", "

Returns: UQResult containing data (prompts, responses, sampled responses, and confidence scores) and metadata

\n", "
\n", " ๐Ÿ’ก Best For: Complete end-to-end uncertainty quantification when starting with prompts.\n", "
\n", "
BlackBoxUQ.score\n", "

Compute confidence scores on provided LLM responses. Should only be used if responses and sampled responses are already generated.

\n", "

Parameters:

\n", "
    \n", "
  • responses - (List[str]) A list of LLM responses for the prompts.
  • \n", "
  • sampled_responses - (List[List[str]]) A list of lists of sampled LLM responses for each prompt. Used to compute consistency scores by comparing to the corresponding response from responses.
  • \n", "
  • response_refinement_threshold - (float, default=1/3) Threshold for uncertainty-aware filtering. Claims with confidence scores below this threshold are dropped from the refined response. Only used if response_refinement is True.
  • \n", "
  • show_progress_bars - (bool, default=True) If True, displays a progress bar while scoring responses.
  • \n", "
\n", "

Returns: UQResult containing data (responses, sampled responses, and confidence scores) and metadata

\n", "
\n", " ๐Ÿ’ก Best For: Computing uncertainty scores when responses are already generated elsewhere.\n", "
\n", "
" ] }, { "cell_type": "code", "execution_count": 5, "metadata": { "tags": [] }, "outputs": [ { "data": { "application/vnd.jupyter.widget-view+json": { "model_id": "35873441961448f7839f5577cd288abf", "version_major": 2, "version_minor": 0 }, "text/plain": [ "Output()" ] }, "metadata": {}, "output_type": "display_data" }, { "data": { "text/html": [ "
\n"
      ],
      "text/plain": []
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "results = await luq.generate_and_score(\n",
    "    prompts=factscore.prompt.to_list(),\n",
    "    num_responses=5,  # choose num_responses based on cost and latency requirements (higher means better hallucination detection but more cost and latency)\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/html": [
       "
\n", "\n", "\n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", "
promptresponsesampled_responsesentailmentclaims_datarefined_responserefined_entailment
0Tell me a bio of Suthida.\\nSuthida Bajrasudhabimalalakshana, born on June...[Suthida Bajrasudhabimalalakshana, commonly kn...0.378289[{'claim': 'Suthida Bajrasudhabimalalakshana w...Suthida Bajrasudhabimalalakshana, born on June...0.786631
1Tell me a bio of Miguel รngel Fรฉlix Gallardo.\\nMiguel รngel Fรฉlix Gallardo, often referred to...[Miguel รngel Fรฉlix Gallardo, often referred t...0.472164[{'claim': 'Miguel รngel Fรฉlix Gallardo is oft...Miguel รngel Fรฉlix Gallardo, often referred to...0.654868
2Tell me a bio of Iggy Azalea.\\nIggy Azalea, born Amethyst Amelia Kelly on Jun...[Iggy Azalea, born Amethyst Amelia Kelly on Ju...0.468483[{'claim': 'Iggy Azalea was born Amethyst Amel...Iggy Azalea, born Amethyst Amelia Kelly on Jun...0.650532
3Tell me a bio of Fernando da Costa Novaes.\\nFernando da Costa Novaes was a prominent Brazi...[Fernando da Costa Novaes was a Brazilian orni...0.494438[{'claim': 'Fernando da Costa Novaes was a pro...Fernando da Costa Novaes was a highly respecte...0.705326
4Tell me a bio of Jan Zamoyski.\\nJan Zamoyski (1542โ€“1605) was a prominent Polis...[Jan Zamoyski (1542โ€“1605) was a prominent Poli...0.573752[{'claim': 'Jan Zamoyski was a Polish nobleman...Jan Zamoyski, born in 1542 and deceased in 160...0.733766
\n", "
" ], "text/plain": [ " prompt \\\n", "0 Tell me a bio of Suthida.\\n \n", "1 Tell me a bio of Miguel รngel Fรฉlix Gallardo.\\n \n", "2 Tell me a bio of Iggy Azalea.\\n \n", "3 Tell me a bio of Fernando da Costa Novaes.\\n \n", "4 Tell me a bio of Jan Zamoyski.\\n \n", "\n", " response \\\n", "0 Suthida Bajrasudhabimalalakshana, born on June... \n", "1 Miguel รngel Fรฉlix Gallardo, often referred to... \n", "2 Iggy Azalea, born Amethyst Amelia Kelly on Jun... \n", "3 Fernando da Costa Novaes was a prominent Brazi... \n", "4 Jan Zamoyski (1542โ€“1605) was a prominent Polis... \n", "\n", " sampled_responses entailment \\\n", "0 [Suthida Bajrasudhabimalalakshana, commonly kn... 0.378289 \n", "1 [Miguel รngel Fรฉlix Gallardo, often referred t... 0.472164 \n", "2 [Iggy Azalea, born Amethyst Amelia Kelly on Ju... 0.468483 \n", "3 [Fernando da Costa Novaes was a Brazilian orni... 0.494438 \n", "4 [Jan Zamoyski (1542โ€“1605) was a prominent Poli... 0.573752 \n", "\n", " claims_data \\\n", "0 [{'claim': 'Suthida Bajrasudhabimalalakshana w... \n", "1 [{'claim': 'Miguel รngel Fรฉlix Gallardo is oft... \n", "2 [{'claim': 'Iggy Azalea was born Amethyst Amel... \n", "3 [{'claim': 'Fernando da Costa Novaes was a pro... \n", "4 [{'claim': 'Jan Zamoyski was a Polish nobleman... \n", "\n", " refined_response refined_entailment \n", "0 Suthida Bajrasudhabimalalakshana, born on June... 0.786631 \n", "1 Miguel รngel Fรฉlix Gallardo, often referred to... 0.654868 \n", "2 Iggy Azalea, born Amethyst Amelia Kelly on Jun... 0.650532 \n", "3 Fernando da Costa Novaes was a highly respecte... 0.705326 \n", "4 Jan Zamoyski, born in 1542 and deceased in 160... 0.733766 " ] }, "execution_count": 6, "metadata": {}, "output_type": "execute_result" } ], "source": [ "result_df = results.to_df()\n", "result_df.head(5)" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "#### Response refinement" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "Response refinement works by dropping claims with confidence scores (specified with `claim_filtering_scorer`) below a specified threshold (specified with `response_refinement_threshold`) and reconstructing the response from the retained claims.\n", "\n", "![Sample Image](https://raw.githubusercontent.com/cvs-health/uqlm/develop/assets/images/uad_graphic.png)" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "To illustrate how the response refinement operates, let's view an example. We first view the fine-grained claim-level data, including the claims in the original response, the claim-level confidence scores, and whether each claim was removed during the response refinement process. " ] }, { "cell_type": "code", "execution_count": 7, "metadata": { "tags": [] }, "outputs": [ { "data": { "text/plain": [ "[{'claim': 'Suthida Bajrasudhabimalalakshana was born on June 3, 1978.',\n", " 'removed': False,\n", " 'entailment': 0.9548099517822266},\n", " {'claim': 'Suthida Bajrasudhabimalalakshana is the Queen of Thailand.',\n", " 'removed': False,\n", " 'entailment': 0.909833800792694},\n", " {'claim': 'Suthida Bajrasudhabimalalakshana became queen following her marriage to King Maha Vajiralongkorn on May 1, 2019.',\n", " 'removed': False,\n", " 'entailment': 0.9487567067146301},\n", " {'claim': 'Suthida Bajrasudhabimalalakshana was known for her service in the Thai military.',\n", " 'removed': False,\n", " 'entailment': 0.6286507695913315},\n", " {'claim': 'Suthida Bajrasudhabimalalakshana was known for her service in royal security.',\n", " 'removed': False,\n", " 'entailment': 0.4196613132953644},\n", " {'claim': 'Suthida Bajrasudhabimalalakshana joined the Thai military.',\n", " 'removed': False,\n", " 'entailment': 0.8370264410972595},\n", " {'claim': 'Suthida Bajrasudhabimalalakshana rose to the rank of General in the Thai military.',\n", " 'removed': False,\n", " 'entailment': 0.9057967782020568},\n", " {'claim': \"Suthida Bajrasudhabimalalakshana's notable role was as the Deputy Commander of the Kingโ€™s Own Bodyguard Battalion.\",\n", " 'removed': True,\n", " 'entailment': 0.05324118752032518},\n", " {'claim': 'Suthida Bajrasudhabimalalakshana was appointed as the Commander of the Special Operations Unit of the Kingโ€™s Guard in 2013.',\n", " 'removed': True,\n", " 'entailment': 0.011244434397667646},\n", " {'claim': 'Suthida Bajrasudhabimalalakshana was made the Commander of the Royal Thai Aide-de-Camp Department.',\n", " 'removed': True,\n", " 'entailment': 0.0545421352609992},\n", " {'claim': \"Suthida Bajrasudhabimalalakshana's service to the royal family began during Vajiralongkorn's time as Crown Prince.\",\n", " 'removed': True,\n", " 'entailment': 0.17842963952571153},\n", " {'claim': 'Suthida Bajrasudhabimalalakshana was appointed as a General in the Royal Thai Army in December 2016.',\n", " 'removed': True,\n", " 'entailment': 0.20516443867236375},\n", " {'claim': 'Vajiralongkorn ascended to the throne shortly before December 2016.',\n", " 'removed': True,\n", " 'entailment': 0.0191670348867774},\n", " {'claim': \"Queen Suthida's royal name is Her Majesty Queen Suthida Bajrasudhabimalalakshana.\",\n", " 'removed': False,\n", " 'entailment': 0.7257313817739487},\n", " {'claim': \"Queen Suthida's royal name was bestowed upon her after marriage.\",\n", " 'removed': False,\n", " 'entailment': 0.7494151771068573},\n", " {'claim': \"The marriage and Queen Suthida's subsequent coronation were part of the elaborate royal ceremonies.\",\n", " 'removed': True,\n", " 'entailment': 0.04578750394284725},\n", " {'claim': \"The elaborate royal ceremonies solidified Queen Suthida's position as the consort of the reigning monarch.\",\n", " 'removed': True,\n", " 'entailment': 0.09274227768182755},\n", " {'claim': 'Queen Suthida is known for her dignity.',\n", " 'removed': True,\n", " 'entailment': 0.16823009476065637},\n", " {'claim': 'Queen Suthida is known for her dedication to her roles in royal duties.',\n", " 'removed': True,\n", " 'entailment': 0.22584835886955262},\n", " {'claim': 'Queen Suthida is known for her dedication to her previous military service.',\n", " 'removed': True,\n", " 'entailment': 0.04379986636340618},\n", " {'claim': \"Queen Suthida's work and public engagements often highlight charitable activities in Thailand.\",\n", " 'removed': True,\n", " 'entailment': 0.05280689503997564},\n", " {'claim': \"Queen Suthida's work and public engagements often support various social causes within Thailand.\",\n", " 'removed': True,\n", " 'entailment': 0.09166227281093597}]" ] }, "execution_count": 7, "metadata": {}, "output_type": "execute_result" } ], "source": [ "# View fine-grained claim data for the first response\n", "result_df.claims_data[0]" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "We can then visualize the response refinement process for this response using the `display_response_refinement`. This shows the original response vs. the refined response and identifies which claims were removed due to low confidence." ] }, { "cell_type": "code", "execution_count": 8, "metadata": { "tags": [] }, "outputs": [ { "data": { "text/html": [ "
โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€\n",
       "
\n" ], "text/plain": [ "\u001b[1;30mโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€\u001b[0m\n" ] }, "metadata": {}, "output_type": "display_data" }, { "data": { "text/html": [ "
                                            Response Refinement Example                                            \n",
       "
\n" ], "text/plain": [ " \u001b[1;30mResponse Refinement Example\u001b[0m \n" ] }, "metadata": {}, "output_type": "display_data" }, { "data": { "text/html": [ "
โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€\n",
       "
\n" ], "text/plain": [ "\u001b[1;30mโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€\u001b[0m\n" ] }, "metadata": {}, "output_type": "display_data" }, { "data": { "text/html": [ "
\n",
       "
\n" ], "text/plain": [ "\n" ] }, "metadata": {}, "output_type": "display_data" }, { "data": { "text/html": [ "
โ•ญโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€ Original Response โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ•ฎ\n",
       "โ”‚ Suthida Bajrasudhabimalalakshana, born on June 3, 1978, is the Queen of Thailand. She became queen following    โ”‚\n",
       "โ”‚ her marriage to King Maha Vajiralongkorn (Rama X) on May 1, 2019.                                               โ”‚\n",
       "โ”‚                                                                                                                 โ”‚\n",
       "โ”‚ Before becoming queen, Suthida was known for her service in the Thai military and royal security. She joined    โ”‚\n",
       "โ”‚ the Thai military, where she eventually rose to the rank of General. Her notable role was as the Deputy         โ”‚\n",
       "โ”‚ Commander of the Kingโ€™s Own Bodyguard Battalion. Suthida was also appointed as the Commander of the Special     โ”‚\n",
       "โ”‚ Operations Unit of the Kingโ€™s Guard in 2013, and later, she was made the Commander of the Royal Thai            โ”‚\n",
       "โ”‚ Aide-de-Camp Department.                                                                                        โ”‚\n",
       "โ”‚                                                                                                                 โ”‚\n",
       "โ”‚ Her service to the royal family and her close association with King Vajiralongkorn began during his time as     โ”‚\n",
       "โ”‚ Crown Prince. Suthida was appointed as a General in the Royal Thai Army in December 2016, shortly after         โ”‚\n",
       "โ”‚ Vajiralongkorn ascended to the throne.                                                                          โ”‚\n",
       "โ”‚                                                                                                                 โ”‚\n",
       "โ”‚ Queen Suthida's royal name, bestowed upon her after marriage, is Her Majesty Queen Suthida                      โ”‚\n",
       "โ”‚ Bajrasudhabimalalakshana. The marriage and her subsequent coronation as queen were part of the elaborate royal  โ”‚\n",
       "โ”‚ ceremonies that solidified her position as the consort of the reigning monarch.                                 โ”‚\n",
       "โ”‚                                                                                                                 โ”‚\n",
       "โ”‚ Queen Suthida is known for her dignity and dedication to her roles both in royal duties and her previous        โ”‚\n",
       "โ”‚ military service. Her work and public engagements often highlight charitable activities and support for various โ”‚\n",
       "โ”‚ social causes within Thailand.                                                                                  โ”‚\n",
       "โ•ฐโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ•ฏ\n",
       "
\n" ], "text/plain": [ "\u001b[33mโ•ญโ”€\u001b[0m\u001b[33mโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€\u001b[0m\u001b[33m \u001b[0m\u001b[1;33mOriginal Response\u001b[0m\u001b[33m \u001b[0m\u001b[33mโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€\u001b[0m\u001b[33mโ”€โ•ฎ\u001b[0m\n", "\u001b[33mโ”‚\u001b[0m Suthida Bajrasudhabimalalakshana, born on June 3, 1978, is the Queen of Thailand. She became queen following \u001b[33mโ”‚\u001b[0m\n", "\u001b[33mโ”‚\u001b[0m her marriage to King Maha Vajiralongkorn (Rama X) on May 1, 2019. \u001b[33mโ”‚\u001b[0m\n", "\u001b[33mโ”‚\u001b[0m \u001b[33mโ”‚\u001b[0m\n", "\u001b[33mโ”‚\u001b[0m Before becoming queen, Suthida was known for her service in the Thai military and royal security. She joined \u001b[33mโ”‚\u001b[0m\n", "\u001b[33mโ”‚\u001b[0m the Thai military, where she eventually rose to the rank of General. Her notable role was as the Deputy \u001b[33mโ”‚\u001b[0m\n", "\u001b[33mโ”‚\u001b[0m Commander of the Kingโ€™s Own Bodyguard Battalion. Suthida was also appointed as the Commander of the Special \u001b[33mโ”‚\u001b[0m\n", "\u001b[33mโ”‚\u001b[0m Operations Unit of the Kingโ€™s Guard in 2013, and later, she was made the Commander of the Royal Thai \u001b[33mโ”‚\u001b[0m\n", "\u001b[33mโ”‚\u001b[0m Aide-de-Camp Department. \u001b[33mโ”‚\u001b[0m\n", "\u001b[33mโ”‚\u001b[0m \u001b[33mโ”‚\u001b[0m\n", "\u001b[33mโ”‚\u001b[0m Her service to the royal family and her close association with King Vajiralongkorn began during his time as \u001b[33mโ”‚\u001b[0m\n", "\u001b[33mโ”‚\u001b[0m Crown Prince. Suthida was appointed as a General in the Royal Thai Army in December 2016, shortly after \u001b[33mโ”‚\u001b[0m\n", "\u001b[33mโ”‚\u001b[0m Vajiralongkorn ascended to the throne. \u001b[33mโ”‚\u001b[0m\n", "\u001b[33mโ”‚\u001b[0m \u001b[33mโ”‚\u001b[0m\n", "\u001b[33mโ”‚\u001b[0m Queen Suthida's royal name, bestowed upon her after marriage, is Her Majesty Queen Suthida \u001b[33mโ”‚\u001b[0m\n", "\u001b[33mโ”‚\u001b[0m Bajrasudhabimalalakshana. The marriage and her subsequent coronation as queen were part of the elaborate royal \u001b[33mโ”‚\u001b[0m\n", "\u001b[33mโ”‚\u001b[0m ceremonies that solidified her position as the consort of the reigning monarch. \u001b[33mโ”‚\u001b[0m\n", "\u001b[33mโ”‚\u001b[0m \u001b[33mโ”‚\u001b[0m\n", "\u001b[33mโ”‚\u001b[0m Queen Suthida is known for her dignity and dedication to her roles both in royal duties and her previous \u001b[33mโ”‚\u001b[0m\n", "\u001b[33mโ”‚\u001b[0m military service. Her work and public engagements often highlight charitable activities and support for various \u001b[33mโ”‚\u001b[0m\n", "\u001b[33mโ”‚\u001b[0m social causes within Thailand. \u001b[33mโ”‚\u001b[0m\n", "\u001b[33mโ•ฐโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ•ฏ\u001b[0m\n" ] }, "metadata": {}, "output_type": "display_data" }, { "data": { "text/html": [ "
โ•ญโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€ Low-Confidence Claims to be Removed โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ•ฎ\n",
       "โ”‚ โ€ข Suthida Bajrasudhabimalalakshana's notable role was as the Deputy Commander of the Kingโ€™s Own Bodyguard       โ”‚\n",
       "โ”‚ Battalion.                                                                                                      โ”‚\n",
       "โ”‚ โ€ข Suthida Bajrasudhabimalalakshana was appointed as the Commander of the Special Operations Unit of the Kingโ€™s  โ”‚\n",
       "โ”‚ Guard in 2013.                                                                                                  โ”‚\n",
       "โ”‚ โ€ข Suthida Bajrasudhabimalalakshana was made the Commander of the Royal Thai Aide-de-Camp Department.            โ”‚\n",
       "โ”‚ โ€ข Suthida Bajrasudhabimalalakshana's service to the royal family began during Vajiralongkorn's time as Crown    โ”‚\n",
       "โ”‚ Prince.                                                                                                         โ”‚\n",
       "โ”‚ โ€ข Suthida Bajrasudhabimalalakshana was appointed as a General in the Royal Thai Army in December 2016.          โ”‚\n",
       "โ”‚ โ€ข Vajiralongkorn ascended to the throne shortly before December 2016.                                           โ”‚\n",
       "โ”‚ โ€ข The marriage and Queen Suthida's subsequent coronation were part of the elaborate royal ceremonies.           โ”‚\n",
       "โ”‚ โ€ข The elaborate royal ceremonies solidified Queen Suthida's position as the consort of the reigning monarch.    โ”‚\n",
       "โ”‚ โ€ข Queen Suthida is known for her dignity.                                                                       โ”‚\n",
       "โ”‚ โ€ข Queen Suthida is known for her dedication to her roles in royal duties.                                       โ”‚\n",
       "โ”‚ โ€ข Queen Suthida is known for her dedication to her previous military service.                                   โ”‚\n",
       "โ”‚ โ€ข Queen Suthida's work and public engagements often highlight charitable activities in Thailand.                โ”‚\n",
       "โ”‚ โ€ข Queen Suthida's work and public engagements often support various social causes within Thailand.              โ”‚\n",
       "โ•ฐโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ•ฏ\n",
       "
\n" ], "text/plain": [ "\u001b[31mโ•ญโ”€\u001b[0m\u001b[31mโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€\u001b[0m\u001b[31m \u001b[0m\u001b[1;31mLow-Confidence Claims to be Removed\u001b[0m\u001b[31m \u001b[0m\u001b[31mโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€\u001b[0m\u001b[31mโ”€โ•ฎ\u001b[0m\n", "\u001b[31mโ”‚\u001b[0m โ€ข Suthida Bajrasudhabimalalakshana's notable role was as the Deputy Commander of the Kingโ€™s Own Bodyguard \u001b[31mโ”‚\u001b[0m\n", "\u001b[31mโ”‚\u001b[0m Battalion. \u001b[31mโ”‚\u001b[0m\n", "\u001b[31mโ”‚\u001b[0m โ€ข Suthida Bajrasudhabimalalakshana was appointed as the Commander of the Special Operations Unit of the Kingโ€™s \u001b[31mโ”‚\u001b[0m\n", "\u001b[31mโ”‚\u001b[0m Guard in 2013. \u001b[31mโ”‚\u001b[0m\n", "\u001b[31mโ”‚\u001b[0m โ€ข Suthida Bajrasudhabimalalakshana was made the Commander of the Royal Thai Aide-de-Camp Department. \u001b[31mโ”‚\u001b[0m\n", "\u001b[31mโ”‚\u001b[0m โ€ข Suthida Bajrasudhabimalalakshana's service to the royal family began during Vajiralongkorn's time as Crown \u001b[31mโ”‚\u001b[0m\n", "\u001b[31mโ”‚\u001b[0m Prince. \u001b[31mโ”‚\u001b[0m\n", "\u001b[31mโ”‚\u001b[0m โ€ข Suthida Bajrasudhabimalalakshana was appointed as a General in the Royal Thai Army in December 2016. \u001b[31mโ”‚\u001b[0m\n", "\u001b[31mโ”‚\u001b[0m โ€ข Vajiralongkorn ascended to the throne shortly before December 2016. \u001b[31mโ”‚\u001b[0m\n", "\u001b[31mโ”‚\u001b[0m โ€ข The marriage and Queen Suthida's subsequent coronation were part of the elaborate royal ceremonies. \u001b[31mโ”‚\u001b[0m\n", "\u001b[31mโ”‚\u001b[0m โ€ข The elaborate royal ceremonies solidified Queen Suthida's position as the consort of the reigning monarch. \u001b[31mโ”‚\u001b[0m\n", "\u001b[31mโ”‚\u001b[0m โ€ข Queen Suthida is known for her dignity. \u001b[31mโ”‚\u001b[0m\n", "\u001b[31mโ”‚\u001b[0m โ€ข Queen Suthida is known for her dedication to her roles in royal duties. \u001b[31mโ”‚\u001b[0m\n", "\u001b[31mโ”‚\u001b[0m โ€ข Queen Suthida is known for her dedication to her previous military service. \u001b[31mโ”‚\u001b[0m\n", "\u001b[31mโ”‚\u001b[0m โ€ข Queen Suthida's work and public engagements often highlight charitable activities in Thailand. \u001b[31mโ”‚\u001b[0m\n", "\u001b[31mโ”‚\u001b[0m โ€ข Queen Suthida's work and public engagements often support various social causes within Thailand. \u001b[31mโ”‚\u001b[0m\n", "\u001b[31mโ•ฐโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ•ฏ\u001b[0m\n" ] }, "metadata": {}, "output_type": "display_data" }, { "data": { "text/html": [ "
โ•ญโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€ Refined Response โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ•ฎ\n",
       "โ”‚ Suthida Bajrasudhabimalalakshana, born on June 3, 1978, is the Queen of Thailand. She became queen following    โ”‚\n",
       "โ”‚ her marriage to King Maha Vajiralongkorn on May 1, 2019, and upon marriage, she was bestowed with the royal     โ”‚\n",
       "โ”‚ name Her Majesty Queen Suthida Bajrasudhabimalalakshana. Before her ascension to the throne, Queen Suthida was  โ”‚\n",
       "โ”‚ recognized for her dedicated service in the Thai military, where she rose to the rank of General, and in royal  โ”‚\n",
       "โ”‚ security. Her military career and commitment to royal security played a significant role in her rise to         โ”‚\n",
       "โ”‚ prominence, ultimately leading to her role as queen.                                                            โ”‚\n",
       "โ•ฐโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ•ฏ\n",
       "
\n" ], "text/plain": [ "\u001b[32mโ•ญโ”€\u001b[0m\u001b[32mโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€\u001b[0m\u001b[32m \u001b[0m\u001b[1;32mRefined Response\u001b[0m\u001b[32m \u001b[0m\u001b[32mโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€\u001b[0m\u001b[32mโ”€โ•ฎ\u001b[0m\n", "\u001b[32mโ”‚\u001b[0m Suthida Bajrasudhabimalalakshana, born on June 3, 1978, is the Queen of Thailand. She became queen following \u001b[32mโ”‚\u001b[0m\n", "\u001b[32mโ”‚\u001b[0m her marriage to King Maha Vajiralongkorn on May 1, 2019, and upon marriage, she was bestowed with the royal \u001b[32mโ”‚\u001b[0m\n", "\u001b[32mโ”‚\u001b[0m name Her Majesty Queen Suthida Bajrasudhabimalalakshana. Before her ascension to the throne, Queen Suthida was \u001b[32mโ”‚\u001b[0m\n", "\u001b[32mโ”‚\u001b[0m recognized for her dedicated service in the Thai military, where she rose to the rank of General, and in royal \u001b[32mโ”‚\u001b[0m\n", "\u001b[32mโ”‚\u001b[0m security. Her military career and commitment to royal security played a significant role in her rise to \u001b[32mโ”‚\u001b[0m\n", "\u001b[32mโ”‚\u001b[0m prominence, ultimately leading to her role as queen. \u001b[32mโ”‚\u001b[0m\n", "\u001b[32mโ•ฐโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ•ฏ\u001b[0m\n" ] }, "metadata": {}, "output_type": "display_data" } ], "source": [ "display_response_refinement(original_text=result_df.response[0], claims_data=result_df.claims_data[0], refined_text=result_df.refined_response[0])" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "## 3. Evaluate Hallucination Detection Performance" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "To evaluate hallucination detection performance, we 'grade' the atomic claims in the responses against an answer key. Here, we use UQLM's out-of-the-box `FactScoreGrader`, which can be used with [LangChain Chat Model](https://js.langchain.com/docs/integrations/chat/). **If you are using your own prompts/questions, be sure to update the grading method accordingly**." ] }, { "cell_type": "code", "execution_count": 9, "metadata": { "tags": [] }, "outputs": [], "source": [ "# set up the LLM grader\n", "from langchain_google_vertexai import ChatVertexAI\n", "\n", "gemini_flash = ChatVertexAI(model=\"gemini-2.5-flash\")\n", "grader = FactScoreGrader(llm=gemini_flash)" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "Before grading, we need to have claims formatted in list of lists where each interior list corresponds to a generated response. " ] }, { "cell_type": "code", "execution_count": 10, "metadata": { "tags": [] }, "outputs": [], "source": [ "# Convert claims to list of lists\n", "claims_data_lists = claims_dicts_to_lists(result_df.claims_data.tolist())" ] }, { "cell_type": "code", "execution_count": 12, "metadata": { "tags": [] }, "outputs": [ { "data": { "text/html": [ "
\n", "\n", "\n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", "
promptresponsesampled_responsesentailmentclaims_datarefined_responserefined_entailmentclaim_gradesanswer
0Tell me a bio of Suthida.\\nSuthida Bajrasudhabimalalakshana, born on June...[Suthida Bajrasudhabimalalakshana, commonly kn...0.378289[{'claim': 'Suthida Bajrasudhabimalalakshana w...Suthida Bajrasudhabimalalakshana, born on June...0.786631[True, True, False, True, True, True, True, Fa...Suthida Bajrasudhabimalalakshana (Thai: เธชเธกเน€เธ”เน‡เธˆ...
1Tell me a bio of Miguel รngel Fรฉlix Gallardo.\\nMiguel รngel Fรฉlix Gallardo, often referred to...[Miguel รngel Fรฉlix Gallardo, often referred t...0.472164[{'claim': 'Miguel รngel Fรฉlix Gallardo is oft...Miguel รngel Fรฉlix Gallardo, often referred to...0.654868[True, True, True, True, False, True, True, Tr...Miguel รngel Fรฉlix Gallardo (born January 8, 1...
2Tell me a bio of Iggy Azalea.\\nIggy Azalea, born Amethyst Amelia Kelly on Jun...[Iggy Azalea, born Amethyst Amelia Kelly on Ju...0.468483[{'claim': 'Iggy Azalea was born Amethyst Amel...Iggy Azalea, born Amethyst Amelia Kelly on Jun...0.650532[True, True, True, True, False, True, True, Fa...Amethyst Amelia Kelly (born 7 June 1990), know...
3Tell me a bio of Fernando da Costa Novaes.\\nFernando da Costa Novaes was a prominent Brazi...[Fernando da Costa Novaes was a Brazilian orni...0.494438[{'claim': 'Fernando da Costa Novaes was a pro...Fernando da Costa Novaes was a highly respecte...0.705326[True, True, True, True, False, True, True, Tr...Fernando da Costa Novaes (April 6, 1927 โ€“ Marc...
4Tell me a bio of Jan Zamoyski.\\nJan Zamoyski (1542โ€“1605) was a prominent Polis...[Jan Zamoyski (1542โ€“1605) was a prominent Poli...0.573752[{'claim': 'Jan Zamoyski was a Polish nobleman...Jan Zamoyski, born in 1542 and deceased in 160...0.733766[True, True, True, True, True, True, True, Tru...Jan Sariusz Zamoyski (Latin: Ioannes Zamoyski ...
\n", "
" ], "text/plain": [ " prompt \\\n", "0 Tell me a bio of Suthida.\\n \n", "1 Tell me a bio of Miguel รngel Fรฉlix Gallardo.\\n \n", "2 Tell me a bio of Iggy Azalea.\\n \n", "3 Tell me a bio of Fernando da Costa Novaes.\\n \n", "4 Tell me a bio of Jan Zamoyski.\\n \n", "\n", " response \\\n", "0 Suthida Bajrasudhabimalalakshana, born on June... \n", "1 Miguel รngel Fรฉlix Gallardo, often referred to... \n", "2 Iggy Azalea, born Amethyst Amelia Kelly on Jun... \n", "3 Fernando da Costa Novaes was a prominent Brazi... \n", "4 Jan Zamoyski (1542โ€“1605) was a prominent Polis... \n", "\n", " sampled_responses entailment \\\n", "0 [Suthida Bajrasudhabimalalakshana, commonly kn... 0.378289 \n", "1 [Miguel รngel Fรฉlix Gallardo, often referred t... 0.472164 \n", "2 [Iggy Azalea, born Amethyst Amelia Kelly on Ju... 0.468483 \n", "3 [Fernando da Costa Novaes was a Brazilian orni... 0.494438 \n", "4 [Jan Zamoyski (1542โ€“1605) was a prominent Poli... 0.573752 \n", "\n", " claims_data \\\n", "0 [{'claim': 'Suthida Bajrasudhabimalalakshana w... \n", "1 [{'claim': 'Miguel รngel Fรฉlix Gallardo is oft... \n", "2 [{'claim': 'Iggy Azalea was born Amethyst Amel... \n", "3 [{'claim': 'Fernando da Costa Novaes was a pro... \n", "4 [{'claim': 'Jan Zamoyski was a Polish nobleman... \n", "\n", " refined_response refined_entailment \\\n", "0 Suthida Bajrasudhabimalalakshana, born on June... 0.786631 \n", "1 Miguel รngel Fรฉlix Gallardo, often referred to... 0.654868 \n", "2 Iggy Azalea, born Amethyst Amelia Kelly on Jun... 0.650532 \n", "3 Fernando da Costa Novaes was a highly respecte... 0.705326 \n", "4 Jan Zamoyski, born in 1542 and deceased in 160... 0.733766 \n", "\n", " claim_grades \\\n", "0 [True, True, False, True, True, True, True, Fa... \n", "1 [True, True, True, True, False, True, True, Tr... \n", "2 [True, True, True, True, False, True, True, Fa... \n", "3 [True, True, True, True, False, True, True, Tr... \n", "4 [True, True, True, True, True, True, True, Tru... \n", "\n", " answer \n", "0 Suthida Bajrasudhabimalalakshana (Thai: เธชเธกเน€เธ”เน‡เธˆ... \n", "1 Miguel รngel Fรฉlix Gallardo (born January 8, 1... \n", "2 Amethyst Amelia Kelly (born 7 June 1990), know... \n", "3 Fernando da Costa Novaes (April 6, 1927 โ€“ Marc... \n", "4 Jan Sariusz Zamoyski (Latin: Ioannes Zamoyski ... " ] }, "execution_count": 12, "metadata": {}, "output_type": "execute_result" } ], "source": [ "# grade original responses against the answer key using the grader\n", "result_df[\"claim_grades\"] = await grader.grade_claims(claim_sets=claims_data_lists[\"claim\"], answers=factscore[\"wikipedia_text\"].to_list())\n", "result_df[\"answer\"] = factscore[\"wikipedia_text\"]\n", "result_df.head(5)" ] }, { "cell_type": "code", "execution_count": 13, "metadata": { "tags": [] }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "Baseline LLM accuracy: 0.6737967914438503\n" ] } ], "source": [ "all_claim_scores, all_claim_grades = [], []\n", "for i in range(len(result_df)):\n", " all_claim_scores.extend(claims_data_lists[\"entailment\"][i])\n", " all_claim_grades.extend(result_df[\"claim_grades\"][i])\n", "\n", "print(f\"\"\"Baseline LLM accuracy: {np.mean(all_claim_grades)}\"\"\")" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "#### 3.1 Claim-Level Hallucination Detection AUROC" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "To evaluate fine-grained hallucination detection performance, we compute AUROC of claim-level hallucination detection. Below, we plot the ROC curve and report these results." ] }, { "cell_type": "code", "execution_count": 14, "metadata": { "tags": [] }, "outputs": [], "source": [ "from sklearn.metrics import roc_curve, roc_auc_score\n", "\n", "fpr, tpr, thresholds = roc_curve(y_true=all_claim_grades, y_score=all_claim_scores)\n", "roc_auc = roc_auc_score(y_true=all_claim_grades, y_score=all_claim_scores)" ] }, { "cell_type": "code", "execution_count": 15, "metadata": { "tags": [] }, "outputs": [ { "data": { "image/png": "iVBORw0KGgoAAAANSUhEUgAAAkIAAAHHCAYAAABTMjf2AAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjcsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvTLEjVAAAAAlwSFlzAAAPYQAAD2EBqD+naQAAg61JREFUeJzt3Xd8zdf/B/DXTWQvISIRIYLYM2aMWBWliBlFhKJWaI3WDqpGqV21ipi1SqmVlhpFvrT2TEqkYgQhsmRI7vn9kd+9cpObceMmn+Te1/PxuA/uuZ/xvvdzb+77nikTQggQERER6SEDqQMgIiIikgoTISIiItJbTISIiIhIbzERIiIiIr3FRIiIiIj0FhMhIiIi0ltMhIiIiEhvMREiIiIivcVEiIiIiPQWEyEqdC4uLhg8eLDUYeidNm3aoE2bNlKHkavZs2dDJpMhKipK6lCKHJlMhtmzZ2vlWOHh4ZDJZAgMDNTK8QDg0qVLMDY2xn///ae1Y2pbv3790LdvX6nDoCKEiZCOCQwMhEwmU95KlCgBJycnDB48GE+ePJE6vCItISEBc+fORd26dWFubg4bGxu0atUKW7duRXFZiebOnTuYPXs2wsPDpQ4li7S0NGzevBlt2rRBqVKlYGJiAhcXFwwZMgT//POP1OFpxc6dO7F8+XKpw1BRmDFNnz4dn376KSpWrKgsa9OmjcrfJDMzM9StWxfLly+HXC5Xe5xXr17hq6++QrVq1WBqaopSpUrBy8sLhw8fzvbcsbGxmDNnDurVqwdLS0uYmZmhdu3amDx5Mp4+farcbvLkyfjll19w/fr1PD8vfXjv6jVBOmXz5s0CgPjmm2/Etm3bxIYNG8TQoUOFoaGhqFy5skhMTJQ6RJGUlCRSUlKkDkNFZGSkqFWrljAwMBD9+/cX69atEytWrBCtW7cWAISPj49ITU2VOsxc7d27VwAQp06dyvJYcnKySE5OLvyghBBv374VnTp1EgBE69atxeLFi8XGjRvFzJkzRbVq1YRMJhMRERFCCCFmzZolAIiXL19KEuuH6NKli6hYsWKBHT8xMVG8e/dOo32yi0kul4vExEStva+vXr0qAIgLFy6olHt6eory5cuLbdu2iW3btolly5aJxo0bCwBi2rRpWY5z79494eTkJIyNjcWIESPEhg0bxOLFi0X9+vUFADFp0qQs+zx48EBUqlRJGBoain79+okffvhBrF+/Xvj7+4vSpUuLqlWrqmzfpEkT4evrm6fnpcl7l4onJkI6RpEI/f333yrlkydPFgDE7t27JYpMWomJiSItLS3bx728vISBgYE4ePBglscmTZokAIiFCxcWZIhqxcfHa7R9TomQlMaMGSMAiGXLlmV5LDU1VSxevLhQEyG5XC7evn2r9eMWRCKUlpb2QT9gCjo5Uxg3bpyoUKGCkMvlKuWenp6iVq1aKmWJiYmiYsWKwsrKSiURS0lJEbVr1xbm5ubif//7n8o+qampwsfHRwAQu3btUpa/e/dO1KtXT5ibm4u//vorS1wxMTFZEq7vv/9eWFhYiLi4uFyflybv3Q/xodeZ8o+JkI7JLhE6fPiwACDmz5+vUn737l3Rq1cvYWtrK0xMTIS7u7vaZCA6Olp8+eWXomLFisLY2Fg4OTkJX19flS+rpKQkERAQICpXriyMjY1F+fLlxVdffSWSkpJUjlWxYkXh5+cnhBDi77//FgBEYGBglnMeP35cABC//fabsuzx48diyJAhwt7eXhgbG4uaNWuKjRs3qux36tQpAUD8/PPPYvr06aJcuXJCJpOJ6Ohota9ZcHCwACA+++wztY+/e/dOVK1aVdja2iq/PB8+fCgAiMWLF4ulS5eKChUqCFNTU9G6dWtx8+bNLMfIy+usuHanT58Wo0aNEmXKlBElS5YUQggRHh4uRo0aJdzc3ISpqakoVaqU6N27t3j48GGW/TPfFEmRp6en8PT0zPI67d69W3z77bfCyclJmJiYiHbt2ol///03y3P44YcfRKVKlYSpqalo3LixOHv2bJZjqhMRESFKlCghPvrooxy3U1AkQv/++6/w8/MTNjY2wtraWgwePFgkJCSobLtp0ybRtm1bUaZMGWFsbCxq1KghfvzxxyzHrFixoujSpYs4fvy4cHd3FyYmJsovtrweQwghjh49Klq3bi0sLS2FlZWVaNSokdixY4cQIv31zfzaZ0xA8vr5ACDGjBkjtm/fLmrWrClKlCghDhw4oHxs1qxZym1jY2PFF198ofxclilTRnTo0EFcvnw515gU7+HNmzernP/u3buiT58+ws7OTpiamgo3Nze1NTeZVahQQQwePDhLubpESAghevfuLQCIp0+fKst+/vlnZY22Om/evBElS5YU1atXV5bt2rVLABDz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VSskJydj//79OH36NHx8fPDVV19l2a9KlSpo2bIlRo0aheTkZCxfvhylS5fG119/rdwmr69zTj755BNs27YNNjY2qFmzJoKDg3HixAllk4RC/fr1YWhoiO+++w4xMTEwMTFBu3btYG9vn+/XxtjYGLNnz8bYsWPRrl079O3bF+Hh4QgMDETlypXz9Gt0yZIlePDgAcaNG4f9+/fjk08+ga2tLR49eoS9e/fi3r17KjWAedGxY0cYGxuja9euGDFiBOLj47FhwwbY29urTTo/5BjW1tZYtmwZhg0bhsaNG6N///6wtbXF9evX8fbtW2zZsgUA4O7ujt27d2PChAlo3LgxLC0t0bVrV618PjKLi4tD+fLl0bt3b+WyEidOnMDff/+tUnOYXUzqrFy5Ei1btkTDhg3x+eefo1KlSggPD8eRI0dw7dq1HOPp3r07Dhw4kKe+N0B601bnzp3x008/YebMmShdujSMjY2xb98+tG/fHi1btsSQIUPQqFEjvHnzBjt37sSVK1cwceJElfeKkZER9u/fjw4dOqB169bo27cvWrRoASMjI9y+fVtZm5tx+P8ff/wBc3NzfPTRR7nGqcl7t1+/fpg8eTJ69OiBcePG4e3bt1izZg3c3Nw0HtTg4+ODVatWYdasWahTp06WaTAK4j2ltwp/oBoVpOwmVBQifebSypUri8qVKyuHZz948EAMGjRIODg4CCMjI+Hk5CQ++eQTsW/fPpV9X716Jfz9/ZVT35cvX174+fmpDGVPSUkR3333nahVq5YwMTERtra2wt3dXcyZM0fExMQot8s8fF7h33//VU76du7cObXP7/nz52LMmDHC2dlZGBkZCQcHB9G+fXuxfv165TaKYeF79+7V6LWLi4sTs2fPFrVq1RJmZmbCyspKtGjRQgQGBmYZPpxxQsUlS5YIZ2dnYWJiIlq1aiWuX7+e5dh5eZ1zunbR0dFiyJAhws7OTlhaWgovLy9x7949ta/lhg0bhKurqzA0NMzThIqZX6fsJtpbuXKlqFixojAxMRFNmjQR58+fF+7u7qJTp055eHXTZ+H96aefRKtWrYSNjY0wMjISFStWFEOGDFEZnpzdzNKK1yfjJJKHDh0SdevWFaampsLFxUV89913YtOmTVm2U0yoqE5ej6HY1sPDQ5iZmQlra2vRpEkT8fPPPysfj4+PF/379xcl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OWJiYrI974ABA3DkyBFs2rRJ2UlaISAgAFu3bsWcOXNw+/Zt3L17F7t27cKMGTM0em7NmzdH3bp1MX/+fABA1apV8c8//yAoKAihoaGYOXMm/v77b5V9XFxccOPGDYSEhCAqKgrv3r3DgAEDYGdnh+7du+Ovv/7Cw4cPcfr0aYwbNw6PHz/WKCYivSd1JyUi0j51HWwVli5dKhwdHYWZmZnw8vISW7duFQBEdHS0EEK1M3NycrLo16+fcHZ2FsbGxqJcuXLC399fpSP0pUuXxEcffSQsLS2FhYWFqFu3bpbOzhll7iydWVpampg9e7ZwcnISRkZGol69euLYsWPKx9evXy/q168vLCwshLW1tWjfvr24cuWK8nFk6CwthBAbNmwQzs7OwsDAQHh6emb7+qSlpQlHR0cBQDx48CBLXMePHxceHh7CzMxMWFtbiyZNmoj169dn+zxmzZol6tWrl6X8559/FiYmJuLRo0ciKSlJDB48WNjY2IiSJUuKUaNGiSlTpqjs9+LFC+XrC0CcOnVKCCHEs2fPxKBBg4SdnZ0wMTERrq6uYvjw4SImJibbmIgoK5kQQkibihERERFJg01jREREpLeYCBEREZHeYiJEREREeouJEBEREektJkJERESkt5gIERERkd5iIkRERER6i4kQERER6S0mQkRERKS3mAgRERGR3mIiRERERHqLiRARERHprf8DzLdsIRv+JBkAAAAASUVORK5CYII=", "text/plain": [ "
" ] }, "metadata": {}, "output_type": "display_data" } ], "source": [ "import matplotlib.pyplot as plt\n", "\n", "plt.figure()\n", "plt.plot(fpr, tpr, color=\"darkorange\", lw=2, label=f\"ROC curve (AUC = {roc_auc:.2f})\")\n", "plt.plot([0, 1], [0, 1], color=\"navy\", lw=2, linestyle=\"--\")\n", "plt.xlim([0.0, 1.0])\n", "plt.ylim([0.0, 1.05])\n", "plt.xlabel(\"False Positive Rate\")\n", "plt.ylabel(\"True Positive Rate\")\n", "plt.title(\"Receiver Operating Characteristic (ROC) Curve\")\n", "plt.legend(loc=\"lower right\")\n", "plt.show()" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "#### 3.2 Gains from Uncertainty-Aware Decoding" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "Lastly, we evaluate the gains from uncertainty-aware decoding (UAD) by measuring the factual precision over claims at various filtering thresholds. " ] }, { "cell_type": "code", "execution_count": 16, "metadata": { "tags": [] }, "outputs": [ { "data": { "image/png": "iVBORw0KGgoAAAANSUhEUgAAA/MAAAMrCAYAAAAFkcLhAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjcsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvTLEjVAAAAAlwSFlzAAAPYQAAD2EBqD+naQAAzW5JREFUeJzs3Xd4FOX6xvF7N5VAQk1CgoHQi1RBIoKAgAZQjoAFsFDFA4KCESlKFQVEQSwoFqoN61F/wsESwYII0lSQEhCIIAmhpkDqzu+POdmwJkACSSabfD/XtdfJzszOPvsQOdz7vvOOzTAMQwAAAAAAwG3YrS4AAAAAAAAUDGEeAAAAAAA3Q5gHAAAAAMDNEOYBAAAAAHAzhHkAAAAAANwMYR4AAAAAADdDmAcAAAAAwM0Q5gEAAAAAcDOEeQAAAAAA3AxhHgCAYmaz2fTpp59a8t6dO3fW2LFj8338unXrZLPZdPr06SKrqTi8/vrrCgsLk91u14IFCzR9+nS1bNnyoq8ZPHiwevfuXSz1FaX8fNaiUBj9W7ZsmSpVqnTRY6z6fABgNcI8AJQBl/pHdXh4uBYsWJDnvoMHD8pms8nDw0NHjhxx2Xf06FF5enrKZrPp4MGDl6zjvffek4eHh0aNGlWA6pFf6enpmjt3rlq0aCE/Pz9Vq1ZN7du319KlS5WRkXFZ57z++ut19OhRVaxYsZCrLZp685KYmKjRo0drwoQJOnLkiB544AGNGzdO0dHRhfYeVsj+ouVij3Xr1lldJgCgiBDmAQD5UqNGDa1YscJl2/Lly1WjRo18n2Px4sUaP3683nvvPaWmphZ2iQWSnp5u6fsXtvT0dEVGRmrOnDl64IEH9NNPP2nTpk0aNWqUXnrpJe3cufOyzuvt7a3q1avLZrO5Rb15iY2NVUZGhm655RaFhITIz89PFSpUUNWqVQvtPayQ/UVL9uOuu+5S9+7dXbZdf/31l3Xu0vbfBwCURoR5AEC+DBo0SEuXLnXZtnTpUg0aNChfrz9w4IB++uknTZw4UQ0aNNAnn3yS65glS5bo6quvlo+Pj0JCQjR69GjnvtOnT+vf//63goOD5evrq6ZNm+qLL76QlPc02wULFig8PNz5PHt2wtNPP63Q0FA1bNhQkvTWW2+pTZs28vf3V/Xq1XX33Xfr2LFjLufauXOnbr31VgUEBMjf31833HCD9u/fr++//15eXl6Ki4tzOX7s2LG64YYbLtqPo0ePqkePHipXrpzq1Kmjjz76yLmvS5cuLp9dkhISEuTt7X3B0eQFCxbo+++/V3R0tEaNGqWWLVuqTp06uvvuu7Vx40bVr18/z9dd6vP/c5p99rTnL774Qg0bNpSfn5/uuOMOnT17VsuXL1d4eLgqV66shx9+WFlZWRf8/PmtNy0tTQ8//LCCgoLk6+urDh066JdffslVX3R0tNq0aSM/Pz9df/312rNnj7PeZs2aSZLq1KnjnEXyz9+ZrKwsRUVFqVKlSqpatarGjx8vwzBcanY4HJo9e7Zq166tcuXKqUWLFi5/bpeqJdv//d//6dprr5Wvr6+qVaumPn36OPelpaVp3LhxqlGjhsqXL6+IiIgLjq5nf9GS/ShXrpx8fHxctnl7e7v8WYeHh6tixYrq37+/kpKSnPs6d+6s0aNHa+zYsapWrZoiIyMlSTt27FCPHj1UoUIFBQcH67777tPx48edr/voo4/UrFkzlStXTlWrVlW3bt2UkpLiUudzzz2nkJAQVa1aVaNGjXKZdXHq1CkNHDhQlStXlp+fn3r06KGYmJg8P2+2OXPmKDg4WP7+/ho2bJjlXwwCgFUI8wCAfPnXv/6lU6dO6ccff5Qk/fjjjzp16pR69eqVr9cvXbpUt9xyiypWrKh7771Xixcvdtn/6quvatSoUXrggQf0+++/6/PPP1e9evUkmSGqR48eWr9+vd5++2398ccfmjNnjjw8PAr0GaKjo7Vnzx59/fXXzi8CMjIyNHPmTP3666/69NNPdfDgQQ0ePNj5miNHjqhjx47y8fHRt99+qy1btmjo0KHKzMxUx44dVadOHb311lvO4zMyMvTOO+9o6NChF61lypQpuv322/Xrr7/qnnvuUf/+/bVr1y5J0v333693331XaWlpzuPffvtt1ahRQ126dMnzfO+88466deumVq1a5drn5eWl8uXL5/m6S33+vJw9e1YvvviiVq5cqTVr1mjdunXq06ePVq9erdWrV+utt97Sa6+95hJ0L7fe8ePH6+OPP9by5cu1detW1atXT5GRkTp58qTLa5544gnNmzdPmzdvlqenp7P//fr10zfffCNJ2rRpk44ePaqwsLBc7zlv3jwtW7ZMS5Ys0Y8//qiTJ0/qP//5j8sxs2fP1ooVK7Ro0SLt3LlTjzzyiO6991599913+apFklatWqU+ffqoZ8+e2rZtm6Kjo9W2bVvn/tGjR2vDhg1auXKlfvvtN915553q3r37JQPupezfv1+ffvqpvvjiC33xxRf67rvvNGfOHJdjli9fLm9vb61fv16LFi3S6dOn1aVLF7Vq1UqbN2/WmjVrFB8fr7vuukuS+YXUgAEDNHToUO3atUvr1q1T3759Xb4EWbt2rfbv36+1a9dq+fLlWrZsmZYtW+bcP3jwYG3evFmff/65NmzYIMMw1LNnzwteZvHBBx9o+vTpmjVrljZv3qyQkBC98sorV9QbAHBbBgCg1Bs0aJBx2223XXB/rVq1jOeffz7PfQcOHDAkGdu2bTPGjh1rDBkyxDAMwxgyZIjxyCOPGNu2bTMkGQcOHLjg+bOysoywsDDj008/NQzDMBISEgxvb2/jzz//dB4TGhpqPPHEE3m+/ssvvzTsdruxZ8+ePPdPmzbNaNGihcu2559/3qhVq5bz+aBBg4zg4GAjLS3tgnUahmH88ssvhiQjKSnJMAzDmDRpklG7dm0jPT09z+OfeeYZo3Hjxs7nH3/8sVGhQgUjOTn5gu8hyRgxYoTLtoiICGPkyJGGYRjGuXPnjMqVKxvvv/++c3/z5s2N6dOnX/Cc5cqVMx5++OGLfjbDMIxOnToZY8aMueD+f37+tWvXGpKMU6dOGYZhGEuXLjUkGfv27XO+5t///rfh5+fnfI1hGEZkZKTx73//+4rqTU5ONry8vIx33nnHuS09Pd0IDQ015s6d61LfN9984zxm1apVhiTj3LlzhmEYef6O/vN3JiQkxHlOwzCMjIwM46qrrnL+d5Oammr4+fkZP/30k0uNw4YNMwYMGJDvWtq1a2fcc889eX7eQ4cOGR4eHsaRI0dctnft2tWYNGnSRXtlGBf+73zatGmGn5+fkZiY6Nz22GOPGREREc7nnTp1Mlq1auXyupkzZxo333yzy7a//vrLkGTs2bPH2LJliyHJOHjw4AXrqVWrlpGZmencdueddxr9+vUzDMMw9u7da0gy1q9f79x//Phxo1y5csYHH3xgGIb5+1axYkXn/nbt2hkPPvigy/tERETk+u8fAMoCRuYBAPk2dOhQffjhh4qLi9OHH354ydHnbF9//bVSUlLUs2dPSVK1atV00003acmSJZKkY8eO6e+//1bXrl3zfP327dt11VVXqUGDBldUf7NmzVymHUvSli1b1KtXL9WsWVP+/v7q1KmTJPM66+z3vuGGG+Tl5ZXnOQcPHqx9+/bp559/lmRO677rrrsuOBKerV27drmeZ4/M+/r66r777nP2Z+vWrdqxY8dFR8yNf0wJz69Lff68+Pn5qW7dus7nwcHBCg8PV4UKFVy2/fNyhYLWu3//fmVkZKh9+/bObV5eXmrbtq2zV9maN2/u/DkkJESSLvr+5ztz5oyOHj2qiIgI5zZPT0+1adPG+Xzfvn06e/asbrrpJlWoUMH5WLFihfbv35/vWrZv337B3/Pff/9dWVlZatCggct7fPfdd7neo6DCw8Pl7+/vUtc/+9O6dWuX57/++qvWrl3rUkujRo0kmX82LVq0UNeuXdWsWTPdeeedeuONN3Tq1CmXc1x99dUuM2jOf99du3bJ09PTpe9Vq1ZVw4YNc/35Ztu1a5fL8VLu/5YAoKzwtLoAAID7aNasmRo1aqQBAwaocePGatq0qbZv337J1y1evFgnT55UuXLlnNscDod+++03zZgxw2V7Xi6132635wqHeU3T/WfATklJUWRkpCIjI/XOO+8oMDBQsbGxioyMdC4Adqn3DgoKUq9evbR06VLVrl1b//3vfwtlBfH7779fLVu21OHDh7V06VJ16dJFtWrVuuDxDRo00O7duwv0Hvn5/Hn55xcbNpstz20Oh6NQ672Y898/e7G+i71/QSUnJ0syp8n/c9FHHx+ffNdysd+n5ORkeXh4aMuWLbkuITn/i5LLkZ8/n3/+95GcnKxevXrpmWeeyXW+kJAQeXh46Ouvv9ZPP/2kr776Si+99JKeeOIJbdy4UbVr1873+wIALg8j8wCAAhk6dKjWrVuX71H5EydO6LPPPtPKlSu1fft252Pbtm06deqUvvrqK/n7+ys8PPyCi7s1b95chw8f1t69e/PcHxgYqLi4OJdAn58vGXbv3q0TJ05ozpw5uuGGG9SoUaNco5XNmzfXDz/8cNFbpd1///16//339frrr6tu3bouI8kXkj2Sf/7zxo0bO583a9ZMbdq00RtvvKF33333kv2+++679c0332jbtm259mVkZORalEzK3+cvKvmpt27dus5ruM/f98svv6hJkyaFVkvFihUVEhKijRs3OrdlZmZqy5YtzudNmjSRj4+PYmNjVa9ePZdH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T8m6eAAAAAAAcEkl7TpwFExh/PnxGwAAAAAAgJshzAMAAAAA4GYI8wAAAAAAuBnCPAAAAACg2GzYsEEeHh665ZZbrC7FrRHmAQAAAADFZvHixXrooYf0/fff6++//7asjvT0dMveuzAQ5gEAAACgjImJkbZuzf2IiSna901OTtb777+vkSNH6pZbbtGyZctc9v/f//2frr32Wvn6+qpatWrq06ePc19aWpomTJigsLAw+fj4qF69elq8eLEkadmyZapUqZLLuT777DOXVeOnT5+uli1b6s0331Tt2rWdt4Rbs2aNOnTooEqVKqlq1aq69dZbtX//fpdzHT58WAMGDFCVKlVUvnx5tWnTRhs3btTBgwdlt9u1efNml+MXLFigWrVqyeFwXGnLLoj7zAMAAABAGRITIzVocOH9e/dK9esXzXt/8MEHatSokRo2bKh7771XY8eO1aRJk2Sz2bRq1Sr16dNHTzzxhFasWKH09HStXr3a+dqBAwdqw4YNevHFF9WiRQsdOHBAx48fL9D779u3Tx9//LE++eQTeXh4SJJSUlIUFRWl5s2bKzk5WVOnTlWfPn20fft22e12JScnq1OnTqpRo4Y+//xzVa9eXVu3bpXD4VB4eLi6deumpUuXqk2bNs73Wbp0qQYPHlyktxAkzAMAAABAGZKUdGX7r8TixYt17733SpK6d++uM2fO6LvvvlPnzp319NNPq3///poxY4bz+BYtWkiS9u7dqw8++EBff/21unXrJkmqU6dOgd8/PT1dK1asUGBgoHPb7bff7nLMkiVLFBgYqD/++ENNmzbVu+++q4SEBP3yyy+qUqWKJKlevXrO4++//36NGDFC8+fPl4+Pj7Zu3arff/9dn332WYHrKwim2QMAAAAAityePXu0adMmDRgwQJLk6empfv36OafKb9++XV27ds3ztdu3b5eHh4c6dep0RTXUqlXLJchLUkxMjAYMGKA6deooICBA4eHhkqTY2Fjne7dq1coZ5P+pd+/e8vDw0H/+8x9J5pT/G2+80XmeosLIPAAAAACgyC1evFiZmZkKDQ11bjMMQz4+Pnr55ZdVrly5C772YvskyW63yzAMl20ZGRm5jitfvnyubb169VKtWrX0xhtvKDQ0VA6HQ02bNnUukHep9/b29tbAgQO1dOlS9e3bV++++65eeOGFi76mMDAyDwAA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24KDpYkTpX//WypXztr6AABA4bisW9ONHDlSI0eOVEJCgsqVK6cKFSpIkk6ePKkqVaoUaoEAAODSMjOl994zQ3xMjLktMNAM8SNGSH5+1tYHAAAKV4GvmT9fYGCgKlSooK+++kp33XWXatSoUVh1AQCAfMjKMkfir75aGjjQDPLVqklz55rT66OiCPIAAJRGlx3mDx06pGnTpik8PFx33nmn7Ha7VqxYUZi1AQCAC8jKklaulJo2le6917ytXJUq0uzZZoh/7DGpfHmrqwQAAEWlQNPs09PT9cknn+jNN9/U+vXr1a1bNx0+fFjbtm1Ts2bNiqpGAADwPw6H9NFH0owZ0h9/mNsqV5bGjZMeekjy97e2PgAAUDzyHeYfeughvffee6pfv77uvfdevf/++6pataq8vLzk4eFRlDUCAFDmORzSJ5+YIX7HDnNbpUrSo49KDz8sBQRYWh4AAChm+Q7zr776qiZMmKCJEyfKn6/9AQAoFoYhffqpNH269Ntv5raKFaVHHpHGjjV/BgAAZU++r5l/6623tGnTJoWEhKhfv3764osvlJWVVZS1AQBQZhmG9Nln0jXXSH37mkE+IECaOlU6eFCaNo0gDwBAWZbvkfkBAwZowIABOnDggJYtW6ZRo0bp7Nmzcjgc+uOPP9SkSZOirBMAgFInJkZKSjKDe2qqdOSIuX3LFun1183/laQKFaQxY8yV6bkDLAAAkC7jPvO1a9fWjBkzNH36dH311VdavHix7r33Xo0dO1Z9+/bViy++WBR1AgBQqsTESA0amD/b7eYI/JYtZrDPVr68eT38o49KVataUycAACiZChzms9lsNkVGRioyMlInT57UihUrtHTp0sKsDQCAUispKednw5B27aoiw8i5+m3QIOm558x7xgMAAPzTZYf581WpUkVjx47V2LFjC+N0AACUOoYh/fmntHmz+Vi79vx9dqWkeEsyJNkkmSPyBHkAAHAhhRLmAQBADsOQDh3KCe6bN5tT6E+fvuArFBKSorg4PxmGrRgrBQAA7oowDwDAFTAM6a+/zLB+fng/eTL3sT4+UosWUps2UmCgec94SbLbDV11VbLi4/1crpkHAAC4EMI8AAAF8PffrqF982YpISH3cV5eUvPmZnDPflx9tbldkrZuzQnzAAAABUWYBwDgAuLico+4x8XlPs7TU2rWTGrdOie4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AAAAQBlHmHcjdrshX98sq8sAAAAAAFiMMF/C+ftf2X4AAAAAQOnDAnglXP360t69rveZ9/U17zPv72/uBwAAAACULYR5N5Ad2B0O6dgxKSjIvOc8AAAAAKBsIhICAAAAAOBmCPMAAAAAALgZwjwAAAAAAG6GMA8AAAAAgJshzAMAAAAA4GYI8wAAAAAAuBnCPAAAAAAAboYwDwAAAACAmyHMAwAAAADgZgjzAAAAAAC4GcI8AAAAAABuhjAPAAAAAICbIcwDAAAAAOBmCPMAAAAAALgZwjwAAAAAAG6GMA8AAAAAgJshzAMAAAAA4GYI8wAAAAAAuBnLw/zChQsVHh4uX19fRUREaNOmTRc9/vTp0xo1apRCQkLk4+OjBg0aaPXq1c7906dPl81mc3k0atSoqD8GAAAAAADFxtPKN3///fcVFRWlRYsWKSIiQgsWLFBkZKT27NmjoKCgXMenp6frpptuUlBQkD766CPVqFFDhw4dUqVKlVyOu/rqq/XNN984n3t6WvoxAQAAAAAoVJam3Pnz52v48OEaMmSIJGnRokVatWqVlixZookTJ+Y6fsmSJTp58qR++ukneXl5SZLCw8NzHefp6anq1avnu460tDSlpaU5nycmJkqSHA6HHA5HQT5SkXI4HDIMo0TVVBbQd2vQd2vQd2vQd2vQd2vQd2vQd+vQe2u4c9/zW7NlYT49PV1btmzRpEmTnNvsdru6deumDRs25Pmazz//XO3atdOoUaP02WefKTAwUHfffbcmTJggDw8P53ExMTEKDQ2Vr6+v2rVrp9mzZ6tmzZoXrGX27NmaMWNGru0JCQlKTU29gk9ZuBwOh86cOSPDMGS3W36FRJlB361B361B361B361B361B361B361D763hzn1PSkrK13GWhfnjx48rKytLwcHBLtuDg4O1e/fuPF/z559/6ttvv9U999yj1atXa9++fXrwwQeVkZGhadOmSZIiIiK0bNkyNWzYUEePHtWMGTN0ww03aMeOHfL398/zvJMmTVJUVJTzeWJiosLCwhQYGKiAgIBC+sRXzuFwyGazKTAw0O1+Id0ZfbcGfbcGfbcGfbcGfbcGfbcGfbcOvbeGO/fd19c3X8e51cXkDodDQUFBev311+Xh4aHWrVvryJEjevbZZ51hvkePHs7jmzdvroiICNWqVUsffPCBhg0blud5fXx85OPjk2u73W4vcX/wNputRNZV2tF3a9B3a9B3a9B3a9B3a9B3a9B369B7a7hr3/Nbr2Vhvlq1avLw8FB8fLzL9vj4+Ate7x4SEiIvLy+XKfWNGzdWXFyc0tPT5e3tnes1lSpVUoMGDbRv377C/QAAAAAAAFjEsq8ovL291bp1a0VHRzu3ORwORUdHq127dnm+pn379tq3b5/LggB79+5VSEhInkFekpKTk7V//36FhIQU7gcAAAAAAMAils43iIqK0htvvKHly5dr165dGjlypFJSUpyr2w8cONBlgbyRI0fq5MmTGjNmjPbu3atVq1Zp1qxZGjVqlPOYcePG6bvvvtPBgwf1008/qU+fPvLw8NCAAQOK/fMBAAAAAFAULL1mvl+/fkpISNDUqVMVFxenli1bas2aNc5F8WJjY12uFwgLC9OXX36pRx55RM2bN1eNGjU0ZswYTZgwwXnM4cOHNWDAAJ04cUKBgYHq0KGDfv75ZwUGBhb75wMAAAAAoChYvgDe6NGjNXr06Dz3rVu3Lte2du3a6eeff77g+VauXFlYpQEAAAAAUCK517J+AAAAAACAMA8AAAAAgLshzAMAAAAA4GYI8wAAAAAAuBnCPAAAAAAAboYwDwAAAACAmyHMAwAAAADgZgjzAAAAAAC4GcI8AAAAAABuhjAPAAAAAICbIcwDAAAAAOBmCPMAAAAAALgZwjwAAAAAAG6GMA8AAAAAgJshzAMAAAAA4GYI8wAAAAAAuBnCPAAAAAAAboYwDwAAAACAmyHMAwAAAADgZgjzAAAAAAC4GcI8AAAAAABuhjAPAAAAAICbIcwDAAAAAOBmCPMAAAAAALgZwjwAAAAAAG6GMA8AAAAAgJshzAMAAAAA4GYI8wAAAAAAuBnCPAAAAAAAboYwDwAAAACAmyHMAwAAAADgZgjzAAAAAAC4GcI8AAAAAABuhjAPAAAAAICbIcwDAAAAAOBmCPMAAAAAALgZwjwAAAAAAG6GMA8AAAAAgJshzAMAAAAA4GYI8wAAAAAAuBnCPAAAAAAAbsbT6gJKIsMwJEmJiYkWV+LK4XAoKSlJvr6+stv5Hqa40Hdr0Hdr0Hdr0Hdr0Hdr0Hdr0Hfr0HtruHPfs3Nodi69EMJ8HpKSkiRJYWFhFlcCAAAAACiLkpKSVLFixQvutxmXivtlkMPh0N9//y1/f3/ZbDary3FKTExUWFiY/vrrLwUEBFhdTplB361B361B361B361B361B361B361D763hzn03DENJSUkKDQ296KwCRubzYLfbddVVV1ldxgUFBAS43S9kaUDfrUHfrUHfrUHfrUHfrUHfrUHfrUPvreGufb/YiHw297p4AAAAAAAAEOYBAAAAAHA3hHk34uPjo2nTpsnHx8fqUsoU+m4N+m4N+m4N+m4N+m4N+m4N+m4dem+NstB3FsADAAAAAMDNMDIPAAAAAICbIcwDAAAAAOBmCPMAAAAAALgZwjwAAAAAAG6GMA8AAAAAgJvxtLqAksjhcOjvv/+Wv7+/bDab1eUAAAAAAMoIwzCUlJSk0NBQ2e0XHn8nzOfh77//VlhYmNVlAAAAAADKqL/++ktXXXXVBfcT5vPg7+8vyWxeQECAxdUAAAAAAMqKxMREhYWFOXPphRDm85A9tT4gIKBIwvzDDz+szz//XIcOHdK2bdvUsmVLSVJMTIwGDRqk48ePq2LFilq2bJmuvvrqi+7LyMjQnXfeqQMHDqhu3br64IMP5OnpqdTUVN1888367LPPVLly5UL/DAAAAACAonOpS75ZAM8Cd9xxh3788UfVqlXLZfu///1vPfDAA9q7d68mTJigwYMHX3Lfl19+qSpVqujXX39VpUqVtGbNGknSzJkzNXr0aII8AAAAAJRChHkLdOzYMde1D8eOHdPmzZt17733SpJuv/12/fXXX9q3b99F93l5eens2bOSpLNnz8rb21u//fabdu/erbvuuqt4PxgAAAAAoFgQ5kuIv/76SyEhIfL0NK98sNlsqlmzpmJjYy+676abbpK/v79atGihihUrqkuXLoqKitILL7xg5ccBAAAAABQhrpl3c3a7XW+88Ybz+YIFC9S7d29lZmbq7rvvVlpamkaNGqUuXbpYWCUAAABQcmRlZSkjI8PqMlBGeXl5ycPD44rPQ5gvIcLCwnT06FFlZmbK09NThmEoNjZWNWvWVEBAwAX3ne/QoUNavXq11qxZo0GDBumBBx5Q69atdd1112nnzp0WfTIAAACgZDAMQ3FxcTp9+rTVpaCMq1SpkqpXr37JRe4upkSF+e+//17PPvustmzZoqNHj+o///mPevfu7dxvGIamTZumN954Q6dPn1b79u316quvqn79+s5jTp48qYceekj/93//J7vdrttv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Z3kX/kYt/1W/LW6rd+YBAAAAANm5u7urRYsWatGihUaOHKlevXpp9OjReu6553TmzBm1bdtWL730kiZMmCAfHx9999136tmzp9LS0uTh4SFJcnFxyXJMk8mU45jFkv8LASYmJqpevXr64IMPsm0rU6bMv+4bFBSkoKAg9erVS6+//rqqVaumVatWqUePHjnOX758uWbOnKnt27frrrvuylLDo48+qilTpmTb5+93Rvs7X19fJScnKy0tTa6urjnO+eOPPzRmzBjt2LFDP/74o6pVq6aqVauqatWqSk9P16+//qqQkBBJUnx8fK7WbAvCPAAAAAA4mJo1a2r9+vWSpL1798pisWj69OnWe5SvXr26wJ5r165d2R4HBwfnOLdu3bpatWqV/Pz85O3tne/nrFSpkjw8PJSUlJTj9h9++EG9evXSvHnzFBYWlq2Gjz/+WJUqVcp2pfmbuXFxvWPHjmW50N7fDRw4UAMHDlT58uW1Z88epaenW7dlZGRkuXDgkSNHVL58efn6+ubq+fOD0+wBAAAA4DZ16dIlNWvWTMuXL9ehQ4cUHR2tjz76SFOnTlW7du0kSXfffbfS09M1e/ZsnT59WsuWLdPcuXMLrIadO3dq6tSp+vXXXzVnzhx99NFH6t+/f45zu3TpIl9fX7Vr107ffvutoqOjtX37dr3yyis6f/58jvu88cYbGjJkiLZv367o6Gjt379fzz//vNLT03P8XH5MTIwef/xxPf3002rVqpViYmIUExOjixcvSpIiIyMVHx+vZ555Rnv27NGpU6e0efNm9ejRI0vg/rsyZcqobt26+u6773LcvnXrVv3666/WW83df//9+uWXX/TFF19o/vz5cnJyUvXq1a3zv/322xyvD1CQeGceAAAAwB3vjzizpMK5z3xeeHp6qkGDBpo5c6ZOnTql9PR0BQYGqnfv3nrttdckSbVr19aMGTM0ZcoUDR8+XA899JAmTZqkZ599tkBqHjRokH766SeNGTNG3t7emjFjhlq1apXjXA8PD+3YsUNDhw5Vhw4ddPXqVd11111q3rz5Td+pb9y4sebMmaNnn31WsbGxKlWqlOrUqaMtW7ZkCcg3/PLLL4qNjdWSJUu0ZMkS63jFihV15swZlStXTjt37tTQoUPVsmVLpaamqmLFimrdurX1zIWc9OrVS0uXLlW/fv2yjF+7dk39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3qwHH3ywIOoBAAAAkAerV6+2Xvx53bp1eu6553Tw4MGbjm/evFk+Pj5av369nn/+eW3atElt27bVuHHj1K9fP4I84CBsvsZnYGBgnm7fBgAAAKDg/P0uTleuXLGeKXuzcRcXFyUnJ0uSkpOT5erqqkOHDumXX35Rx44dC61uALax+Z356dOna8iQIZo7d64qVapUACUBAAAAyItnn31WX3/9tSRp48aN/zreokULrVmzRrVr11ZYWJiaNWum1q1ba/HixYVeN4D8sznMd+3aVcnJyQoKCpKHh0e2C+DFx8fb+hQAAAAA/sXSpUslSUuWLNHQoUOtwT2ncbPZrAULFlj3nTVrltq3b6+MjAx17txZqampioyMVLNmzQp/IQByzeYwP2vWrAIoAwAAAICtunfvrhdffFGXLl1S6dKl/3P87Nmz2rhxozZt2qTu3burT58+qlevnsLCwnT06FF7LAFALhXI1ewBAAAAFL7Lly8rOTlZ5cqVkyStX79epUuXltls1u+//55t3MfHJ8v+/fv3t97aOSkpSSaTyfo9gNubzWH+71JSUpSWlpZljIvjAQAAALfGlStX9NRTT+natWsym80qU6aMPvvsMyUkJOQ4/vfbSH/44YeqXbu2atWqJUkaNmyYevfurbS0NI0cOdJeSwKQSzaH+aSkJA0dOlSrV6/WpUuXsm3PzMy09SkAAAAA5KBixYravXt3jttuNn5D586dszyuX7++Dh48WGC1Abi1bA7zQ4YM0ddff613331X3bp105w5c/S///1P8+bN0+TJkwuiRgAAAOCOEB8vJSbau4r88fSU/nEWP4BbyOYw/+mnn2rp0qVq0qSJevTooUaNGunuu+9WxYoV9cEHH6hLly4FUScAAABQpMXHS8NHWJScYrF3Kfni4W7WpPFmAj1QSGwO8/Hx8apSpYqk65+Pv3ErugcffFAvvfSSrYcHAAAA7giJiVJyikURT6bI18+xAv0fcWZ9ucZdiYmEeaCw2Bzmq1SpoujoaFWoUEE1atTQ6tWrVb9+fX366acqWbJkAZQIAAAA3Dl8/SwqW96wdxl55FgvPgBFgdnWA/To0cN6oYxhw4Zpzpw5cnd318CBA/Xqq6/aXCAAAAAAAMjK5nfmBw4caP0+IiJCP//8s/bt26e7775b9957r62HBwAAAAAA/1Cg95mXpEqVKqlS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DbR79+5/nf/RRx+pRo0acnd3V0hIiDZu3FhIlRYteen70aNH9cQTT6hSpUoymUyaNWtW4RVaxOSl7wsWLFCjRo1UqlQplSpVShEREf/5/wdylpe+r127Vvfdd59Kliyp4sWLKzQ0VMuWLSvEaouOvP77fsPKlStlMpnUvn37W1tgEZWXvi9evFgmkynLl7u7eyFWW3Tk9ef98uXLioyMVNmyZeXm5qZq1arxN00+5KXvTZo0yfbzbjKZ9MgjjxRixUVDXn/eZ82aperVq6tYsWIKDAzUwIEDlZKSUkjVFh156Xt6errGjh2roKAgubu7q3bt2tq0aVMhVnuLGLhtrFy50nB1dTXef/994+jRo0bv3r2NkiVLGrGxsTnO37lzp+Hk5GRMnTrVOHbsmDFixAjDxcXFOHz4cCFX7tjy2vfdu3cbgwcPNlasWGEEBAQYM2fOLNyCi4i89r1z587GnDlzjP379xs///yz8dxzzxklSpQwzp8/X8iVO7a89v3rr7821q5daxw7dsw4efKkMWvWLMPJycnYtGlTIVfu2PLa9xuio6ONu+66y2jUqJHRrl27wim2CMlr3xctWmR4e3sbFy5csH7FxMQUctWOL699T01NNe677z6jTZs2xnfffWdER0cb27dvNw4cOFDIlTu2vPb90qVLWX7Wjxw5Yjg5ORmLFi0q3MIdXF77/sEHHxhubm7GBx98YERHRxubN282ypYtawwcOLCQK3dsee37kCFDjHLlyhmff/65cerUKeOdd94x3N3djX379hVy5QWLMH8bqV+/vhEZGWl9nJmZaZQrV86YNGlSjvM7duxoPPLII1nGGjRoYLzwwgu3tM6iJq99/7uKFSsS5vPJlr4bhmFkZGQYXl5expIlS25ViUWSrX03DMOoU6eOMWLEiFtRXpGVn75nZGQYDzzwgPHee+8Z3bt3J8znQ177vmjRIqNEiRKFVF3Rlde+v/vuu0aVKlWMtLS0wiqxSLL13/eZM2caXl5eRmJi4q0qsUjKa98jIyONZs2aZRmLiooywsPDb2mdRU1e+162bFnj7bffzjLWoUMHo0uXLre0zluN0+xvE2lpadq7d68iIiKsY2azWREREfrhhx9y3OeHH37IMl+SWrVqddP5yC4/fYftCqLvycnJSk9Pl4+Pz60qs8ixte+GYWjbtm06fvy4HnrooVtZapGS376PHTtWfn5+6tmzZ2GUWeTkt++JiYmqWLGiAgMD1a5dOx09erQwyi0y8tP3Tz75RA0bNlRkZKT8/f11zz33aOLEicrMzCyssh1eQfxeXbhwoZ5++mkVL178VpVZ5OSn7w888ID27t1rPSX89OnT2rhxo9q0aVMoNRcF+el7ampqto9NFStWTN99990trfVWI8zfJv744w9lZmbK398/y7i/v79iYmJy3CcmJiZP85FdfvoO2xVE34cOHapy5cple0ELN5ffvl+5ckWenp5ydXXVI488otmzZ6tFixa3utwiIz99/+6777Rw4UItWLCgMEoskvLT9+rVq+v999/Xhg0btHz5clksFj3wwAM6f/58YZRcJOSn76dPn9aaNWuUmZmpjRs3auTIkZo+fbrGjx9fGCUXCbb+Xt29e7eOHDmiXr163aoSi6T89L1z584aO3asHnzwQbm4uCgoKEhNmjTRa6+9VhglFwn56XurVq00Y8YMnThxQhaLRVu3btXatWt14cKFwij5liHMA3A4kydP1sqVK7Vu3TouTlUIvLy8dODAAe3Zs0cTJkxQVFSUtm/fbu+yiqyrV6+qW7duWrBggXx9fe1dzh2lYcOGevbZZxUaGqrGjRtr7dq1KlOmjObNm2fv0oo0i8UiPz8/zZ8/X/Xq1VOnTp30+uuva+7cufYu7Y6xcOFChYSEqH79+vYupcjbvn27Jk6cqHfeeUf79u3T2rVr9fnnn2vcuHH2Lq1Ie/PNN1W1alXVqFFDrq6u6tevn3r06CGz2bHjsLO9C8B1vr6+cnJyUmxsbJbx2NhYBQQE5LhPQEBAnuYju/z0Hbazpe/Tpk3T5MmT9eWXX+ree++9lWUWOfntu9ls1t133y1JCg0N1c8//6xJkyapSZMmt7LcIiOvfT916pTOnDmjRx991DpmsVgkSc7Ozjp+/LiCgoJubdFFQEH8++7i4qI6dero5MmTt6LEIik/fS9btqxcXFzk5ORkHQsODlZMTIzS0tLk6up6S2suCmz5eU9KStLKlSs1duzYW1likZSfvo8cOVLdunWzngUREhKipKQk9enTR6+//rrDh8vCkJ++lylTRuvXr1dKSoouXbqkcuXKadiwYapSpUphlHzL8NNym3B1dVW9evW0bds265jFYtG2bdvUsGHDHPdp2LBhlvmStHXr1pvOR3b5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", "text/plain": [ "
" ] }, "metadata": {}, "output_type": "display_data" } ], "source": [ "plot_model_accuracies(scores=all_claim_scores, correct_indicators=all_claim_grades, title=\"LLM Accuracy by Claim Confidence Threshold\", display_percentage=True)" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "Since, we have selected a threshold of 1/3, we can measure LLM accuracy with and without UAD." ] }, { "cell_type": "code", "execution_count": 17, "metadata": { "tags": [] }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "Baseline LLM factual precision: 0.6737967914438503\n", "UAD-Improved LLM factual precision: 0.7665952890792291\n" ] } ], "source": [ "thresh = 1 / 3\n", "filtered_grades, filtered_scores = [], []\n", "for grade, score in zip(all_claim_grades, all_claim_scores):\n", " if score > thresh:\n", " filtered_grades.append(grade)\n", " filtered_scores.append(score)\n", "\n", "print(f\"Baseline LLM factual precision: {np.mean(all_claim_grades)}\")\n", "print(f\"UAD-Improved LLM factual precision: {np.mean(filtered_grades)}\")" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "## 4. Scorer Definitions" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "Long-form uncertainty quantification implements a three-stage pipeline after response generation:\n", "\n", "1. Response Decomposition: The response $y$ is decomposed into units (claims or sentences), where a unit as denoted as $s$.\n", "\n", "2. Unit-Level Confidence Scoring: Confidence scores are computed using function $c_g(s;\\cdot) \\in [0, 1]$. Higher scores indicate greater likelihood of factual correctness. Units with scores below threshold $\\tau$ are flagged as potential hallucinations.\n", "\n", "3. Response-Level Aggregation: Unit scores are combined to provide an overall response confidence.\n", "\n", "The Long-text UQ (LUQ) approach demonstrated here is adapted from [Zhang et al., 2024](https://arxiv.org/abs/2403.20279). Similar to standard black-box UQ, this approach requires generating a original response and sampled candidate responses to the same prompt. The original response is then decomposed into units (claims or sentences). Unit-level confidence scores are then obtained by averaging entailment probabilities across candidate responses:\n", "\n", "$$c_g(s; \\mathbf{y}_{\\text{cand}}) = \\frac{1}{m} \\sum_{j=1}^m P(\\text{entail}|y_j, s)$$\n", "\n", "where $\\mathbf{y}^{(s)}_{\\text{cand}} = {y_1^{(s)}, ..., y_m^{(s)}}$ are $m$ candidate responses, and $P(\\text{entail}|y_j, s)$ denotes the NLI-estimated probability that $s$ is entailed in $y_j$." ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "ยฉ 2025 CVS Health and/or one of its affiliates. All rights reserved." ] } ], "metadata": { "environment": { "kernel": "uqlm_my_test", "name": "workbench-notebooks.m126", "type": "gcloud", "uri": "us-docker.pkg.dev/deeplearning-platform-release/gcr.io/workbench-notebooks:m126" }, "kernelspec": { "display_name": "uqlm_my_test", "language": "python", "name": "uqlm_my_test" }, "language_info": { "codemirror_mode": { "name": "ipython", "version": 3 }, "file_extension": ".py", "mimetype": "text/x-python", "name": "python", "nbconvert_exporter": "python", "pygments_lexer": "ipython3", "version": "3.11.12" } }, "nbformat": 4, "nbformat_minor": 4 }