我有两点要问:
1)
我想了解NumPy的np.random.randn
和PyTorch的{{1}}究竟返回了什么。它们都从具有均值0和std 1的正态分布返回具有随机数的张量,因此是标准正态分布。但是,这与将torch.randn
值放入标准正态分布函数here中并获取其各自的图像值x
不同。 PyTorch和NumPy返回的值看起来不是这样。
对我来说,似乎这些库中的y
和np.random.randn
都从函数中返回torch.randn
的值,而不是我下面计算的图像x
。正确吗?
y
打印normal = np.array([(1/np.sqrt(2*np.pi))*np.exp(-(1/2)*(i**2)) for i in range(-38,39)])
变量会显示类似这样的内容。
normal
2)另外,如果我们问这些库我想要标准正态分布的值矩阵,是否意味着所有行和列都来自同一标准分布?如果我想在每一行进行i.i.d分布,我需要通过array([1.10e-314, 2.12e-298, 1.51e-282, 3.94e-267, 3.79e-252, 1.34e-237,
1.75e-223, 8.36e-210, 1.47e-196, 9.55e-184, 2.28e-171, 2.00e-159,
6.45e-148, 7.65e-137, 3.34e-126, 5.37e-116, 3.17e-106, 6.90e-097,
5.52e-088, 1.62e-079, 1.76e-071, 7.00e-064, 1.03e-056, 5.53e-050,
1.10e-043, 8.00e-038, 2.15e-032, 2.12e-027, 7.69e-023, 1.03e-018,
5.05e-015, 9.13e-012, 6.08e-009, 1.49e-006, 1.34e-004, 4.43e-003,
5.40e-002, 2.42e-001, 3.99e-001, 2.42e-001, 5.40e-002, 4.43e-003,
1.34e-004, 1.49e-006, 6.08e-009, 9.13e-012, 5.05e-015, 1.03e-018,
7.69e-023, 2.12e-027, 2.15e-032, 8.00e-038, 1.10e-043, 5.53e-050,
1.03e-056, 7.00e-064, 1.76e-071, 1.62e-079, 5.52e-088, 6.90e-097,
3.17e-106, 5.37e-116, 3.34e-126, 7.65e-137, 6.45e-148, 2.00e-159,
2.28e-171, 9.55e-184, 1.47e-196, 8.36e-210, 1.75e-223, 1.34e-237,
3.79e-252, 3.94e-267, 1.51e-282, 2.12e-298, 1.10e-314])
循环为每一行调用np.random.randn
,然后for
进行调用吗?
答案 0 :(得分:0)
1)是的,因为phi(x)的公式给出了采样值x的概率密度,所以它们给了x而不是phi(x)。如果您想知道在间隔[a,b]中获取值的可能性,则需要对a和b之间的phi(x)进行积分。直观地看一下函数phi(x),您会发现比零附近的值更容易得到零附近的值。 一种简单的查看方法是查看采样值的直方图。
import numpy as np
import matplotlib.pyplot as plt
samples = np.random.normal(size=[1000])
plt.hist(samples)
2)他们是iid。只需像这样使用2d大小:
samples = np.random.normal(size=[10, 10])