当前位置: 首页 > news >正文

深入解析:python学智能算法(三十九)|使用PyTorch模块的normal()函数绘制正态分布函数图

【1】引言

前序已经学习了使用Numpy和PyTorch模块绘制正态分布函数图的基本技巧,掌握了
p(x)=12πσ2exp(−12σ2(x−μ)2)p(x)=\frac{1}{\sqrt{2\pi\sigma^2}}exp(-\frac{1}{2\sigma^2}(x-\mu)^2)p(x)=2πσ21exp(2σ21(xμ)2)
在PyTorch里面绘制图像的基本技巧。
今天更进一步,使用torch.normal()函数直接绘制正态分布函数图。

【2】torch.normal()函数

【2.1】生成随机数

torch.normal()函数可以直接绘制正态分布函数图。
这个函数的作用是生成符合正态分布的随机数,比如:

# 引入模块 
import torch
# 使用torch.normal()函数生成随机数
x=torch.normal(0,1,(2,3))
print(x)
a=len(x)
print('a=',a)

这个代码运行会生成2行3列的满足均值为0、标准差为1的正态分布随机数。

【2.2】对随机数绘图

torch.normal()函数可以直接获得正态分布随机数,那数据就可以画出图像。
这个图像的最佳画法就是使用hist()函数来绘制概率分布图,随机数如何分布的情况一目了然。
为了做对比,我们也可以自己按照上述正态分布函数式来自定义图像。
这里给出代码:

import torch
import matplotlib.pyplot as plt
import numpy as np
# 生成不同样本量的数据
sample_sizes = [100, 1000, 10000]  # 三种样本量
# 生成x轴数据(用于理论曲线)
x_range = np.arange(-5, 5,0.01)
datasets = [torch.normal(0, 1, (size,)).numpy() for size in sample_sizes]
# 定义正态分布概率密度函数(理论曲线)
def normal_pdf(x, mean=0, std=1):
return (1 / (std * np.sqrt(2 * np.pi))) * np.exp(-0.5 * ((x - mean) / std) ** 2)
# 计算理论曲线值
y_theoretical = normal_pdf(x_range)
# 创建画布和子图
fig, ax = plt.subplots(1, 3)
for i in range(3):
ax[i].hist(datasets[i],bins=int(sample_sizes[i]*0.3), density=True, alpha=0.5, color='skyblue', edgecolor='black')
# 叠加理论正态分布曲线
ax[i].plot(x_range, y_theoretical, 'r-', linewidth=2, label='理论分布')
print(len(datasets[i]))
if i == 0:  # 仅第一个子图显示y轴标签(避免重复)
ax[i].set_ylabel('torch.normal', fontsize=12)
if i == 1:  # 仅第二个子图显示x轴标签(避免重复)
ax[1].set_xlabel('x', fontsize=12)
plt.show()

代码给出了三个数量级的随机数概率分布直方图,第一个有100个数据,第二个有1000个数据,第三个有10000个数据。数据越多,理论上正态分布的效果越明显,实际的图像效果为:
在这里插入图片描述
虽然图像在高度上发生了变化,但显然数据越多,直方图和曲线图拟合得更好。

【3】细节

需要注意的是,图像越来越黑,是因为hist()函数绘制了很多边框,边框的颜色edgecolor是黑色的。bins=int(sample_sizes[i]*0.3)表明数据越多,边框越多,所以黑色越来越多。

ax[i].hist(datasets[i],bins=int(sample_sizes[i]*0.3), density=True, alpha=0.5, color=‘skyblue’, edgecolor=‘black’)

如果想让图像的颜色一致,最佳办法就是统一所有的边框数量,比如限制边框数量为30,此时的图像效果为:
在这里插入图片描述

【4】说明

虽然上述代码简洁的表明了torch.normal()函数可以生成好用的正态分布随机数,但是这个代码显然写起来要比numpy模块复杂一些。
并且当前只对torch.normal(0, 1, (size,))画了图,还没有开展更复杂的图像绘制。,学习的路还长。

【5】总结

学习了使用PyTorch模块的normal()函数绘制正态分布函数图的基本方法。

http://www.rkmt.cn/news/14940.html

相关文章:

  • 2025污水处理设备厂家 TOP 企业品牌推荐排行榜,一体化,生活,工业,养殖,医疗,农村,学校,餐厨,隧洞,高速污水处理设备公司推荐!
  • 详细介绍:告别“下次注意”,用这套结构化事故复盘方案就对了
  • 关于树状数组的一些东西
  • [问题记录] vmagent 增加 aggregation 表达式后,CPU 上升 2.43 倍, 内存上升 3.82 倍
  • CF1081F Tricky Interactor
  • JAVA SE 基础语法 —— A / 初识 - 指南
  • 2025机械加工供货厂家权威口碑排行:实力与服务深度解析!
  • 2025七水硫酸锌厂家权威推荐榜:优质供应与专业定制首选
  • CustomKD论文阅读 - 实践
  • 2025 年水质测定仪厂家 TOP 企业品牌推荐排行榜,多参数,便携式,cod 快速,台式,污水,自来水,养殖,便携式总磷总氮,余氯总氯,废水水质测定仪公司推荐
  • AI+Decodo:构建智能电商价格监控系统的完整实战指南 - 实践
  • 2025公考培训机构权威推荐榜:实力师资与高效备考口碑之选
  • Mapper.xml中SQL语句的用法示例
  • MX-J24 题解(T1 - T4) - 指南
  • 2025球墨铸铁管厂家TOP企业品牌推荐排行榜,k9球墨铸铁管,c25球墨铸铁管,c30球墨铸铁管,c级国标离心球墨铸铁管,c级供水球墨铸铁管,dn900球墨铸铁管公司推荐!
  • 10/2
  • 使用 VictoriaLogs 存储和查询服务器日志
  • 详细介绍:Git 基础 - 查看提交历史
  • 2025年光亮剂源头厂家最新推荐榜单:聚焦实力厂商,为电镀企业精选高口碑品牌
  • 详细介绍:机器学习+数字孪生:从诊断到自主决策的跨越
  • vue3 知识点快速入门整理
  • 红色面纱
  • 创建 SQL Server 数据库
  • JVM的内存分配策略有哪些?
  • 51单片机-实现DAC(PWM)数模转换PWM控制呼吸灯、直流电机实验教程 - 教程
  • Elasticsearch集群监控信息(亲测) - 教程
  • 基于Java springboot农村政务服务管理便捷的系统(源码+文档+运行视频+讲解视频)
  • ESP32与SPI网口芯片DM9051ANX模块硬件引脚接法与ESP-IDF设定参数
  • 完整教程:Nginx反向代理核心原理揭秘
  • 详细介绍:五大关系数据库(sqlserver、mysql、oracle、pgsql、sqlite)的对象名称和转义字符