Форум программистов, компьютерный форум, киберфорум
Python: Научные вычисления
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.82/11: Рейтинг темы: голосов - 11, средняя оценка - 4.82
3 / 3 / 0
Регистрация: 02.04.2017
Сообщений: 273

Логистическая регрессия

14.04.2019, 19:01. Показов 2297. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Нашел готовую реализацию алгоритма логистической регрессии, но работает он довольно странно. Может быть кто-нибудь поможет найти проблему?

Python
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
class LogisticRegression(object):
    def __init__(self, eta=0.1, n_iter=50):
        self.eta = eta
        self.n_iter = n_iter
 
    def fit(self, X, y):
        X = np.insert(X, 0, 1, axis=1)
        self.w = np.ones(X.shape[1])
        m = X.shape[0]
 
        for _ in range(self.n_iter):
            output = X.dot(self.w)
            errors = y - self._sigmoid(output)
            self.w += self.eta / m * errors.dot(X)
        return self
 
    def predict(self, X):
        output = np.insert(X, 0, 1, axis=1).dot(self.w)
        return (np.floor(self._sigmoid(output) + .5)).astype(int)
 
    def score(self, X, y):
        return sum(self.predict(X) == y) / len(y)
 
    def _sigmoid(self, x):
        return 1 / (1 + np.exp(-x))

Если делать с помощью этого класса:

Python
1
2
3
log1 = LogisticRegression().fit(X, y)
print(log1.predict(X))
print(collections.Counter(log1.predict(X)))
То результат будет такой: [0 0 0 ..., 0 0 0] Counter({0: 4899}) - одни нули.

При этом, если использовать библиотеку sklearn,

Python
1
2
3
4
5
from sklearn.linear_model import LogisticRegression
 
log2 = LogisticRegression()
log2.fit(X,y)
print(log2.predict(X))
то результат будет:
[ 1. 1. 1. ..., 0. 1. 0.] Counter({1.0: 2653, 0.0: 2246})

PS
Кликните здесь для просмотра всего текста

На всякий случай приложу кусок данных
Bash
1
2
X_list=[[10.0, 1.0, 1999.0, 14.0, 14.25, 14.0, 14.125, 9.904241, 3162400.0], [10.0, 4.0, 1999.0, 14.125, 14.125, 14.0, 14.0, 9.816596, 533400.0], [10.0, 5.0, 1999.0, 14.0, 14.125, 14.0, 14.125, 9.904241, 270600.0], [10.0, 6.0, 1999.0, 14.125, 14.875, 14.125, 14.875, 10.430133, 205400.0], [10.0, 7.0, 1999.0, 14.875, 14.875, 14.0625, 14.125, 9.904241, 214200.0], [10.0, 8.0, 1999.0, 14.1875, 14.1875, 14.0625, 14.0625, 9.860417, 65600.0], [10.0, 11.0, 1999.0, 14.0625, 14.125, 14.0, 14.0625, 9.860417, 77500.0], [10.0, 12.0, 1999.0, 14.0625, 14.125, 14.0, 14.125, 9.904241, 49200.0], [10.0, 13.0, 1999.0, 14.125, 14.375, 14.0, 14.0625, 9.860417, 49900.0], [10.0, 14.0, 1999.0, 14.0, 14.0625, 13.25, 13.625, 9.55365, 430900.0]]
y_list = [1.0, 0.0, 1.0, 1.0, 0.0, 0.0, 1.0, 1.0, 0.0, 0.0]
Далее делаю
Python
1
2
X = np.array(X_list)
y = np.array(y_list2)
и передаю X и y в функцию
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
14.04.2019, 19:01
Ответы с готовыми решениями:

Линейная и Логистическая Регрессия
Всем привет. Дело такое: Изучаю сейчас машинное обучение, а если конкретнее - Supervised Learning. С логистической регрессией у меня все...

Логистическая регрессия Python
Коллеги, здравствуйте! У меня к вам следующий вопрос, буду рад, если дадите ответ или интересную мысль. У меня есть достаточный набор...

Sklearn регрессия
Считал данные из .csv файла, затем каждый столбец поместил в переменную, хочет обучить методом .fit, но DeprecationWarning: Passing 1d...

1
0 / 0 / 0
Регистрация: 20.09.2016
Сообщений: 3
17.04.2019, 02:08
Она не странно, она неверно работает. Взгляните на формулы и сверьте)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
17.04.2019, 02:08
Помогаю со студенческими работами здесь

Множественная линейная регрессия
При отсутствии корреляционной зависимости (коэффициенты корреляции близки к нулю) имеет ли смысл построения множественной регрессии? ...

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

Нелинейная регрессия (оценка частоты синуса)
Час добрый, не работает (не оценивается частота) следующий код: import numpy as np import matplotlib.pyplot as plt from...

Полиномиальная регрессия. Не удаётся подобрать коэффициенты
Пробовал для полиномов меньшей степени. Код работает хорошо, всё подбирается. А вот для полинома 9 степени перестаёт работать, после 1000...

Полиномиальная регрессия используя Градиентный Спуск и Матричный Способ
Здравствуйте! Мне нужно было применить линейную и полиномиальную регрессии (без использования Scikit-Learn и специальных функций, например...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
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
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru