pytorch基本运算-torch.normal()函数生成的随机数据添加噪声

【1】引言

前序学习进程中,已经学习了https://blog.csdn.net/weixin_44855046/article/details/148383432?spm=1001.2014.3001.5502,掌握了一些基本运算方法。

此外也学习了使用PyTorch模块的normal()函数绘制正态分布函数图,掌握了torch.normal()函数生成正态分布随机数的基本技巧。

今天的学习任务就是将两种计算方法结合起来,顺路学习一个强大的新函数torch.matmul()。

【2】矩阵运算

前序学习已经知道:

  • hadamard积是元素对位相乘,用"*"连接张量
  • 点积是元素对位相乘后再求和,用"torch.sum(*)"连接张量,
  • 矩阵乘法是第一个矩阵的第i行与第二个矩阵第j列相乘的效果,用"torch.mm()"连接矩阵,就是大家所熟悉的线性代数中得矩阵乘法,
  • torch.normal()函数生成正态分布随机数。

然后我们尝试写一段代码:

python 复制代码
# 引入模块
import matplotlib.pyplot as plt
import torch
from matplotlib.pyplot import subplots
from sympy.abc import alpha

# 定义随机数数量
n_features=3000
# 生成随机数
w=torch.tensor([1,2]).float()
print(len(w))
x=torch.normal(0,1,(n_features,len(w)))
n=torch.normal(0,0.01,(n_features,))

这段代码的作用是,生成一不同的随机数,这里取len(w)有一个小细节:

当w是1行多列的数据形式时,len(w)=列数;当w是多行多列的数据形式时,len(w)=行数。

此时就会输出不同维度数的x,n是最为常规的正态分布随机数,可以理解为一个行向量。

然后展开计算:

python 复制代码
# 随机数计算
c=2*x
d=torch.matmul(x,w)+n
print('d=',d)

这里使用了torch.matmul(x,w)函数,之所以说torch.matmul(x,w)函数很强大,是因为这个函数可以自动根据x和w的维度自行选择计算方法:

如果两个二维张量满足常规矩阵计算方法的维度,它们就会按照常规矩阵乘法的计算法则计算;

如果两个二维张量不满足常规矩阵计算方法的维度,它们会先自动广播,然后按照常规矩阵乘法的计算法则计算;

如果两个一维张量相乘,它们会按照元素对位相乘后叠加,类似于"torch.sum(*);

其他的暂时不学,用到了再说,总之就是很灵活。

这里定义的x张量的列数和w的行数相等,每行数据是[x1,x2],所以会按照每行数据x1w1+x2w2+n的方式计算。

然后输出图像就可以:

python 复制代码
# 绘制综合效果
fig,ax=subplots(3,1)
ax[0].scatter(x[:,(0)],d.flatten())
ax[1].hist(d.flatten(),bins=50,color='blue',alpha=0.5)
ax[2].plot(x[:,(1)],d.flatten(),color='blue',alpha=0.5)
plt.grid(True)
plt.show()

代码运行效果为:

此时的完整代码为:

python 复制代码
# 引入模块
import matplotlib.pyplot as plt
import torch
from matplotlib.pyplot import subplots
from sympy.abc import alpha

# 定义随机数数量
n_features=3000
# 生成随机数
w=torch.tensor([1,2]).float()
print(len(w))
x=torch.normal(0,1,(n_features,len(w)))
n=torch.normal(0,0.01,(n_features,))

# 随机数计算
c=2*x
d=torch.matmul(x,w)+n
print('d=',d)

# 绘制综合效果
fig,ax=subplots(3,1)
ax[0].scatter(x[:,(0)],d.flatten())
ax[1].hist(d.flatten(),bins=50,color='blue',alpha=0.5)
ax[2].plot(x[:,(1)],d.flatten(),color='blue',alpha=0.5)
plt.grid(True)
plt.show()

【3】总结

学习了torch.normal()函数生成的随机数据,再对随机数据使用torch.matmul(x,w)函数进行张量计算和添加噪声的基本操作。

相关推荐
世人万千丶1 天前
Flutter 框架跨平台鸿蒙开发 - 恐惧清单应用
学习·flutter·华为·开源·harmonyos·鸿蒙
财富自由且长命百岁1 天前
移动端老兵转型端侧 AI:第一周,我跑通了 ResNet50 推理
机器学习
美酒没故事°1 天前
Open WebUI安装指南。搭建自己的自托管 AI 平台
人工智能·windows·ai
yuzhuanhei1 天前
Visual Studio 配置C++opencv
c++·学习·visual studio
云烟成雨TD1 天前
Spring AI Alibaba 1.x 系列【6】ReactAgent 同步执行 & 流式执行
java·人工智能·spring
Csvn1 天前
🌟 LangChain 30 天保姆级教程 · Day 13|OutputParser 进阶!让 AI 输出自动转为结构化对象,并支持自动重试!
python·langchain
简简单单做算法1 天前
基于GA遗传优化的Transformer-LSTM网络模型的时间序列预测算法matlab性能仿真
深度学习·matlab·lstm·transformer·时间序列预测·ga遗传优化·电池剩余寿命预测
AI攻城狮1 天前
用 Obsidian CLI + LLM 构建本地 RAG:让你的笔记真正「活」起来
人工智能·云原生·aigc
鸿乃江边鸟1 天前
Nanobot 从onboard启动命令来看个人助理Agent的实现
人工智能·ai
lpfasd1231 天前
基于Cloudflare生态的应用部署与开发全解
人工智能·agent·cloudflare