numpy.random.shuffle打乱顺序函数的实现
2019-09-10 10:31
2967 查看
numpy.random.shuffle
在做将caffe模型和预训练的参数转化为tensorflow的模型和预训练的参数,以便微调,遇到如下函数:
def gen_data(source): while True: indices = range(len(source.images)) # indices = the number of images in the source data set random.shuffle(indices) for i in indices: image = np.reshape(source.images[i], (28, 28, 1)) label = source.labels[i] yield image, label
之前卑鄙陋寡闻,不知道这个用法,按照字面上的意思是打乱,那么这里就应该是让训练数据集中的数据打乱顺序,然后一个挨着一个地(for i in indices)生成训练数据对。下面就从docs.scipy.org中查到的random.shuffle的用法:
numpy.random.shuffle(x)
Modify a sequence in-place by shuffling its contents.
Parameters: |
x : array_like
|
---|---|
Returns: |
None |
举例
python>>> >>> arr = np.arange(10) >>> np.random.shuffle(arr) >>> arr [1 7 5 2 9 4 3 6 0 8]
This function only shuffles the array along the first index of a multi-dimensional array(多维矩阵中,只对第一维(行)做打乱顺序操作):
python>>> >>> arr = np.arange(9).reshape((3, 3)) >>> np.random.shuffle(arr) >>> arr array([[3, 4, 5], [6, 7, 8], [0, 1, 2]])This function only shuffles the array along the first index of a multi-dimensional array:
参考:
[1] https://docs.scipy.org/doc/numpy/reference/generated/numpy.random.shuffle.html#numpy-random-shuffle
[2] https://github.com/ethereon/caffe-tensorflow/blob/master/examples/mnist/finetune_mnist.py
以上就是本文的全部内容,希望对大家的学习有所帮助
您可能感兴趣的文章:
相关文章推荐
- numpy.random.shuffle打乱顺序函数
- PHP内部实现打乱字符串顺序函数str_shuffle的方法
- JavaScript中实现PHP的打乱数组函数shuffle实例
- random_shuffle (stl算法)打乱顺序
- random_shuffle(stl算法)打乱顺序
- js为Array添加打乱元素顺序的函数shuffle()
- random_shuffle()打乱顺序
- random_shuffle (stl算法)打乱顺序 - 飞不会的日志 - 网易博客
- Numpy:利用Numpy库建立可视化输入的二次函数数据点集np.linspace+np.random.shuffle——daiding
- 将一个5*5的矩阵中最大的元素放在中心,四个角分别放四个最小的元素(顺序从左到右,从上到下顺序依次从小到大存放),写一个函数实现之。用main函数调用。
- 用Collection.shuffle()随机打乱一个顺序数组
- 将n个数按输入时顺序的逆序排列,用函数实现(指针)
- Python numpy包 np.random.shuffle(x) 数据集 batch 预处理
- date_format str_to_date str_shuffle() 函数随机地打乱字符串中的所有字符
- C/C++函数参数的入栈顺序,计算顺序和可变参数的实现
- 入一个整数数组,实现一个函数,来调整该数组中数字的顺序使得数组中所有的奇数位于数组的前半部分,所有偶数位于数组的后半部分。
- 输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有的奇数位于数组的前半部分,所有的偶数位于位于数组的后半部分,并保证奇数和奇数,偶数和偶数之间的相对位置不变。
- shuffle:随机打乱一个数组的顺序的另一种方法
- 一道试题中备选答案打乱顺序,随机展示,用数组实现
- 输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有的奇数位于数组的前半部分,所有的偶数位于位于数组的后半部分,并保证奇数和奇数,偶数和偶数之间的相对位置不变。