File size: 2,148 Bytes
374d18f
aad4ca6
374d18f
 
aad4ca6
374d18f
aad4ca6
374d18f
 
 
 
 
aad4ca6
 
 
 
 
 
 
 
374d18f
aad4ca6
374d18f
 
aad4ca6
 
 
374d18f
 
aad4ca6
 
 
 
 
 
 
 
 
374d18f
 
 
aad4ca6
374d18f
 
 
aad4ca6
 
 
 
374d18f
 
 
aad4ca6
 
374d18f
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
import streamlit as st
from transformers import AutoModelForSeq2SeqLM, AutoTokenizer, pipeline
import torch

# Load grammar correction model
@st.cache_resource
def load_grammar_model():
    model_name = "prithivida/grammar_error_correcter_v1"
    tokenizer = AutoTokenizer.from_pretrained(model_name)
    model = AutoModelForSeq2SeqLM.from_pretrained(model_name)
    return tokenizer, model

# Load explanation model
@st.cache_resource
def load_explainer():
    explainer = pipeline("text2text-generation", model="google/flan-t5-base", max_length=256)
    return explainer

grammar_tokenizer, grammar_model = load_grammar_model()
explanation_model = load_explainer()

# Grammar correction function
def correct_grammar(text):
    input_text = "gec: " + text
    inputs = grammar_tokenizer.encode(input_text, return_tensors="pt", truncation=True)
    outputs = grammar_model.generate(inputs, max_length=512, num_beams=4, early_stopping=True)
    corrected_text = grammar_tokenizer.decode(outputs[0], skip_special_tokens=True)
    return corrected_text

# Explanation function using second model
def explain_correction(original, corrected):
    prompt = f"Explain the grammar improvements made from: \"{original}\" to: \"{corrected}\""
    result = explanation_model(prompt)[0]['generated_text']
    return result

# Streamlit App UI
st.title("πŸ“ Smart Grammar Correction with Explanations")
st.write("Enter your text below. The AI will correct grammar **and explain why** the changes were made using grammar principles.")

user_input = st.text_area("Your Text", height=200, placeholder="Type or paste your text here...")

if st.button("Correct and Explain"):
    if user_input.strip():
        with st.spinner("Correcting grammar..."):
            corrected = correct_grammar(user_input)

        with st.spinner("Explaining corrections..."):
            explanation = explain_correction(user_input, corrected)

        st.subheader("βœ… Corrected Text")
        st.success(corrected)

        st.subheader("πŸ“˜ Explanation (Why it was changed)")
        st.markdown(explanation)
    else:
        st.warning("Please enter some text to correct.")