您的位置:首页 > 科技 > 能源 > 0_(机器学习)逻辑回归介绍

0_(机器学习)逻辑回归介绍

2025/1/16 10:15:40 来源:https://blog.csdn.net/m0_74357009/article/details/140907600  浏览:    关键词:0_(机器学习)逻辑回归介绍

模型简介

逻辑回归(logistic回归)即对数几率回归,它虽然被称作“回归”,但却是一种用于二分类的分类方法。逻辑回归是通过分析一个样本被分为各个类的概率比较后得出该样本最有可能属于的类的一种分类方法。

逻辑回归公式推导

 

 

 训练、测试过程简述

 

代码实现 

from sklearn.datasets import load_breast_cancer
from sklearn.model_selection import train_test_split
import math
import numpy as np
'''定义sigmoid函数'''
def sigmoid(x):if x>0:return 1.0/(1.0+np.exp(-x))else:return np.exp(x)/(1.0+np.exp(x))class LogisticRegression:def __init__(self,learning_rate=0.01,num_iterations=1000):self.learning_rate=learning_rateself.num_iterations=num_iterationsself.weights=Noneself.bias=Nonedef fit(self,X,y,weights,bias=0):#num_samples是样本的数量,num_features是样本特征的数量num_samples,num_features=X.shapeself.weights=weightsself.bias=biasfor _ in range(self.num_iterations):y_pred=[]for x in X:dot=np.dot(x, self.weights)linear_model = dot + self.biasy_pred.append(sigmoid(linear_model))y_pred=np.array(y_pred)dw = (1 / num_samples) * np.dot(X.T, (y_pred - y))db = (1 / num_samples) * np.sum(y_pred - y)self.weights -= self.learning_rate * dwself.bias -= self.learning_rate * dbdef predict_prob(self, X):y_pred = []for x in X:dot = np.dot(x, self.weights)linear_model = dot + self.biasy_pred.append(sigmoid(linear_model))y_pred = np.array(y_pred)return y_preddef predict(self, X, threshold=0.5):y_pred_prob = self.predict_prob(X)y_pred = np.zeros_like(y_pred_prob)y_pred[y_pred_prob >= threshold] = 1return y_preddef calculate_accuracy(self,y_pred,y_test):sum=0for p,t in zip(y_pred,y_test):if p==t:sum+=1return float(sum)/float(len(y_pred))if __name__ == "__main__":l=LogisticRegression()breast_cancer = load_breast_cancer()X = breast_cancer.datay = breast_cancer.targetX_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2, random_state=1)num_samples, num_features = X.shape#w = np.ones(num_features)w = np.zeros(num_features)l.fit(X_train,y_train,w)y_pred=l.predict(X_test)print(y_pred)print(y_test)print("准确率:",l.calculate_accuracy(y_pred,y_test))

 

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com