Форум программистов, компьютерный форум, киберфорум
Python: Научные вычисления
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.63/8: Рейтинг темы: голосов - 8, средняя оценка - 4.63
7 / 7 / 1
Регистрация: 24.01.2017
Сообщений: 229

Модель для бинарной классификации не обучается с точностью больше 0.5

14.03.2021, 13:23. Показов 1736. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть вот такая модель:

Python
1
2
3
4
5
6
7
8
9
model = tf.keras.Sequential()
model.add(tf.keras.layers.InputLayer(input_shape=train_data.shape[1]))
model.add(tf.keras.layers.Dense(30, activation=tf.nn.relu))
model.add(tf.keras.layers.Dense(64, activation=tf.nn.relu))
model.add(tf.keras.layers.Dense(27, activation=tf.nn.relu))
model.add(tf.keras.layers.Dense(2, activation=tf.nn.softmax))
 
model.compile(optimizer="Adam", loss=tf.keras.losses.binary_crossentropy, metrics=[tf.keras.metrics.binary_accuracy])
model.fit(train_data, train_results, batch_size=15, epochs=50)
Что бы я не менял и как бы не обрабатывал данные, но он не обучается больше 0.5. Думаю, что что-то делаю не так, но что, не знаю. Ноутбук и данные для модели прилагаю.
Вложения
Тип файла: 7z Model.7z (929.3 Кб, 9 просмотров)
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
14.03.2021, 13:23
Ответы с готовыми решениями:

GridSearchCV на собственной метрике для бинарной классификации
Классы 0 и 1. У каждой 1 своя заданная польза от 1 до 10 - power. Известна заранее метрика для GridsearchCV считает сумму...

Методика подготовки датасета для бинарной текстовой классификации при наличии обучающих примеров лишь для одного класса
С учетом возможностей распространенных на сегодняшний день способов классификации текстов: машинное обучение (SVM,Naive Bayes и т.п.);...

Сложности в реализации скрипта по бинарной классификации
Коллеги, здравствуйте! Подскажите пожалуйста, дайте свои комментарии. Есть набор данных и результирующее поле (EXIST_KASKO_2018) - 0...

8
533 / 438 / 47
Регистрация: 17.07.2013
Сообщений: 2,236
15.03.2021, 08:36
Цитата Сообщение от SharpProg Посмотреть сообщение
2, activation=tf.nn.softmax
А классическую форму бинарной классификации пробовали?
Типа:
1, activation=tf.nn.sigmoid

Добавлено через 1 минуту
Цитата Сообщение от SharpProg Посмотреть сообщение
но он
А это что??

Добавлено через 1 минуту
Цитата Сообщение от SharpProg Посмотреть сообщение
не обучается больше 0.5
Вполне банальная ситуация, НС не "золотая пуля"

Добавлено через 1 минуту
Цитата Сообщение от SharpProg Посмотреть сообщение
.binary_crossentropy
Противоречит SOFTMAX

Добавлено через 1 минуту
Приведите обоснование архитектуры и гиперпараметров
2
7 / 7 / 1
Регистрация: 24.01.2017
Сообщений: 229
15.03.2021, 20:11  [ТС]
Цитата Сообщение от Nick07 Посмотреть сообщение
А это что??
Он - это модель. Как мыш, но модель.

Цитата Сообщение от Nick07 Посмотреть сообщение
Вполне банальная ситуация, НС не "золотая пуля"
Тут речь не идёт о золотой пуле, или каком-то граале. 0,5 - это подбрасывание монетки. У меня в данных не белый шум, хотя бы до 0,6-0,7 можно обучить.

Цитата Сообщение от Nick07 Посмотреть сообщение
Приведите обоснование архитектуры и гиперпараметров
Увидел на каком-то сайте. Я в этой теме плохо понимаю.

Поменял softmax на sigmoid и теперь сразу такие результаты:

Epoch 1/50
200/200 [==============================] - 0s 851us/step - loss: 0.0088 - binary_accuracy: 0.9957
Epoch 2/50
200/200 [==============================] - 0s 573us/step - loss: 0.0182 - binary_accuracy: 0.9917
Epoch 3/50
200/200 [==============================] - 0s 573us/step - loss: 0.0199 - binary_accuracy: 0.9927
Epoch 4/50
200/200 [==============================] - 0s 613us/step - loss: 0.0114 - binary_accuracy: 0.9947
Epoch 5/50
200/200 [==============================] - 0s 608us/step - loss: 0.0210 - binary_accuracy: 0.9913
Epoch 6/50
200/200 [==============================] - 0s 593us/step - loss: 0.0088 - binary_accuracy: 0.9953

