栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Python

Python编程实现对率回归(Python缂栫▼瀹炵幇瀵圭巼鍥炲綊,骞剁粰鍑鸿タ鐡滄暟鎹泦R浠g爜)

Python 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Python编程实现对率回归(Python缂栫▼瀹炵幇瀵圭巼鍥炲綊,骞剁粰鍑鸿タ鐡滄暟鎹泦R浠g爜)

根据西瓜的密度,含糖率来判断该瓜是不是好瓜

代码如下:

# coding=UTF-8
from numpy import *
import numpy as np
import matplotlib.pyplot as plt

x=np.array([ [0.697,0.460],[0.774,0.376],[0.634,0.264],[0.608,0.318],[
0.556,0.215],[0.403,0.237],[0.481,0.149],[0.437,0.211],[0.666,0.091],

[0.243,0.267],[0.245,0.057],[0.343,0.099],[0.639,0.161],[0.657,0.198]
,[0.360,0.370],[0.591,0.042],[0.719,0.103]])

y=np.array ([1,1,1,1,1,1,1,1,0,0,0,0,0,0,0,0,0])
#对率回归的实现前期数据处理↓
ones1=np.array ([[1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1]])
ones1=ones1.T
x1=np.concatenate((x,ones1),axis=1)
beta=np.array([ 1,1,1])
n=1000;

def func_sigmod (beta,x0):
   y=math.exp(np.dot (beta,x0))/( 1+math.exp (np.dot(beta, x0)))
   return y

#算法实现↓
for k in range (0,n):
   B1=0
   for j in range (len(x)):
      B1=B1-x1[j,:]*(y[j]-func_sigmod(beta,x1[j,:]))
   B2=0
   for j in range (len(x)) :
      B2=B2+(x1[j,:] **2).sum()*func_sigmod(beta,x1[j,:])*(1-
func_sigmod (beta,x1[j,:]))
   beta=beta-1/B2*B1
print (beta)

f1 = plt.figure(1)
plt.title('watermelon_3a')
plt.xlabel('density')
plt.ylabel('ratio sugar')
plt.scatter(x[y == 1,0],x[y == 1,1], marker ='+', color = 'r',
s = 100,label= 'good')
plt.scatter(x[y == 0,0],x[y == 0,1], marker ='*',color = 'b',
s = 100,label = 'bad')
plt.legend(loc= 'upper right')
plt.show()

如若代码出现numpy不存在的错误,则需要在file settings中的Project:pythonProject1添加matplot和matplotlib两个包,此时便可正常运行

运行结果:

 由图可看出,+为好瓜。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/772859.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号