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

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

14.04.2019, 19:01. Показов 2316. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Доступность команды формы по условию
Maks 07.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: сделать доступной кнопку (команда формы "ЗавершитьСписание") при. . .
Уведомление о неверно выбранном значении справочника
Maks 06.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "НарядПутевка", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если в документе выбран неверный склад. . .
Установка Qt Creator для C и C++: ставим среду, CMake и MinGW без фреймворка Qt
8Observer8 05.04.2026
Среду разработки Qt Creator можно установить без фреймворка Qt. Есть отдельный репозиторий для этой среды: https:/ / github. com/ qt-creator/ qt-creator, где можно скачать установщик, на вкладке Releases:. . .
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
Отображение реквизитов в документе по условию и контроль их заполнения
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеСпецтехники", разработанного в конфигурации КА2. Данный документ берёт данные из другого нетипового документа. . .
Фото всей Земли с борта корабля Orion миссии Artemis II
kumehtar 04.04.2026
Это первое подобное фото сделанное человеком за 50 лет. Снимок называют новым вариантом легендарной фотографии «The Blue Marble» 1972 года, сделанной с борта корабля «Аполлон-17». Новое фото. . .
Вывод диалогового окна перед закрытием, если документ не проведён
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать программный контроль на предмет проведения документа. . .
Программный контроль заполнения реквизитов табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: 1. Реализовать контроль заполнения реквизита. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru