李宏毅 机器学习课程 Gradient Desent Demo 代码与实现

 
  

   
   
 
  

   
   

    
    
  1. import np
  2. # import plot
  3. # import matplotlib
  4. import matplotlib.pyplot as plt # plt
  5. # 李宏毅原代码没有加载相关参数,以上为我自行加载的。
  6. x_data = [ 338, 333, 328, 207, 226, 25, 179, 60, 208, 606]
  7. y_data = [ 640, 633, 619, 393, 428, 27, 193, 66, 226, 1591]
  8. x = np.arange( -200, -100, 1) # bias
  9. y = np.arange( -5, 5, 0.1) # weight
  10. Z = np.zeros((len(x), len(y)))
  11. X,Y = np.meshgrid(x, y)
  12. for i in range(len(x)):
  13. for j in range(len(y)):
  14. b = x[i]
  15. w = y[j]
  16. Z[j][i] = 0
  17. for n in range(len(x_data)):
  18. Z[j][i] = Z[j][i] + (y_data[n] - b - w*x_data[n])** 2
  19. Z[j][i] = Z[j][i]/len(x_data)
  20. # yadata = b + w*xdata
  21. b = -120 # intial b
  22. w = -4 # intial w
  23. lr = 0.0000001 # learning rate
  24. iteration = 100000
  25. # store initial values for plotting
  26. b_history = [b]
  27. w_history = [w]
  28. # iterations
  29. for i in range(iteration):
  30. b_grad = 0.0
  31. w_grad = 0.0
  32. for n in range(len(x_data)):
  33. b_grad = b_grad - 2.0*(y_data[n] - b - w*x_data[n])* 1.0
  34. w_grad = w_grad - 2.0*(y_data[n] - b - w*x_data[n])*x_data[n]
  35. # update parameters
  36. b = b - lr*b_grad
  37. w = w - lr*w_grad
  38. # store parameters for plotting
  39. b_history.append(b)
  40. w_history.append(w)
  41. # plot the figure
  42. plt.contourf(x, y, Z, 50, alpha= 0.5, cmap=plt.get_cmap( 'jet'))
  43. plt.plot([ -188.4], [ 2.67], 'x', ms= 6, marker= 6, color= 'orange')
  44. # 李宏毅课程原代码为markeredeweight=3,无法运行,改为了marker=3。
  45. # ms和marker分别代表指定点的长度和宽度。
  46. plt.plot(b_history, w_history, 'o-', ms= 3, lw= 1.5, color= 'black')
  47. plt.xlim( -200, -100)
  48. plt.ylim( -5, 5)
  49. plt.xlabel( r'$b$', fontsize= 16)
  50. plt.ylabel( r'$w$', fontsize= 16)
  51. plt.show()


 对 b 和 w 给予克制化的Learning Rate:

学习率 lr 改为 1,lr_b = 0 / lr_w = 0 ;

对b、w定制化的学习率lr,采用Adagard

b = b - lr / np.sqrt(lr_b) * b_grad  ;  w = w - lr / np.sqrt(lr_w) * w_grad


   
   
  1. import np
  2. # import plot
  3. # import matplotlib
  4. import matplotlib.pyplot as plt # plt
  5. # 李宏毅原代码没有加载相关参数,以上为我自行加载的。
  6. x_data = [ 338, 333, 328, 207, 226, 25, 179, 60, 208, 606]
  7. y_data = [ 640, 633, 619, 393, 428, 27, 193, 66, 226, 1591]
  8. x = np.arange( -200, -100, 1) # bias
  9. y = np.arange( -5, 5, 0.1) # weight
  10. Z = np.zeros((len(x), len(y)))
  11. X,Y = np.meshgrid(x, y)
  12. for i in range(len(x)):
  13. for j in range(len(y)):
  14. b = x[i]
  15. w = y[j]
  16. Z[j][i] = 0
  17. for n in range(len(x_data)):
  18. Z[j][i] = Z[j][i] + (y_data[n] - b - w*x_data[n])** 2
  19. Z[j][i] = Z[j][i]/len(x_data)
  20. # yadata = b + w*xdata
  21. b = -120 # intial b
  22. w = -4 # intial w
  23. lr = 1 # learning rate,通过调节不同的lr参数可以获得不同的曲线长度
  24. iteration = 100000
  25. # store initial values for plotting
  26. b_history = [b]
  27. w_history = [w]
  28. # 对b、w定制化的学习率lr
  29. lr_b = 0
  30. lr_w = 0
  31. # iterations
  32. for i in range(iteration):
  33. b_grad = 0.0
  34. w_grad = 0.0
  35. for n in range(len(x_data)):
  36. b_grad = b_grad - 2.0*(y_data[n] - b - w*x_data[n])* 1.0
  37. w_grad = w_grad - 2.0*(y_data[n] - b - w*x_data[n])*x_data[n]
  38. # 对b、w定制化的学习率lr
  39. lr_b = lr_b + b_grad ** 2
  40. lr_w = lr_w + w_grad ** 2
  41. # update parameters
  42. # b = b - lr*b_grad
  43. # w = w - lr*w_grad
  44. # update parameters
  45. # 对b、w定制化的学习率lr,采用Adagard
  46. b = b - lr / np.sqrt(lr_b) * b_grad
  47. w = w - lr / np.sqrt(lr_w) * w_grad
  48. # store parameters for plotting
  49. b_history.append(b)
  50. w_history.append(w)
  51. # plot the figure
  52. plt.contourf(x, y, Z, 50, alpha= 0.5, cmap=plt.get_cmap( 'jet'))
  53. plt.plot([ -188.4], [ 2.67], 'x', ms= 6, marker= 6, color= 'orange')
  54. # 李宏毅课程原代码为markeredeweight=3,无法运行,改为了marker=3。
  55. # ms和marker分别代表指定点的长度和宽度,
  56. plt.plot(b_history, w_history, 'o-', ms= 3, lw= 1.5, color= 'black')
  57. plt.xlim( -200, -100)
  58. plt.ylim( -5, 5)
  59. plt.xlabel( r'$b$', fontsize= 16)
  60. plt.ylabel( r'$w$', fontsize= 16)
  61. plt.show()

 经过100000次迭代,找到了最优解。


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值