{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "c8dc6d38",
   "metadata": {},
   "outputs": [],
   "source": [
    "import json\n",
    "import numpy as np"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c49fedcb",
   "metadata": {},
   "source": [
    "## analysis"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 86,
   "id": "1d975cbe",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2018 23\n"
     ]
    }
   ],
   "source": [
    "wnum=0\n",
    "anum=0\n",
    "with open(\"llama2_data/pubhealth+0.9/references_0.9_test.jsonl\") as file:\n",
    "    for line in file:\n",
    "        anum+=1\n",
    "        if \"Claim: \" not in line:\n",
    "            wnum+=1\n",
    "        #else:\n",
    "        #    print(claim[1].encode().decode('unicode_escape'))\n",
    "print(anum,wnum)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 76,
   "id": "ee0af99c",
   "metadata": {
    "collapsed": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Bat from Shawnee County tests positive for rabies.\n",
      "Germany has banned pork from school canteens because it offends Muslim 'migrants.'\n",
      "Coronavirus prompts Canada to roll out safe drugs for street users.\n",
      "Wayne National Forest plans fires for tree, wildlife health.\n",
      "School closures will have little impact on COVID-19 control, review finds.\n",
      "The state of Michigan threatened local beavers with a $10,000 per day fine for failing to remove their dams.\n",
      "More infected in fresh wave of China bird flu - WHO.\n",
      "Raw Milk Straight from the Cow\n",
      "“Maine House Democrats Vote to Allow Female Genital Mutilation.”\n",
      "Trump: Asian-Americans not responsible for virus, need protection.\n",
      "Kansas officials suggest alternatives to deal with pond scum.\n",
      "Wholly domestic communication between you and your wife can go to New York to London and back and get caught up in the (NSA) database.\n",
      "New Findings Show Xience Stents Are as Safe and Effective as Others\n",
      "Italy looks to safeguard biomedical valley leading fight against COVID-19.\n",
      "Microsoft owns patent \"666,\" which involves inserting microchips into people to mine their activity for cryptocurrency purposes. \n",
      "House passes $1.4T government spending bill amid impeachment.\n",
      "Chumlee from 'Pawn Stars' has passed away.\n",
      "The seasonal flu kills more people every year in the U.S. than COVID-19 has to date. \n",
      "Just on the issue of immigration alone, it is next to impossible to find a policy difference between (Donald) Trump and Congressman (Joe) Heck.\n",
      "The 1918 influenza pandemic was called the \"Spanish Flu\" because it emanated from Spain.\n",
      "Woman strangled at North Carolina assisted living center.\n",
      "Getting your hair washed at a beauty salon can, in rare cases, increase the chances of a stroke.\n",
      "UN demands immediate halt to attacks in Ebola areas in Congo.\n",
      "Minnesota environmentalists aren’t excited about DFL’s wins.\n",
      "More \"25- to 34-year-olds are moving to Austin than any other city in America.\n",
      "Denver Zoo mourns death of oldest hippo, 58-year-old 'Bertie'.\n",
      "EU court orders countries take hard line on air quality.\n",
      "Alabama: Case of meningococcal disease in Jackson County.\n",
      "America’s air isn’t getting cleaner as fast as it used to.\n",
      "Drug critic slams FDA over antibiotic oversight in meat production.\n",
      "Astrophysicist Neil DeGrasse Tyson admonished a little girl who said she wanted to live on the planet Jupiter.\n",
      "Indonesian barber gears up to groom during coronavirus.\n",
      "China detains man for spreading 'panic' with bird flu rumors.\n",
      "Voted the ‘best specialty plate in America’\n",
      "WVa Senate forms committee dedicated to child welfare issues.\n",
      "Northern Colorado to get new VA clinic.\n",
      "Women absorb and retain DNA from every man they have had sex with.\n",
      "Canada has legalized euthanasia, enabling parents to \"kill disabled children.\n",
      "Children in intensive care recover faster with little to no nutrition\n",
      "A passenger plane was forced to make an emergency landing because one passenger's vagina had an offensive odor.\n",
      "Drone technology now allows an individual to be recorded in their homes by drones as small as birds and immediately uploaded to the internet.\n",
      "A photograph shows people lining up outside a Houston, Texas shelter to turn in unwanted animals to be euthanized.\n",
      "Hillary Clinton supported and helped free two Black Panthers accused of torturing and murdering Alex Rackley.\n",
      "A painting depicting J. Marion Sims' experiments on enslaved Black women is on display at the Alabama state Capitol.\n",
      "World closes borders, restricts travel to contain coronavirus spread.\n",
      "“The national coin shortage was done intentionally, the Mint is no longer releasing coins into circulation aka this is the beginning of the end of paper money.”\n",
      "Jordan, Egypt faulted for deaths of US-trained sniffer dogs.\n",
      "State regulators strip ex-USC dean of medical license.\n",
      "UK’s Johnson pushes his Brexit message as election nears.\n",
      "Governor Rauner has called every year for eliminating funding for afterschool programs for at-risk youth, homeless prevention services and programs that help autistic children.\n",
      " The Centers for Disease Control and Prevention (CDC) has admitted that 98 million Americans were given cancer through polio shots contaminated with SV40, a cancer-causing virus found in monkeys. \n",
      "A stranger who stopped to change a tire on a disabled limo was rewarded for his efforts when the vehicle's passenger, Donald Trump, paid off his mortgage.\n",
      "Santa Barbara Zoo’s elderly elephant Little Mac euthanized.\n",
      "The Trump Administration’s policies have halted a research effort seeking a cure for HIV.\n",
      "Judge blocks graphic cigarette warnings.\n",
      "Selenium Supplements Might Give Modest Benefit Against Cholesterol\n",
      "“President Trump has come into contact with a potential coronavirus sufferer!”\n",
      "The Democrat-backed health care reform plan \"will require (Americans) to subsidize abortion with their hard-earned tax dollars.\n",
      "Rhode Island’s teen binge drinking rate is double the national average.\n",
      "New Delhi declares public emergency as pollution at year's worst.\n",
      "Sun, sand and root canal: Medical tourism booms in Costa Rica.\n",
      "Raised for meat in South Korea, dogs head for new homes in U.S.\n",
      "Sanitizer will do nothing for the coronavirus.\n",
      "France's 20th century radium craze still haunts Paris.\n",
      "President Barack Obama’s budget threatens national security by proposing \"an Army of fewer personnel than we had before Pearl Harbor.\n",
      "Increasing H7N9 bird flu toll demands constant vigilance.\n",
      "Baltimore mayor says her $500K book deal was a ‘mistake’.\n",
      "Chain message Says \"special military helicopters will spray pesticide against the Corona virus in the skies all over the country.\n",
      "Legionnaires' disease can be contracted from a face mask used repeatedly.\n",
      "Justin Bieber and Katy Perry made public statements warning that the music industry is run by pedophiles.\n",
      "The Michigan secretary of state's office sent absentee ballots to 7.7 million people\n",
      "Indiana veteran who wanted final flight dies after reunion.\n",
      "Pakistan battles dengue epidemic, with 20 deaths so far.\n",
      "UK trials new breathing aid developed by Mercedes Formula One.\n",
      "The trouble with mammograms\n",
      "Bike sharing offers big fitness benefits for the little commute.\n",
      "Pop culture, wealthy Chinese spur medical tourism in Asia.\n",
      "Over half the people on disability are either anxious or their back hurts.\n",
      "People in Kansas have been jailed due to medical debt.\n",
      "Chicago teachers’ contract talks about more than money.\n",
      "FDA approves Epclusa for treatment of chronic Hepatitis C virus infection\n",
      "Lorraine Fende Says that in Ohio \"right now, you could be 8½ months pregnant and have an abortion for no reason.\n",
      "To Inspect the Heart, Some Doctors Now Start at the Wrist\n",
      "Singapore seizes ivory from nearly 300 elephants in record haul.\n",
      "The \"Wall Street Journal\" (or another large news outlet) has published documents leaked from Walter Reed Medical Center which show President Donald Trump's \"true\" weight and prove a conspiracy to mislead the public.\n",
      "Steve McQueen Says 21 million people \"still suffer slavery today.\n",
      "Tom Barrett Says \"Scott Walker says he would ban stem cell research\n",
      "MRI Might Screen for Autism\n",
      "Five-Year Follow-Up Study Further Supports Effectiveness and Safety of the Essure® Procedure as a Non-Surgical, Non-Hormonal Option for Permanent Contraception\n",
      "California’s new governor says ‘God no’ to run for president.\n",
      "Gallbladder removed through mouth in new surgical technique\n",
      "Jimmy Carter published an open letter entitled \"Losing My Religion for Equality.\n",
      "Unfortunately we have documented instances where people defecated in the (Statehouse) building.\n",
      "Over-the-counter painkiller paracetamol is contaminated with the Machupo virus and should be avoided.\n",
      "Jack Andraka, 15, came up with a “100 percent accurate” cancer-detection method that was “168 times faster, 26,000 times less expensive, and 400 times more sensitive” than current methods.\n",
      "“Presidential alerts” are capable of accessing the E911 chip in your phones, which provides the government full access to your location, microphone, camera and every function of your phone.\n",
      "Health officials warn of possible Legionnaires’ exposure.\n",
      "Former Vice President Joe Biden received five medical deferments, allowing him to avoid serving in the Vietnam War.\n",
      "Study finds computers hinder accuracy in mammography\n",
      "Nelson Wolff Says uncompensated health care costs absorbed by Texas hospitals are adding $1,800 a year to Texas private insurance rates.\n",
      "Zinc eaten at levels found in biofortified crops reduces 'wear and tear' on DNA\n",
      " Little Lauren Renee Pingel was in a car accident in Amarillo, Texas, and despite being strapped in a car seat, was severely injured.  Her grandmother has issued an email request for prayer. \n",
      "Over 200 visitors enroll in New Mexico medical pot program.\n",
      "Boy on hospital floor dominates Britain’s election campaign.\n",
      "Tom Hanks, wife Rita Wilson test positive for coronavirus in Australia.\n",
      "1st federal opioid crisis trial to focus on distribution.\n",
      "Nearly 40 percent of his McAllen-area constituents suffer from obesity.\n",
      "In countries where there are higher, more strict gun laws, there is more gun violence.\n",
      "Film academy president keeps job following investigation.\n",
      "When people enter the service, there’s not a mental health evaluation.\n",
      "Under Hillary Clinton, State Department \"officials were sending official thank-yous to people who gave to the Clinton Foundation.\n",
      "Every day, four North Carolinians die from a medication or drug overdose.\n",
      "County contracts mental health provider for Montana jail.\n",
      "Breast cancer diagnosis gets a boost with gammagrams\n",
      "Vaping illness, deaths likely very rare beyond U.S., experts say.\n",
      "China dangles a potentially harmful new threat in trade war.\n",
      "  Up to 70% of Americans have been infected with a “Vampire Fungus” from eating unhealthy foods that causes weight gain, skin problems and indigestion.   \n",
      "Hurricane Harvey’s toxic impact deeper than public told.\n",
      "Britons warned some coronavirus lockdown measures could last months.\n",
      "Gardens at VA Hospital provide recreation and therapy.\n",
      "A video shows a chicken being hypnotized by holding its head down and \"drawing\" a line in the sand extending from its beak. \n",
      "The attorney general requires that rape victims pay for the rape kit.\n",
      "The number of new cases in South Korea is declining.\n",
      "Anxiety, anger and hope as women face childbirth during coronavirus pandemic.\n",
      "GSK hands back failed muscular dystrophy drug to Prosensa.\n",
      "Typhoon lashes Japanese capital, one dead, power, transport disrupted.\n",
      "3 win Nobel Prize for showing how cells sense low oxygen.\n",
      "Trump administration drops Obama-era water protection rule.\n",
      "Mitch McConnell Says he \"voted for even stronger protections (in the Violence Against Women Act) than Obama's agenda will allow.\n",
      "UN says Ebola in Congo still qualifies as global emergency.\n",
      "A news reporter in Florida was diagnosed with cancer after a viewer spotted a lump in her throat during a broadcast. \n",
      "Once-a-day AIDS pill may be OK’d soon\n",
      "Ireland to clarify abortion rules after woman's death.\n",
      "The president looks like he was ahead of the curve – as you know, he talks about this all the time – on shutting down travel from China.\n",
      "Fourth Canadian farm hit by pig killing virus: Ontario official.\n",
      "Doctors and nurses suffered as Iran ignored virus concerns .\n",
      "Toking up while working out: Pair plan gym allowing pot use.\n",
      "New schizophrenia drugs no better, Dutch team find.\n",
      "Key moments in lead in water crisis in Flint, Michigan.\n",
      "J&J recalls 33,000 bottles of baby powder as FDA finds asbestos in sample.\n",
      "Definitive tests for irritable bowel syndrome developed at Cedars-Sinai: New blood tests will speed up diagnosis for the most common GI disorder\n",
      "Donald Trump was not accused of sexual assault until he ran for President in 2016.\n",
      "TravelLab: Adults take over science museums when night falls.\n",
      "Testing Athletes’ Hearts May Cut Deaths\n",
      "A dog named Daisy rescued hundreds of people from the damaged World Trade Center towers on 9/11.\n",
      "Brain scans may help diagnose neurological, psychiatric disorders\n",
      "Ban trans fats and cut salt, demands UK health body.\n",
      "Women Taking Calcium Supplements May Risk Heart Health, Researchers Say\n",
      "Study finds deregulation fuelling obesity epidemic.\n",
      "The opening line of the Christmas carol \"God Rest Ye Merry Gentlemen\" means \"God make you mighty, gentlemen.\n",
      "Scans cut heart attack rates and save lives, major study finds\n",
      "Methamphetamine use soars in Iran as lifestyles speed up.\n",
      "Bill Gates has openly admitted that vaccinations are designed so that governments can depopulate the world.\n",
      "United States President Donald Trump's website is selling breathing masks bearing his slogan, \"Make America Great Again.\n",
      "Syria, insisting it is coronavirus-free, takes broad steps to prevent spread.\n",
      "Chicago woman finds 15 half siblings through DNA test.\n",
      "Early Cesareans put babies at risk, study finds\n",
      "Twenty-three million Americans suffer from addiction, but only 1 in 10 get treatment.\n",
      "Singer Dolly Parton donated USD$1 million toward research into treatments against COVID-19.\n",
      "Zambia to vaccinate 1 million against cholera amid outbreak.\n",
      "State to labs: report all results of tests for 3 diseases.\n",
      "Boston Scientific sees opportunity in rival's setback.\n",
      "Under David Dewhurst’s leadership, the Texas \"Senate passed an expansion of in-state tuition and free health care to illegal immigrants.\n",
      "Treatment for Peanut Allergies Shows Promise\n",
      "Depressed? You must like chocolate.\n",
      "New drug ‘big deal’ in cystic fibrosis fight\n",
      "WHO recommends one-hour maximum screen time per day for under-5s.\n",
      "European politicians, CEOs, lawmakers urge green coronavirus recovery.\n",
      "Africa’s booming cities face a severe toilet crisis.\n",
      "Authorities in Mexico have seized a massive shipment of cocaine headed towards a U.S. government facility.\n",
      "Dutch doctor dies of lassa fever contracted in Sierra Leone.\n",
      "U.S. unveils graphic tobacco warnings.\n",
      "Saturated fat could be good for you\n",
      " Those who purchase hunting and fishing gear at Cabela’s (and other retailers) now have to pay a medical excise tax established under Obamacare, according to social media posts. \n",
      "Earlier this year, [John DePetro] was accused of sexually assaulting a female co-worker.\n",
      "Massachusetts retailers can again sell pot vaping products.\n",
      "WHO hails 'triumph' as Merck's Ebola vaccine gets European green light.\n",
      "After Fukushima, mother fights to get her life back.\n",
      "Congo Ebola survivor passes college exam taken in isolation.\n",
      "Britain unveils ban on e-cigarettes for under-18s.\n",
      "Hepatitis A on rise in Colorado with nearly 300 known cases.\n",
      "State officials warn of algae bloom along Boston river.\n",
      "Australian animal health firm apparently leaves Lawrence.\n",
      "UAB Recruiting for Clinical Trial to Determine Therapies for Eradication of Multiple Myeloma –University of Alabama at Birmingham\n",
      "Lawyers making final pitches in Flint water criminal case.\n",
      "China's tobacco monopoly means big risks for e-cigarette startups.\n",
      "Wyoming residents concerned about proposed horse facility.\n",
      "In Chilean desert, global thirst for lithium is fueling a 'water war'.\n",
      "In Nagoya, scramble for hospital beds shows coronavirus challenge for aging Japan.\n",
      "Study Questions Chiropractic’s Impact on Back Pain\n",
      "Fertility supplements may help some women conceive\n",
      "Study finds early potential in GSK leukaemia drug\n",
      "Former Winona candy factory to become pet vitamin plant.\n",
      "Cabin crew swap aircraft aisles for hospitals in UK's coronavirus fight.\n",
      "Utah banning ‘conversion therapy’ with Mormon church backing.\n",
      "Health care worker in Grant County has mumps.\n",
      "India cyclone kills at least 33, hundreds of thousands homeless.\n",
      "2020 hopeful Moulton shares mental health woes as war vet.\n",
      "“Guess what, [children are] not at risk unless they have an underlying medical issue.”\n",
      "H9N2 bird flu threat understated in humans says expert.\n",
      "Autopsy results from Vince Foster’s exhumed body — Cause of death to be changed!\n",
      "Players’ mental health becoming major issue in cricket.\n",
      " President Obama has changed the Oath of Allegiance so that new naturalized citizens don’t have to pledge to take up arms to defend the U.S. \n",
      "Profit-hungry tiger breeders behind push to lift China’s trading ban.\n",
      "Talk Therapy Found to Ease Schizophrenia\n",
      "Prostate Cancer Studies Find Benefit in Daily Acetaminophen and Brisk Walks\n",
      "John Bel Edwards Says of the coronavirus threat, “there was not a single suggestion by anyone, a doctor, a scientist, a political figure, that we needed to cancel Mardi Gras.”\n",
      "Cancer-fighting spices offer flavorful way to eat healthy\n",
      "Ohio’s stockpile got its start after the attacks of Sept. 11.\n",
      "Cocoa mulch contains a chemical (theobromine) that can be harmful to pets.\n",
      "Robotic surgery grows, but so do questions\n",
      "Shortage of drugs and equipment: Brussels hospitals sound the alarm.\n",
      "Illinois nurse express regret for bar visit without mask.\n",
      "Just like Donald Trump, David Jolly wants to outlaw a woman's right to choose.\n",
      "Coronavirus cases top half a million, protective gear lacking: WHO.\n",
      "Progesterone may be key to preventing recurrent miscarriage\n",
      "Pepsi admitted that their soda contains cancer-causing ingredients.\n",
      "The Democratic health care bill in the House would \"create 53 new government bureaucracies.\n",
      "In 2020, two school boys in China died suddenly after wearing face masks during physical exercise.\n",
      "  This             email says that in the event of a heart attack when you are by             yourself, coughing repeatedly and vigorously can keep the heart             beating until help arrives.   \n",
      "Austria plans to test all retirement home residents for coronavirus.\n",
      "2020 Dems’ health care battle is decades in the making.\n",
      "New easy-to-use TB test achieves accuracy comparable to IGRAs in Phase III trials\n",
      "The U.S.'s leading group of pediatricians issued a strong statement condemning tolerance of gender dysphoria in children.\n",
      "Iowa Legislature back to talk taxes, workers, child care.\n",
      "‘Super coral’ scientist dies in Hawaii at age 56.\n",
      "Older patients with knee pain may benefit from allograft transplant technique\n",
      "Babies Should Eat Eggs and Peanuts Early to Avoid Food Allergies\n",
      "Kettlebells swing to a full body workout.\n",
      "Meet Eugene’s young climate ‘warriors’.\n",
      "Georgia health agency warns of widespread flu, urges shots.\n",
      "Congressional candidate Chris Jacobs “voted against paid leave for COVID-19.”\n",
      "Eagle center struggles to supply American Indians rituals.\n",
      "Oklahoma attorney general sues distributors of opioids.\n",
      "New studies say antibiotics are good for infants with confirmed ear infections\n",
      "Wedding guests should refrain from throwing rice at newly-wedded couples because the rice kills birds who eat it.\n",
      "Democratic 2020 candidates vie for unions, Latinos in Nevada.\n",
      "FDA approves AstraZeneca type 2 diabetes drug.\n",
      "Viagra may help heart effects of muscular dystrophy\n",
      "Officials: 21 measles cases in Detroit area since March 13.\n",
      "The name Frank has risen in popularity by 20 percent\" since the debut of 'House of Cards' on Netflix.\n",
      "The state GOP ticket \"says their top priority is a career-long mission to outlaw abortion in all cases and ban some common forms of birth control.\n",
      "Bill Clinton Says Hillary Clinton tripled the number of people with AIDS whose \"lives are being saved .. and it did not cost you any more money.\n",
      "Potential Parkinson’s Treatment Explored\n",
      "Drug May Delay Pancreatic Cancer Return\n",
      "Hearing concludes in Missouri abortion clinic licensing case.\n",
      "US plans reimagine fighting wildfires amid crews’ virus risk.\n",
      "U.S. Democratic presidential nominee Joe Biden supports \"defunding\" police agencies.\n",
      "Scientists find clues to why binge-drinking causes binge-eating.\n",
      "Breakthrough in Creating Artificial Pancreas\n",
      "A drunk crop duster pilot dumped four tons of manure over parts of Kansas.\n",
      "Evidence shows Zika virus turns fetus brains to liquid.\n",
      "States with \"the highest gun ownership rates also have the highest suicide rates.\n",
      "“People are starting to enter ERs with fungal lung infections from wearing masks!!\n",
      "Actress Martha Raye entertained troops and tended to wounded soldiers in the field in Vietnam.\n",
      "Gene Therapy Cures Adult Leukemia\n",
      "Chicago officials urge flu vaccine before peak season.\n",
      "Study: New blood thinner works as well as Coumadin\n",
      "Blood-Pressure Drugs Linked to Birth Defects\n",
      "Bread a culprit in Americans eating too much salt.\n",
      "Jury Still Out on Radiation for Early Prostate Cancer\n",
      "A major part\" of the climate change bill sponsored by Sens. John Kerry and Joe Lieberman \"was essentially written by BP.\n",
      "Hepatitis A confirmed at Redfield, Arkansas, diner.\n",
      "Tom Petri Says President Barack Obama’s debt commission recommended converting Medicare \"to a system where Medicare participants are given a voucher to purchase insurance in the private market.\n",
      "Gabapentin is now considered the most dangerous drug in America and will surpass opioids as the largest prescription drug killer.\n",
      "Disney closes controversial fat-fighting exhibit.\n",
      "Abaloparatide may help prevent fractures in postmenopausal women with osteoporosis\n",
      "People vaccinated for seasonal influenza face higher chances of catching SARS-COV-2, which causes COVID-19, or testing positive for the virus when they do not actually have it. \n",
      "Gun homicide is down 49 percent in the past 12 years.\n",
      "Viral image Says two patients at Valley Regional Medical Center in Brownsville, Texas, “are being looked at” for possible coronavirus infections.\n",
      "EPA to issue permits for Los Alamos storm water runoff.\n",
      "Ireland has mostly contained coronavirus outbreak: health chief.\n",
      "Novartis Drug Curbs Repeat Hip Fractures\n",
      "In Providence, R.I., it's illegal to sell toothpaste and a toothbrush to the same customer on a Sunday.\n",
      "Here in Wisconsin, we've put in previous budgets more money into mental health services than any governor has in the last 25 years.\n",
      "Sen. Elizabeth Warren \"doesn’t have any Indian blood.\n",
      "Insurance companies \"have made a fortune with Obamacare.\n",
      "As of July 17, 2020, Nueces County in Texas had seen 85 positive COVID-19 tests among children aged under 1 year.\n",
      "COVID-19 started because we eat animals.\n",
      "Coronavirus death toll jumps to 107 in Italy, all schools shut.\n",
      "Fast-food restaurants target U.S. kids, study shows.\n",
      "Melania Trump was the first First Lady to visit troops in a war zone. \n",
      "Iran says coronavirus death toll nearing 4,000.\n",
      "Merck Says Thousands File for Vioxx Payments.\n",
      "Residents: Tests find toxic chemicals after Texas plant fire.\n",
      "Rural Wisconsin schools getting mental health help by video.\n",
      "President Trump intends to nominate Dr. Oz to the Presidential Council on Sport, Fitness and Nutrition.\n",
      "4th Massachusetts resident dies of vaping-related illness.\n",
      "Iowa public health officials tackle vaping health concerns.\n",
      "John McCain accused Barack Obama \"of letting infants die.\n",
      "From 1947 to 1979, family incomes for rich, middle-income and poor Americans grew about the same rate. But since 1979, incomes for rich families have grown much faster.\n",
      "Common antibiotic may help to prevent or treat PTSD\n",
      "Russian border becomes China's frontline in fight against second virus wave.\n",
      "With U.S. hit by virus, China courts Latin America with medical diplomacy.\n",
      "Evidence a high-fat diet works to treat epilepsy\n",
      "Georgia could be first state to test Trump health proposals.\n",
      "Police opened fire on a store mannequin after it failed to follow their orders.\n",
      "Senator McCain would pay for part of his (health care) plan by making drastic cuts in Medicare — $882-billion worth.\n",
      "Disney arranged to have himself frozen in cryonic chamber full of liquid nitrogen upon his death,\n",
      "Ultrasound jiggles open brain barrier, a step to better care.\n",
      "Lake worshipped by Incans now littered with trash.\n",
      "U.S. says science should settle farm debates in trade deal with EU.\n",
      "US surgeon general urges caution, not panic, on new virus.\n",
      "Virginia is \"the number one state per capita in screening out people with mental illness from gun purchases.\n",
      "Climate is changing. Investing needs to, too, says BlackRock.\n",
      "Regulator grants license for Britain's first three-parent IVF babies.\n",
      "EPA chemical safety nominee drops out amid strong opposition.\n",
      "Hormone patch shows benefit over pill\n",
      "A California Senate bill gives the state the right to seize children from their families\n",
      "Jackson Laboratory gets funding boost for genetics research.\n",
      "Steyer visiting North Carolina, including Barber’s church.\n",
      "Louisiana to name nursing homes where outbreaks happen.\n",
      "US begins ‘warp speed’ vaccine push as studies ramp up.\n",
      "The seeds of certain common household plants can be used as an alternative to LSD.\n",
      "U.S. travel warning adds to pressure on Tanzania over suspected Ebola cases.\n",
      "Photos and video clips narrated by a medical doctor demonstrate that Democratic presidential candidate Hillary Clinton likely has Parkinson's disease.\n",
      "Hair-grooming syncope\" is a real fainting disorder that can occur during acts of hair care. \n",
      "Donald Trump Says Joe Biden has “written a letter of apology” for calling Trump’s travel restrictions from China “xenophobic.”\n",
      "Study Shows Chest Pain From Heart Disease Can Be Treated With Stem Cell Therapy\n",
      "Principal who went into coma after bone marrow donation dies.\n",
      "Massachusetts officials rescind ban on vaping product sales\n",
      ".\n",
      "Taiwan reports no new coronavirus cases for first time in a month.\n",
      "By spring 2020, the sun had entered a \"lockdown\" period where its solar activity decreased to the point that famine, earthquakes, and freezing weather threatened life on Earth.\n",
      "Julian Assange asked President-Elect Donald Trump for a pardon in exchange for his help in defeating Hillary Clinton.\n",
      "Officals say the flu is ‘prevalent’ in New York.\n",
      "Jeb Bush Says that during his eight years as Florida governor, \"we created 1.3 million net new jobs -- more jobs created than Texas.\n",
      "Today in America, between 40 and 50 percent of all African-American babies, virtually 1-in-2, are killed before they are born.\n",
      "Raw milk debate simmers as states and FDA mull rules.\n",
      "Fewer mammograms means more breast cancer deaths\n",
      "Cuban doctors head to Italy to battle coronavirus.\n",
      "Activities by foreign governments had \"absolutely no effect on the outcome of this election.\n",
      "Officials say 2 meningitis deaths in Ohio county unrelated.\n",
      "Getting relief from sexual dysfunction and incontinence caused by menopause\n",
      "Obamacare isn't helping anyone.\n",
      "A secret tape recorded aboard the doomed space shuttle Challenger captured the final panic-stricken moments of the crew. \n",
      "Israel targets fashion industry over underweight models.\n",
      "Doctors, nurses, hospitals, even the pharmaceutical industry, (and) AARP\" say that health reform \"makes sense to do.\n",
      "Account by Apollo 11 astronaut Buzz Aldrin describes his taking Communion on the moon.\n",
      "Quebec appeals court upholds C$15 billion tobacco class action ruling.\n",
      "Hunt on for 'patient zero' who spread coronavirus globally from Singapore.\n",
      "Getting a coronavirus test in Wuhan: fast, cheap and easy.\n",
      "Samoa faces coronavirus threat after recovering from deadly measles outbreak.\n",
      "I lowered taxes over the last two years.\n",
      "An Ohio man died from complications related to the COVID-19 coronavirus disease weeks after he downplayed the virus on social media. \n",
      "CAR-T therapy makes early inroads in treating brain cancer\n",
      "West Virginia physician retires after 41 years.\n",
      "Coronavirus could kill 81,000 in U.S., subside in June - Washington University analysis.\n",
      " Charles Krauthammer has penned a column under the headline, “The Enemy Among Us,” about President Obama’s use of a group called Organizing for  Action (OFA) to advance his political agenda after leaving the White House. \n",
      "EU should scrap emissions trading scheme, Polish official says.\n",
      "Public urged to avoid wild animals after rabid skunk cases.\n",
      "These Houston residents dream of moving to where the air is clear.\n",
      "First lady calls for end of e-cigarette marketing to youth.\n",
      "Joe Barton Says you can buy four light bulbs for $1.99 at Walmart, while a single compact fluorescent lamp (CFL) costs \"$10 a pop.\n",
      "Drug resistant superbugs are killing 33,000 in Europe each year.\n",
      "Healthcare group Novacyt wins British orders for coronavirus testing product.\n",
      "Poorer countries lack midwives to cut birth deaths: report.\n",
      "Video clip shows a middle-aged woman punching another woman in the mouth.\n",
      "UK was too slow on coronavirus and 40,000 could die, professor says.\n",
      "Inner-city students \"fall back and don’t succeed, whereas if there was a less intensive track, they would.\n",
      "As measles returns, U.S. states look to cut vaccine exemptions.\n",
      "Rep. Debbie Dingell is introducing a bill that would lead to widespread gun confiscations.\n",
      "Nobel prize honors breakthroughs on lithium-ion batteries.\n",
      "Amid tighter race, Clinton and Trump trade barbs over health.\n",
      "2 measles cases from exposure at Portland, Oregon airport.\n",
      "Balkan drought highlights years of farm neglect.\n",
      "US drinking more now than just before Prohibition.\n",
      "Obama Makes Huge Move to BAN Social Security Recipients From Owning Guns\n",
      "Pakistan study blames HIV outbreak in kids on bad healthcare.\n",
      "Person with measles passed through Portland airport.\n",
      "Gaza resumes coronavirus testing amid shortages.\n",
      "The number of Britons drinking to harmful levels has fallen sharply.\n",
      "Law enforcement agencies recommend that people wash the handle on shopping carts before using them to avoid potential exposure to fentanyl.\n",
      "There were 3,700 drug-related deaths in England and Wales last year.\n",
      "“Why did the state do that with COVID patients in nursing homes? It’s because the state followed President Trump’s CDC guidance.”\n",
      "The Obama administration gave Iran \"$400 million in ransom payment cash.\n",
      "Obamacare will provide coverage for abortions, despite the president’s commitment that it would not.\n",
      "Masks decrease oxygen intake, increase carbon dioxide intake, increase toxin intake, increase stress levels which directly impacts the immune system in a negative way making us more susceptible to illness.\n",
      "Costly New Prostate Cancer Drug Works In Mysterious Ways\n",
      "A couple sued Planned Parenthood for child support over a failed abortion.\n",
      "If voters are turned away from polls on election day, they can ask for a provisional ballot.\n",
      "Antibiotics speed up recovery from ear infections in young children, studies show\n",
      "Study: Safe hormone therapy after hysterectomy\n",
      "Jackson Laboratory grant to help understand addiction, genes.\n",
      "Currently, half a million Floridians have Alzheimer’s disease, and in less than 10 years, a 40 percent growth rate means that another 200,000 Floridians will develop this devastating illness.\n",
      "New Therapy Delivers Long-Term Relief for Chronic Back, Leg Pain, Study Finds\n",
      "Bolsonaro to send army to fight huge fires in the Amazon.\n",
      "Hallmark greeting cards are made in China. \n",
      "Genetic tests detect new way to fight war on breast cancer\n",
      "We’ve doubled the production of clean energy.\n",
      "Bayer, Novartis clash with UK doctors over use of cheap eye drug.\n",
      "Of the 98 top oxycodone-dispensing doctors who used to live in Florida, \"today, there are none.\n",
      "Climate change endangers Scotland's archaeological treasures.\n",
      "Estrogen predicts breast cancer recurrence: study.\n",
      "School water coolers may help kids lose weight\n",
      "Coral die-off predicted as marine heat wave engulfs Hawaii.\n",
      "Thailand bans entry to foreigners, prepares emergency measures against coronavirus.\n",
      "North Korea is telling its people that their men’s national team is in the World Cup final.\n",
      "The Chinese are there\" in Syria.\n",
      "A Maryland doctor who participated in a secret surgery to remove a blood clot from Hillary Clinton's brain died suddenly under mysterious circumstances.\n",
      "California sues US over home health worker union dues.\n",
      "Caitlyn Jenner regrets transitioning to female and wishes to de-transition.\n",
      "Botox may prevent irregular heartbeat after bypass surgery\n",
      "Georgia takes step toward legalizing medical marijuana.\n",
      "A man using the screen name 'DreamWeaverGrey' is luring women to their deaths over the Internet.\n",
      "The National Cancer Institute has \"admitted\" that \"cannabis kills cancer.\n",
      "Tim Canova Says Debbie Wasserman Schultz \"has voted for huge subsidies for the sugar industry ... as well as for delays in cleanups.\n",
      "Cannibals arrested in Florida claim eating human flesh cures diabetes and depression\n",
      "Rapper T.I. said in an interview that he takes his daughter to the gynecologist yearly to ensure she's still a virgin.\n",
      "Electro-acupuncture for disrupted sleep in women with breast cancer\n",
      "“Bill Gates told us about the coronavirus in 2015.”\n",
      "Thai PM asks rich for help with coronavirus fall-out.\n",
      "A new Facebook feature enabling users to report problems by shaking their phones has caused some users to be inadvertently reported for abuse and suspended.\n",
      "Crop invaders: China's small farmers struggle to defeat armyworm.\n",
      "Walker taking gas tax argument to voters at the pumps.\n",
      "The Obama administration \"supported Muslim allies trying to establish a new international blasphemy standard.\n",
      "Statistically, law-enforcement officers die 10 years earlier than the general population.\n",
      "Apollo 11 moon landing had thousands working behind scenes.\n",
      "Virus-hit Carnival cruise ship docks in Australia as country's death toll hits 40.\n",
      "Studies: New type of osteoporosis drug cuts fracture risk in women, men in cancer treatment\n",
      "U.N. wants better life for world of 7 billion.\n",
      "Clamor for GSK shingles shot points to bigger profits.\n",
      "Texas leads \"the country in drunk driving fatalities.\n",
      "A video shows small, white worms inside some cherries.\n",
      "Dr. Anthony Fauci wrote in a 2005 paper published in Virology Journal that hydroxychloroquine was effective in treating SARS. \n",
      "One in five people are drinking too much alcohol.\n",
      "If you want out of the individual mandate... all you have to do now is tick off the box that says 'hardship' and you're out.\n",
      "Mark Pryor Says Tom Cotton \"voted against preparing America for pandemics like Ebola.\n",
      "Virginia Gov. Ralph Northam \"stated he would execute a baby after birth.\n",
      "“The coronavirus is the common cold, folks.”\n",
      "Tanzania rejects suspicions that it covered up Ebola cases.\n",
      "If someone is in a room that has measles and leaves and you walk in two hours later, you could get measles from that person.\n",
      "The rapper DMX (Earl Simmons) died in February 2018.\n",
      "AstraZeneca's Imfinzi gets speedy FDA review for small cell lung cancer.\n",
      "Grants awarded to address lead-based paint in Rhode Island.\n",
      "Test can predict success of IVF: U.S. report.\n",
      "Health department will get $11.3M for kids’ vaccine programs.\n",
      "U.S. President Barack Obama waited until millions were infected and thousands were dead before declaring a public health emergency concerning swine flu, the H1N1 virus. \n",
      "“The coronavirus has made it to Mississippi and the lady that caught it wasn’t around nobody with it which means it is airborne. That means if the wind blows it your direction you’ll have it also.”\n",
      "In September 2020, former Vice President Joe Biden was unable to recite the Pledge of Allegiance, as demonstrated in a video.\n",
      "Senate panel: NY needs addiction treatment professionals.\n",
      "Left-wing protesters vandalized the home of Supreme Court nominee Brett Kavanaugh.\n",
      "Barack and Michelle Obama were forced to surrender their licenses to practice law because of their unethical behavior.\n",
      "Can blood from coronavirus survivors treat the newly ill?.\n",
      "Warren says getting to ‘Medicare for All’ will take 3 years.\n",
      "Brain-dead California girl ordered kept on ventilator for week longer.\n",
      "Louie Gohmert Says a Justice Department memo \"directs that you must openly embrace gay marriage and homosexuality.\n",
      "Video shows President Donald Trump saying COVID-19 is Democrats’ “new hoax.”\n",
      "Musical Exercise Program Cuts Falls in Elderly\n",
      "On whether or not the Philadelphia DA's office will recommend the possibility of parole for all juvenile lifers.\n",
      "Roche says EU panel backs lymphatic cancer drug for approval.\n",
      "State agency says Ohio suicide deaths rose 45% since 2007.\n",
      "Hogan announces environmental agreement with dam operator.\n",
      "India bans export of drug being tested for coronavirus treatment.\n",
      "Walt Disney was an illegitimate child, born out of wedlock to a woman from a town near Almeria in southern Spain and adopted by Flora and Elias Disney.\n",
      "Study challenges health benefits of moderate drinking.\n",
      "We’re paying out-of-state residential facilities hundreds of thousands of dollars, if not more,\" to house children in state custody\n",
      "Joaquin Castro Says the director of an anti-abortion group receiving a Texas grant to provide women’s health services \"believes HIV can be spread through the sewer system.\n",
      "Midwest women join climate change group in Antarctica.\n",
      "5 Minnesotans sickened by E. coli linked to salad kits.\n",
      "Italy suffers setback to hopes its coronavirus epidemic might be in retreat.\n",
      "Rick Scott \"was forced to resign as the head of a company that pled guilty to massive amounts of systematic fraud, including 14 felonies, leading to a historic $1.7 billion fine.\n",
      "Insulin can be purchased at Walmart for $25 a vial.\n",
      "Barron Trump Rushed To The Hospital, Hospital Releases Statement On His Condition\n",
      "The Cancer Act of 1939 makes it illegal to cure cancer.\n",
      "Stem cell test to help treat bowel cancer.\n",
      "Blocking “rogue gene” may stop cancer spread: study\n",
      "Said Democrats manufactured a death toll of 3,000 for Hurricane Maria in Puerto Rico to make him \"look as bad as possible.\n",
      "George Soros owns the WuXi PHARMA LAB located in Wuhan, China where COVID-19 was developed and conveniently Broke Out.\n",
      "20 percent of the time (smart guns) won't work.\n",
      "Congo’s conflict makes fighting Ebola, sexual violence risky.\n",
      "Claimed his administration recently provided “historic levels of funding to improve school safety” through the STOP School Violence Act. \n",
      "Several major brands of lipstick contain dangerous levels of cancer-causing lead which can be detected with a gold ring.\n",
      "Beijing quarantines returning residents as China struggles to pick up economy.\n",
      "In 2009's H1N1 (swine flu) pandemic, 1.4 billion people were sickened globally, and nearly 600,000 died.\n",
      "Troubled Texas anti-abortion group seeks federal grant money.\n",
      "The Healthy Skeptic: Probiotics could help in cold and flu season\n",
      "Indiana: Harmful algae blooms detected on Ohio River.\n",
      "A viral image shows Tamla Horsford, the only black woman at an all-white adult sleepover, hours before she was found dead in a yard under contested circumstances.\n",
      "Overweight Americans who pick diet drinks eat more food: study.\n",
      "Among 2020 Democrats, a debate over ‘Medicare-for-all’.\n",
      "U.S. teen smoking declines to record low in 2012: study.\n",
      "Indonesia hunts for survivors as volcano tsunami toll nears 400.\n",
      "Bernie Sanders and Hillary Clinton both seek an abortion \"cutoff date\" of 36 weeks, and both claim that late-stage fetuses feel no pain and have no rights.\n",
      "Top Nigerian president aide, state governor test positive for coronavirus.\n",
      "Drug trial success a boost for Arena\n",
      "An adopted dog's former owner turned out to be a soldier who was killed in Iraq.\n",
      "Judge tosses $417M award against Johnson & Johnson.\n",
      "Many U.S. kids have chronic health problems: study.\n",
      "The high-dose Fluzone vaccine caused the deaths of 23 senior citizens during a clinical trial.\n",
      "One of the Planned Parenthood videos shows \"a fully formed fetus on the table, its heart beating, its legs kicking, while someone says, 'We have to keep it alive to harvest its brain.' \n",
      "Taiwan says WHO ignored its coronavirus questions at start of outbreak.\n",
      "Vectura, Sandoz win ruling on inhaler packaging case against GSK.\n",
      "UK to use firefighters to deliver food, collect bodies in coronavirus crisis.\n",
      "The government are putting £34 billion into the NHS, the biggest ever cash injection.\n",
      "$300 to learn risk of prostate cancer\n",
      "Boats left high and dry by drought back on Great Salt Lake.\n",
      "Safer Method Found to Treat Heart Failure\n",
      "Antidepressants relieve hot flashes\n",
      "Americans sicker but English die quicker says study.\n",
      "Bike lanes and sidewalks have been proven to reduce crashes by up to 38 percent on Austin’s streets.\n",
      "If you maintain social distancing indoors “there's no reason to have an additional mask on top of that.”\n",
      "Donald Trump Says Cory Booker has accepted over $400,000 from the pharmaceutical industry during his political career.\n",
      "The sap of the giant hogweed plant can cause severe skin and eye irritation.\n",
      "“We have one of the lowest mortality rates in the world” from COVID-19.\n",
      "Evolution Fresh brand cold-pressed juices and smoothies are 'poison.'\n",
      "I've created over 40,000 jobs.\n",
      "Three Syrian refugees raped and murdered a 5-year-old girl at knifepoint in Idaho.\n",
      "UTA researcher patents “roach motel” for cancer\n",
      "A woman in South Korea was impregnated via mouth after eating a squid.\n",
      "Gillibrand to discuss federal effort to combat Lyme disease.\n",
      "Queen Elizabeth removed the Obamas from the guest list for Prince Harry and Meghan Markle's wedding after she learned that Michelle Obama tried to \"sneak a spot.\n",
      "Hank Johnson Says \"by reducing chronic health care costs in the State of Georgia, we can reduce the $32.8 billion lost each year due to lack of productivity and economic costs.\n",
      "Dr. Fauci says every American should be microchipped.\n",
      "Representative Mick Mulvaney, who was recently selected as the Trump administration's nominee for director of the Office of Management and Budget, one posed the question “Do we really need government-funded research at all?” on Facebook.\n",
      "Smoking to kill 5.6 million US kids if not stubbed out: report.\n",
      "Pandemic-related shutdown orders are unconstitutional, and persons arrested for violating them can collect damages.\n",
      "In 1926, engineer and inventor Nikola Tesla predicted that humanity would one day \"be able to communicate with one another instantly, irrespective of distance\" and that \"the instruments through which we shall be able to do all of this will fit in our vest pockets.\n",
      "One study calls fish a lifesaver, another is more cautious\n",
      "ISIS lures women with kittens, nutella.\n",
      "More People Should Get Statins, Report Says\n",
      "Can't exercise? A hot bath may help improve inflammation, metabolism, study suggests\n",
      "In 2010, Clinton \"said Iran could enrich uranium. In 2014 she said she’s always argued against it.\n",
      "A state bill would end a longstanding requirement that local governments repair highways and sidewalks -- and block injured citizens from suing over neglected maintenance.\n",
      "Europe sees more signs of hope as Italy’s virus curve falls.\n",
      "As CEO of WWE, Linda McMahon \"was caught tipping off a ringside physician\" about a federal investigation into illegally distributing steroids to wrestlers.\n",
      "Distinguishing fatal prostate cancer from 'manageable' cancer now possible\n",
      "Avandia may help keep arteries clear after surgery.\n",
      "If masks prevent coronavirus, governors would have given them to prison inmates instead of releasing them.\n",
      "Virus spreads on cruise ship in Japan, U.S. passengers flying home.\n",
      "Study: Many in Ebola outbreak don’t believe virus is real.\n",
      "Baxter Alzheimer's drug promising in small study.\n",
      "Study Results Published in JAMA Conclude that 3D MAMMOGRAPHY™ Exams Outperform Conventional Mammography for Women with Both Dense and Nondense Breasts\n",
      "This is the first time since Roe was decided in 1973 that a court has granted personhood status to the preborn.\n",
      "Multidrug-resistant malaria spreading in Southeast Asia: study.\n",
      "U.S. panel outlines how doctors should ration care in a pandemic.\n",
      "After Texas defunded Planned Parenthood, both the unintended pregnancy and abortion rates dropped.\n",
      "Scientists say quarter of all pigs could die of swine fever.\n",
      "Childrens' YouTube, TikTok, Roblox, and Fortnite channels feature videos with deeply disturbing and violent messages.\n",
      "New class of blood pressure meds as effective as old, analysis shows\n",
      "Thirty-three Florida labs were busted for \"cooking the books\" or tampering with data after not reporting negative COVID-19 test results between March and July 2020.\n",
      "Comments sought on Idaho Medicaid expansion waiver.\n",
      "Cory Gardner Says on contraception, his plan is \"cheaper and easier for you\" than Sen. Mark Udall’s\n",
      "Six new cases of MERS virus hit Saudi Arabia, UAE.\n",
      "Study adds to evidence of vaccine safety\n",
      "Darrell Issa Says Thomas Eric Duncan came into the United States \"with an elevated temperature.\n",
      "Suicide among veterans highest in western US, rural areas.\n",
      "Drug for Immune Disorders Helps Alzheimer’s\n",
      "“This virus has a cure. It is called hydroxychloroquine, zinc, and Zithromax. I know you people want to talk about a mask. Hello? You don’t need (a) mask. There is a cure.”\n",
      "Both real and virtual colonoscopies work: report.\n",
      "An x-ray image shows a snake that entered a woman's stomach by crawling through her vagina.\n",
      "Stem cell experiment lets diabetics forgo insulin\n",
      "Jon Voight once said \"I pray all Americans who have seen and felt the meltdown of America with the Obama years, to please fight for Donald Trump\n",
      "Daraprim is still underpriced, relative to its peers.\n",
      "March 2020 was the first March without a school shooting in the U.S. since 2002.\n",
      "Disneyland tower suggested as Legionnaires’ disease source.\n",
      "Italy threatens to ban outdoor exercise as coronavirus deaths surge.\n",
      "Consumer goods CEOs in Davos hot seat over plastic waste.\n",
      "Liberal feminist Katie Hopkins advocated for driving euthanasia vans around to kill off the elderly.\n",
      "DHEA hormone may help women through menopause: study\n",
      "Joseph Cryan Says direct shipment of wine \"makes underage drinking as simple as a mouse click.\n",
      "Dutch woman aged 107 survives coronavirus.\n",
      "Doors singer Jim Morrison has been found alive in a Paris retirement home.\n",
      "Drug may prevent lung cancer, study finds\n",
      "UK cost agency rejects leukaemia drug from J&J and AbbVie.\n",
      "Bricks of cocaine washed ashore in Florida after Hurricane Dorian. \n",
      "Earl Blumenauer Says ending the direct payment farm subsidy program \"could save up to $28.4 billion over ten years that could be used to reduce the deficit.\n",
      "Cervical cancer vaccine up for FDA review\n",
      "Asthma gene's effect on respiratory symptoms in infancy depends on breastfeeding status\n",
      "Kansas Medicaid patients can now get antiviral Hep-C drugs.\n",
      "A mandatory gun ownership law in Kennesaw, Georgia, caused the town's crime rate to plummet.\n",
      "The restaurant chain Whataburger announced that it was closing its doors.\n",
      "UAE orders overnight curfew for deep clean, Gulf coronavirus cases rise.\n",
      "States have cumulatively cut over $1.8 billion from their mental health services between 2009 and 2011. This is the largest reduction in state mental health services in half a century.\n",
      "UN expert: Zimbabwe hunger ‘shocking’ for country not at war.\n",
      "New pill might be reliable wake-up call\n",
      "Spain's PM to seek longer but more flexible lockdown.\n",
      "WHO rejects 'China-centric' charge after Trump criticism.\n",
      "Florida researchers developing football helmets to reduce concussions.\n",
      "In nine Democratic debates, \"We've not had one question about a woman's right to make her own decisions about reproductive health care, not one question.\n",
      "The best treatment for laryngeal cancer? This approach helps decide\n",
      "Hassan highlights access to health care for female veterans.\n",
      "MAPs (Minor Attracted Persons) created a pride flag\n",
      "The Department of Homeland Security is secretly moving and releasing crowds of undocumented people into the United States.\n",
      "Obama put a 10 percent tax on tanning.\n",
      "Panel favors continuation of ArQule liver cancer drug study.\n",
      "The White House staff risks violating federal ethics rules if they participate in Donald Trump’s \"fake news awards.\n",
      "County offers vaccinations after hepatitis scare.\n",
      "Ebola 'no longer incurable' as Congo trial finds drugs boost survival.\n",
      "Joe Jackson — patriarch of the entertainment family that includes singers Janet Jackson and the late Michael Jackson — has died of cancer.\n",
      "It’s been proven over and over again Medicaid has the worst outcomes in the industrialized world as far as the quality of health care.\n",
      "People on pot \"shoot each other ... stab each other ... strangle each other, drive under the influence, kill families.\n",
      "China to extend winter anti-smog measures for another year.\n",
      "Baby aspirin linked to reduced cancer deaths\n",
      "NY project would map genes of 1 million to fight Alzheimer’s.\n",
      "US proposes new rules to increase organ transplants.\n",
      "Massachusetts OKs funds to offset Planned Parenthood losses.\n",
      "Puppy love: therapy pooches bring peace of mind at Spanish psychiatric center.\n",
      "An audio tape captures VP candidate Tim Kaine yelling at his mistress.\n",
      "South African union takes government to court over COVID-19 gear shortage.\n",
      "What I have done -- and this is unprecedented ... is I've said to each agency ... 'look at regulations that are already on the books and if they don't make sense, let's get rid of them.'\n",
      "Science Says: Too early for forecast on Lyme disease ticks.\n",
      "House Republicans required the use of Styrofoam cups in House cafeterias that are \"part of Koch Industries.\n",
      "Tesla CEO says bought ventilators in China for U.S.\n",
      "“The mainstream media pretended there was a deadly surge in COVID cases thanks to Wisconsinites voting.”\n",
      "Television viewers can drastically lower the TV ratings for Donald Trump's inauguration by changing the channel.\n",
      "Florida ranks first in the nation for access to free prekindergarten.\n",
      "Searching for any three-digit number followed by \"new cases\" on Google provides evidence that the COVID-19 pandemic was manufactured. \n",
      "Cervical cancer in Africa is \"fully preventable with basic education, screening and vaccines.\n",
      "Poll shows a partisan split over virus-era religious freedom.\n",
      "College student in Boston diagnosed with measles.\n",
      "Medical school get $3.7M to address geriatric care shortage.\n",
      "The number of people detained under the Mental Health Act has increased by 47% in ten years.\n",
      "A photograph shows three anti-lockdown protesters hanging on crosses alongside a McDonald's in order to protest COVID-19 stay-at-home orders.\n",
      "     In   an effort preserve the mainstream chronology of human evolution, the   Smithsonian destroyed skeletal remains of giant humans found across the   U.S.     \n",
      "Nursing homes with COVID-19 outbreaks named in Wisconsin.\n",
      "Reverse your diabetes -- and you can stay diabetes-free long-term\n",
      "The murder rate in Atlanta is on the rise this year.\n",
      "Deadly eruption hits New Zealand volcano tourist town hard.\n",
      "Study Suggests Special MRI Might Help Diagnose Autism\n",
      "Donald Trump Says John McCain \"has done nothing to help the vets.\n",
      "Deaths unrelated to COVID-19 are routinely being attributed to the virus in order to make it seem worse than it is.\n",
      "A viral video shows a newborn baby delivered inside an intact amniotic sac.\n",
      "“President Trump just announced that the ‘biological’ lab in Wuhan where the COVID-19 virus was created was ‘funded’ by President Barak (sp) Hussein Obama in 2015 to the tune of $3,800,000 American dollars!”\n",
      "The GOP’s health bill will protect people with pre-existing conditions \"every bit as well as Obamacare did.\n",
      "IVF: Newer ‘eSET’ procedure reduces risk of multiple births\n",
      "Scott Brown Says Jeanne Shaheen \"voted to pave the way for a new national energy tax.\n",
      "Sit back and relax to brain wave music\n",
      "Facebook post Says the Asian, Hong Kong, swine and bird flus each “killed more people than coronavirus.”\n",
      "As China builds biotech sector, cash floods U.S. startups.\n",
      "The \"federal government is going after school districts, trying to force them to let boys shower with little girls.\n",
      "In a First, Gene Therapy Halts a Fatal Brain Disease\n",
      "Arkansas may revoke retailers’ inactive medical pot licenses.\n",
      "Scientists who took chemistry into cyberspace win Nobel Prize.\n",
      "Battle ropes become popular go-to fitness tools in U.S. gyms.\n",
      "We have invested record funding in protecting our environment.\n",
      "Taco Bell recalled two million pounds of meat due to the possibility of contamination by metal shavings.\n",
      "U.S. eclipse watchers howl at Blood Wolf Moon but bitter cold cancels other festivities.\n",
      "Ohio hospital faces lawsuits over Legionnaires’ outbreak.\n",
      "WHO says 4 new Saudi cases of MERS virus, one fatal.\n",
      "2019 coronavirus can live for \"up to 3 hours in the air, up to 4 hours on copper, up to 24 hours on cardboard up to 3 days on plastic and stainless steel.”\n",
      "Tesla plans to supply FDA-approved ventilators free of cost: Musk.\n",
      "108 people died from Covid-19 in China on February 10th, one of the worst days so far.\n",
      "The legislation ... that Senator McCain supports would provide the authority for the federal government to surveille American citizens in their own country without any suspicion whatsoever that they're engaging in discussions with terrorists or about criminal activity.\n",
      "NY officials warn of rising flu cases, hospitalizations.\n",
      "Scientists reconstruct skeleton of elusive, pre-historic human.\n",
      "Anti-gravity treadmills get patients running again after knee surgery\n",
      "Nursing home sues state over banned in-house beauty salon.\n",
      "Cold, wet weather may help spread deadly pig virus: USDA.\n",
      "Congress approved a bill in November 2017 that makes it a federal crime to play Christmas music before Thanksgiving.\n",
      "At least seven missing in Alabama after deadly weekend tornadoes.\n",
      "New York City Council votes to add e-cigarettes to smoking ban.\n",
      "Officials: New California measles cases involve travelers.\n",
      "A photograph shows an STD-related infection known as 'blue waffle disease.'\n",
      "Surgeon fined $3K for removing kidney he thought was tumor.\n",
      "Allergan Reports Topline Phase II Data Supporting Advancement of BOTOX® (onabotulinumtoxinA) for the Treatment of Major Depressive Disorder (MDD)\n",
      "Reverend urges Lee to act during Nashville MLK Day event.\n",
      "Black cats in Vietnam are being killed and consumed as a COVID-19 cure.\n",
      "Stanford catcher Handley’s backup plan is career in medicine.\n",
      "John and Carole Paladino were slated to testify before a grand jury as part of an investigation against HIllary Clinton before they died in an explosion in July 2018.\n",
      "Next year, \"you will be mandated by federal law to get rid of your existing light bulbs.\n",
      "UMass: More than 5,000 vaccinated after meningitis outbreak.\n",
      "Innovative triple pill significantly lowers blood pressure, study finds\n",
      "On COVID-19, Donald Trump said that “maybe if you drank bleach you may be okay.”\n",
      "Viral text accurately outlines how biotechnology company Moderna is linked to Dr. Anthony Fauci, Bill Gates, George Soros, and Jeffrey Epstein.\n",
      "If you have a runny nose and sputum, you have a common cold.\n",
      "NGOs like Doctors Without Borders are profiting from human smuggling in the Mediterranean Sea.\n",
      "Immunotherapy shows promise in preventing leukemia relapse\n",
      "Mexican troops provided aid to U.S. residents in the chaotic aftermath of Hurricane Katrina.\n",
      " Warnings about Powassan Virus, a virus transmitted by ticks that can be deadly or cause permanent neurological symptoms, circulated as summer of 2017 began. \n",
      "The U.S. has now spent more on reconstructing Afghanistan than was spent on the Marshall Plan and the reconstruction of Europe.\n",
      "Anti-terrorism presentation warns about women in burqas buying up cell phones.\n",
      "A $10 million fire fee proposal in St. Petersburg was \"inspired\" by Gov. Rick Scott.\n",
      "Can brain disease explain Aaron Hernandez’s behavior?.\n",
      "Price tag on gene therapy for rare form of blindness: $850K.\n",
      "Study Suggests Breastfeeding May Lower Risk of Childhood Leukemia\n",
      "“U.S. hospitals are preparing for 96 million coronavirus infections and nearly half a million deaths, leaked documents reveal.”\n",
      "Prostate cancer blood test could transform treatment, say scientists\n",
      "Former Baltimore lawmaker charged with bribery, fraud.\n",
      "Allen West Says the coronavirus has a “99.9% recovery rate” in Texas.\n",
      "Voters across Texas have witnessed their votes switch from \"straight Republican\" to Democrat on compromised voting machines.\n",
      "  The Centers for Disease Control and Prevention (CDC) has advised young mothers to delay breastfeeding because studies show that it could make vaccines less effective for their babies.  \n",
      "Bone drug cuts risk of breast cancer\n",
      "An April 2020 image shows the United Kingdom's flag projected onto the Matterhorn as a show of solidarity during the COVID-19 pandemic.\n",
      "Wyoming records first 2 vaping illness cases.\n",
      "Michael Bloomberg named World Health Organization ambassador.\n",
      "Thailand rolls out cannabis clinic based on traditional medicine.\n",
      "Mexico official calls diet a factor as coronavirus death toll climbs.\n",
      "The House Democrats' so-called 'stimulus' has been stuffed with an astonishing $335 million to fund prevention programs of sexually transmitted diseases.\n",
      "NUS researchers use AI to successfully treat metastatic cancer patient\n",
      "U.S. doctors' group says just stop vaping as deaths, illnesses rise.\n",
      "Ten rivals join with NIH to search for new drugs - WSJ.\n",
      "Thailand reports case of coronavirus from China  .\n",
      "“Pelosi’s new coronavirus bill allows illegals to receive billions in relief funds in past, current, and future payments.”\n",
      "Hillary Clinton Says Bernie Sanders \"has reversed his position on immunity\" for gun manufacturers and sellers.\n",
      "Widespread flooding ahead for snowy western New York: officials.\n",
      "For kids’ coughs, silence is golden and sweet\n",
      "Millions of pigs culled as swine fever spreads through Asia.\n",
      "Ardern's online messages keep spirits up in New Zealand's coronavirus lockdown.\n",
      "Owning a chihuahua can help cure a person of asthma.\n",
      "Ex-NFL player, doctor are arrested in Georgia opioid case.\n",
      "EPA boss visits polluted mining sites in Montana.\n",
      "When U.S. President Donald Trump took office, he inherited a “bare” Strategic National Stockpile that lacked an adequate supply of mechanical ventilators that would have aided the nation at the start of the 2020 COVID-19 pandemic.\n",
      " A former Marine called out Sarah Palin for blaming her son, Trek Palin’s, arrest for domestic violence and weapons violations on post-traumatic stress disorder (PTSD) in an open letter. \n",
      "Softer restaurant music, lighting can help cut calories: study.\n",
      "Thanks in part to our all-of-the-above strategy for American energy,\" the United States generates \"more natural gas than anybody.\n",
      "Surgeons Move From Knees to Hips\n",
      "Locks of Love sells most donated hair for profit and charges ailing children exorbitant amounts for wigs.\n",
      "More than 100,000 women in Texas \"have attempted to self-induce abortion in the past year alone.\n",
      "Clinton associate Vince Foster shot himself three times in the back of the head to avoid testifying against Hillary Clinton.\n",
      "You don't know if this (the H1N1 vaccine) is gonna cause neurological damage like it did in the 1970s.\n",
      "NFL players protesting police brutality are doing so because they have many children with different women, leading their families into lives of crime.\n",
      "Whale snot, bat sex win 2010 IgNobel spoof prizes.\n",
      "The Baucus health care bill would require taxes on medical devices such as X-ray machines, female condoms, HIV tests and surgical needles.\n",
      "A video shows the liquid from a can of BANG Energy bursting into flames. \n",
      "There is a growing body of evidence that radiation in excess of what the government says are the minimum amounts you should be exposed to are actually good for you and reduce cases of cancer.\n",
      "Social worker sentenced to jail for having sex with patient.\n",
      "Allergy treatments enter a new era — with a focus on stopping reactions before they start\n",
      "Shingles Vaccine Looks Like a Safe Bet for Seniors: Study\n",
      "108 mins that stunned the world: Russia honors Gagarin.\n",
      "Eroding trust in vaccines leaves populations vulnerable, global study finds.\n",
      "Study finds Americans are eating more - and more often.\n",
      "Flood waters rise, eight killed as Florence dumps 'epic' rain on Carolinas.\n",
      "Soupy Sales was once suspended for asking his young television viewers to send him \"little green pieces of paper\" taken from their parents' wallets.\n",
      "Usain Bolt brings his e-scooter to Japan despite regulatory road bumps.\n",
      "New Mexico OKs more businesses to open, mandates masks.\n",
      "Black women's hair loss tied to braiding, weaving: study.\n",
      "Testing hand-grip strength could be a simple, low-cost way to predict heart attack and stroke risk\n",
      "Immunotherapy reduces cardiovascular risk in rheumatoid arthritis\n",
      "Morning-after pill sold over the counter in Canada.\n",
      "“Every election year has a disease” ... SARS in 2004; avian flu in 2008; swine flu in 2010; MERS in 2012; Ebola in 2014 and 2018; Zika in 2016 and the coronavirus in 2020.\n",
      "Minnesotans are drinking water contaminated by nitrate.\n",
      "A ham and cheese sandwich on one slice of bread is the responsibility of the USDA ... But a ham and cheese sandwich on two slices of bread is the responsibility of the Food and Drug Administration.\n",
      "Sleep apnea patient finds rest with implant device: \"It saved my life\n",
      "Your child's brain on math: Don't bother?.\n",
      "Injection to treat alcoholism OK’d\n",
      "Cancer the latest health woe for resilient Justice Ginsburg.\n",
      "Scottish government identifies case of mad cow disease.\n",
      "Children's radio host Uncle Don inadvertently uttered a shockingly derogatory remark about youngsters that was caught on an open mic.\n",
      "Over 20 dead in U.S. polar vortex, frostbite amputations feared.\n",
      "Nothing was done. I mean, $25 million was spent, but we don’t have that (gun ownership) database.\n",
      "200 consumer laws were destroyed\" in 2011 when Gov. Scott Walker signed Act 92.\n",
      "Texas: Evangelical women’s health group owes state $1.5M.\n",
      "Drug could fight effects of aging\n",
      "The celebration of Christmas was illegal in the United States until 1836.\n",
      "Leo Berman Says the hospital listed on Barack Obama’s just-publicized long-form birth certificate denies the president was born there.\n",
      "Facebook post Says Dr. Anthony Fauci “stands to lose 100 million dollars on Bill Gates ‘vaccine’ for the coronavirus. Because he invested in this vaccine.”\n",
      "Facebook post Says COVID-19 came to the United States in 2019.\n",
      "Judge rules EPA failing to curb pollution blowing east.\n",
      "South Dakota reports 3 flu deaths, 1st of the season.\n",
      "The Drug Enforcement Agency (DEA) will be reclassifying marijuana as a Schedule 2 drug in August 2016.\n",
      "There is a federal criminal law that says it's a crime to transport dentures across state lines.\n",
      "“Florida is doing over five times better” than New Jersey and New York in COVID-19 deaths per million people.\n",
      "We have no [trade] deficit [with Canada], but that doesn't include energy and timber. But when you do we lose $17 billion a year.\" \n",
      "Ohio abortion clinic lands license needed to stay open.\n",
      "If Cory Gardner gets his way, you'd better stock up on condoms.\n",
      "Several widely-available cheeses are partially made from wood.\n",
      "The president's health care proposals will cause \"most Americans to have their premiums increased, not decreased, and hundreds of millions of people lose their current insurance coverage.\n",
      "An 1875 report by the Horseless Carriage Committee warned about the dangers of gasoline-fueled vehicles.\n",
      "According to a government supplier of emergency products, the Disaster Assistance Response Team was told to be prepared to be activated in the month of October for an outbreak of Ebola.\n",
      "Protesters vent their anger as UN climate talks stutter.\n",
      "“Kids are less likely to get it (COVID-19). You know, they’re less likely to spread. So I think there’s some pretty good data out there that will help alleviate some of the concerns.”\n",
      "Tim Kaine Says \"Donald Trump is a guy who has called for privatization\" of the Veterans Administration.\n",
      "Number of Americans killed by terrorism in the last decade: 24. Number of Americans killed by guns in the last decade: 280,024.\n",
      "By the end of 2015, more than 1,300 people will have died on Georgia roads. One of out evey four fatalities resulted from drunken driving.\n",
      "In Liberia, \"a girl is more likely to be married by 18 than to know how to read.\n",
      "Senate OKs Coast Guard bill with ballast water compromise.\n",
      "John McCain Says Obama called Sarah Palin a pig.\n",
      "Louisiana, Mississippi top nation in worst West Nile illness.\n",
      "State high court rules NYC ban on large sodas is illegal.\n",
      "Under Obamacare, people who \"have a doctor they’ve been seeing for the last 15 or 20 years, they won’t be able to keep going to that doctor.\n",
      "Virtual Colonoscopy Can Spot Cancers Outside Colon\n",
      "The Titanic went to a watery grave carrying a cursed mummy in its hold. \n",
      "Tourist may have brought measles to Southern California.\n",
      "Maine lawmakers’ bills focus on solar energy, health care.\n",
      "Personalized treatment for those in blood pressure 'gray zone'\n",
      "In a government shutdown, \"what they are really doing is shutting down our military.\n",
      "A Muslim immigrant in Michigan can list his second, third or fourth wives as \"extended family\" and qualify for welfare.\n",
      "CT Scans Can Reduce Lung Cancer Deaths, Study Finds\n",
      "Surprising news about teens, marijuana, and health issues. It’s all good.\n",
      "Nazi Luftwaffe commander Hermann Goering  proclaimed that although \"the people don't want war,\"  they \"can always be brought to the bidding of their leaders.\n",
      "Researchers use smart phone to make a faster infection detector\n",
      "Lipogen Targets PMS/PMDD Relief, Naturally\n",
      "Medical group: 953 vaccines, tests may be ineffective.\n",
      "After my first year as governor, I was one of the most unpopular governors, maybe the most unpopular governor in the country. ... It changed.\n",
      "J&J, U.S. states settle hip implant claims for $120 million.\n",
      "Ocean coastline, closed to shellfish harvesting due to toxin.\n",
      "Americans are 25x more likely to be shot & killed than others in developed countries.\n",
      "In 2011, texting surpassed alcohol as the leading contributing factor in teen driving deaths.\n",
      " This is a forwarded self   defense tip that says if you do not have pepper spray to use a can of   wasp spray to stop an assailant. Wasp spray shoots a stream up to twenty   feet and can temporality blind an attacker.     \n",
      "U.S. states, cities sue to block Trump 'conscience' rule for healthcare workers.\n",
      "In August 1997, the Baltimore Orioles deliberately created a lighting malfunction before a game to keep Cal Ripken's consecutive game streak intact.\n",
      "David Prosser Says Supreme Court candidate JoAnne Kloppenburg’s record as a state Justice Department lawyer consists only of the prosecution of cases regarding regulation of docks.\n",
      "Under-Skin Defibrillators Seen Closer to Reality\n",
      "California to require abortion medication at public colleges.\n",
      "Exhausted polar bear wanders into Siberian city.\n",
      "New study finds EPA and DHA omega-3s lower risk of coronary heart disease\n",
      "Michigan expands list of conditions medical pot can treat.\n",
      "A hand-held police radar unit successfully tracked a military aircraft on maneuvers, nearly causing the aircraft to fire a missile in response.\n",
      "Health advocates call for action to stem youth e-cig use.\n",
      "Radio Marti and TV Marti have spent more than $500 million to reach less than 1 percent of the Cuban population.\n",
      "The world suicide rate plummeted following Logan Paul's \"suicide forest\" video.\n",
      "North Carolina is one of four states\" that hasn't opened gyms.\n",
      "Trapped Thai boys being closely watched for health problems.\n",
      "“Clearly, the Obama administration did not leave any kind of game plan for something like this.”\n",
      "Facebook post Says the CDC now says that the coronavirus can survive on surfaces for up to 17 days.\n",
      "Drones to deliver vaccines, blood and drugs across Ghana.\n",
      "Bacteria formed on cut onions and potatoes are responsible for more food poisoning cases than spoiled mayonnaise.\n",
      "Repeat blood clots more common with stents: study.\n",
      "Study fuels low-fat vs. low-carb debate\n",
      "Newt Gingrich \"co-sponsored a bill with Nancy Pelosi that would have given $60 million a year to a U.N. program supporting China’s brutal one-child policy.\n",
      "Bayer says won't tolerate unethical behavior as France probes Monsanto file.\n",
      "Republicans hope Trump amenable to food stamp restrictions.\n",
      "A photograph shows a child in a famine-stricken country crawling on the ground while a vulture waits in the background.\n",
      "State sued over involuntary psychiatric boarding.\n",
      "Official: Montana nursing home virus outbreak appears over.\n",
      "Study shows children's best hope for the potassium and fiber missing in their diets is potatoes\n",
      "Research even shows that sending more girls to school can boost an entire country’s GDP.\n",
      "Using toilet paper as a barrier between your derriere and a toilet seat poses more health risks than just sitting down without a barrier.\n",
      "Brigid Shea Says Austin Mayor Lee Leffingwell voted for a toll lane on MoPac.\n",
      "Erbitux OK for colorectal cancer patients with genetic marker\n",
      "Quake amputees embody resilience in broken Haiti.\n",
      "A man was arrested after sugar from his Krispy Kreme donuts tested positive for methamphetamine during a traffic stop.\n",
      "U.S. woman's altruism starts chain of five kidney swaps, extending lives.\n",
      "Ebola patient dies in Congo, first case in 50 days.\n",
      "If you ask Amazon’s Alexa about the origin of the coronavirus pandemic, it says “the government planned” it.\n",
      "Oklahoma top court clears way for Purdue, J&J, Teva to face opioid trial.\n",
      "Task force offers guidelines to treat rat lungworm disease.\n",
      "Melania Trump listens as teens share experiences with vaping.\n",
      "Under those eight years before (Barack) Obama came along, we didn’t have any successful radical Islamic terrorist attack in the United States\" since Sept. 11, 2001.\n",
      "Study finds immune system can cause reaction to cancer drug.\n",
      "World Superbike star Nicky Hayden passed away on 19 May 2017.\n",
      "Bill would OK land swap for Arizona veterinary program.\n",
      "Magnetic brain stimulation causes weight loss by making gut bacteria healthier\n",
      "Before his death, physicist Stephen Hawking declared his Christian faith after a visit with Pope Francis.\n",
      "White House adviser Valerie Jarrett once said she seeks \"to help change America to be a more Islamic country.\n",
      "Mixed Outcomes in Laparoscopy for Prostates\n",
      "Arkansas approves new date for concert shut down by virus.\n",
      "Michigan mom pushes for meningitis vaccination requirement.\n",
      "Blood test that could predict arthritis risk\n",
      "New genetic links to same-sex sexual behavior found.\n",
      "Men in Uxbridge and South Ruislip live 14 years longer than they do in Stockton North.\n",
      "Study: Millions should stop taking aspirin for heart health.\n",
      "The purpose of the 'crash' or 'brace' position in airliners is to kill passengers quickly in the event of an crash, or to preserve their remains so as to make identification of bodies easier.\n",
      "Ted Cruz tried to ban contraception\" five times.\n",
      "A viral photograph depicts soft serve \"cannabis ice cream.\n",
      "Facebook post Says former Federal Reserve Chairman Alan Greenspan said that \"if the workers are more insecure, that's very healthy for the society\" because \"they'll serve the masters gladly and passively.\n",
      "Three Maryland coronavirus patients fully recovered and are able to return to everyday life.\n",
      "Thanks to #ObamaCare, average E.R. wait in California is 5 hours.\n",
      "An alligator captured in the Chicago River in June 2008 was the first such creature ever found in that body of water.\n",
      "Amid the COVID-19 outbreak, “Minnesota now has the highest unemployment rate in U.S. history.”\n",
      "Aspirin cuts heart attacks, not deaths or strokes\n",
      "Attacks on Planned Parenthood \"come at a time when the poverty rate among women is the highest in nearly two decades and 1 in 5 women under 65 don’t have access to health care.\n",
      "Vice President Mike Pence said that White House aide Rob Porter's purported domestic abuse was supported by the Bible.\n",
      "White House moves toward promoting face masks to fight virus.\n",
      "Legal pot sales begin in Uruguay under landmark 2013 law.\n",
      "Republican candidate for governor Nathan Deal \"explicitly voted to fund abortions ...\n",
      "Emergency rooms account for \"2 percent of all health care spending.\n",
      "Warren’s ‘Medicare for All’ plan reignites health care clash.\n",
      "New York Mayor Bill de Blasio was previously named \"Warren Wilhelm Jr.\" and once supported the socialist government of the Sandinistas in Nicaragua.\n",
      "Judge: Treatment of Tennessee inmates with hep C improving.\n",
      "Mel Gibson was the inspiration for the film \"The Man Without a Face.\n",
      "San Francisco Bay Area Medicare kickbacks scheme charged.\n",
      "UNC Hearing Loss Experts Lead Clinical Trials of FDA-Approved Hearing Implant\n",
      "New York has the third lowest rate of gun-caused death in America.\n",
      "Rick Perry thinks \"injecting 11- and 12-year-old girls with a controversial drug (the HPV vaccine), without a parent's consent, is a good idea.\n",
      "Chicago coyote captured after 2 suspected attacks reported.\n",
      "US choir outbreak called ‘superspreader event’ in report.\n",
      "A photograph shows a Japanese Giant Emperor Moth. \n",
      "US-built capsule with a dummy aboard docks at space station.\n",
      "Study: Air pollution greatly affects St. Louis’ poorer areas.\n",
      "North Korea is now allowing the open practice of Christianity.\n",
      " This is a prayer request for   Nick Doize of Katy, Texas who is suffering from acute lymphoblastic   leukemia.  The email also requests readers add their names to a   list at the bottom and forward it to friends.  It also instructs   that when the list reaches 1000 names to email it to the originator.     \n",
      "Possible closure of Ohio clinic shows new tactic in U.S. abortion clash.\n",
      "Idaho bighorns killed after contact with domestic sheep herd.\n",
      "Back Pain: Revolution: Replacement Disc Surgery\n",
      "Bubble cars to provide jolt to Paris motoring.\n",
      "New antibody drug helps cells kill blood cancer.\n",
      "Facebook post Says Goodwill used the pandemic “to fire all of their employees instead of laying them off.”\n",
      "Medtronic atrial fibrillation system shines in study\n",
      "Pakistan court frees ex-PM Sharif for medical treatment.\n",
      "New test can detect autism in children, scientists say\n",
      "Trump scrambles to broaden coronavirus testing options.\n",
      "Scientists angry at UK visa denials for African, Asian researchers.\n",
      "Home for the Holidays? Hold the sugar, please.\n",
      "Iowa research lab identifies new strain of deadly pig virus.\n",
      "Too fat? Study fingers one \"thrifty gene\" suspect.\n",
      "Less Radiation OK for Breast Cancer\n",
      "Central Park hospital tents housed thousands of abused children released from underground captivity.\n",
      "Vermont governor plans incremental health insurance reform.\n",
      "A photograph shows the heart of a child who contracted a fatal case of heartworm from kissing and sleeping with a dog.\n",
      "Death industry reaps grim profit as Japan dies.\n",
      "“Coronavirus — 22. Clintons — 39.”\n",
      "New Stroke Treatment Saves Lives, Improves Recovery\n",
      "Children should avoid school bus stops due to a credible threat of human trafficking.\n",
      " DEW brand bottled water sold in Nigeria and other parts of Africa has caused at least 180 deaths and has been known to infect those who drink it with the Ebola virus. \n",
      " 99-year-old billionaire David Rockefeller has successfully undergone his sixth heart transplant surgery in the last 38 years. \n",
      "Senators draw on own experiences to chastise drug companies.\n",
      "Boiling the same water twice will make your water dangerous to drink.\n",
      "Despite keeping distance from national media interviewers, \"I did local press all along, the last three months.\n",
      "Some Alabama residents likely exposed to measles.\n",
      "Earthquake in Turkey-Iran border region kills nine, injures more than 100.\n",
      "Doctors: Nearly 8000 Malaria cases in Sudan province.\n",
      "Constant migraines may be from an unlikely culprit: a deviated septum\n",
      "Botox use on migraines gains support\n",
      "In December 1915, San Diego agreed to pay $10,000 to \"rainmaker\" Charles Hatfield to bring an end to the region's drought; over the next few weeks the city was inundated by rain and suffered one of the worst floods in its history.\n",
      "New research to treat acute malnutrition\n",
      "Members of the Royal British Legion have been barred from selling poppies to commemorate Remembrance Day in certain areas for fear of \"upset minorities.\n",
      "Seth Rogen, Bette Midler, and other Hollywood \"liberal heroes\" were arrested during an Oscar party drug raid.\n",
      "In the last ten years no one has died of measles in the U.S., but more than 100 people have died due to the MMR vaccine.\n",
      "Butchers just cut cancer out of diseased meat and sell the rest of the contaminated carcass.\n",
      "American Samoa to begin mass measles vaccination this week.\n",
      "Haitian orphan gets nation's first 3-D printer prosthesis.\n",
      "Asthma pill could reduce symptoms in severe sufferers\n",
      "South Dakota plans mass testing in elder care facilities.\n",
      "Winona assisted living facility offers housing for students.\n",
      "Nobel winner and organ transplant pioneer Joseph Murray dies at 93.\n",
      "All the really great programs in American history, Social Security, was done without Republicans. Medicare was done without Republican support until the last vote where they realized they had to get on board.\n",
      "Washington state man who traveled to China is first U.S. victim of coronavirus.\n",
      "Wisconsin sold fresh water to California, helping that state's dairy industry, and \"lost a bunch of jobs (and) a bunch of farmland.\n",
      "A world first: AIDS vaccine cuts the risk of HIV infection by 31 percent in large Thai study\n",
      "Low-Calorie Diet May Lead to Longer Life\n",
      "New recommendations for managing menopausal symptoms in breast cancer survivors\n",
      "You cannot catch Covid-19 from touching surfaces.\n",
      "Southern Illinois University starts marijuana, hemp research.\n",
      "Crisis averted, hospital ship leaves LA; treats 77 patients.\n",
      "U.S. obesity epidemic propels fitness as career.\n",
      "North Carolina man charged for not treating syphilis.\n",
      "Biblical bad guys the ancient Philistines came from Europe, DNA shows.\n",
      "To deprive\" underprivileged children \"of a meat-based protein during school lunch is most likely depriving them of their only source of protein for the day.\n",
      "Experimental Test May Warn of Premature Births\n",
      "Inoculations give endangered California frog a shot at life.\n",
      "   An email claims that the use of antiperspirants is the leading cause of breast cancer.  The theory is that toxins are released by sweat, especially under the arms, and antiperspirants are blocking the release of the toxins, allowing them to build up, and the result is cancer.  It also claims that nearly all breast cancers are in the upper, outside quadrant of the breast, near the armpits. \n",
      "Moscow restricts Easter week church service as coronavirus cases mount.\n",
      "The youngest mother on record was a Peruvian girl who give birth at five years old.\n",
      "Marijuana dealers are using the popular game app Pokémon GO to hook children on drugs.\n",
      "India's coronavirus cases nears 30, hits major payments firm.\n",
      "New Data Shows Irreversible Electroporation Nearly Doubles Overall Survival of Patients with Locally Advanced Pancreatic Cancer When Added to Standard Therapy\n",
      "U. S. House Speaker Nancy Pelosi declared during the COVID-19 pandemic that Congress would be out of session \"unless there is an emergency.\n",
      "Drugmaker will donate meds for US push to end HIV epidemic.\n",
      "Testosterone replacement therapy may slow the progression of COPD\n",
      "As a result of Roe vs. Wade, \"America’s maternal mortality rate dropped dramatically.\n",
      "U.S. says UCB cough medicine overdose can kill.\n",
      "Alan Grayson Says Florida Gov. Rick Scott’s cuts to education are the same as his proposed corporate income tax rate reduction.\n",
      "Lois Kolkhorst Says $500 billion in Medicare cuts are coming.\n",
      "A day fighting COVID-19: U.S. hospital staff share hardest moments on shift.\n",
      "In 2006, Planned Parenthood performed more prevention services and cancer screenings than abortions, but in 2013, there were more abortions.\n",
      "Hillary Clinton Says Donald Trump \"has been talking about the option of using a nuclear weapon against our Western European allies.\n",
      "Marijuana Eases Spasticity in MS Patients\n",
      "Governor works with broadcasters to address mental health.\n",
      "Microwave Technique Fights Lung Tumors\n",
      "Obesity Surgery Helps Diabetic Patients Kick Medicines\n",
      "Missouri \"is leading the country when it comes to improving services for mental and behavioral health. Innovation is happening right here.\n",
      "From Eurovision host to coronavirus care, Rotterdam venue changes tune.\n",
      "Georgia woman gets life sentence in boyfriend’s slaying.\n",
      "Manuka honey, as a topical treatment, is better than all known antibiotics.\n",
      "China expands switch from polluting coal heating in 2018: environment minister.\n",
      "A video shows the aftermath of a school prank in which a student spiked lemonade with laxatives.\n",
      "New York tries to keep alive flavored e-cigarette ban.\n",
      "Rhode Island officials issue air quality alert.\n",
      "In Florida and elsewhere, GOP pressured over climate change.\n",
      "Dan Patrick Says \"566,000 crimes\" were \"made in Texas by criminal aliens in the last 6 years.\n",
      "Caravan migrants demanded $50,000 payments from the U.S. in order to go home.\n",
      "Italy coronavirus deaths jump by almost 800, government shuts most workplaces.\n",
      "President Donald Trump asked about the possibility of injecting people with disinfectant to treat COVID-19.\n",
      "Amazonian tribe study shows how human bodily bacteria is changing.\n",
      "Earl Blumenauer Says \"Every year air pollution protections are delayed, another 34,000 people will die prematurely.\n",
      "Hillary Clinton \"supports unlimited abortion on demand up until the moment of birth, including partial-birth abortion, with taxpayer funding.\n",
      "UK campaigners win appeal case over preventative HIV drug.\n",
      "Blogger Says the Chinese Communist Party \"will finally admit that the real source of the coronavirus is from ‘a lab in Wuhan’ linked to its covert biological weapon programs.\n",
      "A Fresno man turned up at a local emergency room carrying a 5-foot-long tapeworm he pulled out of his own intestine.\n",
      "Bipolar Treatment Comes Into Question\n",
      "Study sees 'severe and acute' emergency for world in coronavirus pandemic.\n",
      "Medtronic insulin pump beats injections in study\n",
      "Slovakia may force women to get pre-abortion ultrasound.\n",
      "California's governor is allowing people who are HIV-positive donate blood\n",
      "Tick, tick, tick: Alaska braces for invading parasites.\n",
      "Easing school lunch regulations \"is not reducing the nutritional standards whatsoever.\n",
      "Sununu appointments to shape judicial, education policy.\n",
      "Sanofi Obesity Drug Helps Sugar Levels Of Diabetics in Study\n",
      "Protesting Poles engage in drive for abortion rights.\n",
      "'You have stolen my dreams,' an angry Thunberg tells U.N. climate summit.\n",
      "FDA approves TB pill that cures more hard-to-treat patients.\n",
      "California legislators focus on climate, immigration, roads.\n",
      "David Attenborough said that \"I am unaware of any animal that is as cruel as Israelis\" as part of a scathing attack on the country's treatment of the Palestinian people.\n",
      "Testing for more breast cancer genes offers useful information\n",
      "Here are some of the things that are more popular than Congress: hemorrhoids, Nickelback, traffic jams, cockroaches, root canals, colonoscopies, herpes. Even herpes, they couldn’t beat herpes in the polls.\n",
      "The CIA found a \"dead man's switch\" on the computer of the deceased father of a doctor treating Hillary Clinton for dementia.\n",
      "A Russian woman was embalmed alive due to the intravenous administration of formalin.\n",
      "Beer brewers toast Australian gluten-free barley.\n",
      "FDA warns of asbestos in Claire’s makeup; company disputes.\n",
      "Alarmed by instances of Marines imperiling their health by eating liquid laundry detergent, top Marine Corps leaders issued a warning to all junior troops to stop participating in the Tide Pod Challenge.\n",
      "Virus delay, early ice melt challenge Arctic science mission.\n",
      "Rick Santorum Says Howard Zinn, \"an anti-American Marxist,\" wrote \"the most popular textbook that's taught in our high schools in America.\n",
      "30 years on, AIDS fight may tilt more to treatment.\n",
      "Mother's stand-off with British authorities over medicinal cannabis stirs debate.\n",
      "Those who go swimming less than one hour after eating will be taken by a cramp and drown.\n",
      "Paralyzed California man recounts re-learning to walk via computer.\n",
      "2nd Ebola vaccine to be used in Congo, as UN efforts slammed.\n",
      "Under U.S. President Donald Trump, federal authorities are confiscating orders of personal protective equipment (PPE) from local governments amid the COVID-19 pandemic.\n",
      "Gene trawl shows curing cancer harder than thought.\n",
      "The Newfoundland town of Gander played host to thousands of airline passengers stranded there when American airspace was closed after the September 11 terrorist attacks.\n",
      "Jaws, the prequel: Scientists find the 'Model T Ford' of sharks.\n",
      "'Sesame Street' to welcome first autistic Muppet.\n",
      "UK confirms two more cases of bird flu on turkey and pheasant farms.\n",
      "New genetic links to same-sex sexuality found in huge study.\n",
      "A social media post correctly contextualizes the 30,000 approximate gun deaths each year in the United States.\n",
      "The state of Florida has seen \"double-digit drops\" in alcohol use among teens.\n",
      "Officials probe respiratory illness at Quincy veterans’ home.\n",
      "US regulators clear path for genetically modified salmon.\n"
     ]
    }
   ],
   "source": [
    "with open(\"pubhealth/pubhealth_dev.json\") as file1:\n",
    "    for line1 in file1:\n",
    "        data = json.loads(line1)\n",
    "        claim1 = data['claim']\n",
    "        anum+=1\n",
    "        print(claim1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 83,
   "id": "e378ef85",
   "metadata": {
    "collapsed": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Bat from Shawnee County tests positive for rabies.\n",
      "More infected in fresh wave of China bird flu - WHO.\n",
      "Indonesian barber gears up to groom during coronavirus.\n",
      "Canada has legalized euthanasia, enabling parents to \"kill disabled children.\n",
      "Selenium Supplements Might Give Modest Benefit Against Cholesterol\n",
      "Raised for meat in South Korea, dogs head for new homes in U.S.\n",
      "Every day, four North Carolinians die from a medication or drug overdose.\n",
      "  Up to 70% of Americans have been infected with a “Vampire Fungus” from eating unhealthy foods that causes weight gain, skin problems and indigestion.   \n",
      "J&J recalls 33,000 bottles of baby powder as FDA finds asbestos in sample.\n",
      "Brain scans may help diagnose neurological, psychiatric disorders\n",
      "Ohio’s stockpile got its start after the attacks of Sept. 11.\n",
      "Coronavirus cases top half a million, protective gear lacking: WHO.\n",
      "Hearing concludes in Missouri abortion clinic licensing case.\n",
      "Evidence shows Zika virus turns fetus brains to liquid.\n",
      "I lowered taxes over the last two years.\n",
      "Public urged to avoid wild animals after rabid skunk cases.\n",
      "2 measles cases from exposure at Portland, Oregon airport.\n",
      "Gaza resumes coronavirus testing amid shortages.\n",
      "Hallmark greeting cards are made in China. \n",
      "Estrogen predicts breast cancer recurrence: study.\n",
      "Tim Canova Says Debbie Wasserman Schultz \"has voted for huge subsidies for the sugar industry ... as well as for delays in cleanups.\n",
      "A new Facebook feature enabling users to report problems by shaking their phones has caused some users to be inadvertently reported for abuse and suspended.\n",
      "“The coronavirus has made it to Mississippi and the lady that caught it wasn’t around nobody with it which means it is airborne. That means if the wind blows it your direction you’ll have it also.”\n",
      "Can blood from coronavirus survivors treat the newly ill?.\n",
      "Top Nigerian president aide, state governor test positive for coronavirus.\n",
      "One of the Planned Parenthood videos shows \"a fully formed fetus on the table, its heart beating, its legs kicking, while someone says, 'We have to keep it alive to harvest its brain.' \n",
      "Six new cases of MERS virus hit Saudi Arabia, UAE.\n",
      "Both real and virtual colonoscopies work: report.\n",
      "Disneyland tower suggested as Legionnaires’ disease source.\n",
      "Doors singer Jim Morrison has been found alive in a Paris retirement home.\n",
      "Baby aspirin linked to reduced cancer deaths\n",
      "What I have done -- and this is unprecedented ... is I've said to each agency ... 'look at regulations that are already on the books and if they don't make sense, let's get rid of them.'\n",
      "The GOP’s health bill will protect people with pre-existing conditions \"every bit as well as Obamacare did.\n",
      "The \"federal government is going after school districts, trying to force them to let boys shower with little girls.\n",
      "U.S. eclipse watchers howl at Blood Wolf Moon but bitter cold cancels other festivities.\n",
      "108 people died from Covid-19 in China on February 10th, one of the worst days so far.\n",
      "Locks of Love sells most donated hair for profit and charges ailing children exorbitant amounts for wigs.\n",
      "Whale snot, bat sex win 2010 IgNobel spoof prizes.\n",
      "Study shows children's best hope for the potassium and fiber missing in their diets is potatoes\n",
      "Quake amputees embody resilience in broken Haiti.\n",
      "Warren’s ‘Medicare for All’ plan reignites health care clash.\n",
      "New York has the third lowest rate of gun-caused death in America.\n",
      "In the last ten years no one has died of measles in the U.S., but more than 100 people have died due to the MMR vaccine.\n",
      "Winona assisted living facility offers housing for students.\n",
      "New Data Shows Irreversible Electroporation Nearly Doubles Overall Survival of Patients with Locally Advanced Pancreatic Cancer When Added to Standard Therapy\n",
      "Alan Grayson Says Florida Gov. Rick Scott’s cuts to education are the same as his proposed corporate income tax rate reduction.\n",
      "A Fresno man turned up at a local emergency room carrying a 5-foot-long tapeworm he pulled out of his own intestine.\n",
      "Tick, tick, tick: Alaska braces for invading parasites.\n",
      "1009 48 961 0\n"
     ]
    }
   ],
   "source": [
    "mnum=0\n",
    "nnum=0\n",
    "xnum=0\n",
    "anum=0\n",
    "with open(\"pubhealth/pubhealth_dev.json\") as file1:\n",
    "    for line1 in file1:\n",
    "        data = json.loads(line1)\n",
    "        claim1 = data['claim']\n",
    "        anum+=1\n",
    "        with open(\"llama2_data/pubhealth+0.9/references_0.9_test.jsonl\") as file:\n",
    "            flag=0\n",
    "            num=0\n",
    "            for line in file:\n",
    "                num+=1\n",
    "                question=line.split(\"\\\"\\\"> Assistant: \")[0]\n",
    "                claim=question.encode().decode('unicode_escape').split(\"Claim: \")\n",
    "                if len(claim)==1:\n",
    "                    claim=claim[0]\n",
    "                    #print('wrong',num,claim)\n",
    "                else:\n",
    "                    claim=claim[1]\n",
    "                if claim.strip()==claim1.strip():\n",
    "                    flag+=1\n",
    "            if flag==1:# flag==1:48;flag==2:961\n",
    "                nnum+=1\n",
    "                print(claim1)\n",
    "            elif flag==2:\n",
    "                mnum+=1\n",
    "            else:\n",
    "                xnum+=1\n",
    "print(anum,nnum,mnum,xnum)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a789bbc5",
   "metadata": {},
   "source": [
    "## 实验 "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "78e849f7",
   "metadata": {},
   "outputs": [],
   "source": [
    "numList=[202,207,192,245,239,242,175,177,184]#p9,p5,p1,w9,w5,w1,c1,c5,c9\n",
    "num=[192]\n",
    "filePath=['llama2_data/climate+0.9/','llama2_data/climate+0.5/','llama2_data/climate+0.1/',\n",
    "          'llama2_data/pubhealth+0.9/','llama2_data/pubhealth+0.5/','llama2_data/pubhealth+0.1/',\n",
    "          'llama2_data/wice+0.9/','llama2_data/wice+0.5/','llama2_data/wice+0.1/']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "a0abae92",
   "metadata": {},
   "outputs": [],
   "source": [
    "def identifyConflict(answer):\n",
    "    if \"here are no conflicting parts\" in answer or\"Conflicting parts not found\" in answer or \"here is no conflicting information\" in answer or \"no conflicting parts\" in answer or \"here is no conflict\" in answer or \"0 conflicts\"in answer or \"0 conflicting parts\" in answer  or \"0 Conflicting parts\" in answer or \"0 Conflicting parts found\" in answer or \"No conflict found\" in answer or \"P1 and P2 are not conflicting.\" in answer or\"do not contain conflicting\" in answer or \"No\\\"\" in answer or \"0\\\"\" in answer: \n",
    "        return True\n",
    "    else:\n",
    "        return False"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 83,
   "id": "93003f2b",
   "metadata": {},
   "outputs": [],
   "source": [
    "def check(ref,ref1):\n",
    "    if ref.strip()==ref1.strip():\n",
    "        return True\n",
    "    # \n",
    "    c1=ref.strip().split(\".\")\n",
    "    c2=ref1.strip().split(\".\")\n",
    "    if len(c1)>2 and len(c2)>2 and c1[-2]==c2[-2]:\n",
    "        return True\n",
    "    \n",
    "    c1=ref.strip().split(\"\\\\\\\\n\")[-1]\n",
    "    c2=ref1.strip().split(\"\\\\\\\\n\")[-1]\n",
    "    if c1==c2:\n",
    "        return True\n",
    "    c1=ref.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "    c2=ref1.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "    if len(c1)>2 and len(c2)>2 and c1[1]==c2[1]:\n",
    "        return True\n",
    "    uni=ref.strip().split('\\\\u')[-1][4:]\n",
    "    length=len(uni)\n",
    "    if ref1.strip()[-length:] == uni:\n",
    "        return True\n",
    "    return False"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "52f33058",
   "metadata": {},
   "source": [
    "# pubhealth+0.5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 627,
   "id": "a2b61cea",
   "metadata": {},
   "outputs": [],
   "source": [
    "tlist=[[] for _ in range(13)]\n",
    "flist=[[] for _ in range(13)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 628,
   "id": "187af456",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "206\n",
      "173\n",
      "34 0.1642512077294686\n",
      "185 0.893719806763285\n",
      "matched num= 414\n",
      "206\n",
      "142\n",
      "65 0.3140096618357488\n",
      "165 0.7971014492753623\n",
      "matched num= 414\n",
      "206\n",
      "169\n",
      "38 0.18357487922705315\n",
      "163 0.7874396135265701\n",
      "matched num= 414\n",
      "206\n",
      "152\n",
      "55 0.26570048309178745\n",
      "183 0.8840579710144928\n",
      "matched num= 414\n",
      "206\n",
      "153\n",
      "54 0.2608695652173913\n",
      "165 0.7971014492753623\n",
      "matched num= 414\n",
      "206\n",
      "171\n",
      "36 0.17391304347826086\n",
      "185 0.893719806763285\n",
      "matched num= 414\n",
      "206\n",
      "156\n",
      "51 0.2463768115942029\n",
      "180 0.8695652173913043\n",
      "matched num= 414\n"
     ]
    }
   ],
   "source": [
    "for i in range(7):\n",
    "    t=0\n",
    "    f=0\n",
    "    n=0\n",
    "    x=0\n",
    "    with open(filePath[4]+\"dataset_0.5.jsonl\") as file1:\n",
    "        for line1 in file1:\n",
    "            label=line1.split(\"label: \")[-1]\n",
    "            ref1=line1.split(\"Response: \")[0].split(\"Reference: \")\n",
    "            if len(ref1)==2:\n",
    "                ref1=ref1[1]\n",
    "            else:\n",
    "                ref1=ref1[1]+\"Reference: \"+ref1[2]\n",
    "            pre=n\n",
    "            flag=False\n",
    "            ref1=ref1[:-8]\n",
    "            mark=[]\n",
    "            if \"Reference: \" in ref1:\n",
    "                ref1=ref1.split(\"Reference: \")[0]\n",
    "            with open(filePath[4]+\"detections_\"+str(i+1)+\".jsonl\") as file:\n",
    "                for line in file:\n",
    "                    answer=line.split(\"Result: \")[1]\n",
    "                    ref=line.split(\"P2: \")[0].split(\"P1: \")[1]\n",
    "                    ref=ref.encode().decode('unicode_escape')\n",
    "                    ref=ref[0:-8]\n",
    "                    if ref.strip()==ref1.strip():\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                tlist[i].append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer): \n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                flist[i].append(ref1)\n",
    "       \n",
    "                    if flag==False:\n",
    "                        # \n",
    "                        c1=ref.strip().split(\",\")[0]\n",
    "                        c2=ref1.strip().split(\",\")[0]\n",
    "                        if c1.strip()==c2.strip() and \"New Approach to Checking the Heart\" not in ref and \"Cuba sends doctors to Italy to help battle coronavirus\" not in ref:\n",
    "                            mark.append(',')\n",
    "                            mark.append(ref)\n",
    "                            flag=True\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                \n",
    "                                x+=1\n",
    "                                if identifyConflict(answer): \n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i].append(ref1)\n",
    "                            else: # factual\n",
    "                                if identifyConflict(answer): \n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i].append(ref1)\n",
    "                    if flag==False:\n",
    "                        # \n",
    "                        c1=ref.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                        c2=ref1.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                        if len(c1)>2 and len(c2)>2 and c1[1]==c2[1]:\n",
    "                            mark.append('\"')\n",
    "                            flag=True\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                if identifyConflict(answer):\n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i].append(ref1)\n",
    "                            else: # factual\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer):\n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i].append(ref1)\n",
    "                    if flag==False:\n",
    "                        if \"\\\\\\\"Trump'\"in ref and \"\\\\\\\"Trump'\" in ref1 and \"after his presidential bid\" not in ref and\"after his presidential bi\" not in ref1:\n",
    "                            flag=True\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                if identifyConflict(answer):\n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i].append(ref1)\n",
    "                            else: # factual\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer):\n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i].append(ref1)\n",
    "            if n-pre!=1:\n",
    "                print(mark)\n",
    "                print(n-pre)\n",
    "                print(ref1)\n",
    "                print()\n",
    "    print(x)\n",
    "    print(t)\n",
    "    print(num[-1]-t,(num[-1]-t)/num[-1])\n",
    "    print(f,f/num[-1])\n",
    "    print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 629,
   "id": "2b9f228a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "206\n",
      "176\n",
      "31 0.1497584541062802\n",
      "180 0.8695652173913043\n",
      "matched num= 414\n",
      "206\n",
      "158\n",
      "49 0.23671497584541062\n",
      "173 0.8357487922705314\n",
      "matched num= 414\n",
      "206\n",
      "173\n",
      "34 0.1642512077294686\n",
      "181 0.8743961352657005\n",
      "matched num= 414\n",
      "206\n",
      "162\n",
      "45 0.21739130434782608\n",
      "185 0.893719806763285\n",
      "matched num= 414\n",
      "206\n",
      "149\n",
      "58 0.28019323671497587\n",
      "157 0.7584541062801933\n",
      "matched num= 414\n",
      "206\n",
      "149\n",
      "58 0.28019323671497587\n",
      "159 0.7681159420289855\n",
      "matched num= 414\n"
     ]
    }
   ],
   "source": [
    "for i in range(6):\n",
    "    t=0\n",
    "    f=0\n",
    "    n=0\n",
    "    x=0\n",
    "    with open(filePath[4]+\"dataset_0.5.jsonl\") as file1:\n",
    "        for line1 in file1:\n",
    "            label=line1.split(\"label: \")[-1]\n",
    "            ref1=line1.split(\"Response: \")[0].split(\"Reference: \")\n",
    "            if len(ref1)==2:\n",
    "                ref1=ref1[1]\n",
    "            else:\n",
    "                ref1=ref1[1]+\"Reference: \"+ref1[2]\n",
    "            pre=n\n",
    "            flag=False\n",
    "            ref1=ref1[:-8]\n",
    "            mark=[]\n",
    "            if \"Reference: \" in ref1:\n",
    "                ref1=ref1.split(\"Reference: \")[0]\n",
    "            with open(filePath[4]+\"detections_\"+str(i+1)+\"_1.jsonl\") as file:\n",
    "                for line in file:\n",
    "                    answer=line.split(\"Result: \")[1]\n",
    "                    ref=line.split(\"P2: \")[0].split(\"P1: \")[1]\n",
    "                    ref=ref.encode().decode('unicode_escape')\n",
    "                    ref=ref[0:-8]\n",
    "                    if ref.strip()==ref1.strip():\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                tlist[i+7].append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer): \n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                flist[i+7].append(ref1)\n",
    "       \n",
    "                    if flag==False:\n",
    "                        # \n",
    "                        c1=ref.strip().split(\",\")[0]\n",
    "                        c2=ref1.strip().split(\",\")[0]\n",
    "                        if c1.strip()==c2.strip() and \"New Approach to Checking the Heart\" not in ref and \"Cuba sends doctors to Italy to help battle coronavirus\" not in ref:\n",
    "                            mark.append(',')\n",
    "                            mark.append(ref)\n",
    "                            flag=True\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                \n",
    "                                x+=1\n",
    "                                if identifyConflict(answer): \n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[7+i].append(ref1)\n",
    "                            else: # factual\n",
    "                                if identifyConflict(answer): \n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i+7].append(ref1)\n",
    "                    if flag==False:\n",
    "                        # \n",
    "                        c1=ref.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                        c2=ref1.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                        if len(c1)>2 and len(c2)>2 and c1[1]==c2[1]:\n",
    "                            mark.append('\"')\n",
    "                            flag=True\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                if identifyConflict(answer):\n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i+7].append(ref1)\n",
    "                            else: # factual\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer):\n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i+7].append(ref1)\n",
    "                    if flag==False:\n",
    "                        if \"\\\\\\\"Trump'\"in ref and \"\\\\\\\"Trump'\" in ref1 and \"after his presidential bid\" not in ref and\"after his presidential bi\" not in ref1:\n",
    "                            flag=True\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                if identifyConflict(answer):\n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i+7].append(ref1)\n",
    "                            else: # factual\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer):\n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i+7].append(ref1)\n",
    "            if n-pre!=1:\n",
    "                print(mark)\n",
    "                print(n-pre)\n",
    "                print(ref1)\n",
    "                print()\n",
    "    print(x)\n",
    "    print(t)\n",
    "    print(num[-1]-t,(num[-1]-t)/num[-1])\n",
    "    print(f,f/num[-1])\n",
    "    print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 593,
   "id": "e77e49a2",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 12 12 12\n",
      "0.5289855072463768\n",
      "0.2585551330798479\n",
      "1 12 12 12\n",
      "0.5555555555555556\n",
      "0.41401273885350315\n",
      "3 12 12 12\n",
      "0.5748792270531401\n",
      "0.38461538461538464\n"
     ]
    }
   ],
   "source": [
    "minV=0\n",
    "for kk in range(13-0):\n",
    "    #for jj in range(kk+1,13-0):\n",
    "        #for ii in range(jj+1,13-0):\n",
    "            #for i in range(ii+1,13-0):\n",
    "                #for j in range(i+1,13-0):\n",
    "                     #for k in range(j+1,13-0):\n",
    "                        #for m in range(k+1,13-0):\n",
    "                            #for n in range(m+1,13-0):\n",
    "                                #for q in range(n+1,13-0):\n",
    "                                    #for w in range(q+1,13-0):\n",
    "                                        #for z in range(w+1,13-0):\n",
    "                                            #for y in range(z+1,13-0):\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",
    "                                                a=list(set(a))\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",
    "                                                a=list(set(a))\n",
    "                                                bb=len(a)\n",
    "                                                TN=(num[-1]-bb)/(num[-1]*2)\n",
    "                                                TP=aa/(num[-1]*2)\n",
    "                                                FN=(num[-1]-aa)/(num[-1]*2)\n",
    "                                                FP=bb/(num[-1]*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": 630,
   "id": "5fc774f8",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "149\n",
      "150\n",
      "0.4975845410628019\n",
      "0.5889328063241107\n"
     ]
    }
   ],
   "source": [
    "a=t1+t2+t3+t4+t5+t6+t7+t11+t22+t33+t44+t55+t66 # \n",
    "res=set(a)\n",
    "a=list(res)\n",
    "print(len(a))\n",
    "aa=len(a)\n",
    "a=f1+f2+f3+f4+f5+f6+f7+f11+f22+f33+f44+f55+f66 # \n",
    "res=set(a)\n",
    "a=list(res)\n",
    "print(len(a))\n",
    "bb=len(a)\n",
    "TN=(num[-1]-bb)/(num[-1]*2)\n",
    "TP=aa/(num[-1]*2)\n",
    "FN=(num[-1]-aa)/(num[-1]*2)\n",
    "FP=bb/(num[-1]*2)\n",
    "F1=2*TP/(2*TP+FP+FN)\n",
    "print(TN+TP)\n",
    "print(F1)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "29440333",
   "metadata": {},
   "source": [
    "# pubhealth+0.9"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 569,
   "id": "7e8b0331",
   "metadata": {},
   "outputs": [],
   "source": [
    "tlist=[[] for _ in range(13)]\n",
    "flist=[[] for _ in range(13)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 570,
   "id": "75d67349",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "202\n",
      "104\n",
      "80 0.43478260869565216\n",
      "125 0.6793478260869565\n",
      "matched num= 404\n",
      "202\n",
      "102\n",
      "82 0.44565217391304346\n",
      "97 0.5271739130434783\n",
      "matched num= 404\n",
      "202\n",
      "88\n",
      "96 0.5217391304347826\n",
      "118 0.6413043478260869\n",
      "matched num= 404\n",
      "202\n",
      "89\n",
      "95 0.5163043478260869\n",
      "97 0.5271739130434783\n",
      "matched num= 404\n",
      "202\n",
      "103\n",
      "81 0.44021739130434784\n",
      "121 0.657608695652174\n",
      "matched num= 404\n",
      "202\n",
      "123\n",
      "61 0.33152173913043476\n",
      "143 0.7771739130434783\n",
      "matched num= 404\n",
      "202\n",
      "111\n",
      "73 0.3967391304347826\n",
      "123 0.6684782608695652\n",
      "matched num= 404\n"
     ]
    }
   ],
   "source": [
    "for i in range(7):\n",
    "    t=0\n",
    "    f=0\n",
    "    n=0\n",
    "    x=0\n",
    "    with open(filePath[3]+\"dataset_0.9.jsonl\") as file1:\n",
    "        for line1 in file1:\n",
    "            label=line1.split(\"label: \")[-1]\n",
    "            ref1=line1.split(\"Response: \")[0].split(\"Reference: \")\n",
    "            if len(ref1)==2:\n",
    "                ref1=ref1[1]\n",
    "            else:\n",
    "                ref1=ref1[1]+\"Reference: \"+ref1[2]\n",
    "            pre=n\n",
    "            flag=False\n",
    "            ref1=ref1[:-8]\n",
    "            mark=[]\n",
    "            if \"Reference: \" in ref1:\n",
    "                ref1=ref1.split(\"Reference: \")[0]\n",
    "            with open(filePath[3]+\"detections_\"+str(i+1)+\".jsonl\") as file:\n",
    "                for line in file:\n",
    "                    answer=line.split(\"Result: \")[1]\n",
    "                    ref=line.split(\"P2: \")[0].split(\"P1: \")[1]\n",
    "                    ref=ref.encode().decode('unicode_escape')\n",
    "                    ref=ref[0:-8]\n",
    "                    if ref.strip()==ref1.strip():\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                tlist[i].append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer): \n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                flist[i].append(ref1)\n",
    "       \n",
    "                    if flag==False:\n",
    "                        # \n",
    "                        c1=ref.strip().split(\",\")[0]\n",
    "                        c2=ref1.strip().split(\",\")[0]\n",
    "                        if c1.strip()==c2.strip() and \"New Approach to Checking the Heart\" not in ref and \"Cuba sends doctors to Italy to help battle coronavirus\" not in ref:\n",
    "                            mark.append(',')\n",
    "                            mark.append(ref)\n",
    "                            flag=True\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                \n",
    "                                x+=1\n",
    "                                if identifyConflict(answer): \n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i].append(ref1)\n",
    "                            else: # factual\n",
    "                                if identifyConflict(answer): \n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i].append(ref1)\n",
    "                    if flag==False:\n",
    "                        # \n",
    "                        c1=ref.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                        c2=ref1.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                        if len(c1)>2 and len(c2)>2 and c1[1]==c2[1]:\n",
    "                            mark.append('\"')\n",
    "                            flag=True\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                if identifyConflict(answer):\n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i].append(ref1)\n",
    "                            else: # factual\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer):\n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i].append(ref1)\n",
    "\n",
    "            if n-pre!=1:\n",
    "                print(mark)\n",
    "                print(n-pre)\n",
    "                print(ref1)\n",
    "                print()\n",
    "    print(x)\n",
    "    print(t)\n",
    "    print(num[-1]-t,(num[-1]-t)/num[-1])\n",
    "    print(f,f/num[-1])\n",
    "    print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 571,
   "id": "7661fc64",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "202\n",
      "120\n",
      "64 0.34782608695652173\n",
      "126 0.6847826086956522\n",
      "matched num= 404\n",
      "202\n",
      "122\n",
      "62 0.33695652173913043\n",
      "128 0.6956521739130435\n",
      "matched num= 404\n",
      "202\n",
      "128\n",
      "56 0.30434782608695654\n",
      "144 0.782608695652174\n",
      "matched num= 404\n",
      "202\n",
      "131\n",
      "53 0.28804347826086957\n",
      "134 0.7282608695652174\n",
      "matched num= 404\n",
      "202\n",
      "105\n",
      "79 0.42934782608695654\n",
      "118 0.6413043478260869\n",
      "matched num= 404\n",
      "202\n",
      "113\n",
      "71 0.3858695652173913\n",
      "117 0.6358695652173914\n",
      "matched num= 404\n"
     ]
    }
   ],
   "source": [
    "for i in range(6):\n",
    "    t=0\n",
    "    f=0\n",
    "    n=0\n",
    "    x=0\n",
    "    with open(filePath[3]+\"dataset_0.9.jsonl\") as file1:\n",
    "        for line1 in file1:\n",
    "            label=line1.split(\"label: \")[-1]\n",
    "            ref1=line1.split(\"Response: \")[0].split(\"Reference: \")\n",
    "            if len(ref1)==2:\n",
    "                ref1=ref1[1]\n",
    "            else:\n",
    "                ref1=ref1[1]+\"Reference: \"+ref1[2]\n",
    "            pre=n\n",
    "            flag=False\n",
    "            ref1=ref1[:-8]\n",
    "            mark=[]\n",
    "            if \"Reference: \" in ref1:\n",
    "                ref1=ref1.split(\"Reference: \")[0]\n",
    "            with open(filePath[3]+\"detections_\"+str(i+1)+\"_1.jsonl\") as file:\n",
    "                for line in file:\n",
    "                    answer=line.split(\"Result: \")[1]\n",
    "                    ref=line.split(\"P2: \")[0].split(\"P1: \")[1]\n",
    "                    ref=ref.encode().decode('unicode_escape')\n",
    "                    ref=ref[0:-8]\n",
    "                    if ref.strip()==ref1.strip():\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                tlist[i+7].append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer): \n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                flist[i+7].append(ref1)\n",
    "       \n",
    "                    if flag==False:\n",
    "                        # \n",
    "                        c1=ref.strip().split(\",\")[0]\n",
    "                        c2=ref1.strip().split(\",\")[0]\n",
    "                        if c1.strip()==c2.strip() and \"New Approach to Checking the Heart\" not in ref and \"Cuba sends doctors to Italy to help battle coronavirus\" not in ref:\n",
    "                            mark.append(',')\n",
    "                            mark.append(ref)\n",
    "                            flag=True\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                \n",
    "                                x+=1\n",
    "                                if identifyConflict(answer): \n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i+7].append(ref1)\n",
    "                            else: # factual\n",
    "                                if identifyConflict(answer): \n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i+7].append(ref1)\n",
    "                    if flag==False:\n",
    "                        # \n",
    "                        c1=ref.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                        c2=ref1.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                        if len(c1)>2 and len(c2)>2 and c1[1]==c2[1]:\n",
    "                            mark.append('\"')\n",
    "                            flag=True\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                if identifyConflict(answer):\n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i+7].append(ref1)\n",
    "                            else: # factual\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer):\n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i+7].append(ref1)\n",
    "\n",
    "            if n-pre!=1:\n",
    "                print(mark)\n",
    "                print(n-pre)\n",
    "                print(ref1)\n",
    "                print()\n",
    "    print(x)\n",
    "    print(t)\n",
    "    print(num[-1]-t,(num[-1]-t)/num[-1])\n",
    "    print(f,f/num[-1])\n",
    "    print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 575,
   "id": "f7534fdf",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 1 2 3\n",
      "0.504950495049505\n",
      "0.6677740863787376\n",
      "0 1 2 3\n",
      "0.504950495049505\n",
      "0.6677740863787376\n",
      "0 1 2 3\n",
      "0.504950495049505\n",
      "0.6677740863787376\n",
      "0 1 2 3\n",
      "0.504950495049505\n",
      "0.6677740863787376\n",
      "0 1 2 3\n",
      "0.504950495049505\n",
      "0.6666666666666666\n",
      "0 2 3 4\n",
      "0.504950495049505\n",
      "0.6677740863787376\n",
      "1 2 3 4\n",
      "0.5074257425742574\n",
      "0.667779632721202\n"
     ]
    }
   ],
   "source": [
    "minV=0\n",
    "for kk in range(13-11):\n",
    "    for jj in range(kk+1,13-10):\n",
    "        for ii in range(jj+1,13-9):\n",
    "            for i in range(ii+1,13-8):\n",
    "                for j in range(i+1,13-7):\n",
    "                     for k in range(j+1,13-6):\n",
    "                        for m in range(k+1,13-5):\n",
    "                            for n in range(m+1,13-4):\n",
    "                                for q in range(n+1,13-3):\n",
    "                                    for w in range(q+1,13-2):\n",
    "                                        for z in range(w+1,13-1):\n",
    "                                            for y in range(z+1,13-0):\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",
    "                                                a=list(set(a))\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",
    "                                                a=list(set(a))\n",
    "                                                bb=len(a)\n",
    "                                                TN=(num[-1]-bb)/(num[-1]*2)\n",
    "                                                TP=aa/(num[-1]*2)\n",
    "                                                FN=(num[-1]-aa)/(num[-1]*2)\n",
    "                                                FP=bb/(num[-1]*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": 594,
   "id": "f8709038",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "176\n",
      "179\n",
      "0.49275362318840576\n",
      "0.6263345195729538\n"
     ]
    }
   ],
   "source": [
    "a=t1+t2+t3+t4+t5+t6+t7+t11+t22+t33+t44+t55+t66 # \n",
    "res=set(a)\n",
    "a=list(res)\n",
    "print(len(a))\n",
    "aa=len(a)\n",
    "a=f1+f2+f3+f4+f5+f6+f7+f11+f22+f33+f44+f55+f66 # \n",
    "res=set(a)\n",
    "a=list(res)\n",
    "print(len(a))\n",
    "bb=len(a)\n",
    "TN=(num[-1]-bb)/(num[-1]*2)\n",
    "TP=aa/(num[-1]*2)\n",
    "FN=(num[-1]-aa)/(num[-1]*2)\n",
    "FP=bb/(num[-1]*2)\n",
    "F1=2*TP/(2*TP+FP+FN)\n",
    "print(TN+TP)\n",
    "print(F1)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ba574c16",
   "metadata": {},
   "source": [
    "# pubhealth+0.1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "839d2e28",
   "metadata": {},
   "outputs": [],
   "source": [
    "tlist=[[] for _ in range(13)]\n",
    "flist=[[] for _ in range(13)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "ad8b59ee",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "192\n",
      "179\n",
      "13 0.06770833333333333\n",
      "182 0.9479166666666666\n",
      "matched num= 384\n",
      "192\n",
      "159\n",
      "33 0.171875\n",
      "163 0.8489583333333334\n",
      "matched num= 384\n",
      "192\n",
      "172\n",
      "20 0.10416666666666667\n",
      "170 0.8854166666666666\n",
      "matched num= 384\n",
      "192\n",
      "162\n",
      "30 0.15625\n",
      "176 0.9166666666666666\n",
      "matched num= 384\n",
      "192\n",
      "163\n",
      "29 0.15104166666666666\n",
      "157 0.8177083333333334\n",
      "matched num= 384\n",
      "192\n",
      "172\n",
      "20 0.10416666666666667\n",
      "181 0.9427083333333334\n",
      "matched num= 384\n",
      "192\n",
      "170\n",
      "22 0.11458333333333333\n",
      "172 0.8958333333333334\n",
      "matched num= 384\n"
     ]
    }
   ],
   "source": [
    "for i in range(7):\n",
    "    t=0\n",
    "    f=0\n",
    "    n=0\n",
    "    x=0\n",
    "    with open(filePath[5]+\"dataset_0.1.jsonl\") as file1:\n",
    "        for line1 in file1:\n",
    "            label=line1.split(\"label: \")[-1]\n",
    "            ref1=line1.split(\"Response: \")[0].split(\"Reference: \")\n",
    "            if len(ref1)==2:\n",
    "                ref1=ref1[1]\n",
    "            else:\n",
    "                ref1=ref1[1]+\"Reference: \"+ref1[2]\n",
    "            pre=n\n",
    "            flag=False\n",
    "            ref1=ref1[:-8]\n",
    "            mark=[]\n",
    "            if \"Reference: \" in ref1:\n",
    "                ref1=ref1.split(\"Reference: \")[0]\n",
    "            with open(filePath[5]+\"detections_\"+str(i+1)+\".jsonl\") as file:\n",
    "                for line in file:\n",
    "                    answer=line.split(\"Result: \")[1]\n",
    "                    ref=line.split(\"P2: \")[0].split(\"P1: \")[1]\n",
    "                    ref=ref.encode().decode('unicode_escape')\n",
    "                    ref=ref[0:-8]\n",
    "                    if ref.strip()==ref1.strip():\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                tlist[i].append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer): \n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                flist[i].append(ref1)\n",
    "                    if flag==False:\n",
    "                        # \n",
    "                        c1=ref.strip().split(\",\")[0]\n",
    "                        c2=ref1.strip().split(\",\")[0]\n",
    "                        if c1.strip()==c2.strip():\n",
    "                            flag=True\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer): \n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i].append(ref1)\n",
    "                            else: # factual\n",
    "                                if identifyConflict(answer): \n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i].append(ref1)\n",
    "                    if flag==False:\n",
    "                        # \n",
    "                        c1=ref.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                        c2=ref1.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                        if len(c1)>2 and len(c2)>2 and c1[1]==c2[1]:\n",
    "                            flag=True\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                if identifyConflict(answer):\n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i].append(ref1)\n",
    "                            else: # factual\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer):\n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i].append(ref1)\n",
    "                    if flag==False:\n",
    "                        if (\"The Economist magazine (2015)\" in ref and \"The Economist magazine (2015)\" in ref1) or (\"2018 Academy Awards Nominations.\" in ref and \"2018 Academy Awards Nominations.\" in ref1) or (\"538 RSS feed for \" in ref and \"538 RSS feed for \" in ref1) or (\"2018 Annual Report of Dignity Heal\" in ref and \"2018 Annual Report of Dignity Heal\" in ref1) or (\"DVD commentary (Creators/Writers Chris Carter, Vince Gilligan\" in ref and \"DVD commentary (Creators/Writers Chris Carter, Vince Gilligan\" in ref1) or (\"247sports.com Summary: According to a report by 247Sports\" in ref and \"247sports.com Summary: According to a report by 247Sports\" in ref1) or (\"The phpBB post by JtRx13 who made the first post on May 6, 2009\" in ref and \"The phpBB post by JtRx13 who made the first post on May 6, 2009\" in ref1) or (\"The Ospreys overcame a late rally by Newcastle to win 17\" in ref and \"The Ospreys overcame a late rally by Newcastle to win 17\" in ref1):\n",
    "                            flag=True\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                if identifyConflict(answer):\n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i].append(ref1)\n",
    "                            else: # factual\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer):\n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i].append(ref1)\n",
    "            if n-pre!=1:\n",
    "                print(mark)\n",
    "                print(n-pre)\n",
    "                print(ref1)\n",
    "                print()\n",
    "    print(x)\n",
    "    print(t)\n",
    "    print(num[-1]-t,(num[-1]-t)/num[-1])\n",
    "    print(f,f/num[-1])\n",
    "    print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "2b2d1c63",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "192\n",
      "171\n",
      "21 0.109375\n",
      "178 0.9270833333333334\n",
      "matched num= 384\n",
      "192\n",
      "174\n",
      "18 0.09375\n",
      "173 0.9010416666666666\n",
      "matched num= 384\n",
      "192\n",
      "179\n",
      "13 0.06770833333333333\n",
      "179 0.9322916666666666\n",
      "matched num= 384\n",
      "192\n",
      "154\n",
      "38 0.19791666666666666\n",
      "169 0.8802083333333334\n",
      "matched num= 384\n",
      "192\n",
      "138\n",
      "54 0.28125\n",
      "139 0.7239583333333334\n",
      "matched num= 384\n",
      "192\n",
      "141\n",
      "51 0.265625\n",
      "152 0.7916666666666666\n",
      "matched num= 384\n"
     ]
    }
   ],
   "source": [
    "for i in range(6):\n",
    "    t=0\n",
    "    f=0\n",
    "    n=0\n",
    "    x=0\n",
    "    with open(filePath[5]+\"dataset_0.1.jsonl\") as file1:\n",
    "        for line1 in file1:\n",
    "            label=line1.split(\"label: \")[-1]\n",
    "            ref1=line1.split(\"Response: \")[0].split(\"Reference: \")\n",
    "            if len(ref1)==2:\n",
    "                ref1=ref1[1]\n",
    "            else:\n",
    "                ref1=ref1[1]+\"Reference: \"+ref1[2]\n",
    "            pre=n\n",
    "            flag=False\n",
    "            ref1=ref1[:-8]\n",
    "            mark=[]\n",
    "            if \"Reference: \" in ref1:\n",
    "                ref1=ref1.split(\"Reference: \")[0]\n",
    "            with open(filePath[5]+\"detections_\"+str(i+1)+\"_1.jsonl\") as file:\n",
    "                for line in file:\n",
    "                    answer=line.split(\"Result: \")[1]\n",
    "                    ref=line.split(\"P2: \")[0].split(\"P1: \")[1]\n",
    "                    ref=ref.encode().decode('unicode_escape')\n",
    "                    ref=ref[0:-8]\n",
    "                    if ref.strip()==ref1.strip():\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                tlist[i+7].append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer): \n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                flist[i+7].append(ref1)\n",
    "                    if flag==False:\n",
    "                        # \n",
    "                        c1=ref.strip().split(\",\")[0]\n",
    "                        c2=ref1.strip().split(\",\")[0]\n",
    "                        if c1.strip()==c2.strip():\n",
    "                            flag=True\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer): \n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i+7].append(ref1)\n",
    "                            else: # factual\n",
    "                                if identifyConflict(answer): \n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[7+i].append(ref1)\n",
    "                    if flag==False:\n",
    "                        # \n",
    "                        c1=ref.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                        c2=ref1.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                        if len(c1)>2 and len(c2)>2 and c1[1]==c2[1]:\n",
    "                            flag=True\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                if identifyConflict(answer):\n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i+7].append(ref1)\n",
    "                            else: # factual\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer):\n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i+7].append(ref1)\n",
    "                    if flag==False:\n",
    "                        if (\"The Economist magazine (2015)\" in ref and \"The Economist magazine (2015)\" in ref1) or (\"2018 Academy Awards Nominations.\" in ref and \"2018 Academy Awards Nominations.\" in ref1) or (\"538 RSS feed for \" in ref and \"538 RSS feed for \" in ref1) or (\"2018 Annual Report of Dignity Heal\" in ref and \"2018 Annual Report of Dignity Heal\" in ref1) or (\"DVD commentary (Creators/Writers Chris Carter, Vince Gilligan\" in ref and \"DVD commentary (Creators/Writers Chris Carter, Vince Gilligan\" in ref1) or (\"247sports.com Summary: According to a report by 247Sports\" in ref and \"247sports.com Summary: According to a report by 247Sports\" in ref1) or (\"The phpBB post by JtRx13 who made the first post on May 6, 2009\" in ref and \"The phpBB post by JtRx13 who made the first post on May 6, 2009\" in ref1) or (\"The Ospreys overcame a late rally by Newcastle to win 17\" in ref and \"The Ospreys overcame a late rally by Newcastle to win 17\" in ref1):\n",
    "                            flag=True\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                if identifyConflict(answer):\n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i+7].append(ref1)\n",
    "                            else: # factual\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer):\n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i+7].append(ref1)\n",
    "            if n-pre!=1:\n",
    "                print(mark)\n",
    "                print(n-pre)\n",
    "                print(ref1)\n",
    "                print()\n",
    "    print(x)\n",
    "    print(t)\n",
    "    print(num[-1]-t,(num[-1]-t)/num[-1])\n",
    "    print(f,f/num[-1])\n",
    "    print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "ab1f8449",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 1 2 11\n",
      "0.49739583333333337\n",
      "0.35451505016722407\n",
      "0 1 3 11\n",
      "0.5520833333333334\n",
      "0.43790849673202614\n",
      "0 3 5 11\n",
      "0.5546875\n",
      "0.3643122676579926\n",
      "0 3 10 11\n",
      "0.5651041666666667\n",
      "0.44147157190635455\n",
      "1 3 10 11\n",
      "0.5677083333333334\n",
      "0.4876543209876543\n",
      "3 5 10 11\n",
      "0.5729166666666666\n",
      "0.45333333333333337\n"
     ]
    }
   ],
   "source": [
    "minV=0\n",
    "for kk in range(13-2):\n",
    "    for jj in range(kk+1,13-1):\n",
    "        for ii in range(jj+1,13-0):\n",
    "            #for i in range(ii+1,13-1):\n",
    "                #for j in range(i+1,13-0):\n",
    "                     #for k in range(j+1,13-4):\n",
    "                        #for m in range(k+1,13-3):\n",
    "                            #for n in range(m+1,13-2):\n",
    "                                #for q in range(n+1,13-1):\n",
    "                                    #for w in range(q+1,13-0):\n",
    "                                        #for z in range(w+1,13-0):\n",
    "                                            #for y in range(z+1,13-0):\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",
    "                                                a=list(set(a))\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",
    "                                                a=list(set(a))\n",
    "                                                bb=len(a)\n",
    "                                                TN=(num[-1]-bb)/(num[-1]*2)\n",
    "                                                TP=aa/(num[-1]*2)\n",
    "                                                FN=(num[-1]-aa)/(num[-1]*2)\n",
    "                                                FP=bb/(num[-1]*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": 19,
   "id": "d5b68727",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "148\n",
      "142\n",
      "0.515625\n",
      "0.6141078838174274\n"
     ]
    }
   ],
   "source": [
    "a=[]\n",
    "for i in range(13):\n",
    "    a+=tlist[i]\n",
    "res=set(a)\n",
    "a=list(res)\n",
    "print(len(a))\n",
    "aa=len(a)\n",
    "a=[]\n",
    "for i in range(13):\n",
    "    a+=flist[i]\n",
    "res=set(a)\n",
    "a=list(res)\n",
    "print(len(a))\n",
    "bb=len(a)\n",
    "TN=(num[-1]-bb)/(num[-1]*2)\n",
    "TP=aa/(num[-1]*2)\n",
    "FN=(num[-1]-aa)/(num[-1]*2)\n",
    "FP=bb/(num[-1]*2)\n",
    "F1=2*TP/(2*TP+FP+FN)\n",
    "print(TN+TP)\n",
    "print(F1)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "15de13b4",
   "metadata": {},
   "source": [
    "# wice+0.9"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 396,
   "id": "61c512c0",
   "metadata": {},
   "outputs": [],
   "source": [
    "tlist=[[] for _ in range(13)]\n",
    "flist=[[] for _ in range(13)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 397,
   "id": "95be7d08",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "244\n",
      "186\n",
      "59 0.24081632653061225\n",
      "183 0.746938775510204\n",
      "matched num= 490\n",
      "244\n",
      "150\n",
      "95 0.3877551020408163\n",
      "162 0.6612244897959184\n",
      "matched num= 490\n",
      "244\n",
      "113\n",
      "132 0.5387755102040817\n",
      "120 0.4897959183673469\n",
      "matched num= 490\n",
      "244\n",
      "126\n",
      "119 0.4857142857142857\n",
      "159 0.6489795918367347\n",
      "matched num= 490\n",
      "244\n",
      "128\n",
      "117 0.4775510204081633\n",
      "146 0.5959183673469388\n",
      "matched num= 490\n",
      "244\n",
      "144\n",
      "101 0.4122448979591837\n",
      "154 0.6285714285714286\n",
      "matched num= 490\n",
      "244\n",
      "130\n",
      "115 0.46938775510204084\n",
      "136 0.5551020408163265\n",
      "matched num= 490\n"
     ]
    }
   ],
   "source": [
    "for i in range(7):\n",
    "    t=0\n",
    "    f=0\n",
    "    n=0\n",
    "    x=0\n",
    "    with open(filePath[6]+\"dataset_0.9.jsonl\") as file1:\n",
    "        for line1 in file1:\n",
    "            label=line1.split(\"label: \")[-1]\n",
    "            ref1=line1.split(\"Response: \")[0].split(\"Reference: \")\n",
    "            if len(ref1)==2:\n",
    "                ref1=ref1[1]\n",
    "            else:\n",
    "                ref1=ref1[1]+\"Reference: \"+ref1[2]\n",
    "            pre=n\n",
    "            flag=False\n",
    "            ref1=ref1[:-8]\n",
    "            mark=[]\n",
    "            if \"Reference: \" in ref1:\n",
    "                ref1=ref1.split(\"Reference: \")[0]\n",
    "            with open(filePath[6]+\"detections_\"+str(i+1)+\".jsonl\") as file:\n",
    "                for line in file:\n",
    "                    answer=line.split(\"Result: \")[1]\n",
    "                    ref=line.split(\"P2: \")[0].split(\"P1: \")[1]\n",
    "                    ref=ref.encode().decode('unicode_escape')\n",
    "                    ref=ref[0:-8]\n",
    "                    if ref.strip()==ref1.strip():\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                tlist[i].append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer): \n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                flist[i].append(ref1)\n",
    "                    if flag==False:\n",
    "                        # \n",
    "                        c1=ref.strip().split(\",\")[0]\n",
    "                        c2=ref1.strip().split(\",\")[0]\n",
    "                        if c1.strip()==c2.strip():\n",
    "                            flag=True\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer): \n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i].append(ref1)\n",
    "                            else: # factual\n",
    "                                if identifyConflict(answer): \n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i].append(ref1)\n",
    "                    if flag==False:\n",
    "                        # \n",
    "                        c1=ref.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                        c2=ref1.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                        if len(c1)>2 and len(c2)>2 and c1[1]==c2[1]:\n",
    "                            flag=True\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                if identifyConflict(answer):\n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i].append(ref1)\n",
    "                            else: # factual\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer):\n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i].append(ref1)\n",
    "                    if flag==False:\n",
    "                        if (\"The Economist magazine (2015)\" in ref and \"The Economist magazine (2015)\" in ref1) or (\"2018 Academy Awards Nominations.\" in ref and \"2018 Academy Awards Nominations.\" in ref1) or (\"538 RSS feed for \" in ref and \"538 RSS feed for \" in ref1) or (\"2018 Annual Report of Dignity Heal\" in ref and \"2018 Annual Report of Dignity Heal\" in ref1) or (\"DVD commentary (Creators/Writers Chris Carter, Vince Gilligan\" in ref and \"DVD commentary (Creators/Writers Chris Carter, Vince Gilligan\" in ref1) or (\"247sports.com Summary: According to a report by 247Sports\" in ref and \"247sports.com Summary: According to a report by 247Sports\" in ref1) or (\"The phpBB post by JtRx13 who made the first post on May 6, 2009\" in ref and \"The phpBB post by JtRx13 who made the first post on May 6, 2009\" in ref1) or (\"The Ospreys overcame a late rally by Newcastle to win 17\" in ref and \"The Ospreys overcame a late rally by Newcastle to win 17\" in ref1):\n",
    "                            flag=True\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                if identifyConflict(answer):\n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i].append(ref1)\n",
    "                            else: # factual\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer):\n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i].append(ref1)\n",
    "            if n-pre!=1:\n",
    "                print(mark)\n",
    "                print(n-pre)\n",
    "                print(ref1)\n",
    "                print()\n",
    "    print(x)\n",
    "    print(t)\n",
    "    print(num[-1]-t,(num[-1]-t)/num[-1])\n",
    "    print(f,f/num[-1])\n",
    "    print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 398,
   "id": "e0a358bb",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "244\n",
      "131\n",
      "114 0.46530612244897956\n",
      "140 0.5714285714285714\n",
      "matched num= 490\n",
      "244\n",
      "171\n",
      "74 0.3020408163265306\n",
      "174 0.710204081632653\n",
      "matched num= 490\n",
      "244\n",
      "204\n",
      "41 0.1673469387755102\n",
      "205 0.8367346938775511\n",
      "matched num= 490\n",
      "244\n",
      "156\n",
      "89 0.363265306122449\n",
      "177 0.7224489795918367\n",
      "matched num= 490\n",
      "244\n",
      "112\n",
      "133 0.5428571428571428\n",
      "101 0.4122448979591837\n",
      "matched num= 490\n",
      "244\n",
      "143\n",
      "102 0.4163265306122449\n",
      "155 0.6326530612244898\n",
      "matched num= 490\n"
     ]
    }
   ],
   "source": [
    "for i in range(6):\n",
    "    t=0\n",
    "    f=0\n",
    "    n=0\n",
    "    x=0\n",
    "    with open(filePath[6]+\"dataset_0.9.jsonl\") as file1:\n",
    "        for line1 in file1:\n",
    "            label=line1.split(\"label: \")[-1]\n",
    "            ref1=line1.split(\"Response: \")[0].split(\"Reference: \")\n",
    "            if len(ref1)==2:\n",
    "                ref1=ref1[1]\n",
    "            else:\n",
    "                ref1=ref1[1]+\"Reference: \"+ref1[2]\n",
    "            pre=n\n",
    "            flag=False\n",
    "            ref1=ref1[:-8]\n",
    "            mark=[]\n",
    "            if \"Reference: \" in ref1:\n",
    "                ref1=ref1.split(\"Reference: \")[0]\n",
    "            with open(filePath[6]+\"detections_\"+str(i+1)+\"_1.jsonl\") as file:\n",
    "                for line in file:\n",
    "                    answer=line.split(\"Result: \")[1]\n",
    "                    ref=line.split(\"P2: \")[0].split(\"P1: \")[1]\n",
    "                    ref=ref.encode().decode('unicode_escape')\n",
    "                    ref=ref[0:-8]\n",
    "                    if ref.strip()==ref1.strip():\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                tlist[i+7].append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer): \n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                flist[i+7].append(ref1)\n",
    "                    if flag==False:\n",
    "                        # \n",
    "                        c1=ref.strip().split(\",\")[0]\n",
    "                        c2=ref1.strip().split(\",\")[0]\n",
    "                        if c1.strip()==c2.strip():\n",
    "                            flag=True\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer): \n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i+7].append(ref1)\n",
    "                            else: # factual\n",
    "                                if identifyConflict(answer): \n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i+7].append(ref1)\n",
    "                    if flag==False:\n",
    "                        # \n",
    "                        c1=ref.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                        c2=ref1.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                        if len(c1)>2 and len(c2)>2 and c1[1]==c2[1]:\n",
    "                            flag=True\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                if identifyConflict(answer):\n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i+7].append(ref1)\n",
    "                            else: # factual\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer):\n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i+7].append(ref1)\n",
    "                    if flag==False:\n",
    "                        if (\"The Economist magazine (2015)\" in ref and \"The Economist magazine (2015)\" in ref1) or (\"2018 Academy Awards Nominations.\" in ref and \"2018 Academy Awards Nominations.\" in ref1) or (\"538 RSS feed for \" in ref and \"538 RSS feed for \" in ref1) or (\"2018 Annual Report of Dignity Heal\" in ref and \"2018 Annual Report of Dignity Heal\" in ref1) or (\"DVD commentary (Creators/Writers Chris Carter, Vince Gilligan\" in ref and \"DVD commentary (Creators/Writers Chris Carter, Vince Gilligan\" in ref1) or (\"247sports.com Summary: According to a report by 247Sports\" in ref and \"247sports.com Summary: According to a report by 247Sports\" in ref1) or (\"The phpBB post by JtRx13 who made the first post on May 6, 2009\" in ref and \"The phpBB post by JtRx13 who made the first post on May 6, 2009\" in ref1) or (\"The Ospreys overcame a late rally by Newcastle to win 17\" in ref and \"The Ospreys overcame a late rally by Newcastle to win 17\" in ref1):\n",
    "                            flag=True\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                if identifyConflict(answer):\n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i+7].append(ref1)\n",
    "                            else: # factual\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer):\n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i+7].append(ref1)\n",
    "            if n-pre!=1:\n",
    "                print(mark)\n",
    "                print(n-pre)\n",
    "                print(ref1)\n",
    "                print()\n",
    "    print(x)\n",
    "    print(t)\n",
    "    print(num[-1]-t,(num[-1]-t)/num[-1])\n",
    "    print(f,f/num[-1])\n",
    "    print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 404,
   "id": "8410165e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 1 2 3\n",
      "0.4938775510204082\n",
      "0.6565096952908587\n",
      "0 1 2 3\n",
      "0.5\n",
      "0.6611341632088521\n",
      "0 1 2 3\n",
      "0.5\n",
      "0.6573426573426573\n",
      "0 1 2 3\n",
      "0.5020408163265306\n",
      "0.6601671309192201\n",
      "0 1 2 3\n",
      "0.5020408163265306\n",
      "0.6582633053221288\n",
      "0 1 2 3\n",
      "0.5040816326530613\n",
      "0.6620305980528511\n",
      "0 1 2 3\n",
      "0.5081632653061224\n",
      "0.6666666666666666\n",
      "0 1 2 3\n",
      "0.5122448979591837\n",
      "0.6609929078014184\n",
      "0 1 2 3\n",
      "0.5122448979591837\n",
      "0.6647966339410939\n",
      "0 1 2 3\n",
      "0.5122448979591837\n",
      "0.6657342657342658\n",
      "0 1 2 4\n",
      "0.5142857142857142\n",
      "0.6647887323943662\n",
      "0 1 2 4\n",
      "0.5142857142857143\n",
      "0.6694444444444444\n",
      "0 1 2 4\n",
      "0.5163265306122449\n",
      "0.6712898751733702\n",
      "0 1 2 4\n",
      "0.5163265306122449\n",
      "0.667601683029453\n",
      "0 1 3 5\n",
      "0.5163265306122449\n",
      "0.6657263751763046\n",
      "0 1 3 5\n",
      "0.5183673469387755\n",
      "0.659942363112392\n",
      "0 1 3 5\n",
      "0.5183673469387755\n",
      "0.6609195402298851\n",
      "0 1 3 7\n",
      "0.5183673469387755\n",
      "0.659942363112392\n",
      "0 1 4 5\n",
      "0.5183673469387755\n",
      "0.6657223796033994\n",
      "0 1 4 6\n",
      "0.5224489795918368\n",
      "0.6685552407932012\n",
      "0 4 5 6\n",
      "0.5224489795918368\n",
      "0.6666666666666666\n"
     ]
    }
   ],
   "source": [
    "minV=0\n",
    "for kk in range(13-7):\n",
    "    for jj in range(kk+1,13-6):\n",
    "        for ii in range(jj+1,13-5):\n",
    "            for i in range(ii+1,13-4):\n",
    "                for j in range(i+1,13-3):\n",
    "                     for k in range(j+1,13-2):\n",
    "                        for m in range(k+1,13-1):\n",
    "                            for n in range(m+1,13-0):\n",
    "                                #for q in range(n+1,13-0):\n",
    "                                    #for w in range(q+1,13-0):\n",
    "                                        #for z in range(w+1,13-0):\n",
    "                                            #for y in range(z+1,13-0):\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",
    "                                                a=list(set(a))\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",
    "                                                a=list(set(a))\n",
    "                                                bb=len(a)\n",
    "                                                TN=(num[-1]-bb)/(num[-1]*2)\n",
    "                                                TP=aa/(num[-1]*2)\n",
    "                                                FN=(num[-1]-aa)/(num[-1]*2)\n",
    "                                                FP=bb/(num[-1]*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": "markdown",
   "id": "e2b19987",
   "metadata": {},
   "source": [
    "# wice+0.5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 284,
   "id": "e13f00a6",
   "metadata": {},
   "outputs": [],
   "source": [
    "tlist=[[] for _ in range(13)]\n",
    "flist=[[] for _ in range(13)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 285,
   "id": "03e53f2b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "239\n",
      "200\n",
      "39 0.16317991631799164\n",
      "204 0.8535564853556485\n",
      "matched num= 478\n",
      "239\n",
      "150\n",
      "89 0.3723849372384937\n",
      "174 0.7280334728033473\n",
      "matched num= 478\n",
      "239\n",
      "156\n",
      "83 0.3472803347280335\n",
      "164 0.6861924686192469\n",
      "matched num= 478\n",
      "239\n",
      "191\n",
      "48 0.200836820083682\n",
      "193 0.8075313807531381\n",
      "matched num= 478\n",
      "239\n",
      "143\n",
      "96 0.401673640167364\n",
      "148 0.6192468619246861\n",
      "matched num= 478\n",
      "239\n",
      "181\n",
      "58 0.24267782426778242\n",
      "200 0.8368200836820083\n",
      "matched num= 478\n",
      "238\n",
      "202\n",
      "37 0.15481171548117154\n",
      "204 0.8535564853556485\n",
      "matched num= 478\n"
     ]
    }
   ],
   "source": [
    "for i in range(7):\n",
    "    t=0\n",
    "    f=0\n",
    "    n=0\n",
    "    x=0\n",
    "    with open(filePath[7]+\"dataset_0.5.jsonl\") as file1:\n",
    "        for line1 in file1:\n",
    "            label=line1.split(\"label: \")[-1]\n",
    "            ref1=line1.split(\"Response: \")[0].split(\"Reference: \")\n",
    "            if len(ref1)==2:\n",
    "                ref1=ref1[1]\n",
    "            else:\n",
    "                ref1=ref1[1]+\"Reference: \"+ref1[2]\n",
    "            pre=n\n",
    "            flag=False\n",
    "            ref1=ref1[:-8]\n",
    "            with open(filePath[7]+\"detections_\"+str(i+1)+\".jsonl\") as file:\n",
    "                mark=[]\n",
    "                for line in file:\n",
    "                    answer=line.split(\"Result: \")[1]\n",
    "                    ref=line.split(\"P2: \")[0].split(\"P1: \")[1]\n",
    "                    ref=ref.encode().decode('unicode_escape')\n",
    "                    if i==6:\n",
    "                        ref=ref[1:-15]\n",
    "                    else:\n",
    "                        ref=ref[1:-8]\n",
    "                    if ref.strip()==ref1.strip():\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                tlist[i].append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer): \n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                flist[i].append(ref1)\n",
    "                    if flag==False:\n",
    "                        # \n",
    "                        c1=ref.strip().split(\",\")[0]\n",
    "                        c2=ref1.strip().split(\",\")[0]\n",
    "                        if c1.strip()==c2.strip():\n",
    "                            flag=True\n",
    "                            n+=1\n",
    "                            mark.append(',')\n",
    "                            if 'true' in label: #hallucination\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer): \n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i].append(ref1)\n",
    "                            else: # factual\n",
    "                                if identifyConflict(answer): \n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i].append(ref1)\n",
    "                    if flag==False:\n",
    "                        # \n",
    "                        c1=ref.strip().split(\".\")\n",
    "                        c2=ref1.strip().split(\".\")\n",
    "                        if len(c1)>2 and len(c2)>2 and c1[-2]==c2[-2]:\n",
    "                            flag=True\n",
    "                            n+=1\n",
    "                            mark.append('.')\n",
    "                            if 'true' in label: #hallucination\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer): \n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i].append(ref1)\n",
    "                            else: # factual\n",
    "                                if identifyConflict(answer): \n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i].append(ref1)\n",
    "                    if flag==False:\n",
    "                        # \n",
    "                        c1=ref.strip().split(\"\\\\\\\\\\\\\\\\n\")\n",
    "                        c2=ref1.strip().split(\"\\\\\\\\\\\\\\\\n\")\n",
    "                        if len(c1)>2 and len(c2)>2 and c1[-1]==c2[-1]:\n",
    "                            flag=True\n",
    "                            mark.append('n')\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer): \n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i].append(ref1)\n",
    "                            else: # factual\n",
    "                                if identifyConflict(answer): \n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i].append(ref1)\n",
    "                    if flag==False:\n",
    "                        # \n",
    "                        c1=ref.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                        if i==6:\n",
    "                            c1=ref.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                        c2=ref1.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                        if len(c1)>2 and len(c2)>2 and c1[1]==c2[1]:\n",
    "                            flag=True\n",
    "                            mark.append('\\\"')\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                if identifyConflict(answer):\n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i].append(ref1)\n",
    "                            else: # factual\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer):\n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i].append(ref1)\n",
    "                    if flag==False:\n",
    "                        if (\" Klobuchar and her husband John Bessler have two daughters,\" in ref and \" Klobuchar and her husband John Bessler have two daughters,\" in ref1) or (\"According to an article published in Forbes on August 21, 2018, titled\" in ref and \"According to an article published in Forbes on August 21, 2018, titled\" in ref1) or (\"The race was set to take place in October 2016 at the Central Harbour Front Event Space,\" in ref and \"The race was set to take place in October 2016 at the Central Harbour Front Event Space,\" in ref1):\n",
    "                            flag=True\n",
    "                            mark.append('k')\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                if identifyConflict(answer):\n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i].append(ref1)\n",
    "                            else: # factual\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer):\n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i].append(ref1)\n",
    "            if n-pre!=1:\n",
    "                print(mark)\n",
    "                print(n-pre)\n",
    "                print(ref1)\n",
    "                print()\n",
    "    print(x)\n",
    "    print(t)\n",
    "    print(num[-1]-t,(num[-1]-t)/num[-1])\n",
    "    print(f,f/num[-1])\n",
    "    print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 286,
   "id": "0e84368e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "239\n",
      "199\n",
      "40 0.16736401673640167\n",
      "188 0.7866108786610879\n",
      "matched num= 478\n",
      "239\n",
      "182\n",
      "57 0.2384937238493724\n",
      "176 0.7364016736401674\n",
      "matched num= 478\n",
      "239\n",
      "194\n",
      "45 0.18828451882845187\n",
      "206 0.8619246861924686\n",
      "matched num= 478\n",
      "239\n",
      "154\n",
      "85 0.35564853556485354\n",
      "170 0.7112970711297071\n",
      "matched num= 478\n",
      "239\n",
      "149\n",
      "90 0.37656903765690375\n",
      "153 0.6401673640167364\n",
      "matched num= 478\n",
      "239\n",
      "111\n",
      "128 0.5355648535564853\n",
      "114 0.4769874476987448\n",
      "matched num= 478\n"
     ]
    }
   ],
   "source": [
    "for i in range(6):\n",
    "    t=0\n",
    "    f=0\n",
    "    n=0\n",
    "    x=0\n",
    "    with open(filePath[7]+\"dataset_0.5.jsonl\") as file1:\n",
    "        for line1 in file1:\n",
    "            label=line1.split(\"label: \")[-1]\n",
    "            ref1=line1.split(\"Response: \")[0].split(\"Reference: \")\n",
    "            if len(ref1)==2:\n",
    "                ref1=ref1[1]\n",
    "            else:\n",
    "                ref1=ref1[1]+\"Reference: \"+ref1[2]\n",
    "            pre=n\n",
    "            flag=False\n",
    "            ref1=ref1[:-8]\n",
    "            with open(filePath[7]+\"detections_\"+str(i+1)+\"_1.jsonl\") as file:\n",
    "                mark=[]\n",
    "                for line in file:\n",
    "                    answer=line.split(\"Result: \")[1]\n",
    "                    ref=line.split(\"P2: \")[0].split(\"P1: \")[1]\n",
    "                    ref=ref.encode().decode('unicode_escape')\n",
    "                    if i==6:\n",
    "                        ref=ref[1:-15]\n",
    "                    else:\n",
    "                        ref=ref[1:-8]\n",
    "                    if ref.strip()==ref1.strip():\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                tlist[i+7].append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer): \n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                flist[i+7].append(ref1)\n",
    "                    if flag==False:\n",
    "                        # \n",
    "                        c1=ref.strip().split(\",\")[0]\n",
    "                        c2=ref1.strip().split(\",\")[0]\n",
    "                        if c1.strip()==c2.strip():\n",
    "                            flag=True\n",
    "                            n+=1\n",
    "                            mark.append(',')\n",
    "                            if 'true' in label: #hallucination\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer): \n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i+7].append(ref1)\n",
    "                            else: # factual\n",
    "                                if identifyConflict(answer): \n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i+7].append(ref1)\n",
    "                    if flag==False:\n",
    "                        # \n",
    "                        c1=ref.strip().split(\".\")\n",
    "                        c2=ref1.strip().split(\".\")\n",
    "                        if len(c1)>2 and len(c2)>2 and c1[-2]==c2[-2]:\n",
    "                            flag=True\n",
    "                            n+=1\n",
    "                            mark.append('.')\n",
    "                            if 'true' in label: #hallucination\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer): \n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i+7].append(ref1)\n",
    "                            else: # factual\n",
    "                                if identifyConflict(answer): \n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i+7].append(ref1)\n",
    "                    if flag==False:\n",
    "                        # \n",
    "                        c1=ref.strip().split(\"\\\\\\\\\\\\\\\\n\")\n",
    "                        c2=ref1.strip().split(\"\\\\\\\\\\\\\\\\n\")\n",
    "                        if len(c1)>2 and len(c2)>2 and c1[-1]==c2[-1]:\n",
    "                            flag=True\n",
    "                            mark.append('n')\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer): \n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i+7].append(ref1)\n",
    "                            else: # factual\n",
    "                                if identifyConflict(answer): \n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i+7].append(ref1)\n",
    "                    if flag==False:\n",
    "                        # \n",
    "                        c1=ref.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                        if i==6:\n",
    "                            c1=ref.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                        c2=ref1.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                        if len(c1)>2 and len(c2)>2 and c1[1]==c2[1]:\n",
    "                            flag=True\n",
    "                            mark.append('\\\"')\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                if identifyConflict(answer):\n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i+7].append(ref1)\n",
    "                            else: # factual\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer):\n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i+7].append(ref1)\n",
    "                    if flag==False:\n",
    "                        if (\" Klobuchar and her husband John Bessler have two daughters,\" in ref and \" Klobuchar and her husband John Bessler have two daughters,\" in ref1) or (\"According to an article published in Forbes on August 21, 2018, titled\" in ref and \"According to an article published in Forbes on August 21, 2018, titled\" in ref1) or (\"The race was set to take place in October 2016 at the Central Harbour Front Event Space,\" in ref and \"The race was set to take place in October 2016 at the Central Harbour Front Event Space,\" in ref1):\n",
    "                            flag=True\n",
    "                            mark.append('k')\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                if identifyConflict(answer):\n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i+7].append(ref1)\n",
    "                            else: # factual\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer):\n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i+7].append(ref1)\n",
    "            if n-pre!=1:\n",
    "                print(mark)\n",
    "                print(n-pre)\n",
    "                print(ref1)\n",
    "                print()\n",
    "    print(x)\n",
    "    print(t)\n",
    "    print(num[-1]-t,(num[-1]-t)/num[-1])\n",
    "    print(f,f/num[-1])\n",
    "    print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 295,
   "id": "eda8466c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 1 2 3\n",
      "0.5146443514644352\n",
      "0.639751552795031\n",
      "0 1 2 3\n",
      "0.5167364016736402\n",
      "0.640746500777605\n",
      "0 1 2 3\n",
      "0.5313807531380753\n",
      "0.6521739130434782\n",
      "0 1 2 3\n",
      "0.5334728033472803\n",
      "0.661608497723824\n",
      "0 1 2 3\n",
      "0.5376569037656904\n",
      "0.6646433990895296\n",
      "0 1 2 3\n",
      "0.5418410041841004\n",
      "0.6551181102362205\n",
      "0 1 2 3\n",
      "0.5418410041841004\n",
      "0.6572769953051643\n"
     ]
    }
   ],
   "source": [
    "minV=0\n",
    "for kk in range(13-7):\n",
    "    for jj in range(kk+1,13-6):\n",
    "        for ii in range(jj+1,13-5):\n",
    "            for i in range(ii+1,13-4):\n",
    "                for j in range(i+1,13-3):\n",
    "                     for k in range(j+1,13-2):\n",
    "                        for m in range(k+1,13-1):\n",
    "                            for n in range(m+1,13-0):\n",
    "                                #for q in range(n+1,13-0):\n",
    "                                    #for w in range(q+1,13-0):\n",
    "                                        #for z in range(w+1,13-0):\n",
    "                                            #for y in range(z+1,13-0):\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",
    "                                                a=list(set(a))\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",
    "                                                a=list(set(a))\n",
    "                                                bb=len(a)\n",
    "                                                TN=(num[-1]-bb)/(num[-1]*2)\n",
    "                                                TP=aa/(num[-1]*2)\n",
    "                                                FN=(num[-1]-aa)/(num[-1]*2)\n",
    "                                                FP=bb/(num[-1]*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": "markdown",
   "id": "afb6cec4",
   "metadata": {},
   "source": [
    "# wice+0.1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 224,
   "id": "6c0033e7",
   "metadata": {},
   "outputs": [],
   "source": [
    "tlist=[[] for _ in range(13)]\n",
    "flist=[[] for _ in range(13)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 320,
   "id": "88494d1d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "242\n",
      "214\n",
      "31 0.12653061224489795\n",
      "221 0.9020408163265307\n",
      "matched num= 484\n",
      "242\n",
      "181\n",
      "64 0.2612244897959184\n",
      "191 0.7795918367346939\n",
      "matched num= 484\n",
      "242\n",
      "167\n",
      "78 0.3183673469387755\n",
      "178 0.726530612244898\n",
      "matched num= 484\n",
      "242\n",
      "199\n",
      "46 0.18775510204081633\n",
      "217 0.8857142857142857\n",
      "matched num= 484\n",
      "242\n",
      "177\n",
      "68 0.27755102040816326\n",
      "174 0.710204081632653\n",
      "matched num= 484\n",
      "242\n",
      "198\n",
      "47 0.19183673469387755\n",
      "210 0.8571428571428571\n",
      "matched num= 484\n",
      "242\n",
      "189\n",
      "56 0.22857142857142856\n",
      "179 0.7306122448979592\n",
      "matched num= 484\n"
     ]
    }
   ],
   "source": [
    "for i in range(7):\n",
    "    t=0\n",
    "    f=0\n",
    "    n=0\n",
    "    x=0\n",
    "    with open(filePath[8]+\"dataset_0.1.jsonl\") as file1:\n",
    "        for line1 in file1:\n",
    "            label=line1.split(\"label: \")[-1]\n",
    "            ref1=line1.split(\"Response: \")[0].split(\"Reference: \")\n",
    "            if len(ref1)==2:\n",
    "                ref1=ref1[1]\n",
    "            else:\n",
    "                ref1=ref1[1]+\"Reference: \"+ref1[2]\n",
    "            pre=n\n",
    "            flag=False\n",
    "            ref1=ref1[:-8]\n",
    "            with open(filePath[8]+\"detections_\"+str(i+1)+\".jsonl\") as file:\n",
    "                mark=[]\n",
    "                for line in file:\n",
    "                    answer=line.split(\"Result: \")[1]\n",
    "                    ref=line.split(\"P2: \")[0].split(\"P1: \")[1]\n",
    "                    ref=ref.encode().decode('unicode_escape')\n",
    "                    ref=ref[1:-8]\n",
    "                    if ref.strip()==ref1.strip():\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                tlist[i].append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer): \n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                flist[i].append(ref1)\n",
    "                    if flag==False:\n",
    "                        # \n",
    "                        c1=ref.strip().split(\",\")[0]\n",
    "                        c2=ref1.strip().split(\",\")[0]\n",
    "                        if c1.strip()==c2.strip():\n",
    "                            flag=True\n",
    "                            n+=1\n",
    "                            mark.append(',')\n",
    "                            if 'true' in label: #hallucination\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer): \n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i].append(ref1)\n",
    "                            else: # factual\n",
    "                                if identifyConflict(answer): \n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i].append(ref1)\n",
    "                    if flag==False:\n",
    "                        # \n",
    "                        c1=ref.strip().split(\".\")\n",
    "                        c2=ref1.strip().split(\".\")\n",
    "                        if len(c1)>2 and len(c2)>2 and c1[-2]==c2[-2]:\n",
    "                            flag=True\n",
    "                            n+=1\n",
    "                            mark.append('.')\n",
    "                            if 'true' in label: #hallucination\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer): \n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i].append(ref1)\n",
    "                            else: # factual\n",
    "                                if identifyConflict(answer): \n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i].append(ref1)\n",
    "                    if flag==False:\n",
    "                        # \n",
    "                        c1=ref.strip().split(\"\\\\\\\\n\")\n",
    "                        c2=ref1.strip().split(\"\\\\\\\\n\")\n",
    "                        if len(c1)>2 and len(c2)>2 and c1[-1]==c2[-1]:\n",
    "                            flag=True\n",
    "                            mark.append('n')\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer): \n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i].append(ref1)\n",
    "                            else: # factual\n",
    "                                if identifyConflict(answer): \n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i].append(ref1)\n",
    "                    if flag==False:\n",
    "                        # \n",
    "                        c1=ref.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                        c2=ref1.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                        if len(c1)>2 and len(c2)>2 and c1[1]==c2[1]:\n",
    "                            flag=True\n",
    "                            mark.append('\\\"')\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                if identifyConflict(answer):\n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i].append(ref1)\n",
    "                            else: # factual\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer):\n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i].append(ref1)\n",
    "            if n-pre!=1:\n",
    "                print(mark)\n",
    "                print(n-pre)\n",
    "                print(ref1)\n",
    "                print()\n",
    "    print(x)\n",
    "    print(t)\n",
    "    print(num[-1]-t,(num[-1]-t)/num[-1])\n",
    "    print(f,f/num[-1])\n",
    "    print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 226,
   "id": "bec1e1db",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "242\n",
      "220\n",
      "22 0.09090909090909091\n",
      "222 0.9173553719008265\n",
      "matched num= 484\n",
      "242\n",
      "198\n",
      "44 0.18181818181818182\n",
      "202 0.8347107438016529\n",
      "matched num= 484\n",
      "242\n",
      "217\n",
      "25 0.10330578512396695\n",
      "217 0.8966942148760331\n",
      "matched num= 484\n",
      "242\n",
      "171\n",
      "71 0.29338842975206614\n",
      "187 0.7727272727272727\n",
      "matched num= 484\n",
      "242\n",
      "141\n",
      "101 0.41735537190082644\n",
      "154 0.6363636363636364\n",
      "matched num= 484\n",
      "255\n",
      "139\n",
      "103 0.4256198347107438\n",
      "147 0.6074380165289256\n",
      "matched num= 484\n"
     ]
    }
   ],
   "source": [
    "for i in range(6):\n",
    "    t=0\n",
    "    f=0\n",
    "    n=0\n",
    "    x=0\n",
    "    with open(filePath[8]+\"dataset_0.1.jsonl\") as file1:\n",
    "        for line1 in file1:\n",
    "            label=line1.split(\"label: \")[-1]\n",
    "            ref1=line1.split(\"Response: \")[0].split(\"Reference: \")\n",
    "            if len(ref1)==2:\n",
    "                ref1=ref1[1]\n",
    "            else:\n",
    "                ref1=ref1[1]+\"Reference: \"+ref1[2]\n",
    "            pre=n\n",
    "            flag=False\n",
    "            ref1=ref1[:-8]\n",
    "            with open(filePath[8]+\"detections_\"+str(i+1)+\"_1.jsonl\") as file:\n",
    "                mark=[]\n",
    "                for line in file:\n",
    "                    answer=line.split(\"Result: \")[1]\n",
    "                    ref=line.split(\"P2: \")[0].split(\"P1: \")[1]\n",
    "                    ref=ref.encode().decode('unicode_escape')\n",
    "                    ref=ref[1:-8]\n",
    "                    if ref.strip()==ref1.strip():\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                tlist[i+7].append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer): \n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                flist[i+7].append(ref1)\n",
    "                    if flag==False:\n",
    "                        # \n",
    "                        c1=ref.strip().split(\",\")[0]\n",
    "                        c2=ref1.strip().split(\",\")[0]\n",
    "                        if c1.strip()==c2.strip():\n",
    "                            flag=True\n",
    "                            n+=1\n",
    "                            mark.append(',')\n",
    "                            if 'true' in label: #hallucination\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer): \n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i+7].append(ref1)\n",
    "                            else: # factual\n",
    "                                if identifyConflict(answer): \n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i+7].append(ref1)\n",
    "                    if flag==False:\n",
    "                        # \n",
    "                        c1=ref.strip().split(\".\")\n",
    "                        c2=ref1.strip().split(\".\")\n",
    "                        if len(c1)>2 and len(c2)>2 and c1[-2]==c2[-2]:\n",
    "                            flag=True\n",
    "                            n+=1\n",
    "                            mark.append('.')\n",
    "                            if 'true' in label: #hallucination\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer): \n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i+7].append(ref1)\n",
    "                            else: # factual\n",
    "                                if identifyConflict(answer): \n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i+7].append(ref1)\n",
    "                    if flag==False:\n",
    "                        # \n",
    "                        c1=ref.strip().split(\"\\\\\\\\n\")\n",
    "                        c2=ref1.strip().split(\"\\\\\\\\n\")\n",
    "                        if len(c1)>2 and len(c2)>2 and c1[-1]==c2[-1]:\n",
    "                            flag=True\n",
    "                            mark.append('n')\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer): \n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i+7].append(ref1)\n",
    "                            else: # factual\n",
    "                                if identifyConflict(answer): \n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i+7].append(ref1)\n",
    "                    if flag==False:\n",
    "                        # \n",
    "                        c1=ref.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                        c2=ref1.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                        if len(c1)>2 and len(c2)>2 and c1[1]==c2[1]:\n",
    "                            flag=True\n",
    "                            mark.append('\\\"')\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                if identifyConflict(answer):\n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i+7].append(ref1)\n",
    "                            else: # factual\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer):\n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i+7].append(ref1)\n",
    "                    if flag==False:\n",
    "                        if \"cording to Deadline, in February 2019, it was announced that Armie Hammer, Gary Old\" in ref and \"cording to Deadline, in February 2019, it was announced that Armie Hammer, Gary Old\" in ref1:\n",
    "                            flag=True\n",
    "                            mark.append('k')\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                if identifyConflict(answer):\n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i+7].append(ref1)\n",
    "                            else: # factual\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer):\n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i+7].append(ref1)\n",
    "                                                      \n",
    "            if n-pre!=1:\n",
    "                print(mark)\n",
    "                print(n-pre)\n",
    "                print(ref1)\n",
    "                print()\n",
    "    print(x)\n",
    "    print(t)\n",
    "    print(num[-1]-t,(num[-1]-t)/num[-1])\n",
    "    print(f,f/num[-1])\n",
    "    print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 236,
   "id": "a4433a35",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 1 2 3\n",
      "0.5082644628099173\n",
      "0.6006711409395973\n",
      "0 1 2 3\n",
      "0.5082644628099173\n",
      "0.5966101694915255\n",
      "0 1 2 3\n",
      "0.5227272727272727\n",
      "0.6231647634584013\n",
      "0 1 2 3\n",
      "0.5227272727272727\n",
      "0.6268174474959612\n",
      "0 1 2 3\n",
      "0.5289256198347108\n",
      "0.6095890410958904\n",
      "0 1 2 3\n",
      "0.5454545454545454\n",
      "0.6381578947368421\n",
      "0 1 3 4\n",
      "0.5495867768595041\n",
      "0.6241379310344827\n"
     ]
    }
   ],
   "source": [
    "minV=0\n",
    "for kk in range(13-8):\n",
    "    for jj in range(kk+1,13-7):\n",
    "        for ii in range(jj+1,13-6):\n",
    "            for i in range(ii+1,13-5):\n",
    "                for j in range(i+1,13-4):\n",
    "                     for k in range(j+1,13-3):\n",
    "                        for m in range(k+1,13-2):\n",
    "                            for n in range(m+1,13-1):\n",
    "                                for q in range(n+1,13-0):\n",
    "                                    #for w in range(q+1,13-0):\n",
    "                                        #for z in range(w+1,13-0):\n",
    "                                            #for y in range(z+1,13-0):\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",
    "                                                a=list(set(a))\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",
    "                                                a=list(set(a))\n",
    "                                                bb=len(a)\n",
    "                                                TN=(num[-1]-bb)/(num[-1]*2)\n",
    "                                                TP=aa/(num[-1]*2)\n",
    "                                                FN=(num[-1]-aa)/(num[-1]*2)\n",
    "                                                FP=bb/(num[-1]*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": "markdown",
   "id": "9fce30da",
   "metadata": {},
   "source": [
    "# climate+0.1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 335,
   "id": "81a729ff",
   "metadata": {},
   "outputs": [],
   "source": [
    "tlist=[[] for _ in range(13)]\n",
    "flist=[[] for _ in range(13)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 336,
   "id": "c7cf8faf",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "181\n",
      "154\n",
      "91 0.37142857142857144\n",
      "159 0.6489795918367347\n",
      "matched num= 350\n",
      "181\n",
      "142\n",
      "103 0.4204081632653061\n",
      "153 0.6244897959183674\n",
      "matched num= 350\n",
      "181\n",
      "144\n",
      "101 0.4122448979591837\n",
      "156 0.636734693877551\n",
      "matched num= 350\n",
      "181\n",
      "153\n",
      "92 0.37551020408163266\n",
      "141 0.5755102040816327\n",
      "matched num= 350\n",
      "181\n",
      "151\n",
      "94 0.3836734693877551\n",
      "145 0.5918367346938775\n",
      "matched num= 350\n",
      "181\n",
      "149\n",
      "96 0.39183673469387753\n",
      "148 0.6040816326530613\n",
      "matched num= 350\n",
      "181\n",
      "140\n",
      "105 0.42857142857142855\n",
      "143 0.5836734693877551\n",
      "matched num= 350\n"
     ]
    }
   ],
   "source": [
    "for i in range(7):\n",
    "    t=0\n",
    "    f=0\n",
    "    n=0\n",
    "    x=0\n",
    "    with open(filePath[2]+\"dataset_0.1.jsonl\") as file1:\n",
    "        for line1 in file1:\n",
    "            label=line1.split(\"label: \")[-1]\n",
    "            ref1=line1.split(\"Response: \")[0].split(\"Reference: \")\n",
    "            if len(ref1)==2:\n",
    "                ref1=ref1[1]\n",
    "            else:\n",
    "                ref1=ref1[1]+\"Reference: \"+ref1[2]\n",
    "            pre=n\n",
    "            flag=False\n",
    "            ref1=ref1[:-8]\n",
    "            with open(filePath[2]+\"detections_\"+str(i+1)+\".jsonl\") as file:\n",
    "                mark=[]\n",
    "                for line in file:\n",
    "                    answer=line.split(\"Result: \")[1]\n",
    "                    ref=line.split(\"P2: \")[0].split(\"P1: \")[1]\n",
    "                    ref=ref.encode().decode('unicode_escape')\n",
    "                    ref=ref[1:-15]\n",
    "                    if ref.strip()==ref1.strip():\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                tlist[i].append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer): \n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                flist[i].append(ref1)\n",
    "#                     if flag==False:\n",
    "#                         # \n",
    "#                         c1=ref.strip().split(\",\")[0]\n",
    "#                         c2=ref1.strip().split(\",\")[0]\n",
    "#                         if c1.strip()==c2.strip():\n",
    "#                             flag=True\n",
    "#                             n+=1\n",
    "#                             mark.append(',')\n",
    "#                             if 'true' in label: #hallucination\n",
    "#                                 x+=1\n",
    "#                                 if identifyConflict(answer): \n",
    "#                                     t+=1\n",
    "#                                 else:    \n",
    "#                                     tlist[i].append(ref1)\n",
    "#                             else: # factual\n",
    "#                                 if identifyConflict(answer): \n",
    "#                                     f+=1\n",
    "#                                 else:    \n",
    "#                                     flist[i].append(ref1)\n",
    "                    if flag==False:\n",
    "                        # \n",
    "                        c1=ref.strip().split(\".\")\n",
    "                        c2=ref1.strip().split(\".\")\n",
    "                        if len(c1)>2 and len(c2)>2 and c1[-2]==c2[-2]:\n",
    "                            flag=True\n",
    "                            n+=1\n",
    "                            mark.append('.')\n",
    "                            if 'true' in label: #hallucination\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer): \n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i].append(ref1)\n",
    "                            else: # factual\n",
    "                                if identifyConflict(answer): \n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i].append(ref1)\n",
    "                    if flag==False:\n",
    "                        # \n",
    "                        c1=ref.strip().split(\"\\\\\\\\n\")\n",
    "                        c2=ref1.strip().split(\"\\\\\\\\n\")\n",
    "                        if len(c1)>2 and len(c2)>2 and c1[-1]==c2[-1]:\n",
    "                            flag=True\n",
    "                            mark.append('n')\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer): \n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i].append(ref1)\n",
    "                            else: # factual\n",
    "                                if identifyConflict(answer): \n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i].append(ref1)\n",
    "                    if flag==False:\n",
    "                        # \n",
    "                        c1=ref.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                        c2=ref1.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                        if len(c1)>2 and len(c2)>2 and c1[1]==c2[1]:\n",
    "                            flag=True\n",
    "                            mark.append('\\\"')\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                if identifyConflict(answer):\n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i].append(ref1)\n",
    "                            else: # factual\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer):\n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i].append(ref1)\n",
    "                    if flag==False:\n",
    "                        if \"2019-07-03-climate-declaration_en.pdf Summarize the refer\" in ref and \"2019-07-03-climate-declaration_en.pdf Summarize the refer\"  in ref1:\n",
    "                            flag=True\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                if identifyConflict(answer):\n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i].append(ref1)\n",
    "                            else: # factual\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer):\n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i].append(ref1)\n",
    "            if n-pre!=1:\n",
    "                print(mark)\n",
    "                print(n-pre)\n",
    "                print(ref1)\n",
    "                print()\n",
    "    print(x)\n",
    "    print(t)\n",
    "    print(num[-1]-t,(num[-1]-t)/num[-1])\n",
    "    print(f,f/num[-1])\n",
    "    print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 337,
   "id": "9a47714c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "181\n",
      "145\n",
      "100 0.40816326530612246\n",
      "153 0.6244897959183674\n",
      "matched num= 350\n",
      "181\n",
      "145\n",
      "100 0.40816326530612246\n",
      "141 0.5755102040816327\n",
      "matched num= 350\n",
      "181\n",
      "145\n",
      "100 0.40816326530612246\n",
      "158 0.6448979591836734\n",
      "matched num= 350\n",
      "181\n",
      "145\n",
      "100 0.40816326530612246\n",
      "149 0.6081632653061224\n",
      "matched num= 350\n",
      "181\n",
      "129\n",
      "116 0.47346938775510206\n",
      "137 0.5591836734693878\n",
      "matched num= 350\n",
      "181\n",
      "133\n",
      "112 0.45714285714285713\n",
      "148 0.6040816326530613\n",
      "matched num= 350\n"
     ]
    }
   ],
   "source": [
    "for i in range(6):\n",
    "    t=0\n",
    "    f=0\n",
    "    n=0\n",
    "    x=0\n",
    "    with open(filePath[2]+\"dataset_0.1.jsonl\") as file1:\n",
    "        for line1 in file1:\n",
    "            label=line1.split(\"label: \")[-1]\n",
    "            ref1=line1.split(\"Response: \")[0].split(\"Reference: \")\n",
    "            if len(ref1)==2:\n",
    "                ref1=ref1[1]\n",
    "            else:\n",
    "                ref1=ref1[1]+\"Reference: \"+ref1[2]\n",
    "            pre=n\n",
    "            flag=False\n",
    "            ref1=ref1[:-8]\n",
    "            with open(filePath[2]+\"detections_\"+str(i+1)+\"_1.jsonl\") as file:\n",
    "                mark=[]\n",
    "                for line in file:\n",
    "                    answer=line.split(\"Result: \")[1]\n",
    "                    ref=line.split(\"P2: \")[0].split(\"P1: \")[1]\n",
    "                    ref=ref.encode().decode('unicode_escape')\n",
    "                    ref=ref[1:-15]\n",
    "                    if ref.strip()==ref1.strip():\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                tlist[i+7].append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer): \n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                flist[i+7].append(ref1)\n",
    "#                     if flag==False:\n",
    "#                         # \n",
    "#                         c1=ref.strip().split(\",\")[0]\n",
    "#                         c2=ref1.strip().split(\",\")[0]\n",
    "#                         if c1.strip()==c2.strip():\n",
    "#                             flag=True\n",
    "#                             n+=1\n",
    "#                             mark.append(',')\n",
    "#                             if 'true' in label: #hallucination\n",
    "#                                 x+=1\n",
    "#                                 if identifyConflict(answer): \n",
    "#                                     t+=1\n",
    "#                                 else:    \n",
    "#                                     tlist[i].append(ref1)\n",
    "#                             else: # factual\n",
    "#                                 if identifyConflict(answer): \n",
    "#                                     f+=1\n",
    "#                                 else:    \n",
    "#                                     flist[i].append(ref1)\n",
    "                    if flag==False:\n",
    "                        # \n",
    "                        c1=ref.strip().split(\".\")\n",
    "                        c2=ref1.strip().split(\".\")\n",
    "                        if len(c1)>2 and len(c2)>2 and c1[-2]==c2[-2]:\n",
    "                            flag=True\n",
    "                            n+=1\n",
    "                            mark.append('.')\n",
    "                            if 'true' in label: #hallucination\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer): \n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i+7].append(ref1)\n",
    "                            else: # factual\n",
    "                                if identifyConflict(answer): \n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i+7].append(ref1)\n",
    "                    if flag==False:\n",
    "                        # \n",
    "                        c1=ref.strip().split(\"\\\\\\\\n\")\n",
    "                        c2=ref1.strip().split(\"\\\\\\\\n\")\n",
    "                        if len(c1)>2 and len(c2)>2 and c1[-1]==c2[-1]:\n",
    "                            flag=True\n",
    "                            mark.append('n')\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer): \n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i+7].append(ref1)\n",
    "                            else: # factual\n",
    "                                if identifyConflict(answer): \n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i+7].append(ref1)\n",
    "                    if flag==False:\n",
    "                        # \n",
    "                        c1=ref.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                        c2=ref1.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                        if len(c1)>2 and len(c2)>2 and c1[1]==c2[1]:\n",
    "                            flag=True\n",
    "                            mark.append('\\\"')\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                if identifyConflict(answer):\n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i+7].append(ref1)\n",
    "                            else: # factual\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer):\n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i+7].append(ref1)\n",
    "                    if flag==False:\n",
    "                        if \"2019-07-03-climate-declaration_en.pdf Summarize the refer\" in ref and \"2019-07-03-climate-declaration_en.pdf Summarize the refer\"  in ref1:\n",
    "                            flag=True\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                if identifyConflict(answer):\n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    tlist[i+7].append(ref1)\n",
    "                            else: # factual\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer):\n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    flist[i+7].append(ref1)\n",
    "            if n-pre!=1:\n",
    "                print(mark)\n",
    "                print(n-pre)\n",
    "                print(ref1)\n",
    "                print()\n",
    "    print(x)\n",
    "    print(t)\n",
    "    print(num[-1]-t,(num[-1]-t)/num[-1])\n",
    "    print(f,f/num[-1])\n",
    "    print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 346,
   "id": "2abf49ed",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 1 2 3\n",
      "0.46122448979591835\n",
      "0.39449541284403666\n",
      "0 1 2 3\n",
      "0.47755102040816333\n",
      "0.41284403669724773\n",
      "0 1 2 3\n",
      "0.4877551020408163\n",
      "0.44097995545657015\n",
      "0 1 2 3\n",
      "0.4897959183673469\n",
      "0.41314553990610325\n",
      "0 1 2 3\n",
      "0.49591836734693884\n",
      "0.4449438202247191\n",
      "0 1 2 3\n",
      "0.5061224489795918\n",
      "0.4598214285714286\n",
      "0 1 2 3\n",
      "0.5081632653061224\n",
      "0.4559819413092551\n",
      "0 1 2 3\n",
      "0.5081632653061224\n",
      "0.4656319290465632\n",
      "0 1 2 3\n",
      "0.5081632653061224\n",
      "0.46325167037861914\n",
      "0 1 2 3\n",
      "0.5081632653061224\n",
      "0.4703296703296703\n",
      "0 1 2 3\n",
      "0.5081632653061224\n",
      "0.46325167037861914\n",
      "0 1 2 3\n",
      "0.5142857142857142\n",
      "0.46875\n",
      "0 1 2 3\n",
      "0.5142857142857142\n",
      "0.4780701754385965\n",
      "0 1 2 3\n",
      "0.5163265306122449\n",
      "0.47216035634743875\n",
      "0 1 2 4\n",
      "0.5163265306122449\n",
      "0.47450110864745015\n",
      "0 1 2 4\n",
      "0.5163265306122449\n",
      "0.4674157303370786\n",
      "0 1 2 4\n",
      "0.5244897959183674\n",
      "0.4716553287981859\n",
      "0 1 2 5\n",
      "0.5285714285714286\n",
      "0.4832214765100671\n",
      "0 1 2 6\n",
      "0.5285714285714286\n",
      "0.4900662251655629\n",
      "0 2 5 6\n",
      "0.5285714285714286\n",
      "0.4832214765100671\n",
      "0 2 5 6\n",
      "0.5306122448979591\n",
      "0.4866071428571429\n"
     ]
    }
   ],
   "source": [
    "minV=0\n",
    "for kk in range(13-7):\n",
    "    for jj in range(kk+1,13-6):\n",
    "        for ii in range(jj+1,13-5):\n",
    "            for i in range(ii+1,13-4):\n",
    "                for j in range(i+1,13-3):\n",
    "                     for k in range(j+1,13-2):\n",
    "                        for m in range(k+1,13-1):\n",
    "                            for n in range(m+1,13-0):\n",
    "                                #for q in range(n+1,13-0):\n",
    "                                    #for w in range(q+1,13-0):\n",
    "                                        #for z in range(w+1,13-0):\n",
    "                                            #for y in range(z+1,13-0):\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",
    "                                                a=list(set(a))\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",
    "                                                a=list(set(a))\n",
    "                                                bb=len(a)\n",
    "                                                TN=(num[-1]-bb)/(num[-1]*2)\n",
    "                                                TP=aa/(num[-1]*2)\n",
    "                                                FN=(num[-1]-aa)/(num[-1]*2)\n",
    "                                                FP=bb/(num[-1]*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": "markdown",
   "id": "17f75b95",
   "metadata": {},
   "source": [
    "# climate+0.5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 596,
   "id": "b4537c5a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2\n",
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a document signed by over 500 scientists and professionals in climate and related fields, stating that there is no climate emergency and that the current climate policies are not based on sound science. The declaration emphasizes that the Earth's climate has been changing for centuries and that the current warming period is not unusual when considering the geological history of the Earth. It also states that the impact of human activities on the climate is relatively small compared to natural factors and that the current policies aimed at reducing CO2 emissions will have little effect on the climate. The signatories of the ECD include climatologists, physicists, chemists, biologists, geologists, and other experts from Europe and around the world. They come from universities, research institutions, and private companies, and represent a wide range of scientific disciplines.\n",
      "\n",
      "2\n",
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a document signed by over 500 scientists and professionals in climate and related fields, stating that there is no climate emergency and that the current climate policies are not based on sound science. The declaration emphasizes that the Earth's climate has been changing for centuries and that the current warming period is not unusual when considering the geological history of the Earth. It also states that the impact of human activities on the climate is relatively small compared to natural factors and that the current policies aimed at reducing CO2 emissions will have little effect on the climate. The signatories of the ECD include climatologists, physicists, chemists, biologists, geologists, and other experts from Europe and around the world. They come from universities, research institutions, and private companies, and represent a wide range of scientific disciplines.\n",
      "\n",
      "2\n",
      " http://www.oism.org/pproject/ (Links to an external site.)Links to an external site. Summarize: The OISM Petition Project is a document that was created by the Oregon Institute of Science and Medicine (OISM) in 1998. The petition states that there is no convincing evidence that human release of greenhouse gases is causing catastrophic climate change. The petition also claims that the scientific consensus on global warming is not as strong as portrayed by the media and advocacy groups. According to the OISM website, over 31,000 scientists have signed the petition, including PhDs in fields such as atmospheric science, biology, chemistry, computer science, economics, engineering, geology, mathematics, medicine, physics, and more. However, the validity of the petition has been widely questioned due to concerns about the lack of transparency and accountability in the signing process. Some critics have pointed out that the list of signatories includes individuals who are not experts in climate science or who do not support the petition's statements. Additionally, there is no\n",
      "\n",
      "2\n",
      " http://www.oism.org/pproject/ (Links to an external site.)Links to an external site. Summarize: The OISM Petition Project is a document that was created by the Oregon Institute of Science and Medicine (OISM) in 1998. The petition states that there is no convincing evidence that human release of greenhouse gases is causing catastrophic climate change. The petition also claims that the scientific consensus on global warming is not as strong as portrayed by the media and advocacy groups. According to the OISM website, over 31,000 scientists have signed the petition, including PhDs in fields such as atmospheric science, biology, chemistry, computer science, economics, engineering, geology, mathematics, medicine, physics, and more. However, the validity of the petition has been widely questioned due to concerns about the lack of transparency and accountability in the signing process. Some critics have pointed out that the list of signatories includes individuals who are not experts in climate science or who do not support the petition's statements. Additionally, there is no\n",
      "\n",
      "2\n",
      " National Research Council (2010) Advancing the science of climate change. Washington, DC: The National Academies Press. Summarize: This reference affirms that most global warming since the mid-20th century is very likely due to human activities such as carbon dioxide emissions from fossil fuel use and land use changes, based on a comprehensive analysis of multiple lines of evidence including temperature records, satellite data, and other indicators.\n",
      "\n",
      "2\n",
      " National Research Council (2010) Advancing the science of climate change. Washington, DC: The National Academies Press. Summarize: This reference affirms that most global warming since the mid-20th century is very likely due to human activities such as carbon dioxide emissions from fossil fuel use and land use changes, based on a comprehensive analysis of multiple lines of evidence including temperature records, satellite data, and other indicators.\n",
      "\n",
      "38 0.21468926553672316\n",
      "143 0.807909604519774\n",
      "matched num= 360\n"
     ]
    }
   ],
   "source": [
    "t=0\n",
    "f=0\n",
    "t1=[]\n",
    "f1=[]\n",
    "n=0\n",
    "with open(filePath[1]+\"dataset_0.5.jsonl\") as file1:\n",
    "    for line1 in file1:\n",
    "        label=line1.split(\"label: \")[-1]\n",
    "        ref1=line1.split(\"Response: \")[0].split(\"Reference: \")[1]\n",
    "        pre=n\n",
    "        flag=False\n",
    "        ref1=ref1[:-8]\n",
    "        with open(filePath[1]+\"detections_1.jsonl\") as file:\n",
    "            for line in file:\n",
    "                answer=line.split(\"Result: \")[1]\n",
    "                ref=line.split(\"P2: \")[0].split(\"P1: \")[1]\n",
    "                ref=ref.encode().decode('unicode_escape')\n",
    "                ref=ref[1:-15]\n",
    "                if ref.strip()==ref1.strip():\n",
    "                    flag=True\n",
    "                    n+=1\n",
    "                    if 'true' in label: #hallucination\n",
    "                        if identifyConflict(answer):\n",
    "                            t+=1\n",
    "                        else:    \n",
    "                            t1.append(ref1)\n",
    "                    else: # factual\n",
    "                        if identifyConflict(answer):\n",
    "                            f+=1\n",
    "                        else:    \n",
    "                            f1.append(ref1)\n",
    "#                 if flag==False:\n",
    "#                     # \n",
    "#                     c1=ref.strip().split(\".\")[0]\n",
    "#                     c2=ref1.strip().split(\".\")[0]\n",
    "#                     if c1.strip()==c2.strip():\n",
    "#                         flag=True\n",
    "#                         n+=1\n",
    "#                         if 'true' in label: #hallucination\n",
    "#                             if identifyConflict(answer):\n",
    "#                                 t+=1\n",
    "#                             else:    \n",
    "#                                 t11.append(ref1)\n",
    "#                         else: # factual\n",
    "#                             if identifyConflict(answer):\n",
    "#                                 f+=1\n",
    "#                             else:    \n",
    "#                                 f11.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\".\")\n",
    "                    c2=ref1.strip().split(\".\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[-2]==c2[-2]:\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t1.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f1.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\n\")[-1]\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\n\")[-1]\n",
    "                    if c1==c2:\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t1.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f1.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[1]==c2[1]:\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t1.append(ref1)\n",
    "                        else: # factual\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f1.append(ref1)\n",
    "                if flag==False:\n",
    "                    uni=ref.strip().split('\\\\u')[-1][4:]\n",
    "                    length=len(uni)\n",
    "                    if ref1.strip()[-length:] == uni:\n",
    "                        flag = True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t1.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f1.append(ref1)\n",
    "        if n-pre!=1:\n",
    "            print(n-pre)\n",
    "            print(ref1)\n",
    "            print()\n",
    "print(num[-1]-t,(num[-1]-t)/num[-1])\n",
    "print(f,f/num[-1])\n",
    "print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 597,
   "id": "b9b2e351",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2\n",
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a document signed by over 500 scientists and professionals in climate and related fields, stating that there is no climate emergency and that the current climate policies are not based on sound science. The declaration emphasizes that the Earth's climate has been changing for centuries and that the current warming period is not unusual when considering the geological history of the Earth. It also states that the impact of human activities on the climate is relatively small compared to natural factors and that the current policies aimed at reducing CO2 emissions will have little effect on the climate. The signatories of the ECD include climatologists, physicists, chemists, biologists, geologists, and other experts from Europe and around the world. They come from universities, research institutions, and private companies, and represent a wide range of scientific disciplines.\n",
      "\n",
      "2\n",
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a document signed by over 500 scientists and professionals in climate and related fields, stating that there is no climate emergency and that the current climate policies are not based on sound science. The declaration emphasizes that the Earth's climate has been changing for centuries and that the current warming period is not unusual when considering the geological history of the Earth. It also states that the impact of human activities on the climate is relatively small compared to natural factors and that the current policies aimed at reducing CO2 emissions will have little effect on the climate. The signatories of the ECD include climatologists, physicists, chemists, biologists, geologists, and other experts from Europe and around the world. They come from universities, research institutions, and private companies, and represent a wide range of scientific disciplines.\n",
      "\n",
      "2\n",
      " http://www.oism.org/pproject/ (Links to an external site.)Links to an external site. Summarize: The OISM Petition Project is a document that was created by the Oregon Institute of Science and Medicine (OISM) in 1998. The petition states that there is no convincing evidence that human release of greenhouse gases is causing catastrophic climate change. The petition also claims that the scientific consensus on global warming is not as strong as portrayed by the media and advocacy groups. According to the OISM website, over 31,000 scientists have signed the petition, including PhDs in fields such as atmospheric science, biology, chemistry, computer science, economics, engineering, geology, mathematics, medicine, physics, and more. However, the validity of the petition has been widely questioned due to concerns about the lack of transparency and accountability in the signing process. Some critics have pointed out that the list of signatories includes individuals who are not experts in climate science or who do not support the petition's statements. Additionally, there is no\n",
      "\n",
      "2\n",
      " http://www.oism.org/pproject/ (Links to an external site.)Links to an external site. Summarize: The OISM Petition Project is a document that was created by the Oregon Institute of Science and Medicine (OISM) in 1998. The petition states that there is no convincing evidence that human release of greenhouse gases is causing catastrophic climate change. The petition also claims that the scientific consensus on global warming is not as strong as portrayed by the media and advocacy groups. According to the OISM website, over 31,000 scientists have signed the petition, including PhDs in fields such as atmospheric science, biology, chemistry, computer science, economics, engineering, geology, mathematics, medicine, physics, and more. However, the validity of the petition has been widely questioned due to concerns about the lack of transparency and accountability in the signing process. Some critics have pointed out that the list of signatories includes individuals who are not experts in climate science or who do not support the petition's statements. Additionally, there is no\n",
      "\n",
      "2\n",
      " National Research Council (2010) Advancing the science of climate change. Washington, DC: The National Academies Press. Summarize: This reference affirms that most global warming since the mid-20th century is very likely due to human activities such as carbon dioxide emissions from fossil fuel use and land use changes, based on a comprehensive analysis of multiple lines of evidence including temperature records, satellite data, and other indicators.\n",
      "\n",
      "2\n",
      " National Research Council (2010) Advancing the science of climate change. Washington, DC: The National Academies Press. Summarize: This reference affirms that most global warming since the mid-20th century is very likely due to human activities such as carbon dioxide emissions from fossil fuel use and land use changes, based on a comprehensive analysis of multiple lines of evidence including temperature records, satellite data, and other indicators.\n",
      "\n",
      "34 0.192090395480226\n",
      "132 0.7457627118644068\n",
      "matched num= 360\n"
     ]
    }
   ],
   "source": [
    "t=0\n",
    "f=0\n",
    "t11=[]\n",
    "f11=[]\n",
    "n=0\n",
    "with open(filePath[1]+\"dataset_0.5.jsonl\") as file1:\n",
    "    for line1 in file1:\n",
    "        label=line1.split(\"label: \")[-1]\n",
    "        ref1=line1.split(\"Response: \")[0].split(\"Reference: \")[1]\n",
    "        pre=n\n",
    "        flag=False\n",
    "        ref1=ref1[:-8]\n",
    "        with open(filePath[1]+\"detections_1_1.jsonl\") as file:\n",
    "            for line in file:\n",
    "                answer=line.split(\"Result: \")[1]\n",
    "                ref=line.split(\"P2: \")[0].split(\"P1: \")[1]\n",
    "                ref=ref.encode().decode('unicode_escape')\n",
    "                ref=ref[1:-15]\n",
    "                if ref.strip()==ref1.strip():\n",
    "                    flag=True\n",
    "                    n+=1\n",
    "                    if 'true' in label: #hallucination\n",
    "                        if identifyConflict(answer):\n",
    "                            t+=1\n",
    "                        else:    \n",
    "                            t11.append(ref1)\n",
    "                    else: # factual\n",
    "                        if identifyConflict(answer):\n",
    "                            f+=1\n",
    "                        else:    \n",
    "                            f11.append(ref1)\n",
    "#                 if flag==False:\n",
    "#                     # \n",
    "#                     c1=ref.strip().split(\".\")[0]\n",
    "#                     c2=ref1.strip().split(\".\")[0]\n",
    "#                     if c1.strip()==c2.strip():\n",
    "#                         flag=True\n",
    "#                         n+=1\n",
    "#                         if 'true' in label: #hallucination\n",
    "#                             if identifyConflict(answer):\n",
    "#                                 t+=1\n",
    "#                             else:    \n",
    "#                                 t11.append(ref1)\n",
    "#                         else: # factual\n",
    "#                             if identifyConflict(answer):\n",
    "#                                 f+=1\n",
    "#                             else:    \n",
    "#                                 f11.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\".\")\n",
    "                    c2=ref1.strip().split(\".\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[-2]==c2[-2]:\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t11.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f11.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\n\")[-1]\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\n\")[-1]\n",
    "                    if c1==c2:\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t11.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f11.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[1]==c2[1]:\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t11.append(ref1)\n",
    "                        else: # factual\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f11.append(ref1)\n",
    "                if flag==False:\n",
    "                    uni=ref.strip().split('\\\\u')[-1][4:]\n",
    "                    length=len(uni)\n",
    "                    if ref1.strip()[-length:] == uni:\n",
    "                        flag = True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t11.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f11.append(ref1)\n",
    "        if n-pre!=1:\n",
    "            print(n-pre)\n",
    "            print(ref1)\n",
    "            print()\n",
    "print(num[-1]-t,(num[-1]-t)/num[-1])\n",
    "print(f,f/num[-1])\n",
    "print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 598,
   "id": "aeee3d03",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2\n",
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a document signed by over 500 scientists and professionals in climate and related fields, stating that there is no climate emergency and that the current climate policies are not based on sound science. The declaration emphasizes that the Earth's climate has been changing for centuries and that the current warming period is not unusual when considering the geological history of the Earth. It also states that the impact of human activities on the climate is relatively small compared to natural factors and that the current policies aimed at reducing CO2 emissions will have little effect on the climate. The signatories of the ECD include climatologists, physicists, chemists, biologists, geologists, and other experts from Europe and around the world. They come from universities, research institutions, and private companies, and represent a wide range of scientific disciplines.\n",
      "\n",
      "2\n",
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a document signed by over 500 scientists and professionals in climate and related fields, stating that there is no climate emergency and that the current climate policies are not based on sound science. The declaration emphasizes that the Earth's climate has been changing for centuries and that the current warming period is not unusual when considering the geological history of the Earth. It also states that the impact of human activities on the climate is relatively small compared to natural factors and that the current policies aimed at reducing CO2 emissions will have little effect on the climate. The signatories of the ECD include climatologists, physicists, chemists, biologists, geologists, and other experts from Europe and around the world. They come from universities, research institutions, and private companies, and represent a wide range of scientific disciplines.\n",
      "\n",
      "2\n",
      " http://www.oism.org/pproject/ (Links to an external site.)Links to an external site. Summarize: The OISM Petition Project is a document that was created by the Oregon Institute of Science and Medicine (OISM) in 1998. The petition states that there is no convincing evidence that human release of greenhouse gases is causing catastrophic climate change. The petition also claims that the scientific consensus on global warming is not as strong as portrayed by the media and advocacy groups. According to the OISM website, over 31,000 scientists have signed the petition, including PhDs in fields such as atmospheric science, biology, chemistry, computer science, economics, engineering, geology, mathematics, medicine, physics, and more. However, the validity of the petition has been widely questioned due to concerns about the lack of transparency and accountability in the signing process. Some critics have pointed out that the list of signatories includes individuals who are not experts in climate science or who do not support the petition's statements. Additionally, there is no\n",
      "\n",
      "2\n",
      " http://www.oism.org/pproject/ (Links to an external site.)Links to an external site. Summarize: The OISM Petition Project is a document that was created by the Oregon Institute of Science and Medicine (OISM) in 1998. The petition states that there is no convincing evidence that human release of greenhouse gases is causing catastrophic climate change. The petition also claims that the scientific consensus on global warming is not as strong as portrayed by the media and advocacy groups. According to the OISM website, over 31,000 scientists have signed the petition, including PhDs in fields such as atmospheric science, biology, chemistry, computer science, economics, engineering, geology, mathematics, medicine, physics, and more. However, the validity of the petition has been widely questioned due to concerns about the lack of transparency and accountability in the signing process. Some critics have pointed out that the list of signatories includes individuals who are not experts in climate science or who do not support the petition's statements. Additionally, there is no\n",
      "\n",
      "2\n",
      " National Research Council (2010) Advancing the science of climate change. Washington, DC: The National Academies Press. Summarize: This reference affirms that most global warming since the mid-20th century is very likely due to human activities such as carbon dioxide emissions from fossil fuel use and land use changes, based on a comprehensive analysis of multiple lines of evidence including temperature records, satellite data, and other indicators.\n",
      "\n",
      "2\n",
      " National Research Council (2010) Advancing the science of climate change. Washington, DC: The National Academies Press. Summarize: This reference affirms that most global warming since the mid-20th century is very likely due to human activities such as carbon dioxide emissions from fossil fuel use and land use changes, based on a comprehensive analysis of multiple lines of evidence including temperature records, satellite data, and other indicators.\n",
      "\n",
      "50 0.2824858757062147\n",
      "132 0.7457627118644068\n",
      "matched num= 360\n"
     ]
    }
   ],
   "source": [
    "t=0\n",
    "f=0\n",
    "t2=[]\n",
    "f2=[]\n",
    "n=0\n",
    "with open(filePath[1]+\"dataset_0.5.jsonl\") as file1:\n",
    "    for line1 in file1:\n",
    "        label=line1.split(\"label: \")[-1]\n",
    "        ref1=line1.split(\"Response: \")[0].split(\"Reference: \")[1]\n",
    "        pre=n\n",
    "        flag=False\n",
    "        ref1=ref1[:-8]\n",
    "        with open(filePath[1]+\"detections_2.jsonl\") as file:\n",
    "            for line in file:\n",
    "                answer=line.split(\"Result: \")[1]\n",
    "                ref=line.split(\"P2: \")[0].split(\"P1: \")[1]\n",
    "                ref=ref.encode().decode('unicode_escape')\n",
    "                ref=ref[1:-15]\n",
    "                if ref.strip()==ref1.strip():\n",
    "                    flag=True\n",
    "                    n+=1\n",
    "                    if 'true' in label: #hallucination\n",
    "                        if identifyConflict(answer):\n",
    "                            t+=1\n",
    "                        else:    \n",
    "                            t2.append(ref1)\n",
    "                    else: # factual\n",
    "                        if identifyConflict(answer):\n",
    "                            f+=1\n",
    "                        else:    \n",
    "                            f2.append(ref1)\n",
    "#                 if flag==False:\n",
    "#                     # \n",
    "#                     c1=ref.strip().split(\".\")[0]\n",
    "#                     c2=ref1.strip().split(\".\")[0]\n",
    "#                     if c1.strip()==c2.strip():\n",
    "#                         flag=True\n",
    "#                         n+=1\n",
    "#                         if 'true' in label: #hallucination\n",
    "#                             if identifyConflict(answer):\n",
    "#                                 t+=1\n",
    "#                             else:    \n",
    "#                                 t2.append(ref1)\n",
    "#                         else: # factual\n",
    "#                             if identifyConflict(answer):\n",
    "#                                 f+=1\n",
    "#                             else:    \n",
    "#                                 f2.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\".\")\n",
    "                    c2=ref1.strip().split(\".\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[-2]==c2[-2]:\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t2.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f2.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\n\")[-1]\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\n\")[-1]\n",
    "                    if c1==c2:\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t2.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f2.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[1]==c2[1]:\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t2.append(ref1)\n",
    "                        else: # factual\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f2.append(ref1)\n",
    "                if flag==False:\n",
    "                    uni=ref.strip().split('\\\\u')[-1][4:]\n",
    "                    length=len(uni)\n",
    "                    if ref1.strip()[-length:] == uni:\n",
    "                        flag = True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer): \n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t2.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f2.append(ref1)\n",
    "        if n-pre!=1:\n",
    "            print(n-pre)\n",
    "            print(ref1)\n",
    "            print()\n",
    "print(num[-1]-t,(num[-1]-t)/num[-1])\n",
    "print(f,f/num[-1])\n",
    "print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 599,
   "id": "3ecb9f7a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a document signed by over 500 scientists and professionals in climate and related fields, stating that there is no climate emergency and that the current climate policies are not based on sound science. The declaration emphasizes that the Earth's climate has been changing for centuries and that the current warming period is not unusual when considering the geological history of the Earth. It also states that the impact of human activities on the climate is relatively small compared to natural factors and that the current policies aimed at reducing CO2 emissions will have little effect on the climate. The signatories of the ECD include climatologists, physicists, chemists, biologists, geologists, and other experts from Europe and around the world. They come from universities, research institutions, and private companies, and represent a wide range of scientific disciplines.\n",
      "\n",
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a document signed by over 500 scientists and professionals in climate and related fields, stating that there is no climate emergency and that the current climate policies are not based on sound science. The declaration emphasizes that the Earth's climate has been changing for centuries and that the current warming period is not unusual when considering the geological history of the Earth. It also states that the impact of human activities on the climate is relatively small compared to natural factors and that the current policies aimed at reducing CO2 emissions will have little effect on the climate. The signatories of the ECD include climatologists, physicists, chemists, biologists, geologists, and other experts from Europe and around the world. They come from universities, research institutions, and private companies, and represent a wide range of scientific disciplines.\n",
      "\n",
      " http://www.oism.org/pproject/ (Links to an external site.)Links to an external site. Summarize: The OISM Petition Project is a document that was created by the Oregon Institute of Science and Medicine (OISM) in 1998. The petition states that there is no convincing evidence that human release of greenhouse gases is causing catastrophic climate change. The petition also claims that the scientific consensus on global warming is not as strong as portrayed by the media and advocacy groups. According to the OISM website, over 31,000 scientists have signed the petition, including PhDs in fields such as atmospheric science, biology, chemistry, computer science, economics, engineering, geology, mathematics, medicine, physics, and more. However, the validity of the petition has been widely questioned due to concerns about the lack of transparency and accountability in the signing process. Some critics have pointed out that the list of signatories includes individuals who are not experts in climate science or who do not support the petition's statements. Additionally, there is no\n",
      "\n",
      " http://www.oism.org/pproject/ (Links to an external site.)Links to an external site. Summarize: The OISM Petition Project is a document that was created by the Oregon Institute of Science and Medicine (OISM) in 1998. The petition states that there is no convincing evidence that human release of greenhouse gases is causing catastrophic climate change. The petition also claims that the scientific consensus on global warming is not as strong as portrayed by the media and advocacy groups. According to the OISM website, over 31,000 scientists have signed the petition, including PhDs in fields such as atmospheric science, biology, chemistry, computer science, economics, engineering, geology, mathematics, medicine, physics, and more. However, the validity of the petition has been widely questioned due to concerns about the lack of transparency and accountability in the signing process. Some critics have pointed out that the list of signatories includes individuals who are not experts in climate science or who do not support the petition's statements. Additionally, there is no\n",
      "\n",
      " National Research Council (2010) Advancing the science of climate change. Washington, DC: The National Academies Press. Summarize: This reference affirms that most global warming since the mid-20th century is very likely due to human activities such as carbon dioxide emissions from fossil fuel use and land use changes, based on a comprehensive analysis of multiple lines of evidence including temperature records, satellite data, and other indicators.\n",
      "\n",
      " National Research Council (2010) Advancing the science of climate change. Washington, DC: The National Academies Press. Summarize: This reference affirms that most global warming since the mid-20th century is very likely due to human activities such as carbon dioxide emissions from fossil fuel use and land use changes, based on a comprehensive analysis of multiple lines of evidence including temperature records, satellite data, and other indicators.\n",
      "\n",
      "31 0.1751412429378531\n",
      "144 0.8135593220338984\n",
      "matched num= 360\n"
     ]
    }
   ],
   "source": [
    "t=0\n",
    "f=0\n",
    "t22=[]\n",
    "f22=[]\n",
    "n=0\n",
    "with open(filePath[1]+\"dataset_0.5.jsonl\") as file1:\n",
    "    for line1 in file1:\n",
    "        label=line1.split(\"label: \")[-1]\n",
    "        ref1=line1.split(\"Response: \")[0].split(\"Reference: \")[1]\n",
    "        pre=n\n",
    "        flag=False\n",
    "        ref1=ref1[:-8]\n",
    "        with open(filePath[1]+\"detections_2_1.jsonl\") as file:\n",
    "            for line in file:\n",
    "                answer=line.split(\"Result: \")[1]\n",
    "                ref=line.split(\"P2: \")[0].split(\"P1: \")[1]\n",
    "                ref=ref.encode().decode('unicode_escape')\n",
    "                ref=ref[1:-15]\n",
    "                if ref.strip()==ref1.strip():\n",
    "                    flag=True\n",
    "                    n+=1\n",
    "                    if 'true' in label: #hallucination\n",
    "                        if identifyConflict(answer):\n",
    "                            t+=1\n",
    "                        else:    \n",
    "                            t22.append(ref1)\n",
    "                    else: # factual\n",
    "                        if identifyConflict(answer):\n",
    "                            f+=1\n",
    "                        else:    \n",
    "                            f22.append(ref1)\n",
    "#                 if flag==False:\n",
    "#                     # \n",
    "#                     c1=ref.strip().split(\".\")[0]\n",
    "#                     c2=ref1.strip().split(\".\")[0]\n",
    "#                     if c1.strip()==c2.strip():\n",
    "#                         flag=True\n",
    "#                         n+=1\n",
    "#                         if 'true' in label: #hallucination\n",
    "#                             if identifyConflict(answer):\n",
    "#                                 t+=1\n",
    "#                             else:    \n",
    "#                                 t22.append(ref1)\n",
    "#                         else: # factual\n",
    "#                             if identifyConflict(answer):\n",
    "#                                 f+=1\n",
    "#                             else:    \n",
    "#                                 f22.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\".\")\n",
    "                    c2=ref1.strip().split(\".\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[-2]==c2[-2]:\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t22.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f22.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\n\")[-1]\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\n\")[-1]\n",
    "                    if c1==c2:\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t22.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f22.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[1]==c2[1]:\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t22.append(ref1)\n",
    "                        else: # factual\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f22.append(ref1)\n",
    "                if flag==False:\n",
    "                    uni=ref.strip().split('\\\\u')[-1][4:]\n",
    "                    length=len(uni)\n",
    "                    if ref1.strip()[-length:] == uni:\n",
    "                        flag = True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t22.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f22.append(ref1)\n",
    "        if n-pre!=1:\n",
    "            print(ref1)\n",
    "            print()\n",
    "print(num[-1]-t,(num[-1]-t)/num[-1])\n",
    "print(f,f/num[-1])\n",
    "print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 600,
   "id": "fc069949",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a document signed by over 500 scientists and professionals in climate and related fields, stating that there is no climate emergency and that the current climate policies are not based on sound science. The declaration emphasizes that the Earth's climate has been changing for centuries and that the current warming period is not unusual when considering the geological history of the Earth. It also states that the impact of human activities on the climate is relatively small compared to natural factors and that the current policies aimed at reducing CO2 emissions will have little effect on the climate. The signatories of the ECD include climatologists, physicists, chemists, biologists, geologists, and other experts from Europe and around the world. They come from universities, research institutions, and private companies, and represent a wide range of scientific disciplines.\n",
      "\n",
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a document signed by over 500 scientists and professionals in climate and related fields, stating that there is no climate emergency and that the current climate policies are not based on sound science. The declaration emphasizes that the Earth's climate has been changing for centuries and that the current warming period is not unusual when considering the geological history of the Earth. It also states that the impact of human activities on the climate is relatively small compared to natural factors and that the current policies aimed at reducing CO2 emissions will have little effect on the climate. The signatories of the ECD include climatologists, physicists, chemists, biologists, geologists, and other experts from Europe and around the world. They come from universities, research institutions, and private companies, and represent a wide range of scientific disciplines.\n",
      "\n",
      " http://www.oism.org/pproject/ (Links to an external site.)Links to an external site. Summarize: The OISM Petition Project is a document that was created by the Oregon Institute of Science and Medicine (OISM) in 1998. The petition states that there is no convincing evidence that human release of greenhouse gases is causing catastrophic climate change. The petition also claims that the scientific consensus on global warming is not as strong as portrayed by the media and advocacy groups. According to the OISM website, over 31,000 scientists have signed the petition, including PhDs in fields such as atmospheric science, biology, chemistry, computer science, economics, engineering, geology, mathematics, medicine, physics, and more. However, the validity of the petition has been widely questioned due to concerns about the lack of transparency and accountability in the signing process. Some critics have pointed out that the list of signatories includes individuals who are not experts in climate science or who do not support the petition's statements. Additionally, there is no\n",
      "\n",
      " http://www.oism.org/pproject/ (Links to an external site.)Links to an external site. Summarize: The OISM Petition Project is a document that was created by the Oregon Institute of Science and Medicine (OISM) in 1998. The petition states that there is no convincing evidence that human release of greenhouse gases is causing catastrophic climate change. The petition also claims that the scientific consensus on global warming is not as strong as portrayed by the media and advocacy groups. According to the OISM website, over 31,000 scientists have signed the petition, including PhDs in fields such as atmospheric science, biology, chemistry, computer science, economics, engineering, geology, mathematics, medicine, physics, and more. However, the validity of the petition has been widely questioned due to concerns about the lack of transparency and accountability in the signing process. Some critics have pointed out that the list of signatories includes individuals who are not experts in climate science or who do not support the petition's statements. Additionally, there is no\n",
      "\n",
      " National Research Council (2010) Advancing the science of climate change. Washington, DC: The National Academies Press. Summarize: This reference affirms that most global warming since the mid-20th century is very likely due to human activities such as carbon dioxide emissions from fossil fuel use and land use changes, based on a comprehensive analysis of multiple lines of evidence including temperature records, satellite data, and other indicators.\n",
      "\n",
      " National Research Council (2010) Advancing the science of climate change. Washington, DC: The National Academies Press. Summarize: This reference affirms that most global warming since the mid-20th century is very likely due to human activities such as carbon dioxide emissions from fossil fuel use and land use changes, based on a comprehensive analysis of multiple lines of evidence including temperature records, satellite data, and other indicators.\n",
      "\n",
      "40 0.22598870056497175\n",
      "134 0.7570621468926554\n",
      "matched num= 360\n"
     ]
    }
   ],
   "source": [
    "t=0\n",
    "f=0\n",
    "t3=[]\n",
    "f3=[]\n",
    "n=0\n",
    "with open(filePath[1]+\"dataset_0.5.jsonl\") as file1:\n",
    "    for line1 in file1:\n",
    "        label=line1.split(\"label: \")[-1]\n",
    "        ref1=line1.split(\"Response: \")[0].split(\"Reference: \")[1]\n",
    "        ref1=ref1[:-8]\n",
    "        pre=n\n",
    "        flag=False\n",
    "        with open(filePath[1]+\"detections_3.jsonl\") as file:\n",
    "            for line in file:\n",
    "                answer=line.split(\"Result: \")[1]\n",
    "                ref=line.split(\"P2: \")[0].split(\"P1: \")[1]\n",
    "                ref=ref.encode().decode('unicode_escape')\n",
    "                ref=ref[1:-15]\n",
    "                if ref.strip()==ref1.strip():\n",
    "                    flag=True\n",
    "                    n+=1\n",
    "                    if 'true' in label: #hallucination\n",
    "                        if identifyConflict(answer):\n",
    "                            t+=1\n",
    "                        else:    \n",
    "                            t3.append(ref1)\n",
    "                    else: # factual\n",
    "                        if identifyConflict(answer):\n",
    "                            f+=1\n",
    "                        else:    \n",
    "                            f3.append(ref1)\n",
    "#                 if flag==False:\n",
    "#                     # \n",
    "#                     c1=ref.strip().split(\".\")[0]\n",
    "#                     c2=ref1.strip().split(\".\")[0]\n",
    "#                     if c1.strip()==c2.strip():\n",
    "#                         flag=True\n",
    "#                         n+=1\n",
    "#                         if 'true' in label: #hallucination\n",
    "#                             if identifyConflict(answer):\n",
    "#                                 t+=1\n",
    "#                             else:    \n",
    "#                                 t3.append(ref1)\n",
    "#                         else: # factual\n",
    "#                             if identifyConflict(answer):\n",
    "#                                 f+=1\n",
    "#                             else:    \n",
    "#                                 f3.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\".\")\n",
    "                    c2=ref1.strip().split(\".\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[-2]==c2[-2]:\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t3.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f3.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\n\")[-1]\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\n\")[-1]\n",
    "                    if c1==c2:\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t3.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f3.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[1]==c2[1]:\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t3.append(ref1)\n",
    "                        else: # factual\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f3.append(ref1)\n",
    "                if flag==False:\n",
    "                    uni=ref.strip().split('\\\\u')[-1][4:]\n",
    "                    length=len(uni)\n",
    "                    if ref1.strip()[-length:] == uni:\n",
    "                        flag = True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer): \n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t3.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f3.append(ref1)\n",
    "        if n-pre!=1:\n",
    "            print(ref1)\n",
    "            print()\n",
    "print(num[-1]-t,(num[-1]-t)/num[-1])\n",
    "print(f,f/num[-1])\n",
    "print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 601,
   "id": "ece1b7c8",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a document signed by over 500 scientists and professionals in climate and related fields, stating that there is no climate emergency and that the current climate policies are not based on sound science. The declaration emphasizes that the Earth's climate has been changing for centuries and that the current warming period is not unusual when considering the geological history of the Earth. It also states that the impact of human activities on the climate is relatively small compared to natural factors and that the current policies aimed at reducing CO2 emissions will have little effect on the climate. The signatories of the ECD include climatologists, physicists, chemists, biologists, geologists, and other experts from Europe and around the world. They come from universities, research institutions, and private companies, and represent a wide range of scientific disciplines.\n",
      "\n",
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a document signed by over 500 scientists and professionals in climate and related fields, stating that there is no climate emergency and that the current climate policies are not based on sound science. The declaration emphasizes that the Earth's climate has been changing for centuries and that the current warming period is not unusual when considering the geological history of the Earth. It also states that the impact of human activities on the climate is relatively small compared to natural factors and that the current policies aimed at reducing CO2 emissions will have little effect on the climate. The signatories of the ECD include climatologists, physicists, chemists, biologists, geologists, and other experts from Europe and around the world. They come from universities, research institutions, and private companies, and represent a wide range of scientific disciplines.\n",
      "\n",
      " http://www.oism.org/pproject/ (Links to an external site.)Links to an external site. Summarize: The OISM Petition Project is a document that was created by the Oregon Institute of Science and Medicine (OISM) in 1998. The petition states that there is no convincing evidence that human release of greenhouse gases is causing catastrophic climate change. The petition also claims that the scientific consensus on global warming is not as strong as portrayed by the media and advocacy groups. According to the OISM website, over 31,000 scientists have signed the petition, including PhDs in fields such as atmospheric science, biology, chemistry, computer science, economics, engineering, geology, mathematics, medicine, physics, and more. However, the validity of the petition has been widely questioned due to concerns about the lack of transparency and accountability in the signing process. Some critics have pointed out that the list of signatories includes individuals who are not experts in climate science or who do not support the petition's statements. Additionally, there is no\n",
      "\n",
      " http://www.oism.org/pproject/ (Links to an external site.)Links to an external site. Summarize: The OISM Petition Project is a document that was created by the Oregon Institute of Science and Medicine (OISM) in 1998. The petition states that there is no convincing evidence that human release of greenhouse gases is causing catastrophic climate change. The petition also claims that the scientific consensus on global warming is not as strong as portrayed by the media and advocacy groups. According to the OISM website, over 31,000 scientists have signed the petition, including PhDs in fields such as atmospheric science, biology, chemistry, computer science, economics, engineering, geology, mathematics, medicine, physics, and more. However, the validity of the petition has been widely questioned due to concerns about the lack of transparency and accountability in the signing process. Some critics have pointed out that the list of signatories includes individuals who are not experts in climate science or who do not support the petition's statements. Additionally, there is no\n",
      "\n",
      " National Research Council (2010) Advancing the science of climate change. Washington, DC: The National Academies Press. Summarize: This reference affirms that most global warming since the mid-20th century is very likely due to human activities such as carbon dioxide emissions from fossil fuel use and land use changes, based on a comprehensive analysis of multiple lines of evidence including temperature records, satellite data, and other indicators.\n",
      "\n",
      " National Research Council (2010) Advancing the science of climate change. Washington, DC: The National Academies Press. Summarize: This reference affirms that most global warming since the mid-20th century is very likely due to human activities such as carbon dioxide emissions from fossil fuel use and land use changes, based on a comprehensive analysis of multiple lines of evidence including temperature records, satellite data, and other indicators.\n",
      "\n",
      "35 0.1977401129943503\n",
      "155 0.8757062146892656\n",
      "matched num= 360\n"
     ]
    }
   ],
   "source": [
    "t=0\n",
    "f=0\n",
    "t33=[]\n",
    "f33=[]\n",
    "n=0\n",
    "with open(filePath[1]+\"dataset_0.5.jsonl\") as file1:\n",
    "    for line1 in file1:\n",
    "        label=line1.split(\"label: \")[-1]\n",
    "        ref1=line1.split(\"Response: \")[0].split(\"Reference: \")[1]\n",
    "        ref1=ref1[:-8]\n",
    "        pre=n\n",
    "        flag=False\n",
    "        with open(filePath[1]+\"detections_3_1.jsonl\") as file:\n",
    "            for line in file:\n",
    "                answer=line.split(\"Result: \")[1]\n",
    "                ref=line.split(\"P2: \")[0].split(\"P1: \")[1]\n",
    "                ref=ref.encode().decode('unicode_escape')\n",
    "                ref=ref[1:-15]\n",
    "                if ref.strip()==ref1.strip():\n",
    "                    flag=True\n",
    "                    n+=1\n",
    "                    if 'true' in label: #hallucination\n",
    "                        if identifyConflict(answer):\n",
    "                            t+=1\n",
    "                        else:    \n",
    "                            t33.append(ref1)\n",
    "                    else: # factual\n",
    "                        if identifyConflict(answer):\n",
    "                            f+=1\n",
    "                        else:    \n",
    "                            f33.append(ref1)\n",
    "#                 if flag==False:\n",
    "#                     # \n",
    "#                     c1=ref.strip().split(\".\")[0]\n",
    "#                     c2=ref1.strip().split(\".\")[0]\n",
    "#                     if c1.strip()==c2.strip():\n",
    "#                         flag=True\n",
    "#                         n+=1\n",
    "#                         if 'true' in label: #hallucination\n",
    "#                             if identifyConflict(answer):\n",
    "#                                 t+=1\n",
    "#                             else:    \n",
    "#                                 t33.append(ref1)\n",
    "#                         else: # factual\n",
    "#                             if identifyConflict(answer):\n",
    "#                                 f+=1\n",
    "#                             else:    \n",
    "#                                 f33.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\".\")\n",
    "                    c2=ref1.strip().split(\".\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[-2]==c2[-2]:\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t33.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f33.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\n\")[-1]\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\n\")[-1]\n",
    "                    if c1==c2:\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t33.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f33.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[1]==c2[1]:\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t33.append(ref1)\n",
    "                        else: # factual\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f33.append(ref1)\n",
    "                if flag==False:\n",
    "                    uni=ref.strip().split('\\\\u')[-1][4:]\n",
    "                    length=len(uni)\n",
    "                    if ref1.strip()[-length:] == uni:\n",
    "                        flag = True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer): \n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t33.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f33.append(ref1)\n",
    "        if n-pre!=1:\n",
    "            print(ref1)\n",
    "            print()\n",
    "print(num[-1]-t,(num[-1]-t)/num[-1])\n",
    "print(f,f/num[-1])\n",
    "print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 602,
   "id": "2e64d0cb",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a document signed by over 500 scientists and professionals in climate and related fields, stating that there is no climate emergency and that the current climate policies are not based on sound science. The declaration emphasizes that the Earth's climate has been changing for centuries and that the current warming period is not unusual when considering the geological history of the Earth. It also states that the impact of human activities on the climate is relatively small compared to natural factors and that the current policies aimed at reducing CO2 emissions will have little effect on the climate. The signatories of the ECD include climatologists, physicists, chemists, biologists, geologists, and other experts from Europe and around the world. They come from universities, research institutions, and private companies, and represent a wide range of scientific disciplines.\n",
      "\n",
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a document signed by over 500 scientists and professionals in climate and related fields, stating that there is no climate emergency and that the current climate policies are not based on sound science. The declaration emphasizes that the Earth's climate has been changing for centuries and that the current warming period is not unusual when considering the geological history of the Earth. It also states that the impact of human activities on the climate is relatively small compared to natural factors and that the current policies aimed at reducing CO2 emissions will have little effect on the climate. The signatories of the ECD include climatologists, physicists, chemists, biologists, geologists, and other experts from Europe and around the world. They come from universities, research institutions, and private companies, and represent a wide range of scientific disciplines.\n",
      "\n",
      " http://www.oism.org/pproject/ (Links to an external site.)Links to an external site. Summarize: The OISM Petition Project is a document that was created by the Oregon Institute of Science and Medicine (OISM) in 1998. The petition states that there is no convincing evidence that human release of greenhouse gases is causing catastrophic climate change. The petition also claims that the scientific consensus on global warming is not as strong as portrayed by the media and advocacy groups. According to the OISM website, over 31,000 scientists have signed the petition, including PhDs in fields such as atmospheric science, biology, chemistry, computer science, economics, engineering, geology, mathematics, medicine, physics, and more. However, the validity of the petition has been widely questioned due to concerns about the lack of transparency and accountability in the signing process. Some critics have pointed out that the list of signatories includes individuals who are not experts in climate science or who do not support the petition's statements. Additionally, there is no\n",
      "\n",
      " http://www.oism.org/pproject/ (Links to an external site.)Links to an external site. Summarize: The OISM Petition Project is a document that was created by the Oregon Institute of Science and Medicine (OISM) in 1998. The petition states that there is no convincing evidence that human release of greenhouse gases is causing catastrophic climate change. The petition also claims that the scientific consensus on global warming is not as strong as portrayed by the media and advocacy groups. According to the OISM website, over 31,000 scientists have signed the petition, including PhDs in fields such as atmospheric science, biology, chemistry, computer science, economics, engineering, geology, mathematics, medicine, physics, and more. However, the validity of the petition has been widely questioned due to concerns about the lack of transparency and accountability in the signing process. Some critics have pointed out that the list of signatories includes individuals who are not experts in climate science or who do not support the petition's statements. Additionally, there is no\n",
      "\n",
      " National Research Council (2010) Advancing the science of climate change. Washington, DC: The National Academies Press. Summarize: This reference affirms that most global warming since the mid-20th century is very likely due to human activities such as carbon dioxide emissions from fossil fuel use and land use changes, based on a comprehensive analysis of multiple lines of evidence including temperature records, satellite data, and other indicators.\n",
      "\n",
      " National Research Council (2010) Advancing the science of climate change. Washington, DC: The National Academies Press. Summarize: This reference affirms that most global warming since the mid-20th century is very likely due to human activities such as carbon dioxide emissions from fossil fuel use and land use changes, based on a comprehensive analysis of multiple lines of evidence including temperature records, satellite data, and other indicators.\n",
      "\n",
      "33 0.1864406779661017\n",
      "140 0.7909604519774012\n",
      "matched num= 360\n"
     ]
    }
   ],
   "source": [
    "t=0\n",
    "f=0\n",
    "t4=[]\n",
    "f4=[]\n",
    "n=0\n",
    "with open(filePath[1]+\"dataset_0.5.jsonl\") as file1:\n",
    "    for line1 in file1:\n",
    "        label=line1.split(\"label: \")[-1]\n",
    "        ref1=line1.split(\"Response: \")[0].split(\"Reference: \")[1]\n",
    "        ref1=ref1[:-8]\n",
    "        pre=n\n",
    "        flag=False\n",
    "        with open(filePath[1]+\"detections_4.jsonl\") as file:\n",
    "            for line in file:\n",
    "                answer=line.split(\"Result: \")[1]\n",
    "                ref=line.split(\"P2: \")[0].split(\"P1: \")[1]\n",
    "                ref=ref.encode().decode('unicode_escape')\n",
    "                ref=ref[1:-15]\n",
    "                if ref.strip()==ref1.strip():\n",
    "                    flag=True\n",
    "                    n+=1\n",
    "                    if 'true' in label: #hallucination\n",
    "                        if identifyConflict(answer):\n",
    "                            t+=1\n",
    "                        else:    \n",
    "                            t4.append(ref1)\n",
    "                    else: # factual\n",
    "                        if identifyConflict(answer):\n",
    "                            f+=1\n",
    "                        else:    \n",
    "                            f4.append(ref1)\n",
    "#                 if flag==False:\n",
    "#                     # \n",
    "#                     c1=ref.strip().split(\".\")[0]\n",
    "#                     c2=ref1.strip().split(\".\")[0]\n",
    "#                     if c1.strip()==c2.strip():\n",
    "#                         flag=True\n",
    "#                         n+=1\n",
    "#                         if 'true' in label: #hallucination\n",
    "#                             if identifyConflict(answer):\n",
    "#                                 t+=1\n",
    "#                             else:    \n",
    "#                                 t4.append(ref1)\n",
    "#                         else: # factual\n",
    "#                             if identifyConflict(answer):\n",
    "#                                 f+=1\n",
    "#                             else:    \n",
    "#                                 f4.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\".\")\n",
    "                    c2=ref1.strip().split(\".\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[-2]==c2[-2]:\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t4.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f4.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\n\")[-1]\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\n\")[-1]\n",
    "                    if c1==c2:\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t4.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f4.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[1]==c2[1]:\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t4.append(ref1)\n",
    "                        else: # factual\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f4.append(ref1)\n",
    "                if flag==False:\n",
    "                    uni=ref.strip().split('\\\\u')[-1][4:]\n",
    "                    length=len(uni)\n",
    "                    if ref1.strip()[-length:] == uni:\n",
    "                        flag = True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer): \n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t4.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f4.append(ref1)\n",
    "        if n-pre!=1:\n",
    "            print(ref1)\n",
    "            print()\n",
    "print(num[-1]-t,(num[-1]-t)/num[-1])\n",
    "print(f,f/num[-1])\n",
    "print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 603,
   "id": "10b1d16d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a document signed by over 500 scientists and professionals in climate and related fields, stating that there is no climate emergency and that the current climate policies are not based on sound science. The declaration emphasizes that the Earth's climate has been changing for centuries and that the current warming period is not unusual when considering the geological history of the Earth. It also states that the impact of human activities on the climate is relatively small compared to natural factors and that the current policies aimed at reducing CO2 emissions will have little effect on the climate. The signatories of the ECD include climatologists, physicists, chemists, biologists, geologists, and other experts from Europe and around the world. They come from universities, research institutions, and private companies, and represent a wide range of scientific disciplines.\n",
      "\n",
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a document signed by over 500 scientists and professionals in climate and related fields, stating that there is no climate emergency and that the current climate policies are not based on sound science. The declaration emphasizes that the Earth's climate has been changing for centuries and that the current warming period is not unusual when considering the geological history of the Earth. It also states that the impact of human activities on the climate is relatively small compared to natural factors and that the current policies aimed at reducing CO2 emissions will have little effect on the climate. The signatories of the ECD include climatologists, physicists, chemists, biologists, geologists, and other experts from Europe and around the world. They come from universities, research institutions, and private companies, and represent a wide range of scientific disciplines.\n",
      "\n",
      " http://www.oism.org/pproject/ (Links to an external site.)Links to an external site. Summarize: The OISM Petition Project is a document that was created by the Oregon Institute of Science and Medicine (OISM) in 1998. The petition states that there is no convincing evidence that human release of greenhouse gases is causing catastrophic climate change. The petition also claims that the scientific consensus on global warming is not as strong as portrayed by the media and advocacy groups. According to the OISM website, over 31,000 scientists have signed the petition, including PhDs in fields such as atmospheric science, biology, chemistry, computer science, economics, engineering, geology, mathematics, medicine, physics, and more. However, the validity of the petition has been widely questioned due to concerns about the lack of transparency and accountability in the signing process. Some critics have pointed out that the list of signatories includes individuals who are not experts in climate science or who do not support the petition's statements. Additionally, there is no\n",
      "\n",
      " http://www.oism.org/pproject/ (Links to an external site.)Links to an external site. Summarize: The OISM Petition Project is a document that was created by the Oregon Institute of Science and Medicine (OISM) in 1998. The petition states that there is no convincing evidence that human release of greenhouse gases is causing catastrophic climate change. The petition also claims that the scientific consensus on global warming is not as strong as portrayed by the media and advocacy groups. According to the OISM website, over 31,000 scientists have signed the petition, including PhDs in fields such as atmospheric science, biology, chemistry, computer science, economics, engineering, geology, mathematics, medicine, physics, and more. However, the validity of the petition has been widely questioned due to concerns about the lack of transparency and accountability in the signing process. Some critics have pointed out that the list of signatories includes individuals who are not experts in climate science or who do not support the petition's statements. Additionally, there is no\n",
      "\n",
      " National Research Council (2010) Advancing the science of climate change. Washington, DC: The National Academies Press. Summarize: This reference affirms that most global warming since the mid-20th century is very likely due to human activities such as carbon dioxide emissions from fossil fuel use and land use changes, based on a comprehensive analysis of multiple lines of evidence including temperature records, satellite data, and other indicators.\n",
      "\n",
      " National Research Council (2010) Advancing the science of climate change. Washington, DC: The National Academies Press. Summarize: This reference affirms that most global warming since the mid-20th century is very likely due to human activities such as carbon dioxide emissions from fossil fuel use and land use changes, based on a comprehensive analysis of multiple lines of evidence including temperature records, satellite data, and other indicators.\n",
      "\n",
      "34 0.192090395480226\n",
      "136 0.768361581920904\n",
      "matched num= 360\n"
     ]
    }
   ],
   "source": [
    "t=0\n",
    "f=0\n",
    "t44=[]\n",
    "f44=[]\n",
    "n=0\n",
    "with open(filePath[1]+\"dataset_0.5.jsonl\") as file1:\n",
    "    for line1 in file1:\n",
    "        label=line1.split(\"label: \")[-1]\n",
    "        ref1=line1.split(\"Response: \")[0].split(\"Reference: \")[1]\n",
    "        ref1=ref1[:-8]\n",
    "        pre=n\n",
    "        flag=False\n",
    "        with open(filePath[1]+\"detections_4_1.jsonl\") as file:\n",
    "            for line in file:\n",
    "                answer=line.split(\"Result: \")[1]\n",
    "                ref=line.split(\"P2: \")[0].split(\"P1: \")[1]\n",
    "                ref=ref.encode().decode('unicode_escape')\n",
    "                ref=ref[1:-15]\n",
    "                if ref.strip()==ref1.strip():\n",
    "                    flag=True\n",
    "                    n+=1\n",
    "                    if 'true' in label: #hallucination\n",
    "                        if identifyConflict(answer):\n",
    "                            t+=1\n",
    "                        else:    \n",
    "                            t44.append(ref1)\n",
    "                    else: # factual\n",
    "                        if identifyConflict(answer):\n",
    "                            f+=1\n",
    "                        else:    \n",
    "                            f44.append(ref1)\n",
    "#                 if flag==False:\n",
    "#                     # \n",
    "#                     c1=ref.strip().split(\".\")[0]\n",
    "#                     c2=ref1.strip().split(\".\")[0]\n",
    "#                     if c1.strip()==c2.strip():\n",
    "#                         flag=True\n",
    "#                         n+=1\n",
    "#                         if 'true' in label: #hallucination\n",
    "#                             if identifyConflict(answer):\n",
    "#                                 t+=1\n",
    "#                             else:    \n",
    "#                                 t44.append(ref1)\n",
    "#                         else: # factual\n",
    "#                             if identifyConflict(answer):\n",
    "#                                 f+=1\n",
    "#                             else:    \n",
    "#                                 f44.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\".\")\n",
    "                    c2=ref1.strip().split(\".\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[-2]==c2[-2]:\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t44.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f44.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\n\")[-1]\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\n\")[-1]\n",
    "                    if c1==c2:\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t44.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f44.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[1]==c2[1]:\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t44.append(ref1)\n",
    "                        else: # factual\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f44.append(ref1)\n",
    "                if flag==False:\n",
    "                    uni=ref.strip().split('\\\\u')[-1][4:]\n",
    "                    length=len(uni)\n",
    "                    if ref1.strip()[-length:] == uni:\n",
    "                        flag = True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer): \n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t44.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f44.append(ref1)\n",
    "        if n-pre!=1:\n",
    "            print(ref1)\n",
    "            print()\n",
    "print(num[-1]-t,(num[-1]-t)/num[-1])\n",
    "print(f,f/num[-1])\n",
    "print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 604,
   "id": "4952270d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a document signed by over 500 scientists and professionals in climate and related fields, stating that there is no climate emergency and that the current climate policies are not based on sound science. The declaration emphasizes that the Earth's climate has been changing for centuries and that the current warming period is not unusual when considering the geological history of the Earth. It also states that the impact of human activities on the climate is relatively small compared to natural factors and that the current policies aimed at reducing CO2 emissions will have little effect on the climate. The signatories of the ECD include climatologists, physicists, chemists, biologists, geologists, and other experts from Europe and around the world. They come from universities, research institutions, and private companies, and represent a wide range of scientific disciplines.\n",
      "\n",
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a document signed by over 500 scientists and professionals in climate and related fields, stating that there is no climate emergency and that the current climate policies are not based on sound science. The declaration emphasizes that the Earth's climate has been changing for centuries and that the current warming period is not unusual when considering the geological history of the Earth. It also states that the impact of human activities on the climate is relatively small compared to natural factors and that the current policies aimed at reducing CO2 emissions will have little effect on the climate. The signatories of the ECD include climatologists, physicists, chemists, biologists, geologists, and other experts from Europe and around the world. They come from universities, research institutions, and private companies, and represent a wide range of scientific disciplines.\n",
      "\n",
      " http://www.oism.org/pproject/ (Links to an external site.)Links to an external site. Summarize: The OISM Petition Project is a document that was created by the Oregon Institute of Science and Medicine (OISM) in 1998. The petition states that there is no convincing evidence that human release of greenhouse gases is causing catastrophic climate change. The petition also claims that the scientific consensus on global warming is not as strong as portrayed by the media and advocacy groups. According to the OISM website, over 31,000 scientists have signed the petition, including PhDs in fields such as atmospheric science, biology, chemistry, computer science, economics, engineering, geology, mathematics, medicine, physics, and more. However, the validity of the petition has been widely questioned due to concerns about the lack of transparency and accountability in the signing process. Some critics have pointed out that the list of signatories includes individuals who are not experts in climate science or who do not support the petition's statements. Additionally, there is no\n",
      "\n",
      " http://www.oism.org/pproject/ (Links to an external site.)Links to an external site. Summarize: The OISM Petition Project is a document that was created by the Oregon Institute of Science and Medicine (OISM) in 1998. The petition states that there is no convincing evidence that human release of greenhouse gases is causing catastrophic climate change. The petition also claims that the scientific consensus on global warming is not as strong as portrayed by the media and advocacy groups. According to the OISM website, over 31,000 scientists have signed the petition, including PhDs in fields such as atmospheric science, biology, chemistry, computer science, economics, engineering, geology, mathematics, medicine, physics, and more. However, the validity of the petition has been widely questioned due to concerns about the lack of transparency and accountability in the signing process. Some critics have pointed out that the list of signatories includes individuals who are not experts in climate science or who do not support the petition's statements. Additionally, there is no\n",
      "\n",
      " National Research Council (2010) Advancing the science of climate change. Washington, DC: The National Academies Press. Summarize: This reference affirms that most global warming since the mid-20th century is very likely due to human activities such as carbon dioxide emissions from fossil fuel use and land use changes, based on a comprehensive analysis of multiple lines of evidence including temperature records, satellite data, and other indicators.\n",
      "\n",
      " National Research Council (2010) Advancing the science of climate change. Washington, DC: The National Academies Press. Summarize: This reference affirms that most global warming since the mid-20th century is very likely due to human activities such as carbon dioxide emissions from fossil fuel use and land use changes, based on a comprehensive analysis of multiple lines of evidence including temperature records, satellite data, and other indicators.\n",
      "\n",
      "48 0.2711864406779661\n",
      "142 0.8022598870056498\n",
      "matched num= 360\n"
     ]
    }
   ],
   "source": [
    "t=0\n",
    "f=0\n",
    "t5=[]\n",
    "f5=[]\n",
    "n=0\n",
    "with open(filePath[1]+\"dataset_0.5.jsonl\") as file1:\n",
    "    for line1 in file1:\n",
    "        label=line1.split(\"label: \")[-1]\n",
    "        ref1=line1.split(\"Response: \")[0].split(\"Reference: \")[1]\n",
    "        ref1=ref1[:-8]\n",
    "        pre=n\n",
    "        flag=False\n",
    "        with open(filePath[1]+\"detections_5.jsonl\") as file:\n",
    "            for line in file:\n",
    "                answer=line.split(\"Result: \")[1]\n",
    "                ref=line.split(\"P2: \")[0].split(\"P1: \")[1]\n",
    "                ref=ref.encode().decode('unicode_escape')\n",
    "                ref=ref[1:-15]\n",
    "                if ref.strip()==ref1.strip():\n",
    "                    flag=True\n",
    "                    n+=1\n",
    "                    if 'true' in label: #hallucination\n",
    "                        if identifyConflict(answer):\n",
    "                            t+=1\n",
    "                        else:    \n",
    "                            t5.append(ref1)\n",
    "                    else: # factual\n",
    "                        if identifyConflict(answer):\n",
    "                            f+=1\n",
    "                        else:    \n",
    "                            f5.append(ref1)\n",
    "#                 if flag==False:\n",
    "#                     # \n",
    "#                     c1=ref.strip().split(\".\")[0]\n",
    "#                     c2=ref1.strip().split(\".\")[0]\n",
    "#                     if c1.strip()==c2.strip():\n",
    "#                         flag=True\n",
    "#                         n+=1\n",
    "#                         if 'true' in label: #hallucination\n",
    "#                             if identifyConflict(answer):\n",
    "#                                 t+=1\n",
    "#                             else:    \n",
    "#                                 t5.append(ref1)\n",
    "#                         else: # factual\n",
    "#                             if identifyConflict(answer):\n",
    "#                                 f+=1\n",
    "#                             else:    \n",
    "#                                 f5.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\".\")\n",
    "                    c2=ref1.strip().split(\".\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[-2]==c2[-2]:\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t5.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f5.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\n\")[-1]\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\n\")[-1]\n",
    "                    if c1==c2:\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t5.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f5.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[1]==c2[1]:\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t5.append(ref1)\n",
    "                        else: # factual\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f5.append(ref1)\n",
    "                if flag==False:\n",
    "                    uni=ref.strip().split('\\\\u')[-1][4:]\n",
    "                    length=len(uni)\n",
    "                    if ref1.strip()[-length:] == uni:\n",
    "                        flag = True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer): \n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t5.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f5.append(ref1)\n",
    "        if n-pre!=1:\n",
    "            print(ref1)\n",
    "            print()\n",
    "print(num[-1]-t,(num[-1]-t)/num[-1])\n",
    "print(f,f/num[-1])\n",
    "print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 605,
   "id": "a336ad0e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a document signed by over 500 scientists and professionals in climate and related fields, stating that there is no climate emergency and that the current climate policies are not based on sound science. The declaration emphasizes that the Earth's climate has been changing for centuries and that the current warming period is not unusual when considering the geological history of the Earth. It also states that the impact of human activities on the climate is relatively small compared to natural factors and that the current policies aimed at reducing CO2 emissions will have little effect on the climate. The signatories of the ECD include climatologists, physicists, chemists, biologists, geologists, and other experts from Europe and around the world. They come from universities, research institutions, and private companies, and represent a wide range of scientific disciplines.\n",
      "\n",
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a document signed by over 500 scientists and professionals in climate and related fields, stating that there is no climate emergency and that the current climate policies are not based on sound science. The declaration emphasizes that the Earth's climate has been changing for centuries and that the current warming period is not unusual when considering the geological history of the Earth. It also states that the impact of human activities on the climate is relatively small compared to natural factors and that the current policies aimed at reducing CO2 emissions will have little effect on the climate. The signatories of the ECD include climatologists, physicists, chemists, biologists, geologists, and other experts from Europe and around the world. They come from universities, research institutions, and private companies, and represent a wide range of scientific disciplines.\n",
      "\n",
      " http://www.oism.org/pproject/ (Links to an external site.)Links to an external site. Summarize: The OISM Petition Project is a document that was created by the Oregon Institute of Science and Medicine (OISM) in 1998. The petition states that there is no convincing evidence that human release of greenhouse gases is causing catastrophic climate change. The petition also claims that the scientific consensus on global warming is not as strong as portrayed by the media and advocacy groups. According to the OISM website, over 31,000 scientists have signed the petition, including PhDs in fields such as atmospheric science, biology, chemistry, computer science, economics, engineering, geology, mathematics, medicine, physics, and more. However, the validity of the petition has been widely questioned due to concerns about the lack of transparency and accountability in the signing process. Some critics have pointed out that the list of signatories includes individuals who are not experts in climate science or who do not support the petition's statements. Additionally, there is no\n",
      "\n",
      " http://www.oism.org/pproject/ (Links to an external site.)Links to an external site. Summarize: The OISM Petition Project is a document that was created by the Oregon Institute of Science and Medicine (OISM) in 1998. The petition states that there is no convincing evidence that human release of greenhouse gases is causing catastrophic climate change. The petition also claims that the scientific consensus on global warming is not as strong as portrayed by the media and advocacy groups. According to the OISM website, over 31,000 scientists have signed the petition, including PhDs in fields such as atmospheric science, biology, chemistry, computer science, economics, engineering, geology, mathematics, medicine, physics, and more. However, the validity of the petition has been widely questioned due to concerns about the lack of transparency and accountability in the signing process. Some critics have pointed out that the list of signatories includes individuals who are not experts in climate science or who do not support the petition's statements. Additionally, there is no\n",
      "\n",
      " National Research Council (2010) Advancing the science of climate change. Washington, DC: The National Academies Press. Summarize: This reference affirms that most global warming since the mid-20th century is very likely due to human activities such as carbon dioxide emissions from fossil fuel use and land use changes, based on a comprehensive analysis of multiple lines of evidence including temperature records, satellite data, and other indicators.\n",
      "\n",
      " National Research Council (2010) Advancing the science of climate change. Washington, DC: The National Academies Press. Summarize: This reference affirms that most global warming since the mid-20th century is very likely due to human activities such as carbon dioxide emissions from fossil fuel use and land use changes, based on a comprehensive analysis of multiple lines of evidence including temperature records, satellite data, and other indicators.\n",
      "\n",
      "48 0.2711864406779661\n",
      "141 0.7966101694915254\n",
      "matched num= 360\n"
     ]
    }
   ],
   "source": [
    "t=0\n",
    "f=0\n",
    "t55=[]\n",
    "f55=[]\n",
    "n=0\n",
    "with open(filePath[1]+\"dataset_0.5.jsonl\") as file1:\n",
    "    for line1 in file1:\n",
    "        label=line1.split(\"label: \")[-1]\n",
    "        ref1=line1.split(\"Response: \")[0].split(\"Reference: \")[1]\n",
    "        ref1=ref1[:-8]\n",
    "        pre=n\n",
    "        flag=False\n",
    "        with open(filePath[1]+\"detections_5_1.jsonl\") as file:\n",
    "            for line in file:\n",
    "                answer=line.split(\"Result: \")[1]\n",
    "                ref=line.split(\"P2: \")[0].split(\"P1: \")[1]\n",
    "                ref=ref.encode().decode('unicode_escape')\n",
    "                ref=ref[1:-15]\n",
    "                if ref.strip()==ref1.strip():\n",
    "                    flag=True\n",
    "                    n+=1\n",
    "                    if 'true' in label: #hallucination\n",
    "                        if identifyConflict(answer):\n",
    "                            t+=1\n",
    "                        else:    \n",
    "                            t55.append(ref1)\n",
    "                    else: # factual\n",
    "                        if identifyConflict(answer):\n",
    "                            f+=1\n",
    "                        else:    \n",
    "                            f55.append(ref1)\n",
    "#                 if flag==False:\n",
    "#                     # \n",
    "#                     c1=ref.strip().split(\".\")[0]\n",
    "#                     c2=ref1.strip().split(\".\")[0]\n",
    "#                     if c1.strip()==c2.strip():\n",
    "#                         flag=True\n",
    "#                         n+=1\n",
    "#                         if 'true' in label: #hallucination\n",
    "#                             if identifyConflict(answer):\n",
    "#                                 t+=1\n",
    "#                             else:    \n",
    "#                                 t55.append(ref1)\n",
    "#                         else: # factual\n",
    "#                             if identifyConflict(answer):\n",
    "#                                 f+=1\n",
    "#                             else:    \n",
    "#                                 f55.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\".\")\n",
    "                    c2=ref1.strip().split(\".\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[-2]==c2[-2]:\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t55.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f55.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\n\")[-1]\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\n\")[-1]\n",
    "                    if c1==c2:\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t55.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f55.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[1]==c2[1]:\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t55.append(ref1)\n",
    "                        else: # factual\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f55.append(ref1)\n",
    "                if flag==False:\n",
    "                    uni=ref.strip().split('\\\\u')[-1][4:]\n",
    "                    length=len(uni)\n",
    "                    if ref1.strip()[-length:] == uni:\n",
    "                        flag = True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer): \n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t55.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f55.append(ref1)\n",
    "        if n-pre!=1:\n",
    "            print(ref1)\n",
    "            print()\n",
    "print(num[-1]-t,(num[-1]-t)/num[-1])\n",
    "print(f,f/num[-1])\n",
    "print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 606,
   "id": "55367ada",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a document signed by over 500 scientists and professionals in climate and related fields, stating that there is no climate emergency and that the current climate policies are not based on sound science. The declaration emphasizes that the Earth's climate has been changing for centuries and that the current warming period is not unusual when considering the geological history of the Earth. It also states that the impact of human activities on the climate is relatively small compared to natural factors and that the current policies aimed at reducing CO2 emissions will have little effect on the climate. The signatories of the ECD include climatologists, physicists, chemists, biologists, geologists, and other experts from Europe and around the world. They come from universities, research institutions, and private companies, and represent a wide range of scientific disciplines.\n",
      "\n",
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a document signed by over 500 scientists and professionals in climate and related fields, stating that there is no climate emergency and that the current climate policies are not based on sound science. The declaration emphasizes that the Earth's climate has been changing for centuries and that the current warming period is not unusual when considering the geological history of the Earth. It also states that the impact of human activities on the climate is relatively small compared to natural factors and that the current policies aimed at reducing CO2 emissions will have little effect on the climate. The signatories of the ECD include climatologists, physicists, chemists, biologists, geologists, and other experts from Europe and around the world. They come from universities, research institutions, and private companies, and represent a wide range of scientific disciplines.\n",
      "\n",
      " http://www.oism.org/pproject/ (Links to an external site.)Links to an external site. Summarize: The OISM Petition Project is a document that was created by the Oregon Institute of Science and Medicine (OISM) in 1998. The petition states that there is no convincing evidence that human release of greenhouse gases is causing catastrophic climate change. The petition also claims that the scientific consensus on global warming is not as strong as portrayed by the media and advocacy groups. According to the OISM website, over 31,000 scientists have signed the petition, including PhDs in fields such as atmospheric science, biology, chemistry, computer science, economics, engineering, geology, mathematics, medicine, physics, and more. However, the validity of the petition has been widely questioned due to concerns about the lack of transparency and accountability in the signing process. Some critics have pointed out that the list of signatories includes individuals who are not experts in climate science or who do not support the petition's statements. Additionally, there is no\n",
      "\n",
      " http://www.oism.org/pproject/ (Links to an external site.)Links to an external site. Summarize: The OISM Petition Project is a document that was created by the Oregon Institute of Science and Medicine (OISM) in 1998. The petition states that there is no convincing evidence that human release of greenhouse gases is causing catastrophic climate change. The petition also claims that the scientific consensus on global warming is not as strong as portrayed by the media and advocacy groups. According to the OISM website, over 31,000 scientists have signed the petition, including PhDs in fields such as atmospheric science, biology, chemistry, computer science, economics, engineering, geology, mathematics, medicine, physics, and more. However, the validity of the petition has been widely questioned due to concerns about the lack of transparency and accountability in the signing process. Some critics have pointed out that the list of signatories includes individuals who are not experts in climate science or who do not support the petition's statements. Additionally, there is no\n",
      "\n",
      " National Research Council (2010) Advancing the science of climate change. Washington, DC: The National Academies Press. Summarize: This reference affirms that most global warming since the mid-20th century is very likely due to human activities such as carbon dioxide emissions from fossil fuel use and land use changes, based on a comprehensive analysis of multiple lines of evidence including temperature records, satellite data, and other indicators.\n",
      "\n",
      " National Research Council (2010) Advancing the science of climate change. Washington, DC: The National Academies Press. Summarize: This reference affirms that most global warming since the mid-20th century is very likely due to human activities such as carbon dioxide emissions from fossil fuel use and land use changes, based on a comprehensive analysis of multiple lines of evidence including temperature records, satellite data, and other indicators.\n",
      "\n",
      "27 0.15254237288135594\n",
      "153 0.864406779661017\n",
      "matched num= 360\n"
     ]
    }
   ],
   "source": [
    "t=0\n",
    "f=0\n",
    "t6=[]\n",
    "f6=[]\n",
    "n=0\n",
    "with open(filePath[1]+\"dataset_0.5.jsonl\") as file1:\n",
    "    for line1 in file1:\n",
    "        label=line1.split(\"label: \")[-1]\n",
    "        ref1=line1.split(\"Response: \")[0].split(\"Reference: \")[1]\n",
    "        ref1=ref1[:-8]\n",
    "        pre=n\n",
    "        flag=False\n",
    "        with open(filePath[1]+\"detections_6.jsonl\") as file:\n",
    "            for line in file:\n",
    "                answer=line.split(\"Result: \")[1]\n",
    "                ref=line.split(\"P2: \")[0].split(\"P1: \")[1]\n",
    "                ref=ref.encode().decode('unicode_escape')\n",
    "                ref=ref[1:-15]\n",
    "                if ref.strip()==ref1.strip():\n",
    "                    flag=True\n",
    "                    n+=1\n",
    "                    if 'true' in label: #hallucination\n",
    "                        if identifyConflict(answer):\n",
    "                            t+=1\n",
    "                        else:    \n",
    "                            t6.append(ref1)\n",
    "                    else: # factual\n",
    "                        if identifyConflict(answer):\n",
    "                            f+=1\n",
    "                        else:    \n",
    "                            f6.append(ref1)\n",
    "#                 if flag==False:\n",
    "#                     # \n",
    "#                     c1=ref.strip().split(\".\")[0]\n",
    "#                     c2=ref1.strip().split(\".\")[0]\n",
    "#                     if c1.strip()==c2.strip():\n",
    "#                         flag=True\n",
    "#                         n+=1\n",
    "#                         if 'true' in label: #hallucination\n",
    "#                             if identifyConflict(answer):\n",
    "#                                 t+=1\n",
    "#                             else:    \n",
    "#                                 t6.append(ref1)\n",
    "#                         else: # factual\n",
    "#                             if identifyConflict(answer):\n",
    "#                                 f+=1\n",
    "#                             else:    \n",
    "#                                 f6.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\".\")\n",
    "                    c2=ref1.strip().split(\".\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[-2]==c2[-2]:\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t6.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f6.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\n\")[-1]\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\n\")[-1]\n",
    "                    if c1==c2:\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t6.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f6.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[1]==c2[1]:\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t6.append(ref1)\n",
    "                        else: # factual\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f6.append(ref1)\n",
    "                if flag==False:\n",
    "                    uni=ref.strip().split('\\\\u')[-1][4:]\n",
    "                    length=len(uni)\n",
    "                    if ref1.strip()[-length:] == uni:\n",
    "                        flag = True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer): \n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t6.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f6.append(ref1)\n",
    "        if n-pre!=1:\n",
    "            print(ref1)\n",
    "            print()\n",
    "print(num[-1]-t,(num[-1]-t)/num[-1])\n",
    "print(f,f/num[-1])\n",
    "print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 607,
   "id": "a84ba5cb",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a document signed by over 500 scientists and professionals in climate and related fields, stating that there is no climate emergency and that the current climate policies are not based on sound science. The declaration emphasizes that the Earth's climate has been changing for centuries and that the current warming period is not unusual when considering the geological history of the Earth. It also states that the impact of human activities on the climate is relatively small compared to natural factors and that the current policies aimed at reducing CO2 emissions will have little effect on the climate. The signatories of the ECD include climatologists, physicists, chemists, biologists, geologists, and other experts from Europe and around the world. They come from universities, research institutions, and private companies, and represent a wide range of scientific disciplines.\n",
      "\n",
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a document signed by over 500 scientists and professionals in climate and related fields, stating that there is no climate emergency and that the current climate policies are not based on sound science. The declaration emphasizes that the Earth's climate has been changing for centuries and that the current warming period is not unusual when considering the geological history of the Earth. It also states that the impact of human activities on the climate is relatively small compared to natural factors and that the current policies aimed at reducing CO2 emissions will have little effect on the climate. The signatories of the ECD include climatologists, physicists, chemists, biologists, geologists, and other experts from Europe and around the world. They come from universities, research institutions, and private companies, and represent a wide range of scientific disciplines.\n",
      "\n",
      " http://www.oism.org/pproject/ (Links to an external site.)Links to an external site. Summarize: The OISM Petition Project is a document that was created by the Oregon Institute of Science and Medicine (OISM) in 1998. The petition states that there is no convincing evidence that human release of greenhouse gases is causing catastrophic climate change. The petition also claims that the scientific consensus on global warming is not as strong as portrayed by the media and advocacy groups. According to the OISM website, over 31,000 scientists have signed the petition, including PhDs in fields such as atmospheric science, biology, chemistry, computer science, economics, engineering, geology, mathematics, medicine, physics, and more. However, the validity of the petition has been widely questioned due to concerns about the lack of transparency and accountability in the signing process. Some critics have pointed out that the list of signatories includes individuals who are not experts in climate science or who do not support the petition's statements. Additionally, there is no\n",
      "\n",
      " http://www.oism.org/pproject/ (Links to an external site.)Links to an external site. Summarize: The OISM Petition Project is a document that was created by the Oregon Institute of Science and Medicine (OISM) in 1998. The petition states that there is no convincing evidence that human release of greenhouse gases is causing catastrophic climate change. The petition also claims that the scientific consensus on global warming is not as strong as portrayed by the media and advocacy groups. According to the OISM website, over 31,000 scientists have signed the petition, including PhDs in fields such as atmospheric science, biology, chemistry, computer science, economics, engineering, geology, mathematics, medicine, physics, and more. However, the validity of the petition has been widely questioned due to concerns about the lack of transparency and accountability in the signing process. Some critics have pointed out that the list of signatories includes individuals who are not experts in climate science or who do not support the petition's statements. Additionally, there is no\n",
      "\n",
      " National Research Council (2010) Advancing the science of climate change. Washington, DC: The National Academies Press. Summarize: This reference affirms that most global warming since the mid-20th century is very likely due to human activities such as carbon dioxide emissions from fossil fuel use and land use changes, based on a comprehensive analysis of multiple lines of evidence including temperature records, satellite data, and other indicators.\n",
      "\n",
      " National Research Council (2010) Advancing the science of climate change. Washington, DC: The National Academies Press. Summarize: This reference affirms that most global warming since the mid-20th century is very likely due to human activities such as carbon dioxide emissions from fossil fuel use and land use changes, based on a comprehensive analysis of multiple lines of evidence including temperature records, satellite data, and other indicators.\n",
      "\n",
      "35 0.1977401129943503\n",
      "132 0.7457627118644068\n",
      "matched num= 360\n",
      "179\n"
     ]
    }
   ],
   "source": [
    "t=0\n",
    "f=0\n",
    "t66=[]\n",
    "f66=[]\n",
    "n=0\n",
    "x=0\n",
    "with open(filePath[1]+\"dataset_0.5.jsonl\") as file1:\n",
    "    for line1 in file1:\n",
    "        label=line1.split(\"label: \")[-1]\n",
    "        ref1=line1.split(\"Response: \")[0].split(\"Reference: \")[1]\n",
    "        ref1=ref1[:-8]\n",
    "        pre=n\n",
    "        flag=False\n",
    "        with open(filePath[1]+\"detections_6_1.jsonl\") as file:\n",
    "            for line in file:\n",
    "                answer=line.split(\"Result: \")[1]\n",
    "                ref=line.split(\"P2: \")[0].split(\"P1: \")[1]\n",
    "                ref=ref.encode().decode('unicode_escape')\n",
    "                ref=ref[1:-15]\n",
    "                if ref.strip()==ref1.strip():\n",
    "                    flag=True\n",
    "                    n+=1\n",
    "                    if 'true' in label: #hallucination\n",
    "                        if identifyConflict(answer):\n",
    "                            t+=1\n",
    "                        else:    \n",
    "                            t66.append(ref1)\n",
    "                    else: # factual\n",
    "                        x+=1\n",
    "                        if identifyConflict(answer):\n",
    "                            f+=1\n",
    "                        else:    \n",
    "                            f66.append(ref1)\n",
    "#                 if flag==False:\n",
    "#                     # \n",
    "#                     c1=ref.strip().split(\".\")[0]\n",
    "#                     c2=ref1.strip().split(\".\")[0]\n",
    "#                     if c1.strip()==c2.strip():\n",
    "#                         flag=True\n",
    "#                         n+=1\n",
    "#                         if 'true' in label: #hallucination\n",
    "#                             if identifyConflict(answer):\n",
    "#                                 t+=1\n",
    "#                             else:    \n",
    "#                                 t66.append(ref1)\n",
    "#                         else: # factual\n",
    "#                             x+=1\n",
    "#                             if identifyConflict(answer):\n",
    "#                                 f+=1\n",
    "#                             else:    \n",
    "#                                 f66.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\".\")\n",
    "                    c2=ref1.strip().split(\".\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[-2]==c2[-2]:\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t66.append(ref1)\n",
    "                        else: # factual\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f66.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\n\")[-1]\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\n\")[-1]\n",
    "                    if c1==c2:\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t66.append(ref1)\n",
    "                        else: # factual\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f66.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[1]==c2[1]:\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t66.append(ref1)\n",
    "                        else: # factual\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f66.append(ref1)\n",
    "                if flag==False:\n",
    "                    uni=ref.strip().split('\\\\u')[-1][4:]\n",
    "                    length=len(uni)\n",
    "                    if ref1.strip()[-length:] == uni:\n",
    "                        flag = True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer): \n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t66.append(ref1)\n",
    "                        else: # factual\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f66.append(ref1)\n",
    "        if n-pre!=1:\n",
    "            print(ref1)\n",
    "            print()\n",
    "print(num[-1]-t,(num[-1]-t)/num[-1])\n",
    "print(f,f/num[-1])\n",
    "print('matched num=',n)\n",
    "print(x)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 608,
   "id": "c4db0f5c",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2\n",
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a document signed by over 500 scientists and professionals in climate and related fields, stating that there is no climate emergency and that the current climate policies are not based on sound science. The declaration emphasizes that the Earth's climate has been changing for centuries and that the current warming period is not unusual when considering the geological history of the Earth. It also states that the impact of human activities on the climate is relatively small compared to natural factors and that the current policies aimed at reducing CO2 emissions will have little effect on the climate. The signatories of the ECD include climatologists, physicists, chemists, biologists, geologists, and other experts from Europe and around the world. They come from universities, research institutions, and private companies, and represent a wide range of scientific disciplines.\n",
      "\n",
      "2\n",
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a document signed by over 500 scientists and professionals in climate and related fields, stating that there is no climate emergency and that the current climate policies are not based on sound science. The declaration emphasizes that the Earth's climate has been changing for centuries and that the current warming period is not unusual when considering the geological history of the Earth. It also states that the impact of human activities on the climate is relatively small compared to natural factors and that the current policies aimed at reducing CO2 emissions will have little effect on the climate. The signatories of the ECD include climatologists, physicists, chemists, biologists, geologists, and other experts from Europe and around the world. They come from universities, research institutions, and private companies, and represent a wide range of scientific disciplines.\n",
      "\n",
      "2\n",
      " http://www.oism.org/pproject/ (Links to an external site.)Links to an external site. Summarize: The OISM Petition Project is a document that was created by the Oregon Institute of Science and Medicine (OISM) in 1998. The petition states that there is no convincing evidence that human release of greenhouse gases is causing catastrophic climate change. The petition also claims that the scientific consensus on global warming is not as strong as portrayed by the media and advocacy groups. According to the OISM website, over 31,000 scientists have signed the petition, including PhDs in fields such as atmospheric science, biology, chemistry, computer science, economics, engineering, geology, mathematics, medicine, physics, and more. However, the validity of the petition has been widely questioned due to concerns about the lack of transparency and accountability in the signing process. Some critics have pointed out that the list of signatories includes individuals who are not experts in climate science or who do not support the petition's statements. Additionally, there is no\n",
      "\n",
      "2\n",
      " http://www.oism.org/pproject/ (Links to an external site.)Links to an external site. Summarize: The OISM Petition Project is a document that was created by the Oregon Institute of Science and Medicine (OISM) in 1998. The petition states that there is no convincing evidence that human release of greenhouse gases is causing catastrophic climate change. The petition also claims that the scientific consensus on global warming is not as strong as portrayed by the media and advocacy groups. According to the OISM website, over 31,000 scientists have signed the petition, including PhDs in fields such as atmospheric science, biology, chemistry, computer science, economics, engineering, geology, mathematics, medicine, physics, and more. However, the validity of the petition has been widely questioned due to concerns about the lack of transparency and accountability in the signing process. Some critics have pointed out that the list of signatories includes individuals who are not experts in climate science or who do not support the petition's statements. Additionally, there is no\n",
      "\n",
      "2\n",
      " National Research Council (2010) Advancing the science of climate change. Washington, DC: The National Academies Press. Summarize: This reference affirms that most global warming since the mid-20th century is very likely due to human activities such as carbon dioxide emissions from fossil fuel use and land use changes, based on a comprehensive analysis of multiple lines of evidence including temperature records, satellite data, and other indicators.\n",
      "\n",
      "2\n",
      " National Research Council (2010) Advancing the science of climate change. Washington, DC: The National Academies Press. Summarize: This reference affirms that most global warming since the mid-20th century is very likely due to human activities such as carbon dioxide emissions from fossil fuel use and land use changes, based on a comprehensive analysis of multiple lines of evidence including temperature records, satellite data, and other indicators.\n",
      "\n",
      "39 0.22033898305084745\n",
      "144 0.8135593220338984\n",
      "matched num= 360\n",
      "179\n"
     ]
    }
   ],
   "source": [
    "t=0\n",
    "f=0\n",
    "t7=[]\n",
    "f7=[]\n",
    "n=0\n",
    "x=0\n",
    "with open(filePath[1]+\"dataset_0.5.jsonl\") as file1:\n",
    "    for line1 in file1:\n",
    "        label=line1.split(\"label: \")[-1]\n",
    "        ref1=line1.split(\"Response: \")[0].split(\"Reference: \")[1]\n",
    "        ref1=ref1[:-8]\n",
    "        pre=n\n",
    "        flag=False\n",
    "        with open(filePath[1]+\"detections_7.jsonl\") as file:\n",
    "            for line in file:\n",
    "                answer=line.split(\"Result: \")[1]\n",
    "                ref=line.split(\"P2: \")[0].split(\"P1: \")[1]\n",
    "                ref=ref.encode().decode('unicode_escape')\n",
    "                ref=ref[1:-15]\n",
    "                if ref.strip()==ref1.strip():\n",
    "                    flag=True\n",
    "                    n+=1\n",
    "                    if 'true' in label: #hallucination\n",
    "                        if identifyConflict(answer):\n",
    "                            t+=1\n",
    "                        else:    \n",
    "                            t7.append(ref1)\n",
    "                    else: # factual\n",
    "                        x+=1\n",
    "                        if identifyConflict(answer):\n",
    "                            f+=1\n",
    "                        else:    \n",
    "                            f7.append(ref1)\n",
    "#                 if flag==False:\n",
    "#                     # \n",
    "#                     c1=ref.strip().split(\".\")[0]\n",
    "#                     c2=ref1.strip().split(\".\")[0]\n",
    "#                     if c1.strip()==c2.strip():\n",
    "#                         flag=True\n",
    "#                         n+=1\n",
    "#                         if 'true' in label: #hallucination\n",
    "#                             if identifyConflict(answer):\n",
    "#                                 t+=1\n",
    "#                             else:    \n",
    "#                                 t7.append(ref1)\n",
    "#                         else: # factual\n",
    "#                             x+=1\n",
    "#                             if identifyConflict(answer):\n",
    "#                                 f+=1\n",
    "#                             else:    \n",
    "#                                 f7.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\".\")\n",
    "                    c2=ref1.strip().split(\".\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[-2]==c2[-2]:\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t7.append(ref1)\n",
    "                        else: # factual\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f7.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\n\")[-1]\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\n\")[-1]\n",
    "                    if c1==c2:\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t7.append(ref1)\n",
    "                        else: # factual\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f7.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[1]==c2[1]:\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t7.append(ref1)\n",
    "                        else: # factual\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f7.append(ref1)\n",
    "                if flag==False:\n",
    "                    uni=ref.strip().split('\\\\u')[-1][4:]\n",
    "                    length=len(uni)\n",
    "                    if ref1.strip()[-length:] == uni:\n",
    "                        flag = True\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer): \n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t7.append(ref1)\n",
    "                        else: # factual\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f7.append(ref1)\n",
    "        if n-pre!=1:\n",
    "            print(n-pre)\n",
    "            print(ref1)\n",
    "            print()\n",
    "print(num[-1]-t,(num[-1]-t)/num[-1])\n",
    "print(f,f/num[-1])\n",
    "print('matched num=',n)\n",
    "print(x)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 625,
   "id": "7b4910cd",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 1 2 3 4 5 6 7 8 9 10\n",
      "0.5\n",
      "0.6226012793176973\n",
      "0 1 2 3 4 5 6 7 8 10 11\n",
      "0.5028248587570621\n",
      "0.6271186440677965\n",
      "0 1 2 3 4 6 7 8 9 10 11\n",
      "0.5056497175141242\n",
      "0.6284501061571125\n",
      "0 1 2 3 5 6 7 8 9 10 11\n",
      "0.5056497175141244\n",
      "0.6268656716417911\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-11):\n",
    "    for jj in range(kk+1,13-10):\n",
    "        for ii in range(jj+1,13-9):\n",
    "            for i in range(ii+1,13-8):\n",
    "                for j in range(i+1,13-7):\n",
    "                     for k in range(j+1,13-6):\n",
    "                        for m in range(k+1,13-5):\n",
    "                            for n in range(m+1,13-4):\n",
    "                                for q in range(n+1,13-3):\n",
    "                                    for w in range(q+1,13-2):\n",
    "                                        for z in range(w+1,13-1):\n",
    "                                            for y in range(z+1,13-0):\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",
    "                                                a=list(set(a))\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",
    "                                                a=list(set(a))\n",
    "                                                bb=len(a)\n",
    "                                                TN=(num[-1]-bb)/(num[-1]*2)\n",
    "                                                TP=aa/(num[-1]*2)\n",
    "                                                FN=(num[-1]-aa)/(num[-1]*2)\n",
    "                                                FP=bb/(num[-1]*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": 610,
   "id": "d85c6a54",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "149\n",
      "0.8418079096045198\n"
     ]
    }
   ],
   "source": [
    "a=t1+t2+t3+t4+t5+t6+t7+t11+t22+t33+t44+t55+t66 # \n",
    "res=set(a)\n",
    "a=list(res)\n",
    "print(len(a))\n",
    "aa=len(a)\n",
    "print(len(a)/num[-1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 611,
   "id": "6af91f5d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "150\n",
      "0.15254237288135594\n"
     ]
    }
   ],
   "source": [
    "a=f1+f2+f3+f4+f5+f6+f7+f11+f22+f33+f44+f55+f66 # \n",
    "res=set(a)\n",
    "a=list(res)\n",
    "print(len(a))\n",
    "bb=len(a)\n",
    "print((num[-1]-len(a))/num[-1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 612,
   "id": "f8fcc6da",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "FN 0.07909604519774012\n",
      "FP 0.423728813559322\n",
      "TN 0.07627118644067797\n",
      "TP 0.4209039548022599\n"
     ]
    }
   ],
   "source": [
    "nu=num[-1]\n",
    "all_nu=nu*2\n",
    "# FN:将正类错误预测为负类数，即未检测出来的幻觉数据比例\n",
    "FN=(nu-aa)/all_nu\n",
    "print('FN',FN)\n",
    "# FP:将负类错误预测为正类数,即误把factual数据判定为有幻觉的比例\n",
    "FP=bb/all_nu\n",
    "print('FP',FP)\n",
    "# TN:将负类正确预测为负类数,即检测出的factual数据比例\n",
    "TN=(nu-bb)/all_nu\n",
    "print('TN',TN)\n",
    "# TP:将正类正确预测为正类数,即检测出来的幻觉数据比例\n",
    "TP=aa/all_nu\n",
    "print('TP',TP)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 613,
   "id": "8a34a27d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.4971751412429379\n",
      "0.4983277591973244\n",
      "0.8418079096045198\n",
      "0.6260504201680673\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": "markdown",
   "id": "b8aa1111",
   "metadata": {},
   "source": [
    "# climate+0.9"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 514,
   "id": "b28f08c0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[]\n",
      "2\n",
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a public statement on climate change signed by over 500 scientists and professionals in climate and related fields from Europe and beyond. The declaration asserts that a human-caused climate emergency does not exist and emphasizes the need for a more balanced and nuanced approach to climate policy. It highlights the benefits of carbon dioxide for plant growth and the lack of evidence supporting extreme weather events being caused by human activity. The ECD acknowledges the potential for climate variability but stresses that natural factors such as solar activity and changes in global and regional temperature patterns are also important drivers of climate change. In conclusion, this reference supports a dissenting view on climate change and its causes, challenging the widely accepted position that human activities, particularly burning fossil fuels, are primarily responsible for global warming.\n",
      "\n",
      "[]\n",
      "2\n",
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a public statement on climate change signed by over 500 scientists and professionals in climate and related fields from Europe and beyond. The declaration asserts that a human-caused climate emergency does not exist and emphasizes the need for a more balanced and nuanced approach to climate policy. It highlights the benefits of carbon dioxide for plant growth and the lack of evidence supporting extreme weather events being caused by human activity. The ECD acknowledges the potential for climate variability but stresses that natural factors such as solar activity and changes in global and regional temperature patterns are also important drivers of climate change. In conclusion, this reference supports a dissenting view on climate change and its causes, challenging the widely accepted position that human activities, particularly burning fossil fuels, are primarily responsible for global warming.\n",
      "\n",
      "[]\n",
      "0\n",
      "\\\\\\\n",
      "\n",
      "184\n",
      "173\n",
      "13\n",
      "171 0.9293478260869565\n",
      "22 0.11956521739130435\n",
      "matched num= 369\n"
     ]
    }
   ],
   "source": [
    "t=0\n",
    "f=0\n",
    "t1=[]\n",
    "f1=[]\n",
    "n=0\n",
    "x=0\n",
    "with open(filePath[0]+\"dataset_0.9.jsonl\") as file1:\n",
    "    for line1 in file1:\n",
    "        label=line1.split(\"label: \")[-1]\n",
    "        ref1=line1.split(\"Response: \")[0].split(\"Reference: \")\n",
    "        if len(ref1)==2:\n",
    "            ref1=ref1[1]\n",
    "        else:\n",
    "            ref1=ref1[1]+\"Reference: \"+ref1[2]\n",
    "        pre=n\n",
    "        flag=False\n",
    "        ref1=ref1[:-8]\n",
    "        with open(\"detections_1_3.jsonl\") as file:\n",
    "            mark=[]\n",
    "            for line in file:\n",
    "                answer=line.split(\"Result: \")[1]\n",
    "                ref=line.split(\"P2: \")[0].split(\"P1: \")[1]\n",
    "                ref=ref.encode().decode('unicode_escape')\n",
    "                ref=ref[1:-15]\n",
    "                if \"The Real Inconvenient Truth\" in ref:\n",
    "                    ref+=\"ng\"\n",
    "                if ref.strip()==ref1.strip():\n",
    "                    flag=True\n",
    "                    n+=1\n",
    "                    if 'true' in label: #hallucination\n",
    "                        x+=1\n",
    "                        if identifyConflict(answer):\n",
    "                            t+=1\n",
    "                        else:    \n",
    "                            t1.append(ref1)\n",
    "                    else: # factual\n",
    "                        if identifyConflict(answer): \n",
    "                            f+=1\n",
    "                        else:    \n",
    "                            f1.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\",\")[0]\n",
    "                    c2=ref1.strip().split(\",\")[0]\n",
    "                    if c1.strip()==c2.strip():\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        mark.append(',')\n",
    "                        if 'true' in label: #hallucination\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer): \n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t1.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer): \n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f1.append(ref1)\n",
    "#                 if flag==False:\n",
    "#                     # \n",
    "#                     c1=ref.strip().split(\".\")\n",
    "#                     c2=ref1.strip().split(\".\")\n",
    "#                     if len(c1)>2 and len(c2)>2 and c1[-2]==c2[-2]:\n",
    "#                         flag=True\n",
    "#                         n+=1\n",
    "#                         mark.append('.')\n",
    "#                         if 'true' in label: #hallucination\n",
    "#                             x+=1\n",
    "#                             if identifyConflict(answer): \n",
    "#                                 t+=1\n",
    "#                             else:    \n",
    "#                                 t1.append(ref1)\n",
    "#                         else: # factual\n",
    "#                             if identifyConflict(answer): \n",
    "#                                 f+=1\n",
    "#                             else:    \n",
    "#                                 f1.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\n\")\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\n\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[-1]==c2[-1]:\n",
    "                        flag=True\n",
    "                        mark.append('n')\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer): \n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t1.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer): \n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f1.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[1]==c2[1]:\n",
    "                        flag=True\n",
    "                        mark.append('\\\"')\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t1.append(ref1)\n",
    "                        else: # factual\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f1.append(ref1)\n",
    "                if flag==False:\n",
    "                    uni=ref.strip().split('\\\\\\\\\\\\\\\\u')\n",
    "                    if len(uni)>1 and \"d Unreliability and Electricity Prices: Th\" not in ref:\n",
    "                        uni=uni[-2][4:]\n",
    "                        length=len(uni)\n",
    "                        #if ref1.strip()[-length:] == uni:\n",
    "                        if uni in ref1.strip():\n",
    "                            flag = True\n",
    "                            mark.append('u')\n",
    "                            mark.append(ref)\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer): \n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    t1.append(ref1)\n",
    "                            else: # factual\n",
    "                                if identifyConflict(answer): \n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    f1.append(ref1)\n",
    "        if n-pre!=1:\n",
    "            print(mark)\n",
    "            print(n-pre)\n",
    "            print(ref1)\n",
    "            print()\n",
    "print(x)\n",
    "print(len(t1))\n",
    "print(t)\n",
    "print(num[-1]-t,(num[-1]-t)/num[-1])\n",
    "print(f,f/num[-1])\n",
    "print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 515,
   "id": "09922d7f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[]\n",
      "2\n",
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a public statement on climate change signed by over 500 scientists and professionals in climate and related fields from Europe and beyond. The declaration asserts that a human-caused climate emergency does not exist and emphasizes the need for a more balanced and nuanced approach to climate policy. It highlights the benefits of carbon dioxide for plant growth and the lack of evidence supporting extreme weather events being caused by human activity. The ECD acknowledges the potential for climate variability but stresses that natural factors such as solar activity and changes in global and regional temperature patterns are also important drivers of climate change. In conclusion, this reference supports a dissenting view on climate change and its causes, challenging the widely accepted position that human activities, particularly burning fossil fuels, are primarily responsible for global warming.\n",
      "\n",
      "[]\n",
      "2\n",
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a public statement on climate change signed by over 500 scientists and professionals in climate and related fields from Europe and beyond. The declaration asserts that a human-caused climate emergency does not exist and emphasizes the need for a more balanced and nuanced approach to climate policy. It highlights the benefits of carbon dioxide for plant growth and the lack of evidence supporting extreme weather events being caused by human activity. The ECD acknowledges the potential for climate variability but stresses that natural factors such as solar activity and changes in global and regional temperature patterns are also important drivers of climate change. In conclusion, this reference supports a dissenting view on climate change and its causes, challenging the widely accepted position that human activities, particularly burning fossil fuels, are primarily responsible for global warming.\n",
      "\n",
      "[]\n",
      "0\n",
      "\\\\\\\n",
      "\n",
      "184\n",
      "173\n",
      "172\n",
      "12 0.06521739130434782\n",
      "173 0.9402173913043478\n",
      "matched num= 369\n"
     ]
    }
   ],
   "source": [
    "t=0\n",
    "f=0\n",
    "t11=[]\n",
    "f11=[]\n",
    "n=0\n",
    "x=0\n",
    "with open(filePath[0]+\"dataset_0.9.jsonl\") as file1:\n",
    "    for line1 in file1:\n",
    "        label=line1.split(\"label: \")[-1]\n",
    "        ref1=line1.split(\"Response: \")[0].split(\"Reference: \")\n",
    "        if len(ref1)==2:\n",
    "            ref1=ref1[1]\n",
    "        else:\n",
    "            ref1=ref1[1]+\"Reference: \"+ref1[2]\n",
    "        pre=n\n",
    "        flag=False\n",
    "        ref1=ref1[:-8]\n",
    "        with open(filePath[0]+\"detections_1_1.jsonl\") as file:\n",
    "            mark=[]\n",
    "            for line in file:\n",
    "                answer=line.split(\"Result: \")[1]\n",
    "                ref=line.split(\"P2: \")[0].split(\"P1: \")[1]\n",
    "                ref=ref.encode().decode('unicode_escape')\n",
    "                ref=ref[1:-15]\n",
    "                if \"The Real Inconvenient Truth\" in ref:\n",
    "                    ref+=\"ng\"\n",
    "                if ref.strip()==ref1.strip():\n",
    "                    flag=True\n",
    "                    n+=1\n",
    "                    if 'true' in label: #hallucination\n",
    "                        x+=1\n",
    "                        if identifyConflict(answer):\n",
    "                            t+=1\n",
    "                        else:    \n",
    "                            t11.append(ref1)\n",
    "                    else: # factual\n",
    "                        if identifyConflict(answer): \n",
    "                            f+=1\n",
    "                        else:    \n",
    "                            f11.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\",\")[0]\n",
    "                    c2=ref1.strip().split(\",\")[0]\n",
    "                    if c1.strip()==c2.strip():\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        mark.append(',')\n",
    "                        if 'true' in label: #hallucination\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer): \n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t11.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer): \n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f11.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\n\")\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\n\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[-1]==c2[-1]:\n",
    "                        flag=True\n",
    "                        mark.append('n')\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer): \n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t11.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer): \n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f11.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[1]==c2[1]:\n",
    "                        flag=True\n",
    "                        mark.append('\\\"')\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t11.append(ref1)\n",
    "                        else: # factual\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f11.append(ref1)\n",
    "                if flag==False:\n",
    "                    uni=ref.strip().split('\\\\\\\\\\\\\\\\u')\n",
    "                    if len(uni)>1 and \"d Unreliability and Electricity Prices: Th\" not in ref:\n",
    "                        uni=uni[-2][4:]\n",
    "                        length=len(uni)\n",
    "                        #if ref1.strip()[-length:] == uni:\n",
    "                        if uni in ref1.strip():\n",
    "                            flag = True\n",
    "                            mark.append('u')\n",
    "                            mark.append(ref)\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer): \n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    t11.append(ref1)\n",
    "                            else: # factual\n",
    "                                if identifyConflict(answer): \n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    f11.append(ref1)\n",
    "        if n-pre!=1:\n",
    "            print(mark)\n",
    "            print(n-pre)\n",
    "            print(ref1)\n",
    "            print()\n",
    "print(x)\n",
    "print(len(t1))\n",
    "print(t)\n",
    "print(num[-1]-t,(num[-1]-t)/num[-1])\n",
    "print(f,f/num[-1])\n",
    "print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 516,
   "id": "393ab6a4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[]\n",
      "2\n",
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a public statement on climate change signed by over 500 scientists and professionals in climate and related fields from Europe and beyond. The declaration asserts that a human-caused climate emergency does not exist and emphasizes the need for a more balanced and nuanced approach to climate policy. It highlights the benefits of carbon dioxide for plant growth and the lack of evidence supporting extreme weather events being caused by human activity. The ECD acknowledges the potential for climate variability but stresses that natural factors such as solar activity and changes in global and regional temperature patterns are also important drivers of climate change. In conclusion, this reference supports a dissenting view on climate change and its causes, challenging the widely accepted position that human activities, particularly burning fossil fuels, are primarily responsible for global warming.\n",
      "\n",
      "[]\n",
      "2\n",
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a public statement on climate change signed by over 500 scientists and professionals in climate and related fields from Europe and beyond. The declaration asserts that a human-caused climate emergency does not exist and emphasizes the need for a more balanced and nuanced approach to climate policy. It highlights the benefits of carbon dioxide for plant growth and the lack of evidence supporting extreme weather events being caused by human activity. The ECD acknowledges the potential for climate variability but stresses that natural factors such as solar activity and changes in global and regional temperature patterns are also important drivers of climate change. In conclusion, this reference supports a dissenting view on climate change and its causes, challenging the widely accepted position that human activities, particularly burning fossil fuels, are primarily responsible for global warming.\n",
      "\n",
      "[]\n",
      "0\n",
      "\\\\\\\n",
      "\n",
      "184\n",
      "173\n",
      "10\n",
      "174 0.9456521739130435\n",
      "24 0.13043478260869565\n",
      "matched num= 369\n"
     ]
    }
   ],
   "source": [
    "t=0\n",
    "f=0\n",
    "t2=[]\n",
    "f2=[]\n",
    "n=0\n",
    "x=0\n",
    "with open(filePath[0]+\"dataset_0.9.jsonl\") as file1:\n",
    "    for line1 in file1:\n",
    "        label=line1.split(\"label: \")[-1]\n",
    "        ref1=line1.split(\"Response: \")[0].split(\"Reference: \")\n",
    "        if len(ref1)==2:\n",
    "            ref1=ref1[1]\n",
    "        else:\n",
    "            ref1=ref1[1]+\"Reference: \"+ref1[2]\n",
    "        pre=n\n",
    "        flag=False\n",
    "        ref1=ref1[:-8]\n",
    "        with open(\"detections_2_3.jsonl\") as file:\n",
    "            mark=[]\n",
    "            for line in file:\n",
    "                answer=line.split(\"Result: \")[1]\n",
    "                ref=line.split(\"P2: \")[0].split(\"P1: \")[1]\n",
    "                ref=ref.encode().decode('unicode_escape')\n",
    "                ref=ref[1:-15]\n",
    "                if \"The Real Inconvenient Truth\" in ref:\n",
    "                    ref+=\"ng\"\n",
    "                if ref.strip()==ref1.strip():\n",
    "                    flag=True\n",
    "                    n+=1\n",
    "                    if 'true' in label: #hallucination\n",
    "                        x+=1\n",
    "                        if identifyConflict(answer):\n",
    "                            t+=1\n",
    "                        else:    \n",
    "                            t2.append(ref1)\n",
    "                    else: # factual\n",
    "                        if identifyConflict(answer): \n",
    "                            f+=1\n",
    "                        else:    \n",
    "                            f2.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\",\")[0]\n",
    "                    c2=ref1.strip().split(\",\")[0]\n",
    "                    if c1.strip()==c2.strip():\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        mark.append(',')\n",
    "                        if 'true' in label: #hallucination\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer): \n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t2.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer): \n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f2.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\n\")\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\n\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[-1]==c2[-1]:\n",
    "                        flag=True\n",
    "                        mark.append('n')\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer): \n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t2.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer): \n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f2.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[1]==c2[1]:\n",
    "                        flag=True\n",
    "                        mark.append('\\\"')\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t2.append(ref1)\n",
    "                        else: # factual\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f2.append(ref1)\n",
    "                if flag==False:\n",
    "                    uni=ref.strip().split('\\\\\\\\\\\\\\\\u')\n",
    "                    if len(uni)>1 and \"d Unreliability and Electricity Prices: Th\" not in ref:\n",
    "                        uni=uni[-2][4:]\n",
    "                        length=len(uni)\n",
    "                        #if ref1.strip()[-length:] == uni:\n",
    "                        if uni in ref1.strip():\n",
    "                            flag = True\n",
    "                            mark.append('u')\n",
    "                            mark.append(ref)\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer): \n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    t2.append(ref1)\n",
    "                            else: # factual\n",
    "                                if identifyConflict(answer): \n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    f2.append(ref1)\n",
    "        if n-pre!=1:\n",
    "            print(mark)\n",
    "            print(n-pre)\n",
    "            print(ref1)\n",
    "            print()\n",
    "print(x)\n",
    "print(len(t1))\n",
    "print(t)\n",
    "print(num[-1]-t,(num[-1]-t)/num[-1])\n",
    "print(f,f/num[-1])\n",
    "print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 517,
   "id": "89b1c563",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[]\n",
      "2\n",
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a public statement on climate change signed by over 500 scientists and professionals in climate and related fields from Europe and beyond. The declaration asserts that a human-caused climate emergency does not exist and emphasizes the need for a more balanced and nuanced approach to climate policy. It highlights the benefits of carbon dioxide for plant growth and the lack of evidence supporting extreme weather events being caused by human activity. The ECD acknowledges the potential for climate variability but stresses that natural factors such as solar activity and changes in global and regional temperature patterns are also important drivers of climate change. In conclusion, this reference supports a dissenting view on climate change and its causes, challenging the widely accepted position that human activities, particularly burning fossil fuels, are primarily responsible for global warming.\n",
      "\n",
      "[]\n",
      "2\n",
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a public statement on climate change signed by over 500 scientists and professionals in climate and related fields from Europe and beyond. The declaration asserts that a human-caused climate emergency does not exist and emphasizes the need for a more balanced and nuanced approach to climate policy. It highlights the benefits of carbon dioxide for plant growth and the lack of evidence supporting extreme weather events being caused by human activity. The ECD acknowledges the potential for climate variability but stresses that natural factors such as solar activity and changes in global and regional temperature patterns are also important drivers of climate change. In conclusion, this reference supports a dissenting view on climate change and its causes, challenging the widely accepted position that human activities, particularly burning fossil fuels, are primarily responsible for global warming.\n",
      "\n",
      "[]\n",
      "0\n",
      "\\\\\\\n",
      "\n",
      "184\n",
      "173\n",
      "179\n",
      "5 0.02717391304347826\n",
      "174 0.9456521739130435\n",
      "matched num= 369\n"
     ]
    }
   ],
   "source": [
    "t=0\n",
    "f=0\n",
    "t22=[]\n",
    "f22=[]\n",
    "n=0\n",
    "x=0\n",
    "with open(filePath[0]+\"dataset_0.9.jsonl\") as file1:\n",
    "    for line1 in file1:\n",
    "        label=line1.split(\"label: \")[-1]\n",
    "        ref1=line1.split(\"Response: \")[0].split(\"Reference: \")\n",
    "        if len(ref1)==2:\n",
    "            ref1=ref1[1]\n",
    "        else:\n",
    "            ref1=ref1[1]+\"Reference: \"+ref1[2]\n",
    "        pre=n\n",
    "        flag=False\n",
    "        ref1=ref1[:-8]\n",
    "        with open(filePath[0]+\"detections_2_1.jsonl\") as file:\n",
    "            mark=[]\n",
    "            for line in file:\n",
    "                answer=line.split(\"Result: \")[1]\n",
    "                ref=line.split(\"P2: \")[0].split(\"P1: \")[1]\n",
    "                ref=ref.encode().decode('unicode_escape')\n",
    "                ref=ref[1:-15]\n",
    "                if \"The Real Inconvenient Truth\" in ref:\n",
    "                    ref+=\"ng\"\n",
    "                if ref.strip()==ref1.strip():\n",
    "                    flag=True\n",
    "                    n+=1\n",
    "                    if 'true' in label: #hallucination\n",
    "                        x+=1\n",
    "                        if identifyConflict(answer):\n",
    "                            t+=1\n",
    "                        else:    \n",
    "                            t22.append(ref1)\n",
    "                    else: # factual\n",
    "                        if identifyConflict(answer): \n",
    "                            f+=1\n",
    "                        else:    \n",
    "                            f22.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\",\")[0]\n",
    "                    c2=ref1.strip().split(\",\")[0]\n",
    "                    if c1.strip()==c2.strip():\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        mark.append(',')\n",
    "                        if 'true' in label: #hallucination\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer): \n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t22.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer): \n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f22.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\n\")\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\n\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[-1]==c2[-1]:\n",
    "                        flag=True\n",
    "                        mark.append('n')\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer): \n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t22.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer): \n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f22.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[1]==c2[1]:\n",
    "                        flag=True\n",
    "                        mark.append('\\\"')\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t22.append(ref1)\n",
    "                        else: # factual\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f22.append(ref1)\n",
    "                if flag==False:\n",
    "                    uni=ref.strip().split('\\\\\\\\\\\\\\\\u')\n",
    "                    if len(uni)>1 and \"d Unreliability and Electricity Prices: Th\" not in ref:\n",
    "                        uni=uni[-2][4:]\n",
    "                        length=len(uni)\n",
    "                        #if ref1.strip()[-length:] == uni:\n",
    "                        if uni in ref1.strip():\n",
    "                            flag = True\n",
    "                            mark.append('u')\n",
    "                            mark.append(ref)\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer): \n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    t22.append(ref1)\n",
    "                            else: # factual\n",
    "                                if identifyConflict(answer): \n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    f22.append(ref1)\n",
    "        if n-pre!=1:\n",
    "            print(mark)\n",
    "            print(n-pre)\n",
    "            print(ref1)\n",
    "            print()\n",
    "print(x)\n",
    "print(len(t1))\n",
    "print(t)\n",
    "print(num[-1]-t,(num[-1]-t)/num[-1])\n",
    "print(f,f/num[-1])\n",
    "print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 518,
   "id": "82073e31",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[]\n",
      "2\n",
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a public statement on climate change signed by over 500 scientists and professionals in climate and related fields from Europe and beyond. The declaration asserts that a human-caused climate emergency does not exist and emphasizes the need for a more balanced and nuanced approach to climate policy. It highlights the benefits of carbon dioxide for plant growth and the lack of evidence supporting extreme weather events being caused by human activity. The ECD acknowledges the potential for climate variability but stresses that natural factors such as solar activity and changes in global and regional temperature patterns are also important drivers of climate change. In conclusion, this reference supports a dissenting view on climate change and its causes, challenging the widely accepted position that human activities, particularly burning fossil fuels, are primarily responsible for global warming.\n",
      "\n",
      "[]\n",
      "2\n",
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a public statement on climate change signed by over 500 scientists and professionals in climate and related fields from Europe and beyond. The declaration asserts that a human-caused climate emergency does not exist and emphasizes the need for a more balanced and nuanced approach to climate policy. It highlights the benefits of carbon dioxide for plant growth and the lack of evidence supporting extreme weather events being caused by human activity. The ECD acknowledges the potential for climate variability but stresses that natural factors such as solar activity and changes in global and regional temperature patterns are also important drivers of climate change. In conclusion, this reference supports a dissenting view on climate change and its causes, challenging the widely accepted position that human activities, particularly burning fossil fuels, are primarily responsible for global warming.\n",
      "\n",
      "[]\n",
      "0\n",
      "\\\\\\\n",
      "\n",
      "184\n",
      "173\n",
      "15\n",
      "169 0.9184782608695652\n",
      "20 0.10869565217391304\n",
      "matched num= 369\n"
     ]
    }
   ],
   "source": [
    "t=0\n",
    "f=0\n",
    "t3=[]\n",
    "f3=[]\n",
    "n=0\n",
    "x=0\n",
    "with open(filePath[0]+\"dataset_0.9.jsonl\") as file1:\n",
    "    for line1 in file1:\n",
    "        label=line1.split(\"label: \")[-1]\n",
    "        ref1=line1.split(\"Response: \")[0].split(\"Reference: \")\n",
    "        if len(ref1)==2:\n",
    "            ref1=ref1[1]\n",
    "        else:\n",
    "            ref1=ref1[1]+\"Reference: \"+ref1[2]\n",
    "        pre=n\n",
    "        flag=False\n",
    "        ref1=ref1[:-8]\n",
    "        with open(\"detections_3_3.jsonl\") as file:\n",
    "            mark=[]\n",
    "            for line in file:\n",
    "                answer=line.split(\"Result: \")[1]\n",
    "                ref=line.split(\"P2: \")[0].split(\"P1: \")[1]\n",
    "                ref=ref.encode().decode('unicode_escape')\n",
    "                ref=ref[1:-15]\n",
    "                if \"The Real Inconvenient Truth\" in ref:\n",
    "                    ref+=\"ng\"\n",
    "                if ref.strip()==ref1.strip():\n",
    "                    flag=True\n",
    "                    n+=1\n",
    "                    if 'true' in label: #hallucination\n",
    "                        x+=1\n",
    "                        if identifyConflict(answer):\n",
    "                            t+=1\n",
    "                        else:    \n",
    "                            t3.append(ref1)\n",
    "                    else: # factual\n",
    "                        if identifyConflict(answer): \n",
    "                            f+=1\n",
    "                        else:    \n",
    "                            f3.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\",\")[0]\n",
    "                    c2=ref1.strip().split(\",\")[0]\n",
    "                    if c1.strip()==c2.strip():\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        mark.append(',')\n",
    "                        if 'true' in label: #hallucination\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer): \n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t3.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer): \n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f3.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\n\")\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\n\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[-1]==c2[-1]:\n",
    "                        flag=True\n",
    "                        mark.append('n')\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer): \n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t3.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer): \n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f3.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[1]==c2[1]:\n",
    "                        flag=True\n",
    "                        mark.append('\\\"')\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t3.append(ref1)\n",
    "                        else: # factual\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f3.append(ref1)\n",
    "                if flag==False:\n",
    "                    uni=ref.strip().split('\\\\\\\\\\\\\\\\u')\n",
    "                    if len(uni)>1 and \"d Unreliability and Electricity Prices: Th\" not in ref:\n",
    "                        uni=uni[-2][4:]\n",
    "                        length=len(uni)\n",
    "                        #if ref1.strip()[-length:] == uni:\n",
    "                        if uni in ref1.strip():\n",
    "                            flag = True\n",
    "                            mark.append('u')\n",
    "                            mark.append(ref)\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer): \n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    t3.append(ref1)\n",
    "                            else: # factual\n",
    "                                if identifyConflict(answer): \n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    f3.append(ref1)\n",
    "        if n-pre!=1:\n",
    "            print(mark)\n",
    "            print(n-pre)\n",
    "            print(ref1)\n",
    "            print()\n",
    "print(x)\n",
    "print(len(t1))\n",
    "print(t)\n",
    "print(num[-1]-t,(num[-1]-t)/num[-1])\n",
    "print(f,f/num[-1])\n",
    "print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 519,
   "id": "ebe16ae0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[]\n",
      "2\n",
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a public statement on climate change signed by over 500 scientists and professionals in climate and related fields from Europe and beyond. The declaration asserts that a human-caused climate emergency does not exist and emphasizes the need for a more balanced and nuanced approach to climate policy. It highlights the benefits of carbon dioxide for plant growth and the lack of evidence supporting extreme weather events being caused by human activity. The ECD acknowledges the potential for climate variability but stresses that natural factors such as solar activity and changes in global and regional temperature patterns are also important drivers of climate change. In conclusion, this reference supports a dissenting view on climate change and its causes, challenging the widely accepted position that human activities, particularly burning fossil fuels, are primarily responsible for global warming.\n",
      "\n",
      "[]\n",
      "2\n",
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a public statement on climate change signed by over 500 scientists and professionals in climate and related fields from Europe and beyond. The declaration asserts that a human-caused climate emergency does not exist and emphasizes the need for a more balanced and nuanced approach to climate policy. It highlights the benefits of carbon dioxide for plant growth and the lack of evidence supporting extreme weather events being caused by human activity. The ECD acknowledges the potential for climate variability but stresses that natural factors such as solar activity and changes in global and regional temperature patterns are also important drivers of climate change. In conclusion, this reference supports a dissenting view on climate change and its causes, challenging the widely accepted position that human activities, particularly burning fossil fuels, are primarily responsible for global warming.\n",
      "\n",
      "[]\n",
      "0\n",
      "\\\\\\\n",
      "\n",
      "184\n",
      "173\n",
      "175\n",
      "9 0.04891304347826087\n",
      "177 0.9619565217391305\n",
      "matched num= 369\n"
     ]
    }
   ],
   "source": [
    "t=0\n",
    "f=0\n",
    "t33=[]\n",
    "f33=[]\n",
    "n=0\n",
    "x=0\n",
    "with open(filePath[0]+\"dataset_0.9.jsonl\") as file1:\n",
    "    for line1 in file1:\n",
    "        label=line1.split(\"label: \")[-1]\n",
    "        ref1=line1.split(\"Response: \")[0].split(\"Reference: \")\n",
    "        if len(ref1)==2:\n",
    "            ref1=ref1[1]\n",
    "        else:\n",
    "            ref1=ref1[1]+\"Reference: \"+ref1[2]\n",
    "        pre=n\n",
    "        flag=False\n",
    "        ref1=ref1[:-8]\n",
    "        with open(filePath[0]+\"detections_3_1.jsonl\") as file:\n",
    "            mark=[]\n",
    "            for line in file:\n",
    "                answer=line.split(\"Result: \")[1]\n",
    "                ref=line.split(\"P2: \")[0].split(\"P1: \")[1]\n",
    "                ref=ref.encode().decode('unicode_escape')\n",
    "                ref=ref[1:-15]\n",
    "                if \"The Real Inconvenient Truth\" in ref:\n",
    "                    ref+=\"ng\"\n",
    "                if ref.strip()==ref1.strip():\n",
    "                    flag=True\n",
    "                    n+=1\n",
    "                    if 'true' in label: #hallucination\n",
    "                        x+=1\n",
    "                        if identifyConflict(answer):\n",
    "                            t+=1\n",
    "                        else:    \n",
    "                            t33.append(ref1)\n",
    "                    else: # factual\n",
    "                        if identifyConflict(answer): \n",
    "                            f+=1\n",
    "                        else:    \n",
    "                            f33.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\",\")[0]\n",
    "                    c2=ref1.strip().split(\",\")[0]\n",
    "                    if c1.strip()==c2.strip():\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        mark.append(',')\n",
    "                        if 'true' in label: #hallucination\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer): \n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t33.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer): \n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f33.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\n\")\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\n\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[-1]==c2[-1]:\n",
    "                        flag=True\n",
    "                        mark.append('n')\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer): \n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t33.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer): \n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f33.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[1]==c2[1]:\n",
    "                        flag=True\n",
    "                        mark.append('\\\"')\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t33.append(ref1)\n",
    "                        else: # factual\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f33.append(ref1)\n",
    "                if flag==False:\n",
    "                    uni=ref.strip().split('\\\\\\\\\\\\\\\\u')\n",
    "                    if len(uni)>1 and \"d Unreliability and Electricity Prices: Th\" not in ref:\n",
    "                        uni=uni[-2][4:]\n",
    "                        length=len(uni)\n",
    "                        #if ref1.strip()[-length:] == uni:\n",
    "                        if uni in ref1.strip():\n",
    "                            flag = True\n",
    "                            mark.append('u')\n",
    "                            mark.append(ref)\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer): \n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    t33.append(ref1)\n",
    "                            else: # factual\n",
    "                                if identifyConflict(answer): \n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    f33.append(ref1)\n",
    "        if n-pre!=1:\n",
    "            print(mark)\n",
    "            print(n-pre)\n",
    "            print(ref1)\n",
    "            print()\n",
    "print(x)\n",
    "print(len(t1))\n",
    "print(t)\n",
    "print(num[-1]-t,(num[-1]-t)/num[-1])\n",
    "print(f,f/num[-1])\n",
    "print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 520,
   "id": "36cb0888",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[]\n",
      "2\n",
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a public statement on climate change signed by over 500 scientists and professionals in climate and related fields from Europe and beyond. The declaration asserts that a human-caused climate emergency does not exist and emphasizes the need for a more balanced and nuanced approach to climate policy. It highlights the benefits of carbon dioxide for plant growth and the lack of evidence supporting extreme weather events being caused by human activity. The ECD acknowledges the potential for climate variability but stresses that natural factors such as solar activity and changes in global and regional temperature patterns are also important drivers of climate change. In conclusion, this reference supports a dissenting view on climate change and its causes, challenging the widely accepted position that human activities, particularly burning fossil fuels, are primarily responsible for global warming.\n",
      "\n",
      "[]\n",
      "2\n",
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a public statement on climate change signed by over 500 scientists and professionals in climate and related fields from Europe and beyond. The declaration asserts that a human-caused climate emergency does not exist and emphasizes the need for a more balanced and nuanced approach to climate policy. It highlights the benefits of carbon dioxide for plant growth and the lack of evidence supporting extreme weather events being caused by human activity. The ECD acknowledges the potential for climate variability but stresses that natural factors such as solar activity and changes in global and regional temperature patterns are also important drivers of climate change. In conclusion, this reference supports a dissenting view on climate change and its causes, challenging the widely accepted position that human activities, particularly burning fossil fuels, are primarily responsible for global warming.\n",
      "\n",
      "[]\n",
      "0\n",
      "\\\\\\\n",
      "\n",
      "184\n",
      "173\n",
      "169\n",
      "15 0.08152173913043478\n",
      "182 0.9891304347826086\n",
      "matched num= 369\n"
     ]
    }
   ],
   "source": [
    "t=0\n",
    "f=0\n",
    "t4=[]\n",
    "f4=[]\n",
    "n=0\n",
    "x=0\n",
    "with open(filePath[0]+\"dataset_0.9.jsonl\") as file1:\n",
    "    for line1 in file1:\n",
    "        label=line1.split(\"label: \")[-1]\n",
    "        ref1=line1.split(\"Response: \")[0].split(\"Reference: \")\n",
    "        if len(ref1)==2:\n",
    "            ref1=ref1[1]\n",
    "        else:\n",
    "            ref1=ref1[1]+\"Reference: \"+ref1[2]\n",
    "        pre=n\n",
    "        flag=False\n",
    "        ref1=ref1[:-8]\n",
    "        with open(\"detections_4_3.jsonl\") as file:\n",
    "            mark=[]\n",
    "            for line in file:\n",
    "                answer=line.split(\"Result: \")[1]\n",
    "                ref=line.split(\"P2: \")[0].split(\"P1: \")[1]\n",
    "                ref=ref.encode().decode('unicode_escape')\n",
    "                ref=ref[1:-15]\n",
    "                if \"The Real Inconvenient Truth\" in ref:\n",
    "                    ref+=\"ng\"\n",
    "                if ref.strip()==ref1.strip():\n",
    "                    flag=True\n",
    "                    n+=1\n",
    "                    if 'true' in label: #hallucination\n",
    "                        x+=1\n",
    "                        if identifyConflict(answer):\n",
    "                            t+=1\n",
    "                        else:    \n",
    "                            t4.append(ref1)\n",
    "                    else: # factual\n",
    "                        if identifyConflict(answer): \n",
    "                            f+=1\n",
    "                        else:    \n",
    "                            f4.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\",\")[0]\n",
    "                    c2=ref1.strip().split(\",\")[0]\n",
    "                    if c1.strip()==c2.strip():\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        mark.append(',')\n",
    "                        if 'true' in label: #hallucination\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer): \n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t4.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer): \n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f4.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\n\")\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\n\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[-1]==c2[-1]:\n",
    "                        flag=True\n",
    "                        mark.append('n')\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer): \n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t4.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer): \n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f4.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[1]==c2[1]:\n",
    "                        flag=True\n",
    "                        mark.append('\\\"')\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t4.append(ref1)\n",
    "                        else: # factual\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f4.append(ref1)\n",
    "                if flag==False:\n",
    "                    uni=ref.strip().split('\\\\\\\\\\\\\\\\u')\n",
    "                    if len(uni)>1 and \"d Unreliability and Electricity Prices: Th\" not in ref:\n",
    "                        uni=uni[-2][4:]\n",
    "                        length=len(uni)\n",
    "                        #if ref1.strip()[-length:] == uni:\n",
    "                        if uni in ref1.strip():\n",
    "                            flag = True\n",
    "                            mark.append('u')\n",
    "                            mark.append(ref)\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer): \n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    t4.append(ref1)\n",
    "                            else: # factual\n",
    "                                if identifyConflict(answer): \n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    f4.append(ref1)\n",
    "        if n-pre!=1:\n",
    "            print(mark)\n",
    "            print(n-pre)\n",
    "            print(ref1)\n",
    "            print()\n",
    "print(x)\n",
    "print(len(t1))\n",
    "print(t)\n",
    "print(num[-1]-t,(num[-1]-t)/num[-1])\n",
    "print(f,f/num[-1])\n",
    "print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 521,
   "id": "76ce710d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[]\n",
      "2\n",
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a public statement on climate change signed by over 500 scientists and professionals in climate and related fields from Europe and beyond. The declaration asserts that a human-caused climate emergency does not exist and emphasizes the need for a more balanced and nuanced approach to climate policy. It highlights the benefits of carbon dioxide for plant growth and the lack of evidence supporting extreme weather events being caused by human activity. The ECD acknowledges the potential for climate variability but stresses that natural factors such as solar activity and changes in global and regional temperature patterns are also important drivers of climate change. In conclusion, this reference supports a dissenting view on climate change and its causes, challenging the widely accepted position that human activities, particularly burning fossil fuels, are primarily responsible for global warming.\n",
      "\n",
      "[]\n",
      "2\n",
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a public statement on climate change signed by over 500 scientists and professionals in climate and related fields from Europe and beyond. The declaration asserts that a human-caused climate emergency does not exist and emphasizes the need for a more balanced and nuanced approach to climate policy. It highlights the benefits of carbon dioxide for plant growth and the lack of evidence supporting extreme weather events being caused by human activity. The ECD acknowledges the potential for climate variability but stresses that natural factors such as solar activity and changes in global and regional temperature patterns are also important drivers of climate change. In conclusion, this reference supports a dissenting view on climate change and its causes, challenging the widely accepted position that human activities, particularly burning fossil fuels, are primarily responsible for global warming.\n",
      "\n",
      "[]\n",
      "0\n",
      "\\\\\\\n",
      "\n",
      "184\n",
      "173\n",
      "16\n",
      "168 0.9130434782608695\n",
      "15 0.08152173913043478\n",
      "matched num= 369\n"
     ]
    }
   ],
   "source": [
    "t=0\n",
    "f=0\n",
    "t44=[]\n",
    "f44=[]\n",
    "n=0\n",
    "x=0\n",
    "with open(filePath[0]+\"dataset_0.9.jsonl\") as file1:\n",
    "    for line1 in file1:\n",
    "        label=line1.split(\"label: \")[-1]\n",
    "        ref1=line1.split(\"Response: \")[0].split(\"Reference: \")\n",
    "        if len(ref1)==2:\n",
    "            ref1=ref1[1]\n",
    "        else:\n",
    "            ref1=ref1[1]+\"Reference: \"+ref1[2]\n",
    "        pre=n\n",
    "        flag=False\n",
    "        ref1=ref1[:-8]\n",
    "        with open(filePath[0]+\"detections_4_1.jsonl\") as file:\n",
    "            mark=[]\n",
    "            for line in file:\n",
    "                answer=line.split(\"Result: \")[1]\n",
    "                ref=line.split(\"P2: \")[0].split(\"P1: \")[1]\n",
    "                ref=ref.encode().decode('unicode_escape')\n",
    "                ref=ref[1:-15]\n",
    "                if \"The Real Inconvenient Truth\" in ref:\n",
    "                    ref+=\"ng\"\n",
    "                if ref.strip()==ref1.strip():\n",
    "                    flag=True\n",
    "                    n+=1\n",
    "                    if 'true' in label: #hallucination\n",
    "                        x+=1\n",
    "                        if identifyConflict(answer):\n",
    "                            t+=1\n",
    "                        else:    \n",
    "                            t44.append(ref1)\n",
    "                    else: # factual\n",
    "                        if identifyConflict(answer): \n",
    "                            f+=1\n",
    "                        else:    \n",
    "                            f44.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\",\")[0]\n",
    "                    c2=ref1.strip().split(\",\")[0]\n",
    "                    if c1.strip()==c2.strip():\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        mark.append(',')\n",
    "                        if 'true' in label: #hallucination\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer): \n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t44.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer): \n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f44.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\n\")\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\n\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[-1]==c2[-1]:\n",
    "                        flag=True\n",
    "                        mark.append('n')\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer): \n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t44.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer): \n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f44.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[1]==c2[1]:\n",
    "                        flag=True\n",
    "                        mark.append('\\\"')\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t44.append(ref1)\n",
    "                        else: # factual\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f44.append(ref1)\n",
    "                if flag==False:\n",
    "                    uni=ref.strip().split('\\\\\\\\\\\\\\\\u')\n",
    "                    if len(uni)>1 and \"d Unreliability and Electricity Prices: Th\" not in ref:\n",
    "                        uni=uni[-2][4:]\n",
    "                        length=len(uni)\n",
    "                        #if ref1.strip()[-length:] == uni:\n",
    "                        if uni in ref1.strip():\n",
    "                            flag = True\n",
    "                            mark.append('u')\n",
    "                            mark.append(ref)\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer): \n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    t44.append(ref1)\n",
    "                            else: # factual\n",
    "                                if identifyConflict(answer): \n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    f44.append(ref1)\n",
    "        if n-pre!=1:\n",
    "            print(mark)\n",
    "            print(n-pre)\n",
    "            print(ref1)\n",
    "            print()\n",
    "print(x)\n",
    "print(len(t1))\n",
    "print(t)\n",
    "print(num[-1]-t,(num[-1]-t)/num[-1])\n",
    "print(f,f/num[-1])\n",
    "print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 522,
   "id": "6183dd81",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[]\n",
      "2\n",
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a public statement on climate change signed by over 500 scientists and professionals in climate and related fields from Europe and beyond. The declaration asserts that a human-caused climate emergency does not exist and emphasizes the need for a more balanced and nuanced approach to climate policy. It highlights the benefits of carbon dioxide for plant growth and the lack of evidence supporting extreme weather events being caused by human activity. The ECD acknowledges the potential for climate variability but stresses that natural factors such as solar activity and changes in global and regional temperature patterns are also important drivers of climate change. In conclusion, this reference supports a dissenting view on climate change and its causes, challenging the widely accepted position that human activities, particularly burning fossil fuels, are primarily responsible for global warming.\n",
      "\n",
      "[]\n",
      "2\n",
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a public statement on climate change signed by over 500 scientists and professionals in climate and related fields from Europe and beyond. The declaration asserts that a human-caused climate emergency does not exist and emphasizes the need for a more balanced and nuanced approach to climate policy. It highlights the benefits of carbon dioxide for plant growth and the lack of evidence supporting extreme weather events being caused by human activity. The ECD acknowledges the potential for climate variability but stresses that natural factors such as solar activity and changes in global and regional temperature patterns are also important drivers of climate change. In conclusion, this reference supports a dissenting view on climate change and its causes, challenging the widely accepted position that human activities, particularly burning fossil fuels, are primarily responsible for global warming.\n",
      "\n",
      "[]\n",
      "0\n",
      "\\\\\\\n",
      "\n",
      "184\n",
      "173\n",
      "176\n",
      "8 0.043478260869565216\n",
      "175 0.9510869565217391\n",
      "matched num= 369\n"
     ]
    }
   ],
   "source": [
    "t=0\n",
    "f=0\n",
    "t5=[]\n",
    "f5=[]\n",
    "n=0\n",
    "x=0\n",
    "with open(filePath[0]+\"dataset_0.9.jsonl\") as file1:\n",
    "    for line1 in file1:\n",
    "        label=line1.split(\"label: \")[-1]\n",
    "        ref1=line1.split(\"Response: \")[0].split(\"Reference: \")\n",
    "        if len(ref1)==2:\n",
    "            ref1=ref1[1]\n",
    "        else:\n",
    "            ref1=ref1[1]+\"Reference: \"+ref1[2]\n",
    "        pre=n\n",
    "        flag=False\n",
    "        ref1=ref1[:-8]\n",
    "        with open(\"detections_5_3.jsonl\") as file:\n",
    "            mark=[]\n",
    "            for line in file:\n",
    "                answer=line.split(\"Result: \")[1]\n",
    "                ref=line.split(\"P2: \")[0].split(\"P1: \")[1]\n",
    "                ref=ref.encode().decode('unicode_escape')\n",
    "                ref=ref[1:-15]\n",
    "                if \"The Real Inconvenient Truth\" in ref:\n",
    "                    ref+=\"ng\"\n",
    "                if ref.strip()==ref1.strip():\n",
    "                    flag=True\n",
    "                    n+=1\n",
    "                    if 'true' in label: #hallucination\n",
    "                        x+=1\n",
    "                        if identifyConflict(answer):\n",
    "                            t+=1\n",
    "                        else:    \n",
    "                            t5.append(ref1)\n",
    "                    else: # factual\n",
    "                        if identifyConflict(answer): \n",
    "                            f+=1\n",
    "                        else:    \n",
    "                            f5.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\",\")[0]\n",
    "                    c2=ref1.strip().split(\",\")[0]\n",
    "                    if c1.strip()==c2.strip():\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        mark.append(',')\n",
    "                        if 'true' in label: #hallucination\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer): \n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t5.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer): \n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f5.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\n\")\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\n\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[-1]==c2[-1]:\n",
    "                        flag=True\n",
    "                        mark.append('n')\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer): \n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t5.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer): \n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f5.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[1]==c2[1]:\n",
    "                        flag=True\n",
    "                        mark.append('\\\"')\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t5.append(ref1)\n",
    "                        else: # factual\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f5.append(ref1)\n",
    "                if flag==False:\n",
    "                    uni=ref.strip().split('\\\\\\\\\\\\\\\\u')\n",
    "                    if len(uni)>1 and \"d Unreliability and Electricity Prices: Th\" not in ref:\n",
    "                        uni=uni[-2][4:]\n",
    "                        length=len(uni)\n",
    "                        #if ref1.strip()[-length:] == uni:\n",
    "                        if uni in ref1.strip():\n",
    "                            flag = True\n",
    "                            mark.append('u')\n",
    "                            mark.append(ref)\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer): \n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    t5.append(ref1)\n",
    "                            else: # factual\n",
    "                                if identifyConflict(answer): \n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    f5.append(ref1)\n",
    "        if n-pre!=1:\n",
    "            print(mark)\n",
    "            print(n-pre)\n",
    "            print(ref1)\n",
    "            print()\n",
    "print(x)\n",
    "print(len(t1))\n",
    "print(t)\n",
    "print(num[-1]-t,(num[-1]-t)/num[-1])\n",
    "print(f,f/num[-1])\n",
    "print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 523,
   "id": "488a2681",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[]\n",
      "2\n",
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a public statement on climate change signed by over 500 scientists and professionals in climate and related fields from Europe and beyond. The declaration asserts that a human-caused climate emergency does not exist and emphasizes the need for a more balanced and nuanced approach to climate policy. It highlights the benefits of carbon dioxide for plant growth and the lack of evidence supporting extreme weather events being caused by human activity. The ECD acknowledges the potential for climate variability but stresses that natural factors such as solar activity and changes in global and regional temperature patterns are also important drivers of climate change. In conclusion, this reference supports a dissenting view on climate change and its causes, challenging the widely accepted position that human activities, particularly burning fossil fuels, are primarily responsible for global warming.\n",
      "\n",
      "[]\n",
      "2\n",
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a public statement on climate change signed by over 500 scientists and professionals in climate and related fields from Europe and beyond. The declaration asserts that a human-caused climate emergency does not exist and emphasizes the need for a more balanced and nuanced approach to climate policy. It highlights the benefits of carbon dioxide for plant growth and the lack of evidence supporting extreme weather events being caused by human activity. The ECD acknowledges the potential for climate variability but stresses that natural factors such as solar activity and changes in global and regional temperature patterns are also important drivers of climate change. In conclusion, this reference supports a dissenting view on climate change and its causes, challenging the widely accepted position that human activities, particularly burning fossil fuels, are primarily responsible for global warming.\n",
      "\n",
      "[]\n",
      "0\n",
      "\\\\\\\n",
      "\n",
      "184\n",
      "173\n",
      "174\n",
      "10 0.05434782608695652\n",
      "171 0.9293478260869565\n",
      "matched num= 369\n"
     ]
    }
   ],
   "source": [
    "t=0\n",
    "f=0\n",
    "t55=[]\n",
    "f55=[]\n",
    "n=0\n",
    "x=0\n",
    "with open(filePath[0]+\"dataset_0.9.jsonl\") as file1:\n",
    "    for line1 in file1:\n",
    "        label=line1.split(\"label: \")[-1]\n",
    "        ref1=line1.split(\"Response: \")[0].split(\"Reference: \")\n",
    "        if len(ref1)==2:\n",
    "            ref1=ref1[1]\n",
    "        else:\n",
    "            ref1=ref1[1]+\"Reference: \"+ref1[2]\n",
    "        pre=n\n",
    "        flag=False\n",
    "        ref1=ref1[:-8]\n",
    "        with open(filePath[0]+\"detections_5_1.jsonl\") as file:\n",
    "            mark=[]\n",
    "            for line in file:\n",
    "                answer=line.split(\"Result: \")[1]\n",
    "                ref=line.split(\"P2: \")[0].split(\"P1: \")[1]\n",
    "                ref=ref.encode().decode('unicode_escape')\n",
    "                ref=ref[1:-15]\n",
    "                if \"The Real Inconvenient Truth\" in ref:\n",
    "                    ref+=\"ng\"\n",
    "                if ref.strip()==ref1.strip():\n",
    "                    flag=True\n",
    "                    n+=1\n",
    "                    if 'true' in label: #hallucination\n",
    "                        x+=1\n",
    "                        if identifyConflict(answer):\n",
    "                            t+=1\n",
    "                        else:    \n",
    "                            t55.append(ref1)\n",
    "                    else: # factual\n",
    "                        if identifyConflict(answer): \n",
    "                            f+=1\n",
    "                        else:    \n",
    "                            f55.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\",\")[0]\n",
    "                    c2=ref1.strip().split(\",\")[0]\n",
    "                    if c1.strip()==c2.strip():\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        mark.append(',')\n",
    "                        if 'true' in label: #hallucination\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer): \n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t55.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer): \n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f55.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\n\")\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\n\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[-1]==c2[-1]:\n",
    "                        flag=True\n",
    "                        mark.append('n')\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer): \n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t55.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer): \n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f55.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[1]==c2[1]:\n",
    "                        flag=True\n",
    "                        mark.append('\\\"')\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t55.append(ref1)\n",
    "                        else: # factual\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f55.append(ref1)\n",
    "                if flag==False:\n",
    "                    uni=ref.strip().split('\\\\\\\\\\\\\\\\u')\n",
    "                    if len(uni)>1 and \"d Unreliability and Electricity Prices: Th\" not in ref:\n",
    "                        uni=uni[-2][4:]\n",
    "                        length=len(uni)\n",
    "                        #if ref1.strip()[-length:] == uni:\n",
    "                        if uni in ref1.strip():\n",
    "                            flag = True\n",
    "                            mark.append('u')\n",
    "                            mark.append(ref)\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer): \n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    t55.append(ref1)\n",
    "                            else: # factual\n",
    "                                if identifyConflict(answer): \n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    f55.append(ref1)\n",
    "        if n-pre!=1:\n",
    "            print(mark)\n",
    "            print(n-pre)\n",
    "            print(ref1)\n",
    "            print()\n",
    "print(x)\n",
    "print(len(t1))\n",
    "print(t)\n",
    "print(num[-1]-t,(num[-1]-t)/num[-1])\n",
    "print(f,f/num[-1])\n",
    "print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 552,
   "id": "2f9f34e7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[]\n",
      "2\n",
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a public statement on climate change signed by over 500 scientists and professionals in climate and related fields from Europe and beyond. The declaration asserts that a human-caused climate emergency does not exist and emphasizes the need for a more balanced and nuanced approach to climate policy. It highlights the benefits of carbon dioxide for plant growth and the lack of evidence supporting extreme weather events being caused by human activity. The ECD acknowledges the potential for climate variability but stresses that natural factors such as solar activity and changes in global and regional temperature patterns are also important drivers of climate change. In conclusion, this reference supports a dissenting view on climate change and its causes, challenging the widely accepted position that human activities, particularly burning fossil fuels, are primarily responsible for global warming.\n",
      "\n",
      "[]\n",
      "2\n",
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a public statement on climate change signed by over 500 scientists and professionals in climate and related fields from Europe and beyond. The declaration asserts that a human-caused climate emergency does not exist and emphasizes the need for a more balanced and nuanced approach to climate policy. It highlights the benefits of carbon dioxide for plant growth and the lack of evidence supporting extreme weather events being caused by human activity. The ECD acknowledges the potential for climate variability but stresses that natural factors such as solar activity and changes in global and regional temperature patterns are also important drivers of climate change. In conclusion, this reference supports a dissenting view on climate change and its causes, challenging the widely accepted position that human activities, particularly burning fossil fuels, are primarily responsible for global warming.\n",
      "\n",
      "[]\n",
      "0\n",
      "\\\\\\\n",
      "\n",
      "184\n",
      "173\n",
      "168\n",
      "16 0.08695652173913043\n",
      "176 0.9565217391304348\n",
      "matched num= 369\n"
     ]
    }
   ],
   "source": [
    "t=0\n",
    "f=0\n",
    "t6=[]\n",
    "f6=[]\n",
    "n=0\n",
    "x=0\n",
    "with open(filePath[0]+\"dataset_0.9.jsonl\") as file1:\n",
    "    for line1 in file1:\n",
    "        label=line1.split(\"label: \")[-1]\n",
    "        ref1=line1.split(\"Response: \")[0].split(\"Reference: \")\n",
    "        if len(ref1)==2:\n",
    "            ref1=ref1[1]\n",
    "        else:\n",
    "            ref1=ref1[1]+\"Reference: \"+ref1[2]\n",
    "        pre=n\n",
    "        flag=False\n",
    "        ref1=ref1[:-8]\n",
    "        with open(\"detections_6_3.jsonl\") as file:\n",
    "            mark=[]\n",
    "            for line in file:\n",
    "                answer=line.split(\"Result: \")[1]\n",
    "                ref=line.split(\"P2: \")[0].split(\"P1: \")[1]\n",
    "                ref=ref.encode().decode('unicode_escape')\n",
    "                ref=ref[1:-15]\n",
    "                if \"The Real Inconvenient Truth\" in ref:\n",
    "                    ref+=\"ng\"\n",
    "                if ref.strip()==ref1.strip():\n",
    "                    flag=True\n",
    "                    n+=1\n",
    "                    if 'true' in label: #hallucination\n",
    "                        x+=1\n",
    "                        if identifyConflict(answer):\n",
    "                            t+=1\n",
    "                        else:    \n",
    "                            t6.append(ref1)\n",
    "                    else: # factual\n",
    "                        if identifyConflict(answer): \n",
    "                            f+=1\n",
    "                        else:    \n",
    "                            f6.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\",\")[0]\n",
    "                    c2=ref1.strip().split(\",\")[0]\n",
    "                    if c1.strip()==c2.strip():\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        mark.append(',')\n",
    "                        if 'true' in label: #hallucination\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer): \n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t6.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer): \n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f6.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\n\")\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\n\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[-1]==c2[-1]:\n",
    "                        flag=True\n",
    "                        mark.append('n')\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer): \n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t6.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer): \n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f6.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[1]==c2[1]:\n",
    "                        flag=True\n",
    "                        mark.append('\\\"')\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t6.append(ref1)\n",
    "                        else: # factual\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f6.append(ref1)\n",
    "                if flag==False:\n",
    "                    uni=ref.strip().split('\\\\\\\\\\\\\\\\u')\n",
    "                    if len(uni)>1 and \"d Unreliability and Electricity Prices: Th\" not in ref:\n",
    "                        uni=uni[-2][4:]\n",
    "                        length=len(uni)\n",
    "                        #if ref1.strip()[-length:] == uni:\n",
    "                        if uni in ref1.strip():\n",
    "                            flag = True\n",
    "                            mark.append('u')\n",
    "                            mark.append(ref)\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer): \n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    t6.append(ref1)\n",
    "                            else: # factual\n",
    "                                if identifyConflict(answer): \n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    f6.append(ref1)\n",
    "        if n-pre!=1:\n",
    "            print(mark)\n",
    "            print(n-pre)\n",
    "            print(ref1)\n",
    "            print()\n",
    "print(x)\n",
    "print(len(t1))\n",
    "print(t)\n",
    "print(num[-1]-t,(num[-1]-t)/num[-1])\n",
    "print(f,f/num[-1])\n",
    "print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 512,
   "id": "62c3bdad",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "one error\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n",
      "xxx\n"
     ]
    }
   ],
   "source": [
    "with open('detections_6_3.jsonl','w') as twofile:\n",
    "    with open(\"llama2_data/climate+0.9/dataset_0.9.jsonl\") as file1:\n",
    "        for line1 in file1:\n",
    "            label=line1.split(\"label: \")[-1]\n",
    "            ref1=line1.split(\"Response: \")[0].split(\"Reference: \")\n",
    "            if len(ref1)==2:\n",
    "                ref1=ref1[1]\n",
    "            else:\n",
    "                ref1=ref1[1]+\"Reference: \"+ref1[2]\n",
    "            pre=n\n",
    "            flag=False\n",
    "            ref1=ref1[:-8]\n",
    "            if (ref1 in f6 and \"false\" in label) or (ref1 not in t6 and \"true\" in label):\n",
    "                with open(\"llama2_data/climate+0.9/detections_6_2.jsonl\") as file:\n",
    "                    flag=False\n",
    "                    for line in file:\n",
    "                        answer=line.split(\"Result: \")[1]\n",
    "                        ref=line.split(\"P2: \")[0].split(\"P1: \")[1]\n",
    "                        ref=ref.encode().decode('unicode_escape')\n",
    "                        ref=ref[1:-15]\n",
    "                        if \"The Real Inconvenient Truth\" in ref:\n",
    "                            ref+=\"ng\"\n",
    "                            if ref.strip()==ref1.strip():\n",
    "                                flag=True\n",
    "                                twofile.write(line)\n",
    "                        if flag==False:\n",
    "                            # \n",
    "                            c1=ref.strip().split(\",\")[0]\n",
    "                            c2=ref1.strip().split(\",\")[0]\n",
    "                            if c1.strip()==c2.strip():\n",
    "                                flag=True\n",
    "                                twofile.write(line)\n",
    "                        if flag==False:\n",
    "                            # \n",
    "                            c1=ref.strip().split(\"\\\\\\\\n\")\n",
    "                            c2=ref1.strip().split(\"\\\\\\\\n\")\n",
    "                            if len(c1)>2 and len(c2)>2 and c1[-1]==c2[-1]:\n",
    "                                flag=True\n",
    "                                twofile.write(line)\n",
    "                        if flag==False:\n",
    "                            # \n",
    "                            c1=ref.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                            c2=ref1.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                            if len(c1)>2 and len(c2)>2 and c1[1]==c2[1]:\n",
    "                                flag=True\n",
    "                                twofile.write(line)\n",
    "                        if flag==False:\n",
    "                            uni=ref.strip().split('\\\\\\\\\\\\\\\\u')\n",
    "                            if len(uni)>1 and \"d Unreliability and Electricity Prices: Th\" not in ref:\n",
    "                                uni=uni[-2][4:]\n",
    "                                length=len(uni)\n",
    "                                #if ref1.strip()[-length:] == uni:\n",
    "                                if uni in ref1.strip():\n",
    "                                    flag = True\n",
    "                                    twofile.write(line)\n",
    "                    if flag==False:\n",
    "                        print('one error')\n",
    "            else:\n",
    "                print('xxx')\n",
    "                with open('llama2_data/climate+0.9/detections_6.jsonl') as file2:\n",
    "                    flag=False\n",
    "                    for line2 in file2:\n",
    "                        answer=line2.split(\"Result: \")[1]\n",
    "                        ref=line2.split(\"P2: \")[0].split(\"P1: \")[1]\n",
    "                        ref=ref.encode().decode('unicode_escape')\n",
    "                        ref=ref[1:-15]\n",
    "                        if \"The Real Inconvenient Truth\" in ref:\n",
    "                            ref+=\"ng\"\n",
    "                            if ref.strip()==ref1.strip():\n",
    "                                flag=True\n",
    "                                twofile.write(line2)\n",
    "                        if flag==False:\n",
    "                            # \n",
    "                            c1=ref.strip().split(\",\")[0]\n",
    "                            c2=ref1.strip().split(\",\")[0]\n",
    "                            if c1.strip()==c2.strip():\n",
    "                                flag=True\n",
    "                                twofile.write(line2)\n",
    "                        if flag==False:\n",
    "                            # \n",
    "                            c1=ref.strip().split(\"\\\\\\\\n\")\n",
    "                            c2=ref1.strip().split(\"\\\\\\\\n\")\n",
    "                            if len(c1)>2 and len(c2)>2 and c1[-1]==c2[-1]:\n",
    "                                flag=True\n",
    "                                twofile.write(line2)\n",
    "                        if flag==False:\n",
    "                            # \n",
    "                            c1=ref.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                            c2=ref1.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                            if len(c1)>2 and len(c2)>2 and c1[1]==c2[1]:\n",
    "                                flag=True\n",
    "                                twofile.write(line2)\n",
    "                        if flag==False:\n",
    "                            uni=ref.strip().split('\\\\\\\\\\\\\\\\u')\n",
    "                            if len(uni)>1 and \"d Unreliability and Electricity Prices: Th\" not in ref:\n",
    "                                uni=uni[-2][4:]\n",
    "                                length=len(uni)\n",
    "                                if uni in ref1.strip():\n",
    "                                    flag = True\n",
    "                                    twofile.write(line2)\n",
    "                    if flag==False:\n",
    "                        print('one error')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 525,
   "id": "c7009075",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[]\n",
      "2\n",
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a public statement on climate change signed by over 500 scientists and professionals in climate and related fields from Europe and beyond. The declaration asserts that a human-caused climate emergency does not exist and emphasizes the need for a more balanced and nuanced approach to climate policy. It highlights the benefits of carbon dioxide for plant growth and the lack of evidence supporting extreme weather events being caused by human activity. The ECD acknowledges the potential for climate variability but stresses that natural factors such as solar activity and changes in global and regional temperature patterns are also important drivers of climate change. In conclusion, this reference supports a dissenting view on climate change and its causes, challenging the widely accepted position that human activities, particularly burning fossil fuels, are primarily responsible for global warming.\n",
      "\n",
      "[]\n",
      "2\n",
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a public statement on climate change signed by over 500 scientists and professionals in climate and related fields from Europe and beyond. The declaration asserts that a human-caused climate emergency does not exist and emphasizes the need for a more balanced and nuanced approach to climate policy. It highlights the benefits of carbon dioxide for plant growth and the lack of evidence supporting extreme weather events being caused by human activity. The ECD acknowledges the potential for climate variability but stresses that natural factors such as solar activity and changes in global and regional temperature patterns are also important drivers of climate change. In conclusion, this reference supports a dissenting view on climate change and its causes, challenging the widely accepted position that human activities, particularly burning fossil fuels, are primarily responsible for global warming.\n",
      "\n",
      "[]\n",
      "0\n",
      "\\\\\\\n",
      "\n",
      "184\n",
      "173\n",
      "14\n",
      "170 0.9239130434782609\n",
      "17 0.09239130434782608\n",
      "matched num= 369\n"
     ]
    }
   ],
   "source": [
    "t=0\n",
    "f=0\n",
    "t66=[]\n",
    "f66=[]\n",
    "n=0\n",
    "x=0\n",
    "with open(filePath[0]+\"dataset_0.9.jsonl\") as file1:\n",
    "    for line1 in file1:\n",
    "        label=line1.split(\"label: \")[-1]\n",
    "        ref1=line1.split(\"Response: \")[0].split(\"Reference: \")\n",
    "        if len(ref1)==2:\n",
    "            ref1=ref1[1]\n",
    "        else:\n",
    "            ref1=ref1[1]+\"Reference: \"+ref1[2]\n",
    "        pre=n\n",
    "        flag=False\n",
    "        ref1=ref1[:-8]\n",
    "        with open(filePath[0]+\"detections_6_1.jsonl\") as file:\n",
    "            mark=[]\n",
    "            for line in file:\n",
    "                answer=line.split(\"Result: \")[1]\n",
    "                ref=line.split(\"P2: \")[0].split(\"P1: \")[1]\n",
    "                ref=ref.encode().decode('unicode_escape')\n",
    "                ref=ref[1:-15]\n",
    "                if \"The Real Inconvenient Truth\" in ref:\n",
    "                    ref+=\"ng\"\n",
    "                if ref.strip()==ref1.strip():\n",
    "                    flag=True\n",
    "                    n+=1\n",
    "                    if 'true' in label: #hallucination\n",
    "                        x+=1\n",
    "                        if identifyConflict(answer):\n",
    "                            t+=1\n",
    "                        else:    \n",
    "                            t66.append(ref1)\n",
    "                    else: # factual\n",
    "                        if identifyConflict(answer): \n",
    "                            f+=1\n",
    "                        else:    \n",
    "                            f66.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\",\")[0]\n",
    "                    c2=ref1.strip().split(\",\")[0]\n",
    "                    if c1.strip()==c2.strip():\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        mark.append(',')\n",
    "                        if 'true' in label: #hallucination\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer): \n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t66.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer): \n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f66.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\n\")\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\n\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[-1]==c2[-1]:\n",
    "                        flag=True\n",
    "                        mark.append('n')\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer): \n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t66.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer): \n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f66.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[1]==c2[1]:\n",
    "                        flag=True\n",
    "                        mark.append('\\\"')\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t66.append(ref1)\n",
    "                        else: # factual\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f66.append(ref1)\n",
    "                if flag==False:\n",
    "                    uni=ref.strip().split('\\\\\\\\\\\\\\\\u')\n",
    "                    if len(uni)>1 and \"d Unreliability and Electricity Prices: Th\" not in ref:\n",
    "                        uni=uni[-2][4:]\n",
    "                        length=len(uni)\n",
    "                        #if ref1.strip()[-length:] == uni:\n",
    "                        if uni in ref1.strip():\n",
    "                            flag = True\n",
    "                            mark.append('u')\n",
    "                            mark.append(ref)\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer): \n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    t66.append(ref1)\n",
    "                            else: # factual\n",
    "                                if identifyConflict(answer): \n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    f66.append(ref1)\n",
    "        if n-pre!=1:\n",
    "            print(mark)\n",
    "            print(n-pre)\n",
    "            print(ref1)\n",
    "            print()\n",
    "print(x)\n",
    "print(len(t1))\n",
    "print(t)\n",
    "print(num[-1]-t,(num[-1]-t)/num[-1])\n",
    "print(f,f/num[-1])\n",
    "print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 526,
   "id": "206e9ed0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[]\n",
      "2\n",
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a public statement on climate change signed by over 500 scientists and professionals in climate and related fields from Europe and beyond. The declaration asserts that a human-caused climate emergency does not exist and emphasizes the need for a more balanced and nuanced approach to climate policy. It highlights the benefits of carbon dioxide for plant growth and the lack of evidence supporting extreme weather events being caused by human activity. The ECD acknowledges the potential for climate variability but stresses that natural factors such as solar activity and changes in global and regional temperature patterns are also important drivers of climate change. In conclusion, this reference supports a dissenting view on climate change and its causes, challenging the widely accepted position that human activities, particularly burning fossil fuels, are primarily responsible for global warming.\n",
      "\n",
      "[]\n",
      "2\n",
      " https://www.thegwpf.com/european-climate-declaration/ The European Climate Declaration (ECD) is a public statement on climate change signed by over 500 scientists and professionals in climate and related fields from Europe and beyond. The declaration asserts that a human-caused climate emergency does not exist and emphasizes the need for a more balanced and nuanced approach to climate policy. It highlights the benefits of carbon dioxide for plant growth and the lack of evidence supporting extreme weather events being caused by human activity. The ECD acknowledges the potential for climate variability but stresses that natural factors such as solar activity and changes in global and regional temperature patterns are also important drivers of climate change. In conclusion, this reference supports a dissenting view on climate change and its causes, challenging the widely accepted position that human activities, particularly burning fossil fuels, are primarily responsible for global warming.\n",
      "\n",
      "[]\n",
      "0\n",
      "\\\\\\\n",
      "\n",
      "184\n",
      "173\n",
      "18\n",
      "166 0.9021739130434783\n",
      "16 0.08695652173913043\n",
      "matched num= 369\n"
     ]
    }
   ],
   "source": [
    "t=0\n",
    "f=0\n",
    "t7=[]\n",
    "f7=[]\n",
    "n=0\n",
    "x=0\n",
    "with open(filePath[0]+\"dataset_0.9.jsonl\") as file1:\n",
    "    for line1 in file1:\n",
    "        label=line1.split(\"label: \")[-1]\n",
    "        ref1=line1.split(\"Response: \")[0].split(\"Reference: \")\n",
    "        if len(ref1)==2:\n",
    "            ref1=ref1[1]\n",
    "        else:\n",
    "            ref1=ref1[1]+\"Reference: \"+ref1[2]\n",
    "        pre=n\n",
    "        flag=False\n",
    "        ref1=ref1[:-8]\n",
    "        with open(filePath[0]+\"detections_7.jsonl\") as file:\n",
    "            mark=[]\n",
    "            for line in file:\n",
    "                answer=line.split(\"Result: \")[1]\n",
    "                ref=line.split(\"P2: \")[0].split(\"P1: \")[1]\n",
    "                ref=ref.encode().decode('unicode_escape')\n",
    "                ref=ref[1:-15]\n",
    "                if \"The Real Inconvenient Truth\" in ref:\n",
    "                    ref+=\"ng\"\n",
    "                if ref.strip()==ref1.strip():\n",
    "                    flag=True\n",
    "                    n+=1\n",
    "                    if 'true' in label: #hallucination\n",
    "                        x+=1\n",
    "                        if identifyConflict(answer):\n",
    "                            t+=1\n",
    "                        else:    \n",
    "                            t7.append(ref1)\n",
    "                    else: # factual\n",
    "                        if identifyConflict(answer): \n",
    "                            f+=1\n",
    "                        else:    \n",
    "                            f7.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\",\")[0]\n",
    "                    c2=ref1.strip().split(\",\")[0]\n",
    "                    if c1.strip()==c2.strip():\n",
    "                        flag=True\n",
    "                        n+=1\n",
    "                        mark.append(',')\n",
    "                        if 'true' in label: #hallucination\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer): \n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t7.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer): \n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f7.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\n\")\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\n\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[-1]==c2[-1]:\n",
    "                        flag=True\n",
    "                        mark.append('n')\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer): \n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t7.append(ref1)\n",
    "                        else: # factual\n",
    "                            if identifyConflict(answer): \n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f7.append(ref1)\n",
    "                if flag==False:\n",
    "                    # \n",
    "                    c1=ref.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    c2=ref1.strip().split(\"\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"\")\n",
    "                    if len(c1)>2 and len(c2)>2 and c1[1]==c2[1]:\n",
    "                        flag=True\n",
    "                        mark.append('\\\"')\n",
    "                        n+=1\n",
    "                        if 'true' in label: #hallucination\n",
    "                            if identifyConflict(answer):\n",
    "                                t+=1\n",
    "                            else:    \n",
    "                                t7.append(ref1)\n",
    "                        else: # factual\n",
    "                            x+=1\n",
    "                            if identifyConflict(answer):\n",
    "                                f+=1\n",
    "                            else:    \n",
    "                                f7.append(ref1)\n",
    "                if flag==False:\n",
    "                    uni=ref.strip().split('\\\\\\\\\\\\\\\\u')\n",
    "                    if len(uni)>1 and \"d Unreliability and Electricity Prices: Th\" not in ref:\n",
    "                        uni=uni[-2][4:]\n",
    "                        length=len(uni)\n",
    "                        #if ref1.strip()[-length:] == uni:\n",
    "                        if uni in ref1.strip():\n",
    "                            flag = True\n",
    "                            mark.append('u')\n",
    "                            mark.append(ref)\n",
    "                            n+=1\n",
    "                            if 'true' in label: #hallucination\n",
    "                                x+=1\n",
    "                                if identifyConflict(answer): \n",
    "                                    t+=1\n",
    "                                else:    \n",
    "                                    t7.append(ref1)\n",
    "                            else: # factual\n",
    "                                if identifyConflict(answer): \n",
    "                                    f+=1\n",
    "                                else:    \n",
    "                                    f7.append(ref1)\n",
    "        if n-pre!=1:\n",
    "            print(mark)\n",
    "            print(n-pre)\n",
    "            print(ref1)\n",
    "            print()\n",
    "print(x)\n",
    "print(len(t1))\n",
    "print(t)\n",
    "print(num[-1]-t,(num[-1]-t)/num[-1])\n",
    "print(f,f/num[-1])\n",
    "print('matched num=',n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 532,
   "id": "b32146c9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "168\n"
     ]
    }
   ],
   "source": [
    "print(len(t7))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 531,
   "id": "6085e4f2",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "169"
      ]
     },
     "execution_count": 531,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(set(t1+t7))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 557,
   "id": "6958d078",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 1 2 3\n",
      "0.4945652173913044\n",
      "0.654275092936803\n",
      "0 1 2 3\n",
      "0.4945652173913044\n",
      "0.654275092936803\n",
      "0 1 2 3\n",
      "0.4945652173913044\n",
      "0.654275092936803\n",
      "0 1 2 3\n",
      "0.4945652173913044\n",
      "0.654275092936803\n",
      "0 1 2 3\n",
      "0.4945652173913044\n",
      "0.654275092936803\n",
      "0 1 2 3\n",
      "0.4945652173913044\n",
      "0.654275092936803\n",
      "0 1 2 3\n",
      "0.4945652173913044\n",
      "0.654275092936803\n",
      "0 1 2 3\n",
      "0.4972826086956522\n",
      "0.6554934823091247\n",
      "0 1 2 3\n",
      "0.4972826086956522\n",
      "0.6554934823091247\n",
      "0 1 2 3\n",
      "0.4972826086956522\n",
      "0.6554934823091247\n",
      "0 1 2 3\n",
      "0.4972826086956522\n",
      "0.6554934823091247\n",
      "0 1 2 3\n",
      "0.5\n",
      "0.6567164179104477\n",
      "0 1 2 3\n",
      "0.5\n",
      "0.6567164179104477\n",
      "0 1 2 3\n",
      "0.5\n",
      "0.6567164179104477\n",
      "0 1 2 3\n",
      "0.5\n",
      "0.6567164179104477\n",
      "0 1 2 3\n",
      "0.5\n",
      "0.6567164179104477\n",
      "0 1 2 3\n",
      "0.5\n",
      "0.6554307116104869\n",
      "0 2 3 4\n",
      "0.5\n",
      "0.6567164179104477\n",
      "0 2 3 4\n",
      "0.5\n",
      "0.6567164179104477\n",
      "0 2 3 4\n",
      "0.5\n",
      "0.6567164179104477\n",
      "0 2 3 4\n",
      "0.5\n",
      "0.6567164179104477\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-9):\n",
    "    for jj in range(kk+1,13-8):\n",
    "        for ii in range(jj+1,13-7):\n",
    "            for i in range(ii+1,13-6):\n",
    "                for j in range(i+1,13-5):\n",
    "                     for k in range(j+1,13-4):\n",
    "                        for m in range(k+1,13-3):\n",
    "                            for n in range(m+1,13-2):\n",
    "                                for q in range(n+1,13-1):\n",
    "                                    for w in range(q+1,13-0):\n",
    "                                        #for z in range(w+1,13-0):\n",
    "                                            #for y in range(z+1,13-0):\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",
    "                                                a=list(set(a))\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",
    "                                                a=list(set(a))\n",
    "                                                bb=len(a)\n",
    "                                                TN=(num[-1]-bb)/(num[-1]*2)\n",
    "                                                TP=aa/(num[-1]*2)\n",
    "                                                FN=(num[-1]-aa)/(num[-1]*2)\n",
    "                                                FP=bb/(num[-1]*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": null,
   "id": "46aa3c2c",
   "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
}
