博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
logistic 回归(线性和非线性)
阅读量:6449 次
发布时间:2019-06-23

本文共 5047 字,大约阅读时间需要 16 分钟。

一:线性logistic 回归

代码如下:

import numpy as npimport pandas as pdimport matplotlib.pyplot as pltimport scipy.optimize as optimport seaborn as sns#读取数据集path = 'ex2data1.txt'data = pd.read_csv(path, header=None, names=['Exam 1', 'Exam 2', 'Admitted'])#将正负数据集分开positive = data[data['Admitted'].isin([1])]negative = data[data['Admitted'].isin([0])]'''#查看分布fig, ax = plt.subplots(figsize=(12, 8))ax.scatter(positive['Exam 1'], positive['Exam 2'], s=60, c='b', marker='o', label='Admitted')ax.scatter(negative['Exam 1'], negative['Exam 2'], s=50, c='r', marker='x', label='UnAdmitted')ax.legend()ax.set_xlabel('Exam 1 Score')ax.set_ylabel('Exam 2 Score')plt.show()'''#sigmoid函数实现def sigmoid(h):    return 1 / (1 + np.exp(-h))'''#测试sigmoid函数nums = np.arange(-10, 11, step=1)fig, ax = plt.subplots(figsize=(12, 8))ax.plot(nums, sigmoid(nums), 'k')plt.show()'''#计算损失函数值def cost(theta, X, y):    theta = np.matrix(theta)    X = np.matrix(X)    y = np.matrix(y)    part1 = np.multiply(-y, np.log(sigmoid(X * theta.T)))    part2 = np.multiply((1-y), np.log(1-sigmoid(X * theta.T)))    return np.sum(part1-part2) / len(X)#在原矩阵第1列前加一列全1data.insert(0, 'ones', 1)cols = data.shape[1]X = data.iloc[:, 0:cols-1]y = data.iloc[:, cols-1:cols]X = np.array(X.values)y = np.array(y.values)theta = np.zeros(3) #这里是一个行向量#返回梯度向量,注意是向量def gradient(theta, X, y):    theta = np.matrix(theta)    X = np.matrix(X)    y = np.matrix(y)    parameters = theta.ravel().shape[1]    grad = np.zeros(parameters)    error = sigmoid(X * theta.T) - y    grad = error.T.dot(X)    grad = grad / len(X)    return grad#通过高级算法计算出最好的theta值result = opt.fmin_tnc(func=cost, x0=theta, fprime=gradient, args=(X, y))#print(cost(result[0], X, y))#测试所得theta的性能#计算原数据集的预测情况def predict(theta, X):    theta = np.matrix(theta)    X = np.matrix(X)    probability = sigmoid(X * theta.T)    return [1 if i > 0.5 else 0 for i in probability]theta_min = result[0]predictions = predict(theta_min, X)correct = [1 if((a == 1 and b == 1) or(a == 0 and b == 0)) else 0 for(a, b) in zip(predictions, y)]accuracy = (sum(map(int, correct)) % len(correct))print('accuracy = {0}%'.format(accuracy))#训练集测试准确度89%# 作图theta_temp = theta_mintheta_temp = theta_temp / theta_temp[2]x = np.arange(130, step=0.1)y = -(theta_temp[0] + theta_temp[1] * x)#画出原点sns.set(context='notebook', style='ticks', font_scale=1.5)sns.lmplot('Exam 1', 'Exam 2', hue='Admitted', data=data,           size=6,           fit_reg=False,           scatter_kws={
"s": 25} )#画出分界线plt.plot(x, y, 'grey')plt.xlim(0, 130)plt.ylim(0, 130)plt.title('Decision Boundary')plt.show()

二:非线性logistic 回归(正则化)

代码如下:

