- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章Python随机数种子(random seed)的使用由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
在科学技术和机器学习等其他算法相关任务中,我们经常需要用到随机数,为了把握随机数的生成特性,从随机数的随机无序中获得确定和秩序。我们可以利用随机数种子(random seed)来实现这一目标,随机数种子,可以使得引入了随机数的整个程序,在多次运行中得到确定的,一致的结果.
很多博文谈到随机数种子,只是简单论及,利用随机数种子,可以每次生成相同的随机数。想真正用好掌握它,对此很容易产生疑惑,生成相同的随机数数怎么个相同法?随机数种子又作何用处?
下面我们从实例中揭开随机数种子的神秘面纱:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
|
import
random
# print(help(random))
def
test_random_seed_in_std_lib(seed
=
0
, cnt
=
3
):
random.seed(seed)
print
(
"test seed: "
, seed)
for
_
in
range
(cnt):
print
(random.random())
print
(random.randint(
0
,
100
))
print
(random.uniform(
1
,
10
))
print
(
'\n'
)
test_random_seed_in_std_lib()
test seed:
0
0.8444218515250481
97
9.01219528753418
0.04048437818077755
65
5.373349269065314
0.9182343317851318
38
9.710199954281542
test_random_seed_in_std_lib()
test seed:
0
0.8444218515250481
97
9.01219528753418
0.04048437818077755
65
5.373349269065314
0.9182343317851318
38
9.710199954281542
test_random_seed_in_std_lib(
99
)
test seed:
99
0.40397807494366633
25
6.39495190686897
0.23026272839629136
17
7.8388969285727015
0.2511510083752201
49
5.777313434770537
|
通过两次运行以上程序,我们得到相同的结果,这说明了以下几点:
以上几点囊括了随机数种子的基本特性,下面我们来对numpy中的随机数种子作进一步的拓展研究.
1
2
3
4
5
6
7
8
9
|
import
numpy as np
def
test_numpy_random_seed(seed
=
0
, cnt
=
3
):
np.random.seed(seed)
print
(
"test numpy seed: "
, seed)
for
_
in
range
(cnt):
print
(np.random.random())
print
(np.random.randn(
1
,
5
))
print
(np.random.uniform(
1
,
10
,
5
))
print
(
'\n'
)
|
多次运行以上的test_numpy_random_seed函数,你可以观察到与使用random模块时相似的情形,进一步验证了我们总结的关于随机数种子的特性.
此外,我们可以对多维随机数组做一些有益的探索:
1
2
3
4
5
6
7
8
9
10
11
12
|
def
test_mult_shape(seed
=
0
):
np.random.seed(seed)
print
(np.random.randn(
1
,
3
))
print
(np.random.randn(
1
,
2
))
np.random.seed(seed)
print
(np.random.randn(
2
,
5
))
test_mult_shape()
[[
1.76405235
0.40015721
0.97873798
]]
[[
2.2408932
1.86755799
]]
[[
1.76405235
0.40015721
0.97873798
2.2408932
1.86755799
]
[
-
0.97727788
0.95008842
-
0.15135721
-
0.10321885
0.4105985
]]
|
运行test_mult_shape函数,我们发现,设定相同的随机数组,两次运行两个一行的多维正态分布的结果,与一次运行两行的多维正态分布的结果的第一行完全相同.
这个结果,说明了对相同类型的随机数分布,形状特征不会影响分布的生成秩序,程序中,np.random.randn(1, 2),这一行不像是第二次运行多维正态分布的随机数组,它"几乎"是后缀于它的前一行一次性生成的.
至此,我们对随机数生成顺序有了初步印象,但是这里的顺序,其实比我们的朴素观察更复杂,我们来进一步考察这一点.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
def
test_numpy_random_seed_order(seed
=
0
):
np.random.seed(seed)
print
(np.random.random())
# print(np.random.randint(1, 10))
print
(np.random.randn(
1
,
5
))
np.random.seed(seed)
print
(np.random.randn(
2
,
5
))
test_numpy_random_seed_order()
0.5488135039273248
[[
0.74159174
1.55291372
-
2.2683282
1.33354538
-
0.84272405
]]
[[
1.76405235
0.40015721
0.97873798
2.2408932
1.86755799
]
[
-
0.97727788
0.95008842
-
0.15135721
-
0.10321885
0.4105985
]]
|
运行以上程序,我们看到,设定了相同的随机数种子,np.random.randn(1, 5)看起来是第一次运行多维正态分布数组,实际上并不是,np.random.randn(2, 5)才是真正的第一次运行多维正态分布随机数组.
这说明,前面的np.random.random()对np.random.randn产生了干扰,使得这次正态分布的随机数组中的任何一个数,都不在np.random.randn(2, 5)中,这样它显示了一种不可把握的随机性.
我们可以把这一点考察得更加深入一点:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
def
test_numpy_random_seed_order_further(seed
=
0
, randint_high
=
10
):
np.random.seed(seed)
print
(np.random.randint(
1
, randint_high))
print
(np.random.randn(
1
,
5
))
np.random.seed(seed)
print
(np.random.randn(
2
,
5
))
test_numpy_random_seed_order_further()
6
[[
0.11849646
0.11396779
0.37025538
1.04053075
-
1.51698273
]]
[[
1.76405235
0.40015721
0.97873798
2.2408932
1.86755799
]
[
-
0.97727788
0.95008842
-
0.15135721
-
0.10321885
0.4105985
]]
test_numpy_random_seed_order_further(randint_high
=
5
)
1
[[
1.12279492
0.30280522
0.07085926
0.07304142
-
1.42232584
]]
[[
1.76405235
0.40015721
0.97873798
2.2408932
1.86755799
]
[
-
0.97727788
0.95008842
-
0.15135721
-
0.10321885
0.4105985
]]
|
紧接上面对随机数干扰项对考察,我们看到,这次我们改变了干扰项随机数生成器,np.random.randn(1, 5)的生成结果不同于test_numpy_random_seed_order中同一行的运行结果.
另外,两次设置不同的randint的右边界,np.random.randn(1, 5)生成的结果也全然不同,这说明了np.random.randint设置不同的参数,即是全然不同的随机数发生器。这一点,也不难在其他类型的随机数分布中得到验证.
到此这篇关于Python随机数种子(random seed)的使用的文章就介绍到这了,更多相关Python随机数种子内容请搜索我以前的文章或继续浏览下面的相关文章希望大家以后多多支持我! 。
原文链接:https://www.cnblogs.com/geeks-reign/p/15060661.html 。
最后此篇关于Python随机数种子(random seed)的使用的文章就讲到这里了,如果你想了解更多关于Python随机数种子(random seed)的使用的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
2017 年 7 月 19 日更新 在这里找到解决方案:https://stackoverflow.com/a/10021912/5729266 如果您不想读到最后,请快速得出结论。 我之前的代码中随
golang 文档说 Seed, unlike the Rand.Seed method, is safe for concurrent use. rand.Seed 实际上是来自math/rand
我正在尝试重现我之前运行的模拟,以便在文本文件中记录当前日期时间的种子,然后使用记录的日期时间种子来获取与之前获得的相同的值 但是,我不确定为什么得出的值与我在之前的模拟中运行的值不相似。 这是我尝试
rake db:seed 每当您修改种子数据时,重新运行种子数据是否会删除现有种子数据并重新创建或仅添加新记录? 最佳答案 当您运行时 rake db:seed , db/seeds.rb 仅包含在
是否可以在 Laravel 5 中使用以下内容为相关表做种? php artisan db:seed 我有两张 table users id first name projects
我正在尝试为一组足球队和足球位置播种,奇怪的是,rails 根本没有这样做。 rake db:seed --trace ** Invoke db:seed (first_time) ** Execut
我正在寻找网络。我发现这个话题https://iamtrask.github.io/2015/07/12/basic-python-network/ 一切顺利,但我无法理解那部分: # seed ra
在Python的numpy库中,np.random.seed方法可以接受两种不同类型的参数:int和array_like[int] . 它们有什么区别?如:np.random.seed(2) 和np.
我正在使用 scikit-learn 和 numpy,我想设置全局种子,以便我的工作可重现。 我应该使用 numpy.random.seed 还是 random.seed? 从评论中的链接,我了解到它
出于某种原因,当我尝试通过 heroku 执行此操作时,我的 db:seed 无法正常工作。当我在本地执行时,它工作正常。 paul@paul-laptop:~/rails_projects/fogl
我正在尝试同步转换我的图像和 mask 标签,但随机增强以不同方式应用于两个生成器(当我将两个图像保存到一个目录时证明)。 我试过了 在我的库堆栈中播种所有生成器 禁用随机播放和多处理 确保图像和蒙版
我想在特定行之后结束set.seed()的范围,以便对其余代码进行真正的随机化处理。这是一个我想让set.seed()用于“ rnorm”(第4行)而不是“ nrow”(第9行)的示例 set.see
想知道你是否可以帮助我: 我有一个名为initializeAll的方法: public final void initializeAll() { //other stuff........ rand
我有一行代码使用高精度时钟的纳秒抓取来为 mersenne twister 伪随机数生成器播种。类似这样的事情: rng.seed(duration_cast(high_resolution_cloc
我正在浏览一些关于 ASP.NET MVC 的教程(here 和 here),并决定自己尝试一些东西。现在,我有三个表,Resume、Descriptions、SubDescriptions。这是三者
我正在使用 random.seed() 来尝试保持 random.sample() 与我从列表中采样更多值相同,并且在某些时候数字会发生变化......我认为那个seed() 函数的目的是保持数字相同
我正在研究中等规模的数据集,比如从具有 100,000 个观察值的大型数据集中采样的 9000 个观察值。 我可以使用以下 set.seed() 函数来保证每次都获得完全相同的子集吗? set.see
我在 Laravel 中有一个 Seeder public function run() { $user = App\Admin::create([ '
在确信学习和使用 Angular.js 后,我打算启动一个具体的 Web UI 应用程序,以便启动经验学习轮。 (该应用程序将是某种个人计划、待办事项列表、提醒、番茄工作法导向等等......) On
在启动程序之前,我多次看到 R 中的 set.seed 函数。我知道它基本上用于随机数生成。有什么具体需要设置吗? 最佳答案 需求是对可重现结果的可能渴望,例如,这可能来自尝试调试程序,或者当然来自尝
我是一名优秀的程序员,十分优秀!