5-26
1.对于矩阵来说:shape[0]表示矩阵的行数,shape[1]表示矩阵的列数
2.enumerate() 函数用于将一个可遍历的数据对象(如列表、元组或字符串)组合为一个索引序列,同时列出数据和数据下标,一般用在 for 循环当中。
示例:for step, (x_train, y_train) in enumerate(db):
- if name == ‘main’:的理解
功能:
一个python的文件有两种使用的方法,第一是作为脚本直接执行,第二是 import 到其他的 python 脚本中被调用(模块重用)执行。在 if name == ‘main’: 之下的代码只有在第一种情况下(即文件作为脚本直接执行)才会被执行,而 import 到其他脚本中是不会被执行的。
示例:在test.py中写入如下代码:
print “I’m the first.”
if name"main":
print “I’m the second.”
并直接执行test.py,结果如下图,可以成功print两行字符串。即,if name"main": 语句之前和之后的代码都被执行。
然后在同一文件夹新建名称为import_test.py的脚本,只输入如代码:
import test
执行import_test.py脚本,输出结果如下:
只输出了第一行字符串。即,if name==“main”: 之前的语句被执行,之后的没有被执行
原理:
每个python模块(python文件,也就是此处的test.py和import_test.py)都包含内置的变量__name__,当运行模块被执行的时候,__name__等于文件名(包含了后缀.py);如果import到其他模块中,则__name__等于模块名称(不包含后缀.py)。
而“main”等于当前执行文件的名称(包含了后缀.py)。进而当模块被直接执行时,name == 'main’结果为真。
4.os模块
代码示例:
import os
path_01 = ‘Test\path_01\path_02\path_03’
解释:os.mkdir()创建路径中的最后一级目录,即:只创建path_03目录,而如果之前的目录不存在并且也需要创建的话,就会报错。os.makedirs()创建多层目录,即:Test,path_01,path_02,path_03如果都不存在的话,会自动创建。
5.python中的predict()函数
predict()是训练后返回预测结果,是标签值。当使用predict()方法进行预测时,返回值是数值,表示样本属于每一个类别的概率。
5-27
GPU占用率低的解决办法:
出现问题的原因:
(1)代码本身不需要占用太多GPU,测试方法,换一个占用GPU多的的代码
(2)batch_size设置的太小,每次喂入的数据太少,增大batch_size数值
(3)CPU数据读取跟不上
提高 GPU 占用率的几个思路:
(1)提高 Batch Size(直到显存爆掉);
(2)提高单层计算量(如增大 channels、kernel_size,减小 stride、group);
(3)使用 cuDNN;
(4)算法运算优化:优化网络图,优化单位batchsize的显存占用量,这样就可以装下更多的batchsize,来更充分的利用GPU core等
(5)减少CPU其他任务的占用:减少其他读写任务等