zoukankan      html  css  js  c++  java
  • Logistic回归和梯度上升 公式推导

    Logistic回归和梯度上升 公式推导

    一、总结

    一句话总结:

    还是得多看视频,这样比较快,如果找不到好视频,还是自己推导比较快

    1、逻辑回归 梯度上升算法迭代更新θ的取值?

    $$ heta _ { j } = heta _ { j } + alpha frac { partial log L ( heta ) ) } { partial heta _ { j } }$$
    $$frac { partial log L ( heta ) ) } { partial heta _ { j } } == sum _ { i = 1 } ^ { m } ( y _ { i } - h _ { heta } ( x ^ { ( i ) } ) ) x ^ { ( i ) }$$
    所以权重的迭代更新式为:$$ heta _ { j } = heta _ { j } + alpha sum _ { i = 1 } ^ { m } ( y _ { i } - h _ { heta } ( x ^ { ( i ) } ) ) x ^ { ( i ) }$$

    2、逻辑回归 批量梯度上升?

    批量梯度上升【每进行一次迭代更新】就会【计算所有样本】,因此得到的模型正确率比较高,但同时计算复杂度高,算法耗时。计算过程如下:
    1.首先根据权重和训练样本计算估计值;2.计算误差;3.迭代更新

    3、随机梯度上升?

    根据样本数量进行迭代,每计算一个样本就进行一次更新,过程如下:(以上步骤更新m次。)
    1.计算x^(i)样本对应的估计值:$$h = left( egin{array} { l l l } { x _ { 1 } ^ { ( i ) } } & { x _ { 2 } ^ { ( i ) } } & { x _ { 3 } ^ { ( i ) } } end{array} ight) left( egin{array} { l } { heta _ { 1 } } \ { heta _ { 2 } } \ { heta _ { 3 } } end{array} ight)$$
    2.计算误差:注意,此处的误差是个数,不再是个向量:$$error= y _ { i } - h ( ext { number } )$$
    3.迭代更新:$$w = w + alpha left( egin{array} { c } { x _ { 1 } ^ { ( i ) } } \ { x _ { 2 } ^ { ( i ) } } \ { x _ { 3 } ^ { ( i ) } } end{array} ight)error$$

    4、随机梯度、批量梯度、改进的随机梯度?

    def stocGradAscent(dataMat,labelMat,alpha = 0.01):   #随机梯度上升
        start_time = time.time()                         #记录程序开始时间
        m,n = dataMat.shape
        weights = np.ones((n,1))                         #分配权值为1
        for i in range(m):
            h = sigmoid(np.dot(dataMat[i],weights).astype('int64')) #注意:这里两个二维数组做内积后得到的dtype是object,需要转换成int64
            error = labelMat[i]-h                        #误差
            weights = weights + alpha*dataMat[i].reshape((3,1))*error #更新权重
        duration = time.time()-start_time
        print('time:',duration)
        return weights
    def gradAscent(dataMat,labelMat,alpha = 0.01,maxstep = 1000): #批量梯度上升
        start_time = time.time()
        m,n = dataMat.shape
        weights = np.ones((n,1))
        for i in range(maxstep):
            h = sigmoid(np.dot(dataMat,weights).astype('int64'))  #这里直接进行矩阵运算
            labelMat = labelMat.reshape((100,1))                  #label本为一维,转成2维
            error = labelMat-h                                    #批量计算误差
            weights = weights + alpha*np.dot(dataMat.T,error)     #更新权重
        duration = time.time()-start_time
        print('time:',duration)
        return weights
    def betterStoGradAscent(dataMat,labelMat,alpha = 0.01,maxstep = 150):
        start_time = time.time()
        m,n = dataMat.shape
        weights = np.ones((n,1))
        for j in range(maxstep):
            for i in range(m):
                alpha = 4/(1+i+j) + 0.01                         #设置更新率随迭代而减小
                h = sigmoid(np.dot(dataMat[i],weights).astype('int64'))
                error = labelMat[i]-h
                weights = weights + alpha*dataMat[i].reshape((3,1))*error
        duration = time.time()-start_time
        print('time:',duration)
        return weights

    二、Logistic回归及梯度上升算法

    转自或参考:Logistic回归及梯度上升算法
    https://blog.csdn.net/u011197534/article/details/53492915

    我的旨在学过的东西不再忘记(主要使用艾宾浩斯遗忘曲线算法及其它智能学习复习算法)的偏公益性质的完全免费的编程视频学习网站: fanrenyi.com;有各种前端、后端、算法、大数据、人工智能等课程。
    博主25岁,前端后端算法大数据人工智能都有兴趣。
    大家有啥都可以加博主联系方式(qq404006308,微信fan404006308)互相交流。工作、生活、心境,可以互相启迪。
    聊技术,交朋友,修心境,qq404006308,微信fan404006308
    26岁,真心找女朋友,非诚勿扰,微信fan404006308,qq404006308
    人工智能群:939687837

    作者相关推荐

  • 相关阅读:
    java 小数点取2位并且四舍五入
    批处理(.bat脚本)基本命令语法
    vue-webpack项目本地开发环境设置代理解决跨域问题
    vue项目引入FastClick组件解决IOS系统下h5页面中的按钮点击延迟,连续点击无反应的问题
    用vue构建多页面应用
    单页面应用和多页面应用对比分析
    html5文件读取+按钮样式重置+文件内容预览
    FileReader读取文件详解
    vue的双向数据绑定实现原理
    译:9.使用Redis进行消息传递
  • 原文地址:https://www.cnblogs.com/Renyi-Fan/p/14111879.html
Copyright © 2011-2022 走看看