DataAIDemo / pages /Auto_Score_Generation.py
themeetjani's picture
Update pages/Auto_Score_Generation.py
327c011 verified
import streamlit as st
from streamlit import session_state
import os
import openai
openai.api_key = os.getenv("OPENAI_API_KEY")
import pandas as pd
from sklearn.preprocessing import LabelEncoder
import numpy as np
def gpt4_score(m_answer, s_answer):
response = openai.ChatCompletion.create(
model="gpt-4",
messages=[
{
"role": "system",
"content": "You are UPSC answers evaluater. You will be given model answer and student answer. Evaluate it by comparing with the model answer. \n<<REMEMBER>>\nIt is 10 marks question. Student can recieve maximum 5 marks. Give marks in the range of 0.25. (ex. 0,0.25,0.5...)\nThere are 3 parts in the answer. Introduction (1 marks), body (3 marks) and conclusion (1 marks). If the student answer and model answer is not relevant then give 0 marks.\ngive output in json form. Give output in this format {\"intro\":,\"body\":,\"con\":,\"total\":}\n<<OUTPUT>>\n"
},
{
"role": "assistant",
"content": f"Model answer: {m_answer}"},
{
"role": "user",
"content": f"Student answer: {s_answer}"}
],
temperature=0,
max_tokens=701,
top_p=1,
frequency_penalty=0,
presence_penalty=0
)
return response.choices[0].message.content
st.write("# Auto Score Generation! 👋")
if 'score' not in session_state:
session_state['score']= ""
text1= st.text_area(label= "Please write the Model Answer bellow",
placeholder="What does the text say?")
text2= st.text_area(label= "Please write the Student Answer bellow",
placeholder="What does the text say?")
def classify(text1,text2):
session_state['score'] = gpt4_score(text1,text2)
st.text_area("result", value=session_state['score'])
st.button("Submit", on_click=classify, args=[text1,text2])