from dotenv import load_dotenv
from openai import OpenAI
import os
from playwright.sync_api import sync_playwright
import re
load_dotenv()
if __name__ == "__main__":
= OpenAI(
client =os.environ.get("OPEN_AI_KEY"),
api_key
)
with sync_playwright() as p:
= p.chromium.launch(headless=False)
browser = browser.new_page()
page
page.goto("https://www.buzzfeed.com/aglover/national-dish-geography-quiz")
(
page"button", name="Reject All")
.get_by_role(
.click()
)
= (
quiz_elements
page".question__iRCfm")
.locator(all()
.
)
for quiz_element in quiz_elements:
= (
question_text
quiz_element".questionTextTitle__VZVh1")
.locator(
.inner_text()
)
= "\n".join(
question_answers
(
quiz_element"li")
.locator(
.all_inner_texts()
)
)
# Submit Question to Chat-GPT -----------------
= [
chat_gpt_messages
{"role": "system",
"content": "I'm going to give you a question about national dishes, plus four possible answers. I want you to give me the answer. Provide just the country name, nothing else.",
},
{"role": "user",
"content": f"{question_text}\n{question_answers}"
},
]
= client.chat.completions.create(
chat_completion =chat_gpt_messages,
messages="gpt-4-0125-preview",
model
)
= (
chat_gpt_answer
chat_completion"choices"][0]["message"]["content"]
.model_dump()[
)
# Select answer based on Chat-GPT response ----
(
quiz_element"li")
.locator(filter(
.=re.compile(f"^{chat_gpt_answer}$")
has_text
)
.click()
)
(
page
.locator(".gradient__R2MwP"
)
.screenshot(="output/buzzfeed_national_dish_quiz/chat_gpt_4_scorecard.png"
path
) )
Background
In the previous post, I showed how Generative AI could be used to complete a Buzzfeed quiz. In the latter example, we answered questions based just on a description alone. The results were impressive, showing how Chat-GPT can easily complete such a quiz with very minor prompting.
In this post, however, we change things slightly. Instead of typing in an answer into a box, we will present Chat-GPT with four possible answers to select from. We used Buzzfeed’s National Dish quiz for this demonstration.
How
We replicate the setup from last time. Using Playwright package to navigate the page to selection questions and responses, and the OpenAI package to interact with Chat-GPT. We’re only using Chat-GPT 4 on this occasion, as we previously saw how well it performs relative to Chat-GPT 3.5.
The only real difference is in what we submit to Chat-GPT:
The prompt now tells Chat-GPT that it will be given a question and four possible answers to choose from.
The message we send to Chat-GPT contains the question and the four possible items.
Results
As expected, Chat-GPT 4 does exceedingly well (far better than how I would score). In this case, it scored 8 out of a possible 10 points, placing it in the top 2% of quiz-takers.
Conclusion
This is just a fun Buzzfeed quiz, but it reiterates the problem that Generative AI will/is having on assessments. It leaves me wondering how standardised assessments will adapt to the risk that Generative AI poses. Moreover, it raises ethical issues in the use of Generative AI in educational- and recruitment-based contexts. Nevertheless, the models are not perfect. We dropped 2 points in this quiz so Generative AI is not infallible, which means standardized tests won’t just see more perfect scores, but the overall performance levels are likely to rise. Perhaps monitoring pass rates over time is required, with a view of identifying spikes in the number of individuals passing.