# 3. Обучение модели (метод k-NN)

knn_model = KNeighborsClassifier(n_neighbors=5)

knn_model.fit(X_train, y_train)

# 4. Оценка качества модели

y_pred = knn_model.predict(X_test)

accuracy = accuracy_score(y_test, y_pred)

conf_matrix = confusion_matrix(y_test, y_pred)

class_report = classification_report(y_test, y_pred)

print("Accuracy:", accuracy)

print("Confusion Matrix:\n", conf_matrix)

print("Classification Report:\n", class_report)

```

Перед выполнением этого кода необходимо убедиться, что данные находятся в файле "student_data.csv" и соответствуют описанной выше структуре. Кроме того, предварительная обработка данных (например, заполнение пропущенных значений, кодирование категориальных признаков) может потребоваться в зависимости от конкретного набора данных.


Метод опорных векторов (SVM):

Метод опорных векторов (SVM) является одним из самых популярных алгоритмов в машинном обучении, применимым как для задач классификации, так и для регрессии. Он основан на поиске гиперплоскости в пространстве признаков, которая максимально разделяет объекты разных классов. Этот подход делает SVM особенно эффективным при работе с данными, которые могут быть линейно разделимы, что позволяет ему обеспечить высокую точность классификации.

Одним из основных преимуществ SVM является его способность максимизировать зазор между классами, что делает его устойчивым к переобучению. Это означает, что даже при наличии ограниченного количества обучающих данных SVM может дать хорошие результаты. Благодаря этой устойчивости он успешно применяется в таких областях, как биомедицинская диагностика, финансовая аналитика и распознавание образов.

SVM, используемый в машинном обучении, обладает уникальной возможностью описывать нелинейные взаимосвязи между признаками при помощи ядерных функций. Это особенно важно в случаях, когда данные имеют сложную структуру и не могут быть линейно разделены в исходном пространстве признаков.

Ядерные функции (kernel functions) – это математические функции, которые позволяют преобразовывать данные из исходного пространства признаков в пространство более высокой размерности. Они играют ключевую роль в методе опорных векторов (SVM), позволяя моделировать сложные нелинейные зависимости между признаками, которые не могут быть эффективно разделены в исходном пространстве.

Использование ядерных функций позволяет SVM строить оптимальную разделяющую гиперплоскость в новом пространстве, где данные становятся линейно разделимыми. Это делает SVM гибким методом, который может успешно применяться к различным типам данных и задачам машинного обучения, включая как классификацию, так и регрессию.

Некоторые из наиболее распространенных ядерных функций включают в себя линейное ядро, полиномиальное ядро, радиальное базисное функциональное ядро (RBF), сигмоидное ядро и другие. Каждая из этих функций имеет свои уникальные характеристики и может быть более или менее подходящей в зависимости от конкретной задачи и особенностей данных.

Эта гибкость делает SVM универсальным методом, который может быть применен к разнообразным типам данных, таким как текст, изображения, временные ряды и другие. Например, в задачах анализа текста SVM может эффективно выявлять нелинейные зависимости между словами и классифицировать тексты по их содержанию или тональности.

Другим примером применения SVM с ядерными функциями является анализ медицинских изображений. SVM может использоваться для классификации изображений с медицинскими снимками, такими как рентгенограммы или снимки МРТ, на основе их характеристик и признаков. При этом ядерные функции позволяют учитывать сложные пространственные и текстурные особенности изображений, что делает SVM мощным инструментом для диагностики и обработки медицинских данных.