函数的随机梯度下降(固定函数与自定义函数随机梯度下降)

1. 基于python实现随机梯度下降

import matplotlib.pyplot as plt
import numpy as np

def f(x):
    """构造函数"""
    #print("calculating f(x) {}".format(x))
    return 0.19 * x*x*x - 1.2 * (x*x) - 6 * x + 2.76
    
def g(x):
    """导数"""
    return 0.57 * x * x - 2.4 * x - 6
    
def autoGD(init_x, lr, thresh, epoch):
    x = init_x
    draw_x,draw_y = [],[]
    for i in range(epoch):
        grad = g(x)
        x = x - lr * grad
        print("Epoch {}: x={:.5f} grad={} y={}".format(i,x,grad,f(x)))
        if i % 200 == 0:
            draw_x.append(x)
            draw_y.append(f(x))
        if abs(grad) < thresh:
            break
    return draw_x,draw_y

1161281-20190611205524761-1216319628.png

1161281-20190611205549225-1108648631.png

2. 根据输入的任意函数进行随机梯度下降

主要是使用sympy库,具体方法请查看sympy库的API

import numpy as np
import matplotlib.pyplot as plt
import sympy
from sympy import S, Symbol

def f(exp,x):
    return exp.evalf(subs={a:x})

def g(exp,x):
    return sympy.diff(exp,a).evalf(subs={a:x})

def sgd(exp,init_x,lr,thresh,epoch):
    x = init_x
    for i in range(epoch):
        grad = g(exp,x)
        x -= grad * lr
        print("[Epoch : {}] x : {} grad : {}".format(i,x,grad))
        if abs(grad) < thresh:
            break
def draw(exp,begin,end):
    x = np.linspace(begin,end,100)
    y = []
    for ix in x:
        iy = exp.evalf(subs={a:ix})
        y.append(iy)
    plt.plot(x,y)
    plt.show()
    
def main():
    a = input('请输入变量:')
    b = input('请使用以上变量进行函数式子的表达:')
    a = Symbol(a)
    exp = S(b)
    draw(exp,-5,5)
    sgd(exp,random.randint(0,10),1e-2,1e-3,200)


if __name__ == "__main__":
    main()

1161281-20190611205556469-817100296.png

转载于:https://www.cnblogs.com/pprp/p/11006001.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值