Это либо чудо, либо что-то опять неправильно.
Ну и модель пришлось немного поправить:

Python
1
2
3
4
5
6
model = tf.keras.Sequential()
model.add(tf.keras.layers.InputLayer(input_shape=train_data.shape[1]))
model.add(tf.keras.layers.Dense(30, activation=tf.nn.relu))
model.add(tf.keras.layers.Dense(64, activation=tf.nn.relu))
model.add(tf.keras.layers.Dense(27, activation=tf.nn.relu))
model.add(tf.keras.layers.Dense(1, activation=tf.nn.sigmoid))
0
533 / 438 / 47
Регистрация: 17.07.2013
Сообщений: 2,236
16.03.2021, 09:39
Цитата Сообщение от SharpProg Посмотреть сообщение
Как мыш, но модель.
Ну тогда, для сохранения стиля: "модел"

График loss приведите, чтобы на переобучение не нарваться.
binary_accuracy: 0.9953 - это еще не о чём не говорит
0
7 / 7 / 1
Регистрация: 24.01.2017
Сообщений: 229
16.03.2021, 23:15  [ТС]
Такие графики получились:
Миниатюры
Модель для бинарной классификации не обучается с точностью больше 0.5   Модель для бинарной классификации не обучается с точностью больше 0.5  
0
533 / 438 / 47
Регистрация: 17.07.2013
Сообщений: 2,236
17.03.2021, 08:51
Цитата Сообщение от SharpProg Посмотреть сообщение
Такие графики получились:
Всё ОК! Нормальные графики

Добавлено через 2 минуты
Результаты классификации лучше представить при помощи:
classification_report
1
5516 / 2869 / 571
Регистрация: 07.11.2019
Сообщений: 4,760
17.03.2021, 19:55
SharpProg, не думали над снижением размерности? У вас данные сильно коррелированы. Первый главный компонент обеспечивает 90.39 % от общей суммы дисперсий. А 5 главных компонент - 99.72% Т.е. вместо 84 столбцов на входе можно обойтись, например, пятью или менее.
0
7 / 7 / 1
Регистрация: 24.01.2017
Сообщений: 229
17.03.2021, 21:14  [ТС]
Цитата Сообщение от u235 Посмотреть сообщение
Первый главный компонент обеспечивает 90.39 % от общей суммы дисперсий. А 5 главных компонент - 99.72% Т.е. вместо 84 столбцов на входе можно обойтись, например, пятью или менее.
Да, там данные достаточно "похожие". А как это сделать? Если после входного слоя поставить Dense(5) это сработает?
0
5516 / 2869 / 571
Регистрация: 07.11.2019
Сообщений: 4,760
17.03.2021, 21:44
SharpProg, сработает или нет - не знаю, надо проверять. Т.е. возможно (но не факт), что архитектуру сети можно будет упростить, т.к. во входном слое будут не 84 признака, а всего 5, допустим...
Сделать это можно или вручную (numpy), вычесть среднее, посчитать матрицу ковариации и посчитать ее собственные вектора и числа. Или воспользоваться scikit-learn, см. пример: https://scikit-learn.org/stabl... -vs-pls-py
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
17.03.2021, 21:44
Помогаю со студенческими работами здесь

Как запустить обученную модель для классификации текста?
Обучил сеть на классификацию текста, сохранил данные в формате json и h5, как теперь запустить данную модель, что бы она обработала...

Как правильно создать модель нейронной сети и подобрать коэффициенты для классификации бинарных признаков?
Товарищи, приветствую! Не знаю в какую ветку можно написать такой вопрос, но так как python сейчас более актуален при машинном...

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

Определить, на каком факультете обучается больше всего студентов
Дан список из n записей о студентах. Каждая запись содержит следующие поля: фамилия, имя, отчество, факультет. На каком факультете...

Разработать систему иерархической классификации информационного обеспечения (универсальная модель)
Добрый день. Пишу курсовик, в котором надо разработать систему иерархической классификации информационного обеспечения (универсальная...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru