首页 > 编程语言 >Python小练习:优化器torch.optim的使用

Python小练习:优化器torch.optim的使用

时间:2023-03-29 11:24:16浏览次数:53  
标签:loss 函数 Python 梯度 torch 损失 data optim 数据

Python小练习:优化器torch.optim的使用

作者:凯鲁嘎吉 - 博客园 http://www.cnblogs.com/kailugaji/

本文主要介绍Pytorch中优化器的使用方法,了解optimizer.zero_grad()、loss.backward()以及optimizer.step()函数的用法。

问题陈述:假设最小化目标函数为$L = \sum\nolimits_{i = 1}^N {x_i^2} $。给定初始值$\left[ {x_1^{(0)},x_2^{(0)}} \right] = [5,{\rm{ }}10]$,求最优解$\hat x = \arg \min L$。

1. optim_test.py

 1 # -*- coding: utf-8 -*-
 2 # Author:凯鲁嘎吉 Coral Gajic
 3 # https://www.cnblogs.com/kailugaji/
 4 # Python小练习:优化器torch.optim的使用
 5 # 假设损失函数为loss = ∑(x^2),给定初始x(0),目的是找到最优的x,使得loss最小化
 6 # 以2维数据为例,loss = x1^2 + x2^2
 7 # loss对x1的偏导为2 * x1,loss对x2的偏导为2 * x2
 8 '''
 9 部分参考:
10     https://www.cnblogs.com/zhouyang209117/p/16048331.html
11 '''
12 import torch
13 import torch.optim as optim
14 import numpy as np
15 import matplotlib.pyplot as plt
16 plt.rc('font',family='Times New Roman')
17 
18 # 方法一:
19 # 自己实现的优化
20 rate = 0.1 # 学习率
21 iteration = 30 # 迭代次数
22 num = 3
23 data = np.array([5.0, 10.0]) # 给定初始数据x(0)
24 for i in range(iteration):
25     loss = (data ** 2).sum(axis = 0) # 优化目标:最小化loss = x1^2 + x2^2
26     my_grad = 2 * data # 梯度d(loss)/dx:2 * x1, 2 * x2
27     print('%d.' %(i+1),
28           '数据:', np.around(data, num),
29           '\t损失函数:', np.around(loss, num),
30           '\t梯度:', np.around(my_grad, num)
31           )
32     data -= my_grad * rate # 优化更新:x = x - learning_rate * (d(loss)/dx)
33 
34 print('----------------------------------------------------------------')
35 # 方法二:
36 # pytorch自带的优化器
37 data = np.array([5.0, 10.0]) # 给定初始数据x(0)
38 data = torch.tensor(data, requires_grad=True) # 需要求梯度
39 optimizer = optim.SGD([data], lr = rate) # 优化器:随机梯度下降
40 plot_loss = []
41 for i in range(iteration):
42     optimizer.zero_grad() # 清空先前的梯度
43     loss = (data ** 2).sum() # 优化目标:最小化loss = x1^2 + x2^2
44     print('%d.' %(i+1),
45           '数据:', np.around(data.detach().numpy(), num),
46           '\t损失函数:', np.around(loss.item(), num),
47           end=' '
48           )
49     loss.backward() # 计算当前梯度d(loss)/dx = 2 * x,并反向传播
50     print('\t梯度:', np.around(data.grad.detach().numpy(), num)) # 打印梯度
51     optimizer.step() # 优化更新:x = x - learning_rate * (d(loss)/dx)
52     plot_loss.append([i+1, loss.item()]) # 保存每次迭代的loss
53 
54 plot_loss = np.array(plot_loss) # 将list转换成numpy
55 # --------------------画Loss曲线图------------------------
56 plt.plot(plot_loss[:, 0], plot_loss[:, 1], color = 'red', ls = '-')
57 plt.xlabel('Iteration')
58 plt.ylabel('Loss')
59 plt.tight_layout()
60 plt.savefig('Loss.png', bbox_inches='tight', dpi=500)
61 plt.show()

2. 结果

D:\ProgramData\Anaconda3\python.exe "D:/Python code/2023.3 exercise/optimizer/optim_test.py"
1. 数据: [ 5. 10.]     损失函数: 125.0     梯度: [10. 20.]
2. 数据: [4. 8.]     损失函数: 80.0     梯度: [ 8. 16.]
3. 数据: [3.2 6.4]     损失函数: 51.2     梯度: [ 6.4 12.8]
4. 数据: [2.56 5.12]     损失函数: 32.768     梯度: [ 5.12 10.24]
5. 数据: [2.048 4.096]     损失函数: 20.972     梯度: [4.096 8.192]
6. 数据: [1.638 3.277]     损失函数: 13.422     梯度: [3.277 6.554]
7. 数据: [1.311 2.621]     损失函数: 8.59     梯度: [2.621 5.243]
8. 数据: [1.049 2.097]     损失函数: 5.498     梯度: [2.097 4.194]
9. 数据: [0.839 1.678]     损失函数: 3.518     梯度: [1.678 3.355]
10. 数据: [0.671 1.342]     损失函数: 2.252     梯度: [1.342 2.684]
11. 数据: [0.537 1.074]     损失函数: 1.441     梯度: [1.074 2.147]
12. 数据: [0.429 0.859]     损失函数: 0.922     梯度: [0.859 1.718]
13. 数据: [0.344 0.687]     损失函数: 0.59     梯度: [0.687 1.374]
14. 数据: [0.275 0.55 ]     损失函数: 0.378     梯度: [0.55 1.1 ]
15. 数据: [0.22 0.44]     损失函数: 0.242     梯度: [0.44 0.88]
16. 数据: [0.176 0.352]     损失函数: 0.155     梯度: [0.352 0.704]
17. 数据: [0.141 0.281]     损失函数: 0.099     梯度: [0.281 0.563]
18. 数据: [0.113 0.225]     损失函数: 0.063     梯度: [0.225 0.45 ]
19. 数据: [0.09 0.18]     损失函数: 0.041     梯度: [0.18 0.36]
20. 数据: [0.072 0.144]     损失函数: 0.026     梯度: [0.144 0.288]
21. 数据: [0.058 0.115]     损失函数: 0.017     梯度: [0.115 0.231]
22. 数据: [0.046 0.092]     损失函数: 0.011     梯度: [0.092 0.184]
23. 数据: [0.037 0.074]     损失函数: 0.007     梯度: [0.074 0.148]
24. 数据: [0.03  0.059]     损失函数: 0.004     梯度: [0.059 0.118]
25. 数据: [0.024 0.047]     损失函数: 0.003     梯度: [0.047 0.094]
26. 数据: [0.019 0.038]     损失函数: 0.002     梯度: [0.038 0.076]
27. 数据: [0.015 0.03 ]     损失函数: 0.001     梯度: [0.03 0.06]
28. 数据: [0.012 0.024]     损失函数: 0.001     梯度: [0.024 0.048]
29. 数据: [0.01  0.019]     损失函数: 0.0     梯度: [0.019 0.039]
30. 数据: [0.008 0.015]     损失函数: 0.0     梯度: [0.015 0.031]
----------------------------------------------------------------
1. 数据: [ 5. 10.]     损失函数: 125.0     梯度: [10. 20.]
2. 数据: [4. 8.]     损失函数: 80.0     梯度: [ 8. 16.]
3. 数据: [3.2 6.4]     损失函数: 51.2     梯度: [ 6.4 12.8]
4. 数据: [2.56 5.12]     损失函数: 32.768     梯度: [ 5.12 10.24]
5. 数据: [2.048 4.096]     损失函数: 20.972     梯度: [4.096 8.192]
6. 数据: [1.638 3.277]     损失函数: 13.422     梯度: [3.277 6.554]
7. 数据: [1.311 2.621]     损失函数: 8.59     梯度: [2.621 5.243]
8. 数据: [1.049 2.097]     损失函数: 5.498     梯度: [2.097 4.194]
9. 数据: [0.839 1.678]     损失函数: 3.518     梯度: [1.678 3.355]
10. 数据: [0.671 1.342]     损失函数: 2.252     梯度: [1.342 2.684]
11. 数据: [0.537 1.074]     损失函数: 1.441     梯度: [1.074 2.147]
12. 数据: [0.429 0.859]     损失函数: 0.922     梯度: [0.859 1.718]
13. 数据: [0.344 0.687]     损失函数: 0.59     梯度: [0.687 1.374]
14. 数据: [0.275 0.55 ]     损失函数: 0.378     梯度: [0.55 1.1 ]
15. 数据: [0.22 0.44]     损失函数: 0.242     梯度: [0.44 0.88]
16. 数据: [0.176 0.352]     损失函数: 0.155     梯度: [0.352 0.704]
17. 数据: [0.141 0.281]     损失函数: 0.099     梯度: [0.281 0.563]
18. 数据: [0.113 0.225]     损失函数: 0.063     梯度: [0.225 0.45 ]
19. 数据: [0.09 0.18]     损失函数: 0.041     梯度: [0.18 0.36]
20. 数据: [0.072 0.144]     损失函数: 0.026     梯度: [0.144 0.288]
21. 数据: [0.058 0.115]     损失函数: 0.017     梯度: [0.115 0.231]
22. 数据: [0.046 0.092]     损失函数: 0.011     梯度: [0.092 0.184]
23. 数据: [0.037 0.074]     损失函数: 0.007     梯度: [0.074 0.148]
24. 数据: [0.03  0.059]     损失函数: 0.004     梯度: [0.059 0.118]
25. 数据: [0.024 0.047]     损失函数: 0.003     梯度: [0.047 0.094]
26. 数据: [0.019 0.038]     损失函数: 0.002     梯度: [0.038 0.076]
27. 数据: [0.015 0.03 ]     损失函数: 0.001     梯度: [0.03 0.06]
28. 数据: [0.012 0.024]     损失函数: 0.001     梯度: [0.024 0.048]
29. 数据: [0.01  0.019]     损失函数: 0.0     梯度: [0.019 0.039]
30. 数据: [0.008 0.015]     损失函数: 0.0     梯度: [0.015 0.031]

