{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "e64fe5a7",
   "metadata": {},
   "outputs": [],
   "source": [
    "import json\n",
    "import numpy as np"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "12f39d64",
   "metadata": {},
   "source": [
    "# WICE-subclaim"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "11f3a6d5",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open('wice_true_or_false.json','w') as outfile:\n",
    "    with open('WICE/dev.jsonl') as file:\n",
    "        for line in file:\n",
    "            data=json.loads(line)\n",
    "            if data['label']=='supported' or data['label']=='not_supported':\n",
    "                outfile.write(json.dumps(data)+\"\\n\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "48a61431",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open('wice_true_or_false.json','a') as outfile:\n",
    "    with open('WICE/test.jsonl') as file:\n",
    "        for line in file:\n",
    "            data=json.loads(line)\n",
    "            if data['label']=='not_supported':\n",
    "                outfile.write(json.dumps(data)+\"\\n\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "130d1320",
   "metadata": {},
   "source": [
    "# WICE-claim"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "4fe47114",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open('wice_true_or_false1.json','w') as outfile:\n",
    "    with open('WICE/claim/dev.jsonl') as file:\n",
    "        for line in file:\n",
    "            data=json.loads(line)\n",
    "            if data['label']=='supported': #or data['label']=='not_supported':\n",
    "                outfile.write(json.dumps(data)+\"\\n\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "70ce2beb",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open('wice_true_or_false1.json','a') as outfile:\n",
    "    with open('WICE/claim/train.jsonl') as file:\n",
    "        for line in file:\n",
    "            data=json.loads(line)\n",
    "            if data['label']=='supported':# or data['label']=='not_supported':\n",
    "                outfile.write(json.dumps(data)+\"\\n\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "f8ab5a89",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open('wice_true_or_false1.json','a') as outfile:\n",
    "    with open('WICE/claim/test.jsonl') as file:\n",
    "        for line in file:\n",
    "            data=json.loads(line)\n",
    "            if data['label']=='supported':# or data['label']=='not_supported':\n",
    "                outfile.write(json.dumps(data)+\"\\n\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c1914863",
   "metadata": {},
   "source": [
    "# temperature=0.1/0.5/0.9"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "a0bbe820",
   "metadata": {},
   "outputs": [],
   "source": [
    "num=251  # 250/254/251"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "4ca1400c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "48 0.19123505976095617\n",
      "201 0.8007968127490039\n",
      "matched num= 502\n"
     ]
    }
   ],
   "source": [
    "t=0\n",
    "f=0\n",
    "t1=[]\n",
    "f1=[]\n",
    "n=0\n",
    "with open('wice+0.9/detections_1.jsonl') as file:\n",
    "    for line in file:\n",
    "        data = json.loads(line)\n",
    "        answer = data[1]['choices'][0]['message']['content']\n",
    "        question = data[0]['messages'][0]['content']\n",
    "        p1 = question.split('P1: \\\"')[1].split('P2: ')[0]\n",
    "        flag = False\n",
    "        pre=n\n",
    "        with open('wice+0.9/dataset_0.9.jsonl') as file1:  \n",
    "            for line1 in file1:\n",
    "                data1 = json.loads(line1)\n",
    "                q = data1[0]['messages'][0]['content']\n",
    "                ref1 = q.split('Reference:')[-1]\n",
    "                # \n",
    "                sentences1=ref1.strip().split('.')\n",
    "                sentences2=p1.strip()[:-1].split('.')\n",
    "                if ref1.strip()==p1.strip()[:-1] or len(sentences1)>1 and len(sentences2)>1 and sentences1[-2] == sentences2[-2]:\n",
    "                    flag = True\n",
    "                    n+=1\n",
    "                    label=data1[0]['label']\n",
    "                    if label == 'true': # hallucination\n",
    "                        if \"here are no conflicting parts\" in answer: # factual\n",
    "                            t+=1\n",
    "                        else:\n",
    "                            t1.append(ref1)\n",
    "                    else:# factual\n",
    "                        if \"here are no conflicting parts\" in answer: # factual\n",
    "                            f+=1\n",
    "                        else:\n",
    "                            f1.append(ref1)\n",
    "        if flag==False:\n",
    "            with open('wice+0.9/dataset_0.9.jsonl') as file1:  \n",
    "                for line1 in file1:\n",
    "                    data1 = json.loads(line1)\n",
    "                    q = data1[0]['messages'][0]['content']\n",
    "                    ref1 = q.split('Reference:')[-1]\n",
    "                    sub=ref1.strip().split('\\\"')\n",
    "                    sub1=p1.strip()[:-1].split('\\\\\\\"')\n",
    "                    if len(sub)>2 and len(sub1)>2 and sub[-2]==sub1[-2]:\n",
    "                        flag = True\n",
    "                        n+=1\n",
    "                        label=data1[0]['label']\n",
    "                        if label == 'true': # hallucination\n",
    "                            if \"here are no conflicting parts\" in answer: # factual\n",
    "                                t+=1\n",
    "                            else:\n",
    "                                t1.append(ref1)\n",
    "                        else:# factual\n",
    "                            if \"here are no conflicting parts\" in answer: # factual\n",
    "                                f+=1\n",
    "                            else:\n",
    "                                f1.append(ref1)\n",
    "                        \n",
    "                    if flag==False:\n",
    "                        if len(sub)>2 and len(sub1)>2 and len(sub1[-2].split('\\\\u'))>1:\n",
    "                            uni=sub1[-2].split('\\\\u')[-1][4:]\n",
    "                            length=len(uni)\n",
    "                            if sub[-2].strip()[-length:] == uni:\n",
    "                                flag = True\n",
    "                                n+=1\n",
    "                                label=data1[0]['label']\n",
    "                                if label == 'true': # hallucination\n",
    "                                    if \"here are no conflicting parts\" in answer: # factual\n",
    "                                        t+=1\n",
    "                                    else:\n",
    "                                        t1.append(ref1)\n",
    "                                else:# factual\n",
    "                                    if \"here are no conflicting parts\" in answer: # factual\n",
    "                                        f+=1\n",
    "                                    else:\n",
    "                                        f1.append(ref1)\n",
    "                               \n",
    "                    if flag==False:\n",
    "                        uni=p1.strip()[:-1].split('\\\\u')[-1][4:]\n",
    "                        length=len(uni)\n",
    "                        if ref1.strip()[-length:] == uni:\n",
    "                            flag = True\n",
    "                            n+=1\n",
    "                            label=data1[0]['label']\n",
    "                            if label == 'true': # hallucination\n",
    "                                if \"here are no conflicting parts\" in answer: # factual\n",
    "                                    t+=1\n",
    "                                else:\n",
    "                                    t1.append(ref1)\n",
    "                            else:# factual\n",
    "                                if \"here are no conflicting parts\" in answer: # factual\n",
    "                                    f+=1\n",
    "                                else:\n",
    "                                    f1.append(ref1)\n",
    "                            \n",
    "        if flag==False:\n",
    "            print(p1)\n",
    "print(num-t,(num-t)/num)\n",
    "print(f,f/num)\n",
    "print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "274a2925",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "39 0.1553784860557769\n",
      "224 0.8924302788844621\n",
      "matched num= 502\n"
     ]
    }
   ],
   "source": [
    "t=0\n",
    "f=0\n",
    "t11=[]\n",
    "f11=[]\n",
    "n=0\n",
    "with open('wice+0.9/detections_1_1.jsonl') as file:\n",
    "    for line in file:\n",
    "        data = json.loads(line)\n",
    "        answer = data[1]['choices'][0]['message']['content']\n",
    "        question = data[0]['messages'][0]['content']\n",
    "        p1 = question.split('P1: \\\"')[1].split('P2: ')[0]\n",
    "        flag = False\n",
    "        pre=n\n",
    "        with open('wice+0.9/dataset_0.9.jsonl') as file1:  \n",
    "            for line1 in file1:\n",
    "                data1 = json.loads(line1)\n",
    "                q = data1[0]['messages'][0]['content']\n",
    "                ref1 = q.split('Reference:')[-1]\n",
    "                # \n",
    "                sentences1=ref1.strip().split('.')\n",
    "                sentences2=p1.strip()[:-1].split('.')\n",
    "                if ref1.strip()==p1.strip()[:-1] or len(sentences1)>1 and len(sentences2)>1 and sentences1[-2] == sentences2[-2]:\n",
    "                    flag = True\n",
    "                    n+=1\n",
    "                    label=data1[0]['label']\n",
    "                    if label == 'true': # hallucination\n",
    "                        if \"here are no conflicting parts\" in answer: # factual\n",
    "                            t+=1\n",
    "                        else:\n",
    "                            t11.append(ref1)\n",
    "                    else:# factual\n",
    "                        if \"here are no conflicting parts\" in answer: # factual\n",
    "                            f+=1\n",
    "                        else:\n",
    "                            f11.append(ref1)\n",
    "        if flag==False:\n",
    "            with open('wice+0.9/dataset_0.9.jsonl') as file1:  \n",
    "                for line1 in file1:\n",
    "                    data1 = json.loads(line1)\n",
    "                    q = data1[0]['messages'][0]['content']\n",
    "                    ref1 = q.split('Reference:')[-1]\n",
    "                    sub=ref1.strip().split('\\\"')\n",
    "                    sub1=p1.strip()[:-1].split('\\\\\\\"')\n",
    "                    if len(sub)>2 and len(sub1)>2 and sub[-2]==sub1[-2]:\n",
    "                        flag = True\n",
    "                        n+=1\n",
    "                        label=data1[0]['label']\n",
    "                        if label == 'true': # hallucination\n",
    "                            if \"here are no conflicting parts\" in answer: # factual\n",
    "                                t+=1\n",
    "                            else:\n",
    "                                t11.append(ref1)\n",
    "                        else:# factual\n",
    "                            if \"here are no conflicting parts\" in answer: # factual\n",
    "                                f+=1\n",
    "                            else:\n",
    "                                f11.append(ref1)\n",
    "                    if flag==False:\n",
    "                        if len(sub)>2 and len(sub1)>2 and len(sub1[-2].split('\\\\u'))>1:\n",
    "                            uni=sub1[-2].split('\\\\u')[-1][4:]\n",
    "                            length=len(uni)\n",
    "                            if sub[-2].strip()[-length:] == uni:\n",
    "                                flag = True\n",
    "                                n+=1\n",
    "                                label=data1[0]['label']\n",
    "                                if label == 'true': # hallucination\n",
    "                                    if \"here are no conflicting parts\" in answer: # factual\n",
    "                                        t+=1\n",
    "                                    else:\n",
    "                                        t11.append(ref1)\n",
    "                                else:# factual\n",
    "                                    if \"here are no conflicting parts\" in answer: # factual\n",
    "                                        f+=1\n",
    "                                    else:\n",
    "                                        f11.append(ref1)\n",
    "                    if flag==False:\n",
    "                        uni=p1.strip()[:-1].split('\\\\u')[-1][4:]\n",
    "                        length=len(uni)\n",
    "                        if ref1.strip()[-length:] == uni:\n",
    "                            flag = True\n",
    "                            n+=1\n",
    "                            label=data1[0]['label']\n",
    "                            if label == 'true': # hallucination\n",
    "                                if \"here are no conflicting parts\" in answer: # factual\n",
    "                                    t+=1\n",
    "                                else:\n",
    "                                    t11.append(ref1)\n",
    "                            else:# factual\n",
    "                                if \"here are no conflicting parts\" in answer: # factual\n",
    "                                    f+=1\n",
    "                                else:\n",
    "                                    f11.append(ref1)\n",
    "print(num-t,(num-t)/num)\n",
    "print(f,f/num)\n",
    "print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "ec409093",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "75 0.29880478087649404\n",
      "206 0.8207171314741036\n",
      "matched num= 502\n"
     ]
    }
   ],
   "source": [
    "t=0\n",
    "f=0\n",
    "t2=[]\n",
    "f2=[]\n",
    "n=0\n",
    "with open('wice+0.9/combine/detections_2_2.jsonl') as file:\n",
    "    for line in file:\n",
    "        data = json.loads(line)\n",
    "        answer = data[1]['choices'][0]['message']['content']\n",
    "        question = data[0]['messages'][0]['content']\n",
    "        p1 = question.split('P1: \\\"')[1].split('P2: ')[0]\n",
    "        flag = False\n",
    "        pre=n\n",
    "        with open('wice+0.9/dataset_0.9.jsonl') as file1:  \n",
    "            for line1 in file1:\n",
    "                data1 = json.loads(line1)\n",
    "                q = data1[0]['messages'][0]['content']\n",
    "                ref1 = q.split('Reference:')[-1]\n",
    "                # \n",
    "                sentences1=ref1.strip().split('.')\n",
    "                sentences2=p1.strip()[:-1].split('.')\n",
    "                if ref1.strip()==p1.strip()[:-1] or len(sentences1)>1 and len(sentences2)>1 and sentences1[-2] == sentences2[-2]:\n",
    "                    flag = True\n",
    "                    n+=1\n",
    "                    label=data1[0]['label']\n",
    "                    if label == 'true': # hallucination\n",
    "                        if \"here are no conflicting parts\" in answer: # factual\n",
    "                            t+=1\n",
    "                        else:\n",
    "                            t2.append(ref1)\n",
    "                    else:# factual\n",
    "                        if \"here are no conflicting parts\" in answer: # factual\n",
    "                            f+=1\n",
    "                        else:\n",
    "                            f2.append(ref1)\n",
    "                    \n",
    "        if flag==False:\n",
    "            with open('wice+0.9/dataset_0.9.jsonl') as file1:  \n",
    "                for line1 in file1:\n",
    "                    data1 = json.loads(line1)\n",
    "                    q = data1[0]['messages'][0]['content']\n",
    "                    ref1 = q.split('Reference:')[-1]\n",
    "                    sub=ref1.strip().split('\\\"')\n",
    "                    sub1=p1.strip()[:-1].split('\\\\\\\"')\n",
    "                    if len(sub)>2 and len(sub1)>2 and sub[-2]==sub1[-2]:\n",
    "                        flag = True\n",
    "                        n+=1\n",
    "                        label=data1[0]['label']\n",
    "                        if label == 'true': # hallucination\n",
    "                            if \"here are no conflicting parts\" in answer: # factual\n",
    "                                t+=1\n",
    "                            else:\n",
    "                                t2.append(ref1)\n",
    "                        else:# factual\n",
    "                            if \"here are no conflicting parts\" in answer: # factual\n",
    "                                f+=1\n",
    "                            else:\n",
    "                                f2.append(ref1)\n",
    "                        \n",
    "                    if flag==False:\n",
    "                        if len(sub)>2 and len(sub1)>2 and len(sub1[-2].split('\\\\u'))>1:\n",
    "                            uni=sub1[-2].split('\\\\u')[-1][4:]\n",
    "                            length=len(uni)\n",
    "                            if sub[-2].strip()[-length:] == uni:\n",
    "                                flag = True\n",
    "                                n+=1\n",
    "                                label=data1[0]['label']\n",
    "                                if label == 'true': # hallucination\n",
    "                                    if \"here are no conflicting parts\" in answer: # factual\n",
    "                                        t+=1\n",
    "                                    else:\n",
    "                                        t2.append(ref1)\n",
    "                                else:# factual\n",
    "                                    if \"here are no conflicting parts\" in answer: # factual\n",
    "                                        f+=1\n",
    "                                    else:\n",
    "                                        f2.append(ref1)\n",
    "                               \n",
    "                    if flag==False:\n",
    "                        uni=p1.strip()[:-1].split('\\\\u')[-1][4:]\n",
    "                        length=len(uni)\n",
    "                        if ref1.strip()[-length:] == uni:\n",
    "                            flag = True\n",
    "                            n+=1\n",
    "                            label=data1[0]['label']\n",
    "                            if label == 'true': # hallucination\n",
    "                                if \"here are no conflicting parts\" in answer: # factual\n",
    "                                    t+=1\n",
    "                                else:\n",
    "                                    t2.append(ref1)\n",
    "                            else:# factual\n",
    "                                if \"here are no conflicting parts\" in answer: # factual\n",
    "                                    f+=1\n",
    "                                else:\n",
    "                                    f2.append(ref1)\n",
    "                            \n",
    "        if n-pre!=1:\n",
    "            print(p1)\n",
    "print(num-t,(num-t)/num)\n",
    "print(f,f/num)\n",
    "print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "646dd100",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "41 0.16334661354581673\n",
      "214 0.852589641434263\n",
      "matched num= 502\n"
     ]
    }
   ],
   "source": [
    "t=0\n",
    "f=0\n",
    "t22=[]\n",
    "f22=[]\n",
    "n=0\n",
    "with open('wice+0.9/detections_2_1.jsonl') as file:\n",
    "    for line in file:\n",
    "        data = json.loads(line)\n",
    "        answer = data[1]['choices'][0]['message']['content']\n",
    "        question = data[0]['messages'][0]['content']\n",
    "        p1 = question.split('P1: \\\"')[1].split('P2: ')[0]\n",
    "        flag = False\n",
    "        pre=n\n",
    "        with open('wice+0.9/dataset_0.9.jsonl') as file1:  \n",
    "            for line1 in file1:\n",
    "                data1 = json.loads(line1)\n",
    "                q = data1[0]['messages'][0]['content']\n",
    "                ref1 = q.split('Reference:')[-1]\n",
    "                # \n",
    "                sentences1=ref1.strip().split('.')\n",
    "                sentences2=p1.strip()[:-1].split('.')\n",
    "                if ref1.strip()==p1.strip()[:-1] or len(sentences1)>1 and len(sentences2)>1 and sentences1[-2] == sentences2[-2]:\n",
    "                    flag = True\n",
    "                    n+=1\n",
    "                    label=data1[0]['label']\n",
    "                    if label == 'true': # hallucination\n",
    "                        if \"here are no conflicting parts\" in answer: # factual\n",
    "                            t+=1\n",
    "                        else:\n",
    "                            t22.append(ref1)\n",
    "                    else:# factual\n",
    "                        if \"here are no conflicting parts\" in answer: # factual\n",
    "                            f+=1\n",
    "                        else:\n",
    "                            f22.append(ref1)\n",
    "                    break\n",
    "        if flag==False:\n",
    "            with open('wice+0.9/dataset_0.9.jsonl') as file1:  \n",
    "                for line1 in file1:\n",
    "                    data1 = json.loads(line1)\n",
    "                    q = data1[0]['messages'][0]['content']\n",
    "                    ref1 = q.split('Reference:')[-1]\n",
    "                    sub=ref1.strip().split('\\\"')\n",
    "                    sub1=p1.strip()[:-1].split('\\\\\\\"')\n",
    "                    if len(sub)>2 and len(sub1)>2 and sub[-2]==sub1[-2]:\n",
    "                        flag = True\n",
    "                        n+=1\n",
    "                        label=data1[0]['label']\n",
    "                        if label == 'true': # hallucination\n",
    "                            if \"here are no conflicting parts\" in answer: # factual\n",
    "                                t+=1\n",
    "                            else:\n",
    "                                t22.append(ref1)\n",
    "                        else:# factual\n",
    "                            if \"here are no conflicting parts\" in answer: # factual\n",
    "                                f+=1\n",
    "                            else:\n",
    "                                f22.append(ref1)\n",
    "                        break\n",
    "                    if flag==False:\n",
    "                        if len(sub)>2 and len(sub1)>2 and len(sub1[-2].split('\\\\u'))>1:\n",
    "                            uni=sub1[-2].split('\\\\u')[-1][4:]\n",
    "                            length=len(uni)\n",
    "                            if sub[-2].strip()[-length:] == uni:\n",
    "                                flag = True\n",
    "                                n+=1\n",
    "                                label=data1[0]['label']\n",
    "                                if label == 'true': # hallucination\n",
    "                                    if \"here are no conflicting parts\" in answer: # factual\n",
    "                                        t+=1\n",
    "                                    else:\n",
    "                                        t22.append(ref1)\n",
    "                                else:# factual\n",
    "                                    if \"here are no conflicting parts\" in answer: # factual\n",
    "                                        f+=1\n",
    "                                    else:\n",
    "                                        f22.append(ref1)\n",
    "                    if flag==False:\n",
    "                        uni=p1.strip()[:-1].split('\\\\u')[-1][4:]\n",
    "                        length=len(uni)\n",
    "                        if ref1.strip()[-length:] == uni:\n",
    "                            flag = True\n",
    "                            n+=1\n",
    "                            label=data1[0]['label']\n",
    "                            if label == 'true': # hallucination\n",
    "                                if \"here are no conflicting parts\" in answer: # factual\n",
    "                                    t+=1\n",
    "                                else:\n",
    "                                    t22.append(ref1)\n",
    "                            else:# factual\n",
    "                                if \"here are no conflicting parts\" in answer: # factual\n",
    "                                    f+=1\n",
    "                                else:\n",
    "                                    f22.append(ref1)\n",
    "print(num-t,(num-t)/num)\n",
    "print(f,f/num)\n",
    "print('matched num=',n)\n",
    "t222=t22\n",
    "f222=f22"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "9991913e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "71 0.28286852589641437\n",
      "196 0.7808764940239044\n",
      "matched num= 502\n"
     ]
    }
   ],
   "source": [
    "t=0\n",
    "f=0\n",
    "t3=[]\n",
    "f3=[]\n",
    "n=0\n",
    "with open('wice+0.9/detections_3.jsonl') as file:\n",
    "    for line in file:\n",
    "        data = json.loads(line)\n",
    "        answer = data[1]['choices'][0]['message']['content']\n",
    "        question = data[0]['messages'][0]['content']\n",
    "        p1 = question.split('P1: \\\"')[1].split('P2: ')[0]\n",
    "        flag = False\n",
    "        pre=n\n",
    "        with open('wice+0.9/dataset_0.9.jsonl') as file1:  \n",
    "            for line1 in file1:\n",
    "                data1 = json.loads(line1)\n",
    "                q = data1[0]['messages'][0]['content']\n",
    "                ref1 = q.split('Reference:')[-1]\n",
    "                # \n",
    "                sentences1=ref1.strip().split('.')\n",
    "                sentences2=p1.strip()[:-1].split('.')\n",
    "                if ref1.strip()==p1.strip()[:-1] or len(sentences1)>1 and len(sentences2)>1 and sentences1[-2] == sentences2[-2]:\n",
    "                    flag = True\n",
    "                    n+=1\n",
    "                    label=data1[0]['label']\n",
    "                    if label == 'true': # hallucination\n",
    "                        if \"here are no conflicting parts\" in answer: # factual\n",
    "                            t+=1\n",
    "                        else:\n",
    "                            t3.append(ref1)\n",
    "                    else:# factual\n",
    "                        if \"here are no conflicting parts\" in answer: # factual\n",
    "                            f+=1\n",
    "                        else:\n",
    "                            f3.append(ref1)\n",
    "                    \n",
    "        if flag==False:\n",
    "            with open('wice+0.9/dataset_0.9.jsonl') as file1:  \n",
    "                for line1 in file1:\n",
    "                    data1 = json.loads(line1)\n",
    "                    q = data1[0]['messages'][0]['content']\n",
    "                    ref1 = q.split('Reference:')[-1]\n",
    "                    sub=ref1.strip().split('\\\"')\n",
    "                    sub1=p1.strip()[:-1].split('\\\\\\\"')\n",
    "                    if len(sub)>2 and len(sub1)>2 and sub[-2]==sub1[-2]:\n",
    "                        flag = True\n",
    "                        n+=1\n",
    "                        label=data1[0]['label']\n",
    "                        if label == 'true': # hallucination\n",
    "                            if \"here are no conflicting parts\" in answer: # factual\n",
    "                                t+=1\n",
    "                            else:\n",
    "                                t3.append(ref1)\n",
    "                        else:# factual\n",
    "                            if \"here are no conflicting parts\" in answer: # factual\n",
    "                                f+=1\n",
    "                            else:\n",
    "                                f3.append(ref1)\n",
    "                        \n",
    "                    if flag==False:\n",
    "                        if len(sub)>2 and len(sub1)>2 and len(sub1[-2].split('\\\\u'))>1:\n",
    "                            uni=sub1[-2].split('\\\\u')[-1][4:]\n",
    "                            length=len(uni)\n",
    "                            if sub[-2].strip()[-length:] == uni:\n",
    "                                flag = True\n",
    "                                n+=1\n",
    "                                label=data1[0]['label']\n",
    "                                if label == 'true': # hallucination\n",
    "                                    if \"here are no conflicting parts\" in answer: # factual\n",
    "                                        t+=1\n",
    "                                    else:\n",
    "                                        t3.append(ref1)\n",
    "                                else:# factual\n",
    "                                    if \"here are no conflicting parts\" in answer: # factual\n",
    "                                        f+=1\n",
    "                                    else:\n",
    "                                        f3.append(ref1)\n",
    "                               \n",
    "                    if flag==False:\n",
    "                        uni=p1.strip()[:-1].split('\\\\u')[-1][4:]\n",
    "                        length=len(uni)\n",
    "                        if ref1.strip()[-length:] == uni:\n",
    "                            flag = True\n",
    "                            n+=1\n",
    "                            label=data1[0]['label']\n",
    "                            if label == 'true': # hallucination\n",
    "                                if \"here are no conflicting parts\" in answer: # factual\n",
    "                                    t+=1\n",
    "                                else:\n",
    "                                    t3.append(ref1)\n",
    "                            else:# factual\n",
    "                                if \"here are no conflicting parts\" in answer: # factual\n",
    "                                    f+=1\n",
    "                                else:\n",
    "                                    f3.append(ref1)\n",
    "                            \n",
    "        if n-pre!=1:\n",
    "            print(p1)\n",
    "print(num-t,(num-t)/num)\n",
    "print(f,f/num)\n",
    "print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "86354883",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "74 0.2948207171314741\n",
      "229 0.9123505976095617\n",
      "matched num= 502\n"
     ]
    }
   ],
   "source": [
    "t=0\n",
    "f=0\n",
    "t33=[]\n",
    "f33=[]\n",
    "n=0\n",
    "with open('wice+0.9/combine/detections_3_3.jsonl') as file:\n",
    "    for line in file:\n",
    "        data = json.loads(line)\n",
    "        answer = data[1]['choices'][0]['message']['content']\n",
    "        question = data[0]['messages'][0]['content']\n",
    "        p1 = question.split('P1: \\\"')[1].split('P2: ')[0]\n",
    "        flag = False\n",
    "        pre=n\n",
    "        with open('wice+0.9/dataset_0.9.jsonl') as file1:  \n",
    "            for line1 in file1:\n",
    "                data1 = json.loads(line1)\n",
    "                q = data1[0]['messages'][0]['content']\n",
    "                ref1 = q.split('Reference:')[-1]\n",
    "                # \n",
    "                sentences1=ref1.strip().split('.')\n",
    "                sentences2=p1.strip()[:-1].split('.')\n",
    "                if ref1.strip()==p1.strip()[:-1] or len(sentences1)>1 and len(sentences2)>1 and sentences1[-2] == sentences2[-2]:\n",
    "                    flag = True\n",
    "                    n+=1\n",
    "                    label=data1[0]['label']\n",
    "                    if label == 'true': # hallucination\n",
    "                        if \"here are no conflicting parts\" in answer: # factual\n",
    "                            t+=1\n",
    "                        else:\n",
    "                            t33.append(ref1)\n",
    "                    else:# factual\n",
    "                        if \"here are no conflicting parts\" in answer: # factual\n",
    "                            f+=1\n",
    "                        else:\n",
    "                            f33.append(ref1)\n",
    "                    break\n",
    "        if flag==False:\n",
    "            with open('wice+0.9/dataset_0.9.jsonl') as file1:  \n",
    "                for line1 in file1:\n",
    "                    data1 = json.loads(line1)\n",
    "                    q = data1[0]['messages'][0]['content']\n",
    "                    ref1 = q.split('Reference:')[-1]\n",
    "                    sub=ref1.strip().split('\\\"')\n",
    "                    sub1=p1.strip()[:-1].split('\\\\\\\"')\n",
    "                    if len(sub)>2 and len(sub1)>2 and sub[-2]==sub1[-2]:\n",
    "                        flag = True\n",
    "                        n+=1\n",
    "                        label=data1[0]['label']\n",
    "                        if label == 'true': # hallucination\n",
    "                            if \"here are no conflicting parts\" in answer: # factual\n",
    "                                t+=1\n",
    "                            else:\n",
    "                                t33.append(ref1)\n",
    "                        else:# factual\n",
    "                            if \"here are no conflicting parts\" in answer: # factual\n",
    "                                f+=1\n",
    "                            else:\n",
    "                                f33.append(ref1)\n",
    "                        break\n",
    "                    if flag==False:\n",
    "                        if len(sub)>2 and len(sub1)>2 and len(sub1[-2].split('\\\\u'))>1:\n",
    "                            uni=sub1[-2].split('\\\\u')[-1][4:]\n",
    "                            length=len(uni)\n",
    "                            if sub[-2].strip()[-length:] == uni:\n",
    "                                flag = True\n",
    "                                n+=1\n",
    "                                label=data1[0]['label']\n",
    "                                if label == 'true': # hallucination\n",
    "                                    if \"here are no conflicting parts\" in answer: # factual\n",
    "                                        t+=1\n",
    "                                    else:\n",
    "                                        t33.append(ref1)\n",
    "                                else:# factual\n",
    "                                    if \"here are no conflicting parts\" in answer: # factual\n",
    "                                        f+=1\n",
    "                                    else:\n",
    "                                        f33.append(ref1)\n",
    "                    if flag==False:\n",
    "                        uni=p1.strip()[:-1].split('\\\\u')[-1][4:]\n",
    "                        length=len(uni)\n",
    "                        if ref1.strip()[-length:] == uni:\n",
    "                            flag = True\n",
    "                            n+=1\n",
    "                            label=data1[0]['label']\n",
    "                            if label == 'true': # hallucination\n",
    "                                if \"here are no conflicting parts\" in answer: # factual\n",
    "                                    t+=1\n",
    "                                else:\n",
    "                                    t33.append(ref1)\n",
    "                            else:# factual\n",
    "                                if \"here are no conflicting parts\" in answer: # factual\n",
    "                                    f+=1\n",
    "                                else:\n",
    "                                    f33.append(ref1)\n",
    "print(num-t,(num-t)/num)\n",
    "print(f,f/num)\n",
    "print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "5eb68ae2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "38 0.15139442231075698\n",
      "212 0.8446215139442231\n",
      "matched num= 502\n"
     ]
    }
   ],
   "source": [
    "t=0\n",
    "f=0\n",
    "t4=[]\n",
    "f4=[]\n",
    "n=0\n",
    "with open('wice+0.9/detections_4.jsonl') as file:\n",
    "    for line in file:\n",
    "        data = json.loads(line)\n",
    "        answer = data[1]['choices'][0]['message']['content']\n",
    "        question = data[0]['messages'][0]['content']\n",
    "        p1 = question.split('P1: \\\"')[1].split('P2: ')[0]\n",
    "        flag = False\n",
    "        pre=n\n",
    "        with open('wice+0.9/dataset_0.9.jsonl') as file1:  \n",
    "            for line1 in file1:\n",
    "                data1 = json.loads(line1)\n",
    "                q = data1[0]['messages'][0]['content']\n",
    "                ref1 = q.split('Reference:')[-1]\n",
    "                # \n",
    "                sentences1=ref1.strip().split('.')\n",
    "                sentences2=p1.strip()[:-1].split('.')\n",
    "                if ref1.strip()==p1.strip()[:-1] or len(sentences1)>1 and len(sentences2)>1 and sentences1[-2] == sentences2[-2]:\n",
    "                    flag = True\n",
    "                    n+=1\n",
    "                    label=data1[0]['label']\n",
    "                    if label == 'true': # hallucination\n",
    "                        if \"here are no conflicting parts\" in answer: # factual\n",
    "                            t+=1\n",
    "                        else:\n",
    "                            t4.append(ref1)\n",
    "                    else:# factual\n",
    "                        if \"here are no conflicting parts\" in answer: # factual\n",
    "                            f+=1\n",
    "                        else:\n",
    "                            f4.append(ref1)\n",
    "                    \n",
    "        if flag==False:\n",
    "            with open('wice+0.9/dataset_0.9.jsonl') as file1:  \n",
    "                for line1 in file1:\n",
    "                    data1 = json.loads(line1)\n",
    "                    q = data1[0]['messages'][0]['content']\n",
    "                    ref1 = q.split('Reference:')[-1]\n",
    "                    sub=ref1.strip().split('\\\"')\n",
    "                    sub1=p1.strip()[:-1].split('\\\\\\\"')\n",
    "                    if len(sub)>2 and len(sub1)>2 and sub[-2]==sub1[-2]:\n",
    "                        flag = True\n",
    "                        n+=1\n",
    "                        label=data1[0]['label']\n",
    "                        if label == 'true': # hallucination\n",
    "                            if \"here are no conflicting parts\" in answer: # factual\n",
    "                                t+=1\n",
    "                            else:\n",
    "                                t4.append(ref1)\n",
    "                        else:# factual\n",
    "                            if \"here are no conflicting parts\" in answer: # factual\n",
    "                                f+=1\n",
    "                            else:\n",
    "                                f4.append(ref1)\n",
    "                        \n",
    "                    if flag==False:\n",
    "                        if len(sub)>2 and len(sub1)>2 and len(sub1[-2].split('\\\\u'))>1:\n",
    "                            uni=sub1[-2].split('\\\\u')[-1][4:]\n",
    "                            length=len(uni)\n",
    "                            if sub[-2].strip()[-length:] == uni:\n",
    "                                flag = True\n",
    "                                n+=1\n",
    "                                label=data1[0]['label']\n",
    "                                if label == 'true': # hallucination\n",
    "                                    if \"here are no conflicting parts\" in answer: # factual\n",
    "                                        t+=1\n",
    "                                    else:\n",
    "                                        t4.append(ref1)\n",
    "                                else:# factual\n",
    "                                    if \"here are no conflicting parts\" in answer: # factual\n",
    "                                        f+=1\n",
    "                                    else:\n",
    "                                        f4.append(ref1)\n",
    "                               \n",
    "                    if flag==False:\n",
    "                        uni=p1.strip()[:-1].split('\\\\u')[-1][4:]\n",
    "                        length=len(uni)\n",
    "                        if ref1.strip()[-length:] == uni:\n",
    "                            flag = True\n",
    "                            n+=1\n",
    "                            label=data1[0]['label']\n",
    "                            if label == 'true': # hallucination\n",
    "                                if \"here are no conflicting parts\" in answer: # factual\n",
    "                                    t+=1\n",
    "                                else:\n",
    "                                    t4.append(ref1)\n",
    "                            else:# factual\n",
    "                                if \"here are no conflicting parts\" in answer: # factual\n",
    "                                    f+=1\n",
    "                                else:\n",
    "                                    f4.append(ref1)\n",
    "                            \n",
    "        if n-pre!=1:\n",
    "            print(p1)\n",
    "print(num-t,(num-t)/num)\n",
    "print(f,f/num)\n",
    "print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "1679335b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "44 0.1752988047808765\n",
      "210 0.8366533864541833\n",
      "matched num= 502\n"
     ]
    }
   ],
   "source": [
    "t=0\n",
    "f=0\n",
    "t44=[]\n",
    "f44=[]\n",
    "n=0\n",
    "with open('wice+0.9/detections_4_1.jsonl') as file:\n",
    "    for line in file:\n",
    "        data = json.loads(line)\n",
    "        answer = data[1]['choices'][0]['message']['content']\n",
    "        question = data[0]['messages'][0]['content']\n",
    "        p1 = question.split('P1: \\\"')[1].split('P2: ')[0]\n",
    "        flag = False\n",
    "        pre=n\n",
    "        with open('wice+0.9/dataset_0.9.jsonl') as file1:  \n",
    "            for line1 in file1:\n",
    "                data1 = json.loads(line1)\n",
    "                q = data1[0]['messages'][0]['content']\n",
    "                ref1 = q.split('Reference:')[-1]\n",
    "                # \n",
    "                sentences1=ref1.strip().split('.')\n",
    "                sentences2=p1.strip()[:-1].split('.')\n",
    "                if ref1.strip()==p1.strip()[:-1] or len(sentences1)>1 and len(sentences2)>1 and sentences1[-2] == sentences2[-2]:\n",
    "                    flag = True\n",
    "                    n+=1\n",
    "                    label=data1[0]['label']\n",
    "                    if label == 'true': # hallucination\n",
    "                        if \"here are no conflicting parts\" in answer: # factual\n",
    "                            t+=1\n",
    "                        else:\n",
    "                            t44.append(ref1)\n",
    "                    else:# factual\n",
    "                        if \"here are no conflicting parts\" in answer: # factual\n",
    "                            f+=1\n",
    "                        else:\n",
    "                            f44.append(ref1)\n",
    "                    break\n",
    "        if flag==False:\n",
    "            with open('wice+0.9/dataset_0.9.jsonl') as file1:  \n",
    "                for line1 in file1:\n",
    "                    data1 = json.loads(line1)\n",
    "                    q = data1[0]['messages'][0]['content']\n",
    "                    ref1 = q.split('Reference:')[-1]\n",
    "                    sub=ref1.strip().split('\\\"')\n",
    "                    sub1=p1.strip()[:-1].split('\\\\\\\"')\n",
    "                    if len(sub)>2 and len(sub1)>2 and sub[-2]==sub1[-2]:\n",
    "                        flag = True\n",
    "                        n+=1\n",
    "                        label=data1[0]['label']\n",
    "                        if label == 'true': # hallucination\n",
    "                            if \"here are no conflicting parts\" in answer: # factual\n",
    "                                t+=1\n",
    "                            else:\n",
    "                                t44.append(ref1)\n",
    "                        else:# factual\n",
    "                            if \"here are no conflicting parts\" in answer: # factual\n",
    "                                f+=1\n",
    "                            else:\n",
    "                                f44.append(ref1)\n",
    "                        break\n",
    "                    if flag==False:\n",
    "                        if len(sub)>2 and len(sub1)>2 and len(sub1[-2].split('\\\\u'))>1:\n",
    "                            uni=sub1[-2].split('\\\\u')[-1][4:]\n",
    "                            length=len(uni)\n",
    "                            if sub[-2].strip()[-length:] == uni:\n",
    "                                flag = True\n",
    "                                n+=1\n",
    "                                label=data1[0]['label']\n",
    "                                if label == 'true': # hallucination\n",
    "                                    if \"here are no conflicting parts\" in answer: # factual\n",
    "                                        t+=1\n",
    "                                    else:\n",
    "                                        t44.append(ref1)\n",
    "                                else:# factual\n",
    "                                    if \"here are no conflicting parts\" in answer: # factual\n",
    "                                        f+=1\n",
    "                                    else:\n",
    "                                        f44.append(ref1)\n",
    "                    if flag==False:\n",
    "                        uni=p1.strip()[:-1].split('\\\\u')[-1][4:]\n",
    "                        length=len(uni)\n",
    "                        if ref1.strip()[-length:] == uni:\n",
    "                            flag = True\n",
    "                            n+=1\n",
    "                            label=data1[0]['label']\n",
    "                            if label == 'true': # hallucination\n",
    "                                if \"here are no conflicting parts\" in answer: # factual\n",
    "                                    t+=1\n",
    "                                else:\n",
    "                                    t44.append(ref1)\n",
    "                            else:# factual\n",
    "                                if \"here are no conflicting parts\" in answer: # factual\n",
    "                                    f+=1\n",
    "                                else:\n",
    "                                    f44.append(ref1)\n",
    "print(num-t,(num-t)/num)\n",
    "print(f,f/num)\n",
    "print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "370e92ca",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "40 0.1593625498007968\n",
      "229 0.9123505976095617\n",
      "matched num= 502\n"
     ]
    }
   ],
   "source": [
    "t=0\n",
    "f=0\n",
    "t5=[]\n",
    "f5=[]\n",
    "n=0\n",
    "with open('wice+0.9/detections_5.jsonl') as file:\n",
    "    for line in file:\n",
    "        data = json.loads(line)\n",
    "        answer = data[1]['choices'][0]['message']['content']\n",
    "        question = data[0]['messages'][0]['content']\n",
    "        p1 = question.split('P1: \\\"')[1].split('P2: ')[0]\n",
    "        flag = False\n",
    "        pre=n\n",
    "        with open('wice+0.9/dataset_0.9.jsonl') as file1:  \n",
    "            for line1 in file1:\n",
    "                data1 = json.loads(line1)\n",
    "                q = data1[0]['messages'][0]['content']\n",
    "                ref1 = q.split('Reference:')[-1]\n",
    "                # \n",
    "                sentences1=ref1.strip().split('.')\n",
    "                sentences2=p1.strip()[:-1].split('.')\n",
    "                if ref1.strip()==p1.strip()[:-1] or len(sentences1)>1 and len(sentences2)>1 and sentences1[-2] == sentences2[-2]:\n",
    "                    flag = True\n",
    "                    n+=1\n",
    "                    label=data1[0]['label']\n",
    "                    if label == 'true': # hallucination\n",
    "                        if \"here are no conflicting parts\" in answer: # factual\n",
    "                            t+=1\n",
    "                        else:\n",
    "                            t5.append(ref1)\n",
    "                    else:# factual\n",
    "                        if \"here are no conflicting parts\" in answer: # factual\n",
    "                            f+=1\n",
    "                        else:\n",
    "                            f5.append(ref1)\n",
    "                    \n",
    "        if flag==False:\n",
    "            with open('wice+0.9/dataset_0.9.jsonl') as file1:  \n",
    "                for line1 in file1:\n",
    "                    data1 = json.loads(line1)\n",
    "                    q = data1[0]['messages'][0]['content']\n",
    "                    ref1 = q.split('Reference:')[-1]\n",
    "                    sub=ref1.strip().split('\\\"')\n",
    "                    sub1=p1.strip()[:-1].split('\\\\\\\"')\n",
    "                    if len(sub)>2 and len(sub1)>2 and sub[-2]==sub1[-2]:\n",
    "                        flag = True\n",
    "                        n+=1\n",
    "                        label=data1[0]['label']\n",
    "                        if label == 'true': # hallucination\n",
    "                            if \"here are no conflicting parts\" in answer: # factual\n",
    "                                t+=1\n",
    "                            else:\n",
    "                                t5.append(ref1)\n",
    "                        else:# factual\n",
    "                            if \"here are no conflicting parts\" in answer: # factual\n",
    "                                f+=1\n",
    "                            else:\n",
    "                                f5.append(ref1)\n",
    "                        \n",
    "                    if flag==False:\n",
    "                        if len(sub)>2 and len(sub1)>2 and len(sub1[-2].split('\\\\u'))>1:\n",
    "                            uni=sub1[-2].split('\\\\u')[-1][4:]\n",
    "                            length=len(uni)\n",
    "                            if sub[-2].strip()[-length:] == uni:\n",
    "                                flag = True\n",
    "                                n+=1\n",
    "                                label=data1[0]['label']\n",
    "                                if label == 'true': # hallucination\n",
    "                                    if \"here are no conflicting parts\" in answer: # factual\n",
    "                                        t+=1\n",
    "                                    else:\n",
    "                                        t5.append(ref1)\n",
    "                                else:# factual\n",
    "                                    if \"here are no conflicting parts\" in answer: # factual\n",
    "                                        f+=1\n",
    "                                    else:\n",
    "                                        f5.append(ref1)\n",
    "                               \n",
    "                    if flag==False:\n",
    "                        uni=p1.strip()[:-1].split('\\\\u')[-1][4:]\n",
    "                        length=len(uni)\n",
    "                        if ref1.strip()[-length:] == uni:\n",
    "                            flag = True\n",
    "                            n+=1\n",
    "                            label=data1[0]['label']\n",
    "                            if label == 'true': # hallucination\n",
    "                                if \"here are no conflicting parts\" in answer: # factual\n",
    "                                    t+=1\n",
    "                                else:\n",
    "                                    t5.append(ref1)\n",
    "                            else:# factual\n",
    "                                if \"here are no conflicting parts\" in answer: # factual\n",
    "                                    f+=1\n",
    "                                else:\n",
    "                                    f5.append(ref1)\n",
    "                            \n",
    "        if n-pre!=1:\n",
    "            print(p1)\n",
    "print(num-t,(num-t)/num)\n",
    "print(f,f/num)\n",
    "print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "5f8386da",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "61 0.24302788844621515\n",
      "217 0.8645418326693227\n",
      "matched num= 502\n"
     ]
    }
   ],
   "source": [
    "t=0\n",
    "f=0\n",
    "t55=[]\n",
    "f55=[]\n",
    "n=0\n",
    "with open('wice+0.9/combine/detections_5_3.jsonl') as file:\n",
    "    for line in file:\n",
    "        data = json.loads(line)\n",
    "        answer = data[1]['choices'][0]['message']['content']\n",
    "        question = data[0]['messages'][0]['content']\n",
    "        p1 = question.split('P1: \\\"')[1].split('P2: ')[0]\n",
    "        flag = False\n",
    "        pre=n\n",
    "        with open('wice+0.9/dataset_0.9.jsonl') as file1:  \n",
    "            for line1 in file1:\n",
    "                data1 = json.loads(line1)\n",
    "                q = data1[0]['messages'][0]['content']\n",
    "                ref1 = q.split('Reference:')[-1]\n",
    "                # \n",
    "                sentences1=ref1.strip().split('.')\n",
    "                sentences2=p1.strip()[:-1].split('.')\n",
    "                if ref1.strip()==p1.strip()[:-1] or len(sentences1)>1 and len(sentences2)>1 and sentences1[-2] == sentences2[-2]:\n",
    "                    flag = True\n",
    "                    n+=1\n",
    "                    label=data1[0]['label']\n",
    "                    if label == 'true': # hallucination\n",
    "                        if \"here are no conflicting parts\" in answer: # factual\n",
    "                            t+=1\n",
    "                        else:\n",
    "                            t55.append(ref1)\n",
    "                    else:# factual\n",
    "                        if \"here are no conflicting parts\" in answer: # factual\n",
    "                            f+=1\n",
    "                        else:\n",
    "                            f55.append(ref1)\n",
    "                    break\n",
    "        if flag==False:\n",
    "            with open('wice+0.9/dataset_0.9.jsonl') as file1:  \n",
    "                for line1 in file1:\n",
    "                    data1 = json.loads(line1)\n",
    "                    q = data1[0]['messages'][0]['content']\n",
    "                    ref1 = q.split('Reference:')[-1]\n",
    "                    sub=ref1.strip().split('\\\"')\n",
    "                    sub1=p1.strip()[:-1].split('\\\\\\\"')\n",
    "                    if len(sub)>2 and len(sub1)>2 and sub[-2]==sub1[-2]:\n",
    "                        flag = True\n",
    "                        n+=1\n",
    "                        label=data1[0]['label']\n",
    "                        if label == 'true': # hallucination\n",
    "                            if \"here are no conflicting parts\" in answer: # factual\n",
    "                                t+=1\n",
    "                            else:\n",
    "                                t55.append(ref1)\n",
    "                        else:# factual\n",
    "                            if \"here are no conflicting parts\" in answer: # factual\n",
    "                                f+=1\n",
    "                            else:\n",
    "                                f55.append(ref1)\n",
    "                        break\n",
    "                    if flag==False:\n",
    "                        if len(sub)>2 and len(sub1)>2 and len(sub1[-2].split('\\\\u'))>1:\n",
    "                            uni=sub1[-2].split('\\\\u')[-1][4:]\n",
    "                            length=len(uni)\n",
    "                            if sub[-2].strip()[-length:] == uni:\n",
    "                                flag = True\n",
    "                                n+=1\n",
    "                                label=data1[0]['label']\n",
    "                                if label == 'true': # hallucination\n",
    "                                    if \"here are no conflicting parts\" in answer: # factual\n",
    "                                        t+=1\n",
    "                                    else:\n",
    "                                        t55.append(ref1)\n",
    "                                else:# factual\n",
    "                                    if \"here are no conflicting parts\" in answer: # factual\n",
    "                                        f+=1\n",
    "                                    else:\n",
    "                                        f55.append(ref1)\n",
    "                    if flag==False:\n",
    "                        uni=p1.strip()[:-1].split('\\\\u')[-1][4:]\n",
    "                        length=len(uni)\n",
    "                        if ref1.strip()[-length:] == uni:\n",
    "                            flag = True\n",
    "                            n+=1\n",
    "                            label=data1[0]['label']\n",
    "                            if label == 'true': # hallucination\n",
    "                                if \"here are no conflicting parts\" in answer: # factual\n",
    "                                    t+=1\n",
    "                                else:\n",
    "                                    t55.append(ref1)\n",
    "                            else:# factual\n",
    "                                if \"here are no conflicting parts\" in answer: # factual\n",
    "                                    f+=1\n",
    "                                else:\n",
    "                                    f55.append(ref1)\n",
    "print(num-t,(num-t)/num)\n",
    "print(f,f/num)\n",
    "print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "b299ec1c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "59 0.2350597609561753\n",
      "228 0.9083665338645418\n",
      "matched num= 502\n"
     ]
    }
   ],
   "source": [
    "t=0\n",
    "f=0\n",
    "t6=[]\n",
    "f6=[]\n",
    "n=0\n",
    "with open('wice+0.9/combine/detections_6_2.jsonl') as file:\n",
    "    for line in file:\n",
    "        data = json.loads(line)\n",
    "        answer = data[1]['choices'][0]['message']['content']\n",
    "        question = data[0]['messages'][0]['content']\n",
    "        p1 = question.split('P1: \\\"')[1].split('P2: ')[0]\n",
    "        flag = False\n",
    "        pre=n\n",
    "        with open('wice+0.9/dataset_0.9.jsonl') as file1:  \n",
    "            for line1 in file1:\n",
    "                data1 = json.loads(line1)\n",
    "                q = data1[0]['messages'][0]['content']\n",
    "                ref1 = q.split('Reference:')[-1]\n",
    "                # \n",
    "                sentences1=ref1.strip().split('.')\n",
    "                sentences2=p1.strip()[:-1].split('.')\n",
    "                if ref1.strip()==p1.strip()[:-1] or len(sentences1)>1 and len(sentences2)>1 and sentences1[-2] == sentences2[-2]:\n",
    "                    flag = True\n",
    "                    n+=1\n",
    "                    label=data1[0]['label']\n",
    "                    if label == 'true': # hallucination\n",
    "                        if \"here are no conflicting parts\" in answer: # factual\n",
    "                            t+=1\n",
    "                        else:\n",
    "                            t6.append(ref1)\n",
    "                    else:# factual\n",
    "                        if \"here are no conflicting parts\" in answer: # factual\n",
    "                            f+=1\n",
    "                        else:\n",
    "                            f6.append(ref1)\n",
    "                    \n",
    "        if flag==False:\n",
    "            with open('wice+0.9/dataset_0.9.jsonl') as file1:  \n",
    "                for line1 in file1:\n",
    "                    data1 = json.loads(line1)\n",
    "                    q = data1[0]['messages'][0]['content']\n",
    "                    ref1 = q.split('Reference:')[-1]\n",
    "                    sub=ref1.strip().split('\\\"')\n",
    "                    sub1=p1.strip()[:-1].split('\\\\\\\"')\n",
    "                    if len(sub)>2 and len(sub1)>2 and sub[-2]==sub1[-2]:\n",
    "                        flag = True\n",
    "                        n+=1\n",
    "                        label=data1[0]['label']\n",
    "                        if label == 'true': # hallucination\n",
    "                            if \"here are no conflicting parts\" in answer: # factual\n",
    "                                t+=1\n",
    "                            else:\n",
    "                                t6.append(ref1)\n",
    "                        else:# factual\n",
    "                            if \"here are no conflicting parts\" in answer: # factual\n",
    "                                f+=1\n",
    "                            else:\n",
    "                                f6.append(ref1)\n",
    "                        \n",
    "                    if flag==False:\n",
    "                        if len(sub)>2 and len(sub1)>2 and len(sub1[-2].split('\\\\u'))>1:\n",
    "                            uni=sub1[-2].split('\\\\u')[-1][4:]\n",
    "                            length=len(uni)\n",
    "                            if sub[-2].strip()[-length:] == uni:\n",
    "                                flag = True\n",
    "                                n+=1\n",
    "                                label=data1[0]['label']\n",
    "                                if label == 'true': # hallucination\n",
    "                                    if \"here are no conflicting parts\" in answer: # factual\n",
    "                                        t+=1\n",
    "                                    else:\n",
    "                                        t6.append(ref1)\n",
    "                                else:# factual\n",
    "                                    if \"here are no conflicting parts\" in answer: # factual\n",
    "                                        f+=1\n",
    "                                    else:\n",
    "                                        f6.append(ref1)\n",
    "                               \n",
    "                    if flag==False:\n",
    "                        uni=p1.strip()[:-1].split('\\\\u')[-1][4:]\n",
    "                        length=len(uni)\n",
    "                        if ref1.strip()[-length:] == uni:\n",
    "                            flag = True\n",
    "                            n+=1\n",
    "                            label=data1[0]['label']\n",
    "                            if label == 'true': # hallucination\n",
    "                                if \"here are no conflicting parts\" in answer: # factual\n",
    "                                    t+=1\n",
    "                                else:\n",
    "                                    t6.append(ref1)\n",
    "                            else:# factual\n",
    "                                if \"here are no conflicting parts\" in answer: # factual\n",
    "                                    f+=1\n",
    "                                else:\n",
    "                                    f6.append(ref1)\n",
    "                            \n",
    "        if n-pre!=1:\n",
    "            print(p1)\n",
    "print(num-t,(num-t)/num)\n",
    "print(f,f/num)\n",
    "print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "b324460b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "48 0.19123505976095617\n",
      "218 0.8685258964143426\n",
      "matched num= 502\n"
     ]
    }
   ],
   "source": [
    "t=0\n",
    "f=0\n",
    "t66=[]\n",
    "f66=[]\n",
    "n=0\n",
    "with open('wice+0.9/detections_6_1.jsonl') as file:\n",
    "    for line in file:\n",
    "        data = json.loads(line)\n",
    "        answer = data[1]['choices'][0]['message']['content']\n",
    "        question = data[0]['messages'][0]['content']\n",
    "        p1 = question.split('P1: \\\"')[1].split('P2: ')[0]\n",
    "        flag = False\n",
    "        pre=n\n",
    "        with open('wice+0.9/dataset_0.9.jsonl') as file1:  \n",
    "            for line1 in file1:\n",
    "                data1 = json.loads(line1)\n",
    "                q = data1[0]['messages'][0]['content']\n",
    "                ref1 = q.split('Reference:')[-1]\n",
    "                # \n",
    "                sentences1=ref1.strip().split('.')\n",
    "                sentences2=p1.strip()[:-1].split('.')\n",
    "                if ref1.strip()==p1.strip()[:-1] or len(sentences1)>1 and len(sentences2)>1 and sentences1[-2] == sentences2[-2]:\n",
    "                    flag = True\n",
    "                    n+=1\n",
    "                    label=data1[0]['label']\n",
    "                    if label == 'true': # hallucination\n",
    "                        if \"here are no conflicting parts\" in answer: # factual\n",
    "                            t+=1\n",
    "                        else:\n",
    "                            t66.append(ref1)\n",
    "                    else:# factual\n",
    "                        if \"here are no conflicting parts\" in answer: # factual\n",
    "                            f+=1\n",
    "                        else:\n",
    "                            f66.append(ref1)\n",
    "                    break\n",
    "        if flag==False:\n",
    "            with open('wice+0.9/dataset_0.9.jsonl') as file1:  \n",
    "                for line1 in file1:\n",
    "                    data1 = json.loads(line1)\n",
    "                    q = data1[0]['messages'][0]['content']\n",
    "                    ref1 = q.split('Reference:')[-1]\n",
    "                    sub=ref1.strip().split('\\\"')\n",
    "                    sub1=p1.strip()[:-1].split('\\\\\\\"')\n",
    "                    if len(sub)>2 and len(sub1)>2 and sub[-2]==sub1[-2]:\n",
    "                        flag = True\n",
    "                        n+=1\n",
    "                        label=data1[0]['label']\n",
    "                        if label == 'true': # hallucination\n",
    "                            if \"here are no conflicting parts\" in answer: # factual\n",
    "                                t+=1\n",
    "                            else:\n",
    "                                t66.append(ref1)\n",
    "                        else:# factual\n",
    "                            if \"here are no conflicting parts\" in answer: # factual\n",
    "                                f+=1\n",
    "                            else:\n",
    "                                f66.append(ref1)\n",
    "                        break\n",
    "                    if flag==False:\n",
    "                        if len(sub)>2 and len(sub1)>2 and len(sub1[-2].split('\\\\u'))>1:\n",
    "                            uni=sub1[-2].split('\\\\u')[-1][4:]\n",
    "                            length=len(uni)\n",
    "                            if sub[-2].strip()[-length:] == uni:\n",
    "                                flag = True\n",
    "                                n+=1\n",
    "                                label=data1[0]['label']\n",
    "                                if label == 'true': # hallucination\n",
    "                                    if \"here are no conflicting parts\" in answer: # factual\n",
    "                                        t+=1\n",
    "                                    else:\n",
    "                                        t66.append(ref1)\n",
    "                                else:# factual\n",
    "                                    if \"here are no conflicting parts\" in answer: # factual\n",
    "                                        f+=1\n",
    "                                    else:\n",
    "                                        f66.append(ref1)\n",
    "                    if flag==False:\n",
    "                        uni=p1.strip()[:-1].split('\\\\u')[-1][4:]\n",
    "                        length=len(uni)\n",
    "                        if ref1.strip()[-length:] == uni:\n",
    "                            flag = True\n",
    "                            n+=1\n",
    "                            label=data1[0]['label']\n",
    "                            if label == 'true': # hallucination\n",
    "                                if \"here are no conflicting parts\" in answer: # factual\n",
    "                                    t+=1\n",
    "                                else:\n",
    "                                    t66.append(ref1)\n",
    "                            else:# factual\n",
    "                                if \"here are no conflicting parts\" in answer: # factual\n",
    "                                    f+=1\n",
    "                                else:\n",
    "                                    f66.append(ref1)\n",
    "print(num-t,(num-t)/num)\n",
    "print(f,f/num)\n",
    "print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "6bccf177",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "53 0.21115537848605578\n",
      "229 0.9123505976095617\n",
      "matched num= 502\n"
     ]
    }
   ],
   "source": [
    "t=0\n",
    "f=0\n",
    "t7=[]\n",
    "f7=[]\n",
    "n=0\n",
    "with open('wice+0.9/combine/detections_7_2.jsonl') as file:\n",
    "    for line in file:\n",
    "        data = json.loads(line)\n",
    "        answer = data[1]['choices'][0]['message']['content']\n",
    "        question = data[0]['messages'][0]['content']\n",
    "        p1 = question.split('P1: \\\"')[1].split('P2: ')[0]\n",
    "        flag = False\n",
    "        pre=n\n",
    "        with open('wice+0.9/dataset_0.9.jsonl') as file1:  \n",
    "            for line1 in file1:\n",
    "                data1 = json.loads(line1)\n",
    "                q = data1[0]['messages'][0]['content']\n",
    "                ref1 = q.split('Reference:')[-1]\n",
    "                # \n",
    "                sentences1=ref1.strip().split('.')\n",
    "                sentences2=p1.strip()[:-1].split('.')\n",
    "                if ref1.strip()==p1.strip()[:-1] or len(sentences1)>1 and len(sentences2)>1 and sentences1[-2] == sentences2[-2]:\n",
    "                    flag = True\n",
    "                    n+=1\n",
    "                    label=data1[0]['label']\n",
    "                    if label == 'true': # hallucination\n",
    "                        if \"here are no conflicting parts\" in answer: # factual\n",
    "                            t+=1\n",
    "                        else:\n",
    "                            t7.append(ref1)\n",
    "                    else:# factual\n",
    "                        if \"here are no conflicting parts\" in answer: # factual\n",
    "                            f+=1\n",
    "                        else:\n",
    "                            f7.append(ref1)\n",
    "                    \n",
    "        if flag==False:\n",
    "            with open('wice+0.9/dataset_0.9.jsonl') as file1:  \n",
    "                for line1 in file1:\n",
    "                    data1 = json.loads(line1)\n",
    "                    q = data1[0]['messages'][0]['content']\n",
    "                    ref1 = q.split('Reference:')[-1]\n",
    "                    sub=ref1.strip().split('\\\"')\n",
    "                    sub1=p1.strip()[:-1].split('\\\\\\\"')\n",
    "                    if len(sub)>2 and len(sub1)>2 and sub[-2]==sub1[-2]:\n",
    "                        flag = True\n",
    "                        n+=1\n",
    "                        label=data1[0]['label']\n",
    "                        if label == 'true': # hallucination\n",
    "                            if \"here are no conflicting parts\" in answer: # factual\n",
    "                                t+=1\n",
    "                            else:\n",
    "                                t7.append(ref1)\n",
    "                        else:# factual\n",
    "                            if \"here are no conflicting parts\" in answer: # factual\n",
    "                                f+=1\n",
    "                            else:\n",
    "                                f7.append(ref1)\n",
    "                        \n",
    "                    if flag==False:\n",
    "                        if len(sub)>2 and len(sub1)>2 and len(sub1[-2].split('\\\\u'))>1:\n",
    "                            uni=sub1[-2].split('\\\\u')[-1][4:]\n",
    "                            length=len(uni)\n",
    "                            if sub[-2].strip()[-length:] == uni:\n",
    "                                flag = True\n",
    "                                n+=1\n",
    "                                label=data1[0]['label']\n",
    "                                if label == 'true': # hallucination\n",
    "                                    if \"here are no conflicting parts\" in answer: # factual\n",
    "                                        t+=1\n",
    "                                    else:\n",
    "                                        t7.append(ref1)\n",
    "                                else:# factual\n",
    "                                    if \"here are no conflicting parts\" in answer: # factual\n",
    "                                        f+=1\n",
    "                                    else:\n",
    "                                        f7.append(ref1)\n",
    "                               \n",
    "                    if flag==False:\n",
    "                        uni=p1.strip()[:-1].split('\\\\u')[-1][4:]\n",
    "                        length=len(uni)\n",
    "                        if ref1.strip()[-length:] == uni:\n",
    "                            flag = True\n",
    "                            n+=1\n",
    "                            label=data1[0]['label']\n",
    "                            if label == 'true': # hallucination\n",
    "                                if \"here are no conflicting parts\" in answer: # factual\n",
    "                                    t+=1\n",
    "                                else:\n",
    "                                    t7.append(ref1)\n",
    "                            else:# factual\n",
    "                                if \"here are no conflicting parts\" in answer: # factual\n",
    "                                    f+=1\n",
    "                                else:\n",
    "                                    f7.append(ref1)\n",
    "                            \n",
    "        if n-pre!=1:\n",
    "            print(p1)\n",
    "print(num-t,(num-t)/num)\n",
    "print(f,f/num)\n",
    "print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "id": "d0f6ae01",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "xxx\n",
      "yyy\n",
      "xxx\n",
      "yyy\n",
      "xxx\n",
      "yyy\n",
      "xxx\n",
      "yyy\n",
      "xxx\n",
      "yyy\n",
      "xxx\n",
      "yyy\n",
      "xxx\n",
      "yyy\n",
      "xxx\n",
      "yyy\n",
      "xxx\n",
      "yyy\n",
      "xxx\n",
      "yyy\n",
      "xxx\n",
      "yyy\n",
      "xxx\n",
      "yyy\n",
      "xxx\n",
      "yyy\n",
      "xxx\n",
      "yyy\n",
      "xxx\n",
      "yyy\n",
      "xxx\n",
      "yyy\n",
      "xxx\n",
      "yyy\n",
      "xxx\n",
      "yyy\n",
      "xxx\n",
      "yyy\n",
      "xxx\n",
      "yyy\n",
      "xxx\n",
      "yyy\n",
      "xxx\n",
      "yyy\n",
      "xxx\n",
      "yyy\n",
      "xxx\n",
      "yyy\n",
      "xxx\n",
      "yyy\n"
     ]
    }
   ],
   "source": [
    "with open('detections_7_2.jsonl','w') as twofile:\n",
    "    with open('detections_7.jsonl') as file:\n",
    "        for line in file:\n",
    "            data = json.loads(line)\n",
    "            answer = data[1]['choices'][0]['message']['content']\n",
    "            question = data[0]['messages'][0]['content']\n",
    "            p1 = question.split('P1: \\\"')[1].split('P2: ')[0]\n",
    "            if p1 in t777:\n",
    "                twofile.write(json.dumps(data)+\"\\n\")\n",
    "            elif p1 in t7:\n",
    "                print('xxx')\n",
    "                with open('wice+0.9/detections_7.jsonl') as file1:\n",
    "                    for line1 in file1:\n",
    "                        data1 = json.loads(line1)\n",
    "                        answer1 = data1[1]['choices'][0]['message']['content']\n",
    "                        question1 = data1[0]['messages'][0]['content']\n",
    "                        p11 = question1.split('P1: \\\"')[1].split('P2: ')[0]\n",
    "                        if p1.strip()==p11.strip():\n",
    "                            print('yyy')\n",
    "                            twofile.write(json.dumps(data1)+\"\\n\")\n",
    "                            break\n",
    "            else:\n",
    "                twofile.write(json.dumps(data)+\"\\n\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "27067559",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 1 2 3 4 5 6\n",
      "0.549800796812749\n",
      "0.6636904761904763\n"
     ]
    }
   ],
   "source": [
    "tlist=[t1,t2,t3,t4,t5,t6,t7,t11,t22,t33,t44,t55,t66]\n",
    "flist=[f1,f2,f3,f4,f5,f6,f7,f11,f22,f33,f44,f55,f66]\n",
    "#      0   1  2  3  4  5  6  7   8   9   10  11  12\n",
    "minV=0\n",
    "for kk in range(13-12):\n",
    "    for jj in range(kk+1,13-11):\n",
    "        for ii in range(jj+1,13-10):\n",
    "            for i in range(ii+1,13-9):\n",
    "                for j in range(i+1,13-8):\n",
    "                     for k in range(j+1,13-7):\n",
    "                        for m in range(k+1,13-6):\n",
    "                            for n in range(m+1,13-5):\n",
    "                                for q in range(n+1,13-4):\n",
    "                                    for w in range(q+1,13-3):\n",
    "                                        for z in range(w+1,13-2):\n",
    "                                            for y in range(z+1,13-1):\n",
    "                                                for p in range(y+1,13):\n",
    "                                                    a=tlist[kk]+tlist[jj]+tlist[ii]+tlist[i]+tlist[j]+tlist[k]+tlist[m]+tlist[n]+tlist[q]+tlist[w]+tlist[z]+tlist[y]+tlist[p]## \n",
    "                                                    res=set(a)\n",
    "                                                    a=list(res)\n",
    "                                                    aa=len(a)\n",
    "                                                    a=flist[kk]+flist[jj]+flist[ii]+flist[i]+flist[j]+flist[k]+flist[m]+flist[n]+flist[q]+flist[w]+flist[z]+flist[y]+flist[p]## \n",
    "                                                    res=set(a)\n",
    "                                                    a=list(res)\n",
    "                                                    bb=len(a)\n",
    "                                                    TN=(num-bb)/(num*2)\n",
    "                                                    TP=aa/(num*2)\n",
    "                                                    FN=(num-aa)/(num*2)\n",
    "                                                    FP=bb/(num*2)\n",
    "                                                    F1=2*TP/(2*TP+FP+FN)\n",
    "                                                    if TN+TP>=minV:\n",
    "                                                        print(kk,jj,ii,i,j,k,m)#,n,q,w,z,y,p)\n",
    "                                                        print(TN+TP)\n",
    "                                                        print(F1)\n",
    "                                                        minV=TN+TP"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "a01cf710",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "500\n",
      "0.908\n",
      "2.196\n"
     ]
    }
   ],
   "source": [
    "with open('wice+0.1/dataset_0.1.jsonl') as file1: \n",
    "    fnum=[]\n",
    "    tnum=[]\n",
    "    num=0\n",
    "    for line1 in file1:\n",
    "        data1 = json.loads(line1)\n",
    "        q = data1[0]['messages'][0]['content']\n",
    "        ref1 = q.split('Reference:')[-1]\n",
    "        label=data1[0]['label']\n",
    "        sub=ref1.strip().split('\\\"')\n",
    "        num+=1\n",
    "        if label == 'false': # factual\n",
    "            num1=0\n",
    "            for f in flist:\n",
    "                if ref1 in f:\n",
    "                    num1+=1\n",
    "            fnum.append(num1)\n",
    "            #print(num,num1)\n",
    "        else:\n",
    "            num2=0\n",
    "            for t in tlist:\n",
    "                if ref1 in t:\n",
    "                    num2+=1\n",
    "            tnum.append(num2)\n",
    "            #print(num,num2)\n",
    "    print(num)\n",
    "    print(np.mean(fnum))\n",
    "    print(np.mean(tnum))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 75,
   "id": "1b0d9fb8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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pPN5enqKuXPnigsXLoinT5+KoKAgcfDgQTF8+HDh4eEhJk2aJOLj43WeKyUlRTaP4PLly8WDBw/EjBkzpG0TJkzQeazm3IElSpQQKSkp0v6uXbvK9jdu3Fh2/MOHD7XmrwMgunbtKq5evSqSkpJEYmKi+P3330XRokVlZSpXriwCAwNFamqqePTokdbcdADE7NmzRUhIiKzOTz/9VKtcxqtYsWLi+PHjWu/zyJEjwsrKSipnZWUl3N3dxbJly6QyjRs3FgCEh4eH+O6778Q///wjNm3aJKysrISdnZ3O8xIZikkTUQ4bMWKE3i+HTz/91KBz/Pbbb2LYsGF696empoqvvvpKlC5dWtjb24u6deuKlStXitTUVJ1fYu+88450rI+Pj974/vjjD9G2bVu9++fNmyfGjRund/+gQYNMunZBQUFiwYIFolWrVqJChQrC0dFRODg4iPLly4sWLVqIuXPniqCgoEzPERwcrDe+jFdwcHC2Y0xPTxeHDx8WH3/8sWjYsKEoWrSosLa2Fk5OTqJcuXKiY8eO4ptvvtGb1GnatWuXeOedd0Tx4sWFra2tKFWqlOjdu7f466+/dJYfMWKELJHIeNWrV0+8fPlS9O3bV+d7btGihYiMjBRCiCyvz19//SUCAgIyLXP9+nVRs2ZNvfs7duyoFfuBAwdEx44dRdGiRYW9vb2oUaOGmD59ulaCpS4gIEDUrVtXODg4iOrVq4tNmzbJ9utK8IsWLSp69Oghrl27ZtD/AZE+CiEsOGAHERERUT7BPk1EREREBmDSRERERGQAJk1EREREBmDSRERERGQAJk1EREREBmDSRERERGQAJk1EREREBmDSRERERGQAJk1EREREBmDSRERERGQAJk1EREREBmDSRERERGQAJk1EREREBmDSRERERGQAJk1EREREBvg/jHDf7zzZVX0AAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "bins=np.arange(1,14)\n",
    "plt.rcParams['font.sans-serif'] = ['Times New Roman']\n",
    "plt.rcParams[\"font.weight\"] = \"bold\"\n",
    "cmap = plt.get_cmap('tab20c')\n",
    "plt.hist([fnum, tnum], bins, label=['Hallucinatory references($H$)', 'Factual references($\\overline{H}$)'],color=cmap([1,10]),edgecolor='black',linewidth=0.6)\n",
    "plt.legend(fontsize=19)\n",
    "plt.xticks(size=22)\n",
    "plt.yticks(fontsize=22)\n",
    "plt.ylabel('Num Of References',size=22,weight = 'bold') \n",
    "plt.xlabel('Num Of Conflicts',size=22,weight = 'bold') \n",
    "plt.savefig('imgs/conflicts.pdf',dpi=600,format='pdf', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "id": "daee1845",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "200\n",
      "0.796812749003984\n"
     ]
    }
   ],
   "source": [
    "a=t2+t3+t6+t7+t33+t55+t66\n",
    "res=set(a)\n",
    "a=list(res)\n",
    "print(len(a))\n",
    "aa=len(a)\n",
    "print(len(a)/num)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "id": "33f1e946",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "134\n",
      "0.46613545816733065\n"
     ]
    }
   ],
   "source": [
    "a=f2+f3+f6+f7+f33+f55+f66\n",
    "res=set(a)\n",
    "a=list(res)\n",
    "print(len(a))\n",
    "bb=len(a)\n",
    "print((num-len(a))/num)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "id": "2ee8a293",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "FN 0.10159362549800798\n",
      "FP 0.26693227091633465\n",
      "TN 0.23306772908366533\n",
      "TP 0.398406374501992\n"
     ]
    }
   ],
   "source": [
    "all_num=num*2\n",
    "# FN:\n",
    "FN=(num-aa)/all_num\n",
    "print('FN',FN)\n",
    "# FP:\n",
    "FP=bb/all_num\n",
    "print('FP',FP)\n",
    "# TN:\n",
    "TN=(num-bb)/all_num\n",
    "print('TN',TN)\n",
    "# TP:\n",
    "TP=aa/all_num\n",
    "print('TP',TP)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "id": "95a81f2c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.6314741035856574\n",
      "0.5988023952095808\n",
      "0.796812749003984\n",
      "0.6837606837606838\n"
     ]
    }
   ],
   "source": [
    "Accuracy=TN+TP\n",
    "print(Accuracy)\n",
    "Precision=TP/(TP+FP)\n",
    "print(Precision)\n",
    "Recall=TP/(TP+FN)\n",
    "print(Recall)\n",
    "F1=2*TP/(2*TP+FP+FN)\n",
    "print(F1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f3651310",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "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.8.16"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
