File size: 2,071 Bytes
730e4d8
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
from datasets import load_dataset
import gradio as gr
from sklearn.pipeline import Pipeline
from sklearn.feature_extraction.text import TfidfVectorizer
from sklearn.linear_model import LogisticRegression
from sklearn.model_selection import train_test_split
import warnings

warnings.filterwarnings("ignore")

# === Шаг 1. Загрузка датасета ===
try:
    dataset = load_dataset("UniversalCEFR/cefr_sp_en")["train"]
    print(f"✅ Датасет успешно загружен: {len(dataset)} строк")
except Exception as e:
    raise RuntimeError(f"❌ Ошибка при загрузке датасета: {e}")

# === Шаг 2. Подготовка данных ===
texts = [item["text"] for item in dataset if item["text"]]
labels = [item["cefr_level"] for item in dataset if item["text"]]

# === Шаг 3. Разделение на train/test ===
X_train, X_test, y_train, y_test = train_test_split(
    texts, labels, test_size=0.2, random_state=42
)

# === Шаг 4. Обучение модели ===
model = Pipeline([
    ("vectorizer", TfidfVectorizer(max_features=5000)),
    ("classifier", LogisticRegression(max_iter=1000))
])

print("🔄 Обучение модели...")
model.fit(X_train, y_train)
print("✅ Модель обучена успешно")

# === Шаг 5. Gradio-интерфейс ===
def predict_level(text):
    if not text.strip():
        return "⛔️ Введите непустой текст"
    prediction = model.predict([text])[0]
    confidence = model.predict_proba([text])[0].max()
    return f"📘 Уровень: {prediction}\nУверенность: {confidence:.2%}"

demo = gr.Interface(
    fn=predict_level,
    inputs=gr.Textbox(lines=4, label="Введите английское предложение"),
    outputs=gr.Text(label="Результат"),
    title="CEFR Level Predictor (A1–C2)",
    description="Модель на основе датасета UniversalCEFR, предсказывает уровень знания английского языка.",
)

demo.launch()