Process finished with exit code 0

标签:loss,函数,Python,梯度,torch,损失,data,optim,数据
From: https://www.cnblogs.com/kailugaji/p/17268214.html

相关文章

  • python代码-基于深度强化学习的微能源网能量管理与优化策略研究
    python代码-基于深度强化学习的微能源网能量管理与优化策略研究关键词:微能源网;能量管理;深度强化学习;Q-learning;DQN内容::面向多种可再生能源接入的微能源网,提出一种基于深......
  • Python爬虫基础总结
    StatsPack是9i使用的性能分析工具,如果建立数据库的时候没有,可以手动创建。新建perfstat表空间createtablespacePERFSTATLOGGINGDATAFILE'/oradata/mescp/perfstat01.d......
  • Python自动化必不可少的测试框架 — pytest
    每天进步一点点,关注我们哦,每天分享测试技术文章本文章出自【码同学软件测试】码同学公众号:自动化软件测试,领取资料可加:Matongxue_8码同学抖音号:小码哥聊软件测试​Pyth......
  • python 路径拼接
     os.path.join()函数:连接两个或更多的路径名组件如果有一个组件是一个绝对路径,则在它之前的所有组件均会被舍弃如果最后一个组件为空,则生成的路径以一个\ 分隔......
  • Python 中 is 和 == 的区别
      is和==的区别相信学过Python小伙伴们都知道is和==都是用来比较Python对象的,但是区别就是is比较需要对象的值和内存地址都相等==比较只需要对象的......
  • python - pdf简单操作
    1.安装PyPDF2pip3installPyPDF22.分割fromPyPDF2importPdfReader,PdfWriterfile=input()pdf_reader=PdfReader(file)foriinrange(len(pdf_reader.pa......
  • python中fetchone()和fetchall()
    *fetchone():返回单个的元组,也就是一条记录(row),如果没有结果,则返回Nonecu.execute("selectuser,passwordfromuserwhereuser='%s'"%name)arr=cur.fetch......
  • python中的while True
    建立一个用户登录系统,用户输入用户名和密码,如果正确就可以进入系统。1、我自己最开始的写法:1d={}#数据库字典,所有用户的用户名密码存储在此25name=......
  • PromptPerfect:prompt optimizer for LLMs LMs and LMOps
    1.IntroduceWelcometoPromptPerfect(完美提示),acutting-edgepromptoptimizerdesignedforlargelanguagemodels(LLMs),largemodels(LMs)andLMOps.Promp......
  • QT调用python打包
    1.参考QT调用python环境,https://www.cnblogs.com/xian-yongchao/p/17238684.html。使用其中的依赖包,如下图所示:   2.加上QT调用python的中间动态库,如下图所示。 ......