tensorflow生成随机数和张量
上述代码是使用TensorFlow生成随机数和随机排列的示例,核心是利用TensorFlow的tf.random模块实现不同类型的随机操作,具体含义如下:
1. 均匀分布随机数
uniform = tf.random.uniform((2,2), minval=0, maxval=1)
print(uniform)
- 功能:生成一个形状为(2,2)(2行2列)的张量,其中每个元素是**[0, 1)区间内的均匀分布随机数**。
- 参数说明:
- (2,2):指定输出张量的形状;
- minval=0:随机数的最小值(包含);
- maxval=1:随机数的最大值(不包含)。
 
- 特点:区间内每个数值被取到的概率相等,常用于需要均匀采样的场景(如初始化权重、随机坐标生成等)。
2. 正态分布随机数(代码中“正泰分布”为笔误,应为“正态分布”)
normal = tf.random.normal((3,3), mean=0, stddev=1)
print(normal)
- 功能:生成一个形状为(3,3)(3行3列)的张量,其中每个元素是符合正态分布(高斯分布)的随机数。
- 参数说明:
- (3,3):指定输出张量的形状;
- mean=0:正态分布的均值(中心位置);
- stddev=1:正态分布的标准差(离散程度)。
 
- 特点:数值集中在均值附近,越偏离均值的概率越低,是深度学习中权重初始化的常用方式(如正态分布初始化)。
3. 随机排列
shuffled = tf.random.shuffle(tf.constant([1,2,3,4,5]))
print(shuffled)
- 功能:对输入的一维张量(此处为[1,2,3,4,5])进行随机打乱顺序,生成一个新的张量。
- 特点:原始元素的位置被随机重排,但元素本身不变,常用于数据打乱(如训练前打乱样本顺序,避免模型学习到数据的顺序依赖)。
为什么能生成随机数?
TensorFlow的tf.random模块基于伪随机数生成器(PRNG) 实现:
- 生成器通过一个“种子(seed)”初始化,种子确定后,生成的随机数序列是固定的(可复现);
- 若未指定种子,系统会自动用当前时间等动态值作为种子,确保每次运行生成不同的随机数;
- 均匀分布和正态分布是两种最常用的概率分布,TensorFlow通过数学算法模拟这两种分布的随机采样过程,从而生成符合分布特征的随机数。
这些随机操作在机器学习中应用广泛,例如数据增强、参数初始化、随机正则化(如Dropout)等场景。
