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

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

14.03.2021, 13:23. Показов 1689. Ответов 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
5514 / 2867 / 571
Регистрация: 07.11.2019
Сообщений: 4,753
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
5514 / 2867 / 571
Регистрация: 07.11.2019
Сообщений: 4,753
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
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru