dnn回归预测_机器学习(回归预测数值型数据)

这篇博客介绍了如何利用DNN进行回归预测,包括数据预处理、加载数据集、定义线性回归函数、局部加权线性回归算法以及岭回归算法,并提供了实际应用示例和交叉验证方法。
摘要由CSDN通过智能技术生成

from numpy import *

def loadDataSet(fileName): #general function to parse tab -delimited floats

numFeat = len(open(fileName).readline().split('\t')) - 1 #get number of fields

dataMat = []; labelMat =[]

fr=open(fileName)for line infr.readlines():

lineArr=[]

curLine= line.strip().split('\t')for i inrange(numFeat):

lineArr.append(float(curLine[i]))

dataMat.append(lineArr)

labelMat.append(float(curLine[-1]))returndataMat,labelMatdefstandRegres(xArr,yArr):

xMat= mat(xArr); yMat =mat(yArr).T

xTx= xMat.T*xMatif linalg.det(xTx) == 0.0:print "This matrix is singular, cannot do inverse"

returnws= xTx.I * (xMat.T*yMat)returnwsdef lwlr(testPoint,xArr,yArr,k=1.0):

xMat= mat(xArr); yMat =mat(yArr).T

m=shape(xMat)[0]

weights=mat(eye((m)))for j in range(m): #next 2 lines create weights matrix

diffMat = testPoint - xMat[j,:] # weights[j,j] = exp(diffMat*diffMat.T/(-2.0*k**2))

xTx= xMat.T * (weights *xMat)if linalg.det(xTx) == 0.0:print "This matrix is singular, cannot do inverse"

returnws= xTx.I * (xMat.T * (weights *yMat))return testPoint *wsdef lwlrTest(testArr,xArr,yArr,k=1.0): #loops over all the data points and applies lwlr to each one

m =shape(testArr)[0]

yHat=zeros(m)for i inrange(m):

yHat[i]=lwlr(testArr[i],xArr,yArr,k)returnyHatdef lwlrTestPlot(xArr,yArr,k=1.0): #same thing as lwlrTest except it sorts X first

yHat

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值