利用torch.distributions生成一些满足不同分布的随机数

利用torch.distributions生成一些满足不同分布的随机数

# 导入工具包
import torch.distributions.log_normal as log_normal
import torch.distributions.normal as normal
import torch.distributions.uniform as uniform
import torch.distributions.bernoulli as bernoulli
import matplotlib.pyplot as plt
# 生成平均值为0.5,标准差为0.25的对数正态分布随机数
log_nor_data = log_normal.LogNormal(torch.tensor([np.log(0.5)]),0.25)
print(type(log_nor_data))

# 利用flatten()对多维数组进行降维
log_nor_data = log_nor_data.sample(sample_shape=(1000,1)).flatten() 

# 画出log_nor_data的频率分布直方图
plt.hist(log_nor_data)
plt.xlabel('log_nor_data intervel')
plt.ylabel('log_nor_data frequency')
plt.show()

利用torch.distributions生成一些满足不同分布的随机数_第1张图片

# 生成平均值为0.5,标准差为0.25的正态分布随机数
nor_data = normal.Normal(torch.tensor([0.5]),0.25)
print(type(nor_data))

# 利用flatten()对多维数组进行降维
nor_data = nor_data.sample(sample_shape=(1000,1)).flatten() 

# 画出nor_data的频率分布直方图
plt.hist(nor_data)
plt.xlabel('nor_data intervel')
plt.ylabel('nor_data frequency')
plt.show()

利用torch.distributions生成一些满足不同分布的随机数_第2张图片

# 生成取值区间为[0,1]的均匀分布随机数
uni_data = uniform.Uniform(0,1)
print(type(uni_data))
# 利用flatten()对多维数组进行降维
uni_data = uni_data.sample(sample_shape=(1000,1)).flatten() 

# 画出uni_data的频率分布直方图
plt.hist(uni_data)
plt.xlabel('uni_data intervel')
plt.ylabel('uni_data frequency')
plt.show()

利用torch.distributions生成一些满足不同分布的随机数_第3张图片

# 生成一组满足伯努力分布的随机数,且满足出现1的概率为80%,出现0的概率为20%
ber_data = bernoulli.Bernoulli(0.8)
print(type(ber_data))
# 利用flatten()对多维数组进行降维
ber_data = ber_data.sample(sample_shape=(1000,1)).flatten() 

# 画出ber_data的频率分布直方图
plt.hist(ber_data)
plt.xlabel('ber_data intervel')
plt.ylabel('ber_data frequency')
plt.show()

利用torch.distributions生成一些满足不同分布的随机数_第4张图片

你可能感兴趣的:(pytorch,python)