import pandas as pdimport numpy as npimport scipy.optimize as optimport matplotlib.pyplot as pltpath = 'ex2data2.txt'data = pd.read_csv(path, header=None, names=['Test 1', 'Test 2', 'Accepted'])positive = data[data['Accepted'].isin([1])]negative = data[data['Accepted'].isin([0])]'''#显示原始数据的分布fig, ax = plt.subplots(figsize=(12, 8))ax.scatter(positive['Test 1'], positive['Test 2'], s=50, c='b', marker='o', label='Accepted')ax.scatter(negative['Test 1'], negative['Test 2'], s=50, c='r', marker='x', label='Unaccepted')ax.legend() #显示右上角的Accepted 和 Unaccepted标签ax.set_xlabel('Test 1 Score')ax.set_ylabel('Test 2 Score')plt.show()'''degree = 5x1 = data['Test 1']x2 = data['Test 2']#在data的第三列插入一列全1data.insert(3, 'Ones', 1)#创建多项式特征值,最高阶为4for i in range(1, degree):    for j in range(0, i):        data['F' + str(i) + str(j)] = np.power(x1, i-j) * np.power(x2, j)#删除原数据中的test 1和test 2两列data.drop('Test 1', axis=1, inplace=True)data.drop('Test 2', axis=1, inplace=True)#sigmoid函数实现def sigmoid(h):    return 1 / (1 + np.exp(-h))def cost(theta, X, y, learnRate):    theta = np.matrix(theta)    X = np.matrix(X)    y = np.matrix(y)    first = np.multiply(-y, np.log(sigmoid(X * theta.T)))    second = np.multiply((1 - y), np.log(1 - sigmoid(X * theta.T)))    reg = (learnRate / (2 * len(X))) * np.sum(np.power(theta[:, 1:theta.shape[1]], 2))    return np.sum(first - second) / len(X) + reglearnRate = 1cols = data.shape[1]X = data.iloc[:, 1:cols]y = data.iloc[:, 0:1]X = np.array(X)y = np.array(y)theta = np.zeros(X.shape[1])#计算原数据集的预测情况def predict(theta, X):    theta = np.matrix(theta)    X = np.matrix(X)    probability = sigmoid(X * theta.T)    return [1 if i > 0.5 else 0 for i in probability]def gradientReg(theta, X, y, learnRate):    theta = np.matrix(theta)    X = np.matrix(X)    y = np.matrix(y)    paramates = int(theta.ravel().shape[1])    grad = np.zeros(paramates)    grad = (sigmoid(X * theta.T) - y).T * X / len(X) + (learnRate / len(X)) * theta[:, i]    grad[0] = grad[0] - (learnRate / len(X)) * theta[:, i]    return gradresult = opt.fmin_tnc(func=cost, x0=theta, fprime=gradientReg, args=(X, y, learnRate))print(result)theta_min = np.matrix(result[0])predictions = predict(theta_min, X)correct = [1 if((a == 1 and b == 1) or(a == 0 and b == 0)) else 0 for(a, b) in zip(predictions, y)]accuracy = (sum(map(int, correct)) % len(correct))print('accuracy = {0}%'.format(accuracy))

 

转载于:https://www.cnblogs.com/qiang-wei/p/9839458.html

你可能感兴趣的文章
Maven多模块项目
查看>>
Oracle、PostgreSQL与Mysql数据写入性能对比
查看>>
整理Java基础知识--选择与判断
查看>>
Linux查看程序端口占用情况
查看>>
jar包冲突案例分析.md
查看>>
控制圈复杂度的9种重构技术总结
查看>>
当软件项目全部能靠自己搞定了,也能接几万元的软件项目时,未必适合创业...
查看>>
数据分析--数字找朋友
查看>>
推荐好用的开源库或软件
查看>>
18年selenium3+python3+unittest自动化测试教程(下)
查看>>
Redis集群中删除/修改节点(master、slave)(实验)
查看>>
memcache数据库和redis数据库的区别(理论)
查看>>
我的友情链接
查看>>
MyBatis+Spring结合
查看>>
shell实例-判断apache是否正常启动
查看>>
SharedPreferences存储复杂对象解决方案
查看>>
Office 365之SkyDrive Pro
查看>>
脑残式网络编程入门(二):我们在读写Socket时,究竟在读写什么?
查看>>
无缝滚动实现原理分析【公告栏】
查看>>
Java Web 高性能开发
查看>>