renewable_eva/常见问题汇总.md

554 lines
35 KiB
Markdown
Raw Permalink Normal View History

2024-06-18 10:59:34 +08:00
问题汇总的博客地址为[https://blog.csdn.net/weixin_44791964/article/details/107517428](https://blog.csdn.net/weixin_44791964/article/details/107517428)。
# 问题汇总
## 1、下载问题
### a、代码下载
**问up主可以给我发一份代码吗代码在哪里下载啊
Github上的地址就在视频简介里。复制一下就能进去下载了。**
**问up主为什么我下载的代码提示压缩包损坏
重新去Github下载。**
**问up主为什么我下载的代码和你在视频以及博客上的代码不一样
答:我常常会对代码进行更新,最终以实际的代码为准。**
### b、 权值下载
**问up主为什么我下载的代码里面model_data下面没有.pth或者.h5文件
我一般会把权值上传到Github和百度网盘在GITHUB的README里面就能找到。**
### c、 数据集下载
**问up主XXXX数据集在哪里下载啊
一般数据集的下载地址我会放在README里面基本上都有没有的话请及时联系我添加直接发github的issue即可**。
## 2、环境配置问题
### a、现在库中所用的环境
**pytorch代码对应的pytorch版本为1.2,博客地址对应**[https://blog.csdn.net/weixin_44791964/article/details/106037141](https://blog.csdn.net/weixin_44791964/article/details/106037141)。
**keras代码对应的tensorflow版本为1.13.2keras版本是2.1.5,博客地址对应**[https://blog.csdn.net/weixin_44791964/article/details/104702142](https://blog.csdn.net/weixin_44791964/article/details/104702142)。
**tf2代码对应的tensorflow版本为2.2.0无需安装keras博客地址对应**[https://blog.csdn.net/weixin_44791964/article/details/109161493](https://blog.csdn.net/weixin_44791964/article/details/109161493)。
**问你的代码某某某版本的tensorflow和pytorch能用嘛
答:最好按照我推荐的配置,配置教程也有!其它版本的我没有试过!可能出现问题但是一般问题不大。仅需要改少量代码即可。**
### b、30系列显卡环境配置
30系显卡由于框架更新不可使用上述环境配置教程。
当前我已经测试的可以用的30显卡配置如下
**pytorch代码对应的pytorch版本为1.7.0cuda为11.0cudnn为8.0.5**。
**keras代码无法在win10下配置cuda11在ubuntu下可以百度查询一下配置tensorflow版本为1.15.4keras版本是2.1.5或者2.3.1(少量函数接口不同,代码可能还需要少量调整。)**
**tf2代码对应的tensorflow版本为2.4.0cuda为11.0cudnn为8.0.5**。
### c、GPU利用问题与环境使用问题
**问为什么我安装了tensorflow-gpu但是却没用利用GPU进行训练呢
确认tensorflow-gpu已经装好利用pip list查看tensorflow版本然后查看任务管理器或者利用nvidia命令看看是否使用了gpu进行训练任务管理器的话要看显存使用情况。**
**问up主我好像没有在用gpu进行训练啊怎么看是不是用了GPU进行训练
查看是否使用GPU进行训练一般使用NVIDIA在命令行的查看命令如果要看任务管理器的话请看性能部分GPU的显存是否利用或者查看任务管理器的Cuda而非Copy。**
![在这里插入图片描述](https://img-blog.csdnimg.cn/20201013234241524.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dlaXhpbl80NDc5MTk2NA==,size_16,color_FFFFFF,t_70#pic_center)
**问up主为什么我按照你的环境配置后还是不能使用
请把你的GPU、CUDA、CUDNN、TF版本以及PYTORCH版本B站私聊告诉我。**
**问:出现如下错误**
```python
Traceback (most recent call last):
File "C:\Users\focus\Anaconda3\ana\envs\tensorflow-gpu\lib\site-packages\tensorflow\python\pywrap_tensorflow.py", line 58, in <module>
from tensorflow.python.pywrap_tensorflow_internal import *
File "C:\Users\focus\Anaconda3\ana\envs\tensorflow-gpu\lib\site-packages\tensorflow\python\pywrap_tensorflow_internal.py", line 28, in <module>
pywrap_tensorflow_internal = swig_import_helper()
File "C:\Users\focus\Anaconda3\ana\envs\tensorflow-gpu\lib\site-packages\tensorflow\python\pywrap_tensorflow_internal.py", line 24, in swig_import_helper
_mod = imp.load_module('_pywrap_tensorflow_internal', fp, pathname, description)
File "C:\Users\focus\Anaconda3\ana\envs\tensorflow-gpu\lib\imp.py", line 243, in load_modulereturn load_dynamic(name, filename, file)
File "C:\Users\focus\Anaconda3\ana\envs\tensorflow-gpu\lib\imp.py", line 343, in load_dynamic
return _load(spec)
ImportError: DLL load failed: 找不到指定的模块。
```
**答如果没重启过就重启一下否则重新按照步骤安装还无法解决则把你的GPU、CUDA、CUDNN、TF版本以及PYTORCH版本私聊告诉我。**
### d、no module问题
**问为什么提示说no module name utils.utilsno module name nets.yolo、no module name nets.ssd等一系列问题
utils并不需要用pip装它就在我上传的仓库的根目录出现这个问题的原因是根目录不对查查相对目录和根目录的概念。查了基本上就明白了。**
**问为什么提示说no module name matplotlibno module name PILno module name cv2等等
这个库没安装打开命令行安装就好。pip install matplotlib**
**问为什么我已经用pip装了opencvpillow、matplotlib等还是提示no module name cv2
没有激活环境装要激活对应的conda环境进行安装才可以正常使用**
**问为什么提示说No module named 'torch'
其实我也真的很想知道为什么会有这个问题……这个pytorch没装是什么情况一般就俩情况一个是真的没装还有一个是装到其它环境了当前激活的环境不是自己装的环境。**
**问为什么提示说No module named 'tensorflow'
答:同上。**
### e、cuda安装失败问题
一般cuda安装前需要安装Visual Studio装个2017版本即可。
### f、Ubuntu系统问题
**所有代码在Ubuntu下可以使用我两个系统都试过。**
### g、VSCODE提示错误的问题
**问为什么在VSCODE里面提示一大堆的错误啊
我也提示一大堆的错误但是不影响是VSCODE的问题如果不想看错误的话就装Pycharm。**
### h、使用cpu进行训练与预测的问题
**对于keras和tf2的代码而言如果想用cpu进行训练和预测直接装cpu版本的tensorflow就可以了。**
**对于pytorch的代码而言如果想用cpu进行训练和预测需要将cuda=True修改成cuda=False。**
### i、tqdm没有pos参数问题
**问:运行代码提示'tqdm' object has no attribute 'pos'。
重装tqdm换个版本就可以了。**
### j、提示decode(“utf-8”)的问题
**由于h5py库的更新安装过程中会自动安装h5py=3.0.0以上的版本会导致decode("utf-8")的错误!
各位一定要在安装完tensorflow后利用命令装h5py=2.10.0**
```
pip install h5py==2.10.0
```
### k、提示TypeError: __array__() takes 1 positional argument but 2 were given错误
可以修改pillow版本解决。
```
pip install pillow==8.2.0
```
### l、其它问题
**问为什么提示TypeError: cat() got an unexpected keyword argument 'axis'Traceback (most recent call last)AttributeError: 'Tensor' object has no attribute 'bool'
这是版本问题建议使用torch1.2以上版本**
**其它有很多稀奇古怪的问题很多是版本问题建议按照我的视频教程安装Keras和tensorflow。比如装的是tensorflow2就不用问我说为什么我没法运行Keras-yolo啥的。那是必然不行的。**
## 3、目标检测库问题汇总人脸检测和分类库也可参考
### a、shape不匹配问题
#### 1、训练时shape不匹配问题
**问up主为什么运行train.py会提示shape不匹配啊
在keras环境中因为你训练的种类和原始的种类不同网络结构会变化所以最尾部的shape会有少量不匹配。**
#### 2、预测时shape不匹配问题
**问为什么我运行predict.py会提示我说shape不匹配呀。
在Pytorch里面是这样的**
![在这里插入图片描述](https://img-blog.csdnimg.cn/20200722171631901.png)
在Keras里面是这样的
![在这里插入图片描述](https://img-blog.csdnimg.cn/20200722171523380.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dlaXhpbl80NDc5MTk2NA==,size_16,color_FFFFFF,t_70)
**答:原因主要有仨:
1、在ssd、FasterRCNN里面可能是train.py里面的num_classes没改。
2、model_path没改。
3、classes_path没改。
请检查清楚了确定自己所用的model_path和classes_path是对应的训练的时候用到的num_classes或者classes_path也需要检查**
### b、显存不足问题
**问为什么我运行train.py下面的命令行闪的贼快还提示OOM啥的
这是在keras中出现的爆显存了可以改小batch_sizeSSD的显存占用率是最小的建议用SSD
2G显存SSD、YOLOV4-TINY
4G显存YOLOV3
6G显存YOLOV4、Retinanet、M2det、Efficientdet、Faster RCNN等
8G+显存:随便选吧。**
**需要注意的是受到BatchNorm2d影响batch_size不可为1至少为2。**
**问:为什么提示 RuntimeError: CUDA out of memory. Tried to allocate 52.00 MiB (GPU 0; 15.90 GiB total capacity; 14.85 GiB already allocated; 51.88 MiB free; 15.07 GiB reserved in total by PyTorch)
这是pytorch中出现的爆显存了同上。**
**问:为什么我显存都没利用,就直接爆显存了?
答:都爆显存了,自然就不利用了,模型没有开始训练。**
### c、训练问题冻结训练LOSS问题、训练效果问题等
**问:为什么要冻结训练和解冻训练呀?
答:这是迁移学习的思想,因为神经网络主干特征提取部分所提取到的特征是通用的,我们冻结起来训练可以加快训练效率,也可以防止权值被破坏。**
在冻结阶段,模型的主干被冻结了,特征提取网络不发生改变。占用的显存较小,仅对网络进行微调。
在解冻阶段,模型的主干不被冻结了,特征提取网络会发生改变。占用的显存较大,网络所有的参数都会发生改变。
**问为什么我的网络不收敛啊LOSS是XXXX。
不同网络的LOSS不同LOSS只是一个参考指标用于查看网络是否收敛而非评价网络好坏我的yolo代码都没有归一化所以LOSS值看起来比较高LOSS的值不重要重要的是是否在变小预测是否有效果。**
**问:为什么我的训练效果不好?预测了没有框(框不准)。
答:**
考虑几个问题:
1、目标信息问题查看2007_train.txt文件是否有目标信息没有的话请修改voc_annotation.py。
2、数据集问题小于500的自行考虑增加数据集同时测试不同的模型确认数据集是好的。
3、是否解冻训练如果数据集分布与常规画面差距过大需要进一步解冻训练调整主干加强特征提取能力。
4、网络问题比如SSD不适合小目标因为先验框固定了。
5、训练时长问题有些同学只训练了几代表示没有效果按默认参数训练完。
6、确认自己是否按照步骤去做了如果比如voc_annotation.py里面的classes是否修改了等。
7、不同网络的LOSS不同LOSS只是一个参考指标用于查看网络是否收敛而非评价网络好坏LOSS的值不重要重要的是是否收敛。
**问我怎么出现了gbk什么的编码错误啊**
```python
UnicodeDecodeError: 'gbk' codec can't decode byte 0xa6 in position 446: illegal multibyte sequence
```
**答标签和路径不要使用中文如果一定要使用中文请注意处理的时候编码的问题改成打开文件的encoding方式改为utf-8。**
**问我的图片是xxx*xxx的分辨率的可以用吗**
**答可以用代码里面会自动进行resize或者数据增强。**
**问怎么进行多GPU训练
pytorch的大多数代码可以直接使用gpu训练keras的话直接百度就好了实现并不复杂我没有多卡没法详细测试还需要各位同学自己努力了。**
### d、灰度图问题
**问:能不能训练灰度图(预测灰度图)啊?
我的大多数库会将灰度图转化成RGB进行训练和预测如果遇到代码不能训练或者预测灰度图的情况可以尝试一下在get_random_data里面将Image.open后的结果转换成RGB预测的时候也这样试试。仅供参考**
### e、断点续练问题
**问:我已经训练过几个世代了,能不能从这个基础上继续开始训练
可以你在训练前和载入预训练权重一样载入训练过的权重就行了。一般训练好的权重会保存在logs文件夹里面将model_path修改成你要开始的权值的路径即可。**
### f、预训练权重的问题
**问:如果我要训练其它的数据集,预训练权重要怎么办啊?**
**答数据的预训练权重对不同数据集是通用的因为特征是通用的预训练权重对于99%的情况都必须要用,不用的话权值太过随机,特征提取效果不明显,网络训练的结果也不会好。**
**问up我修改了网络预训练权重还能用吗
修改了主干的话如果不是用的现有的网络基本上预训练权重是不能用的要么就自己判断权值里卷积核的shape然后自己匹配要么只能自己预训练去了修改了后半部分的话前半部分的主干部分的预训练权重还是可以用的如果是pytorch代码的话需要自己修改一下载入权值的方式判断shape后载入如果是keras代码直接by_name=True,skip_mismatch=True即可。**
权值匹配的方式可以参考如下:
```python
# 加快模型训练的效率
print('Loading weights into state dict...')
device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')
model_dict = model.state_dict()
pretrained_dict = torch.load(model_path, map_location=device)
a = {}
for k, v in pretrained_dict.items():
try:
if np.shape(model_dict[k]) == np.shape(v):
a[k]=v
except:
pass
model_dict.update(a)
model.load_state_dict(model_dict)
print('Finished!')
```
**问:我要怎么不使用预训练权重啊?
答:把载入预训练权重的代码注释了就行。**
**问:为什么我不使用预训练权重效果这么差啊?
因为随机初始化的权值不好提取的特征不好也就导致了模型训练的效果不好voc07+12、coco+voc07+12效果都不一样预训练权重还是非常重要的。**
### g、视频检测问题与摄像头检测问题
**问:怎么用摄像头检测呀?
predict.py修改参数可以进行摄像头检测也有视频详细解释了摄像头检测的思路。**
**问:怎么用视频检测呀?
答:同上**
### h、从0开始训练问题
**问怎么在模型上从0开始训练
在算力不足与调参能力不足的情况下从0开始训练毫无意义。模型特征提取能力在随机初始化参数的情况下非常差。没有好的参数调节能力和算力无法使得网络正常收敛。**
如果一定要从0开始那么训练的时候请注意几点
- 不载入预训练权重。
- 不要进行冻结训练,注释冻结模型的代码。
**问:为什么我不使用预训练权重效果这么差啊?
因为随机初始化的权值不好提取的特征不好也就导致了模型训练的效果不好voc07+12、coco+voc07+12效果都不一样预训练权重还是非常重要的。**
### i、保存问题
**问:检测完的图片怎么保存?
一般目标检测用的是Image所以查询一下PIL库的Image如何进行保存。详细看看predict.py文件的注释。**
**问:怎么用视频保存呀?
详细看看predict.py文件的注释。**
### j、遍历问题
**问:如何对一个文件夹的图片进行遍历?
一般使用os.listdir先找出文件夹里面的所有图片然后根据predict.py文件里面的执行思路检测图片就行了详细看看predict.py文件的注释。**
**问:如何对一个文件夹的图片进行遍历?并且保存。
遍历的话一般使用os.listdir先找出文件夹里面的所有图片然后根据predict.py文件里面的执行思路检测图片就行了。保存的话一般目标检测用的是Image所以查询一下PIL库的Image如何进行保存。如果有些库用的是cv2那就是查一下cv2怎么保存图片。详细看看predict.py文件的注释。**
### k、路径问题No such file or directory
**问:我怎么出现了这样的错误呀:**
```python
FileNotFoundError: 【Errno 2】 No such file or directory
……………………………………
……………………………………
```
**答去检查一下文件夹路径查看是否有对应文件并且检查一下2007_train.txt其中文件路径是否有错。**
关于路径有几个重要的点:
**文件夹名称中一定不要有空格。
注意相对路径和绝对路径。
多百度路径相关的知识。**
**所有的路径问题基本上都是根目录问题,好好查一下相对目录的概念!**
### l、和原版比较问题
**问:你这个代码和原版比怎么样,可以达到原版的效果么?
基本上可以达到我都用voc数据测过我没有好显卡没有能力在coco上测试与训练。**
**问你有没有实现yolov4所有的tricks和原版差距多少
并没有实现全部的改进部分由于YOLOV4使用的改进实在太多了很难完全实现与列出来这里只列出来了一些我比较感兴趣而且非常有效的改进。论文中提到的SAM注意力机制模块作者自己的源码也没有使用。还有其它很多的tricks不是所有的tricks都有提升我也没法实现全部的tricks。至于和原版的比较我没有能力训练coco数据集根据使用过的同学反应差距不大。**
### m、FPS问题检测速度问题
**问你这个FPS可以到达多少可以到 XX FPS么
FPS和机子的配置有关配置高就快配置低就慢。**
**问为什么我用服务器去测试yolov4or others的FPS只有十几
检查是否正确安装了tensorflow-gpu或者pytorch的gpu版本如果已经正确安装可以去利用time.time()的方法查看detect_image里面哪一段代码耗时更长不仅只有网络耗时长其它处理部分也会耗时如绘图等。**
**问为什么论文中说速度可以达到XX但是这里却没有
检查是否正确安装了tensorflow-gpu或者pytorch的gpu版本如果已经正确安装可以去利用time.time()的方法查看detect_image里面哪一段代码耗时更长不仅只有网络耗时长其它处理部分也会耗时如绘图等。有些论文还会使用多batch进行预测我并没有去实现这个部分。**
### n、预测图片不显示问题
**问:为什么你的代码在预测完成后不显示图片?只是在命令行告诉我有什么目标。
答:给系统安装一个图片查看器就行了。**
### o、算法评价问题目标检测的map、PR曲线、Recall、Precision等
**问怎么计算map
看map视频都一个流程。**
**问计算map的时候get_map.py里面有一个MINOVERLAP是什么用的是iou吗
是iou它的作用是判断预测框和真实框的重合成度如果重合程度大于MINOVERLAP则预测正确。**
**问为什么get_map.py里面的self.confidenceself.score要设置的那么小
看一下map的视频的原理部分要知道所有的结果然后再进行pr曲线的绘制。**
**问能不能说说怎么绘制PR曲线啥的呀。
可以看mAP视频结果里面有PR曲线。**
**问怎么计算Recall、Precision指标。
这俩指标应该是相对于特定的置信度的计算map的时候也会获得。**
### p、coco数据集训练问题
**问目标检测怎么训练COCO数据集啊
coco数据训练所需要的txt文件可以参考qqwweee的yolo3的库格式都是一样的。**
### q、模型优化模型修改问题
**问upYOLO系列使用Focal LOSS的代码你有吗有提升吗
很多人试过提升效果也不大甚至变的更Low它自己有自己的正负样本的平衡方式。**
**问up我修改了网络预训练权重还能用吗
修改了主干的话如果不是用的现有的网络基本上预训练权重是不能用的要么就自己判断权值里卷积核的shape然后自己匹配要么只能自己预训练去了修改了后半部分的话前半部分的主干部分的预训练权重还是可以用的如果是pytorch代码的话需要自己修改一下载入权值的方式判断shape后载入如果是keras代码直接by_name=True,skip_mismatch=True即可。**
权值匹配的方式可以参考如下:
```python
# 加快模型训练的效率
print('Loading weights into state dict...')
device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')
model_dict = model.state_dict()
pretrained_dict = torch.load(model_path, map_location=device)
a = {}
for k, v in pretrained_dict.items():
try:
if np.shape(model_dict[k]) == np.shape(v):
a[k]=v
except:
pass
model_dict.update(a)
model.load_state_dict(model_dict)
print('Finished!')
```
**问up怎么修改模型啊我想发个小论文
建议看看yolov3和yolov4的区别然后看看yolov4的论文作为一个大型调参现场非常有参考意义使用了很多tricks。我能给的建议就是多看一些经典模型然后拆解里面的亮点结构并使用。**
### r、部署问题
我没有具体部署到手机等设备上过,所以很多部署问题我并不了解……
## 4、语义分割库问题汇总
### a、shape不匹配问题
#### 1、训练时shape不匹配问题
**问up主为什么运行train.py会提示shape不匹配啊
在keras环境中因为你训练的种类和原始的种类不同网络结构会变化所以最尾部的shape会有少量不匹配。**
#### 2、预测时shape不匹配问题
**问为什么我运行predict.py会提示我说shape不匹配呀。
在Pytorch里面是这样的**
![在这里插入图片描述](https://img-blog.csdnimg.cn/20200722171631901.png)
在Keras里面是这样的
![在这里插入图片描述](https://img-blog.csdnimg.cn/20200722171523380.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dlaXhpbl80NDc5MTk2NA==,size_16,color_FFFFFF,t_70)
**答:原因主要有二:
1、train.py里面的num_classes没改。
2、预测时num_classes没改。
请检查清楚训练和预测的时候用到的num_classes都需要检查**
### b、显存不足问题
**问为什么我运行train.py下面的命令行闪的贼快还提示OOM啥的
这是在keras中出现的爆显存了可以改小batch_size。**
**需要注意的是受到BatchNorm2d影响batch_size不可为1至少为2。**
**问:为什么提示 RuntimeError: CUDA out of memory. Tried to allocate 52.00 MiB (GPU 0; 15.90 GiB total capacity; 14.85 GiB already allocated; 51.88 MiB free; 15.07 GiB reserved in total by PyTorch)
这是pytorch中出现的爆显存了同上。**
**问:为什么我显存都没利用,就直接爆显存了?
答:都爆显存了,自然就不利用了,模型没有开始训练。**
### c、训练问题冻结训练LOSS问题、训练效果问题等
**问:为什么要冻结训练和解冻训练呀?
答:这是迁移学习的思想,因为神经网络主干特征提取部分所提取到的特征是通用的,我们冻结起来训练可以加快训练效率,也可以防止权值被破坏。**
**在冻结阶段,模型的主干被冻结了,特征提取网络不发生改变。占用的显存较小,仅对网络进行微调。**
**在解冻阶段,模型的主干不被冻结了,特征提取网络会发生改变。占用的显存较大,网络所有的参数都会发生改变。**
**问为什么我的网络不收敛啊LOSS是XXXX。
不同网络的LOSS不同LOSS只是一个参考指标用于查看网络是否收敛而非评价网络好坏我的yolo代码都没有归一化所以LOSS值看起来比较高LOSS的值不重要重要的是是否在变小预测是否有效果。**
**问:为什么我的训练效果不好?预测了没有目标,结果是一片黑。
答:**
**考虑几个问题:
1、数据集问题这是最重要的问题。小于500的自行考虑增加数据集一定要检查数据集的标签视频中详细解析了VOC数据集的格式但并不是有输入图片有输出标签即可还需要确认标签的每一个像素值是否为它对应的种类。很多同学的标签格式不对最常见的错误格式就是标签的背景为黑目标为白此时目标的像素点值为255无法正常训练目标需要为1才行。
2、是否解冻训练如果数据集分布与常规画面差距过大需要进一步解冻训练调整主干加强特征提取能力。
3、网络问题可以尝试不同的网络。
4、训练时长问题有些同学只训练了几代表示没有效果按默认参数训练完。
5、确认自己是否按照步骤去做了。
6、不同网络的LOSS不同LOSS只是一个参考指标用于查看网络是否收敛而非评价网络好坏LOSS的值不重要重要的是是否收敛。**
**问:为什么我的训练效果不好?对小目标预测不准确。
对于deeplab和pspnet而言可以修改一下downsample_factor当downsample_factor为16的时候下采样倍数过多效果不太好可以修改为8。**
**问我怎么出现了gbk什么的编码错误啊**
```python
UnicodeDecodeError: 'gbk' codec can't decode byte 0xa6 in position 446: illegal multibyte sequence
```
**答标签和路径不要使用中文如果一定要使用中文请注意处理的时候编码的问题改成打开文件的encoding方式改为utf-8。**
**问我的图片是xxx*xxx的分辨率的可以用吗**
**答可以用代码里面会自动进行resize或者数据增强。**
**问怎么进行多GPU训练
pytorch的大多数代码可以直接使用gpu训练keras的话直接百度就好了实现并不复杂我没有多卡没法详细测试还需要各位同学自己努力了。**
### d、灰度图问题
**问:能不能训练灰度图(预测灰度图)啊?
我的大多数库会将灰度图转化成RGB进行训练和预测如果遇到代码不能训练或者预测灰度图的情况可以尝试一下在get_random_data里面将Image.open后的结果转换成RGB预测的时候也这样试试。仅供参考**
### e、断点续练问题
**问:我已经训练过几个世代了,能不能从这个基础上继续开始训练
可以你在训练前和载入预训练权重一样载入训练过的权重就行了。一般训练好的权重会保存在logs文件夹里面将model_path修改成你要开始的权值的路径即可。**
### f、预训练权重的问题
**问:如果我要训练其它的数据集,预训练权重要怎么办啊?**
**答数据的预训练权重对不同数据集是通用的因为特征是通用的预训练权重对于99%的情况都必须要用,不用的话权值太过随机,特征提取效果不明显,网络训练的结果也不会好。**
**问up我修改了网络预训练权重还能用吗
修改了主干的话如果不是用的现有的网络基本上预训练权重是不能用的要么就自己判断权值里卷积核的shape然后自己匹配要么只能自己预训练去了修改了后半部分的话前半部分的主干部分的预训练权重还是可以用的如果是pytorch代码的话需要自己修改一下载入权值的方式判断shape后载入如果是keras代码直接by_name=True,skip_mismatch=True即可。**
权值匹配的方式可以参考如下:
```python
# 加快模型训练的效率
print('Loading weights into state dict...')
device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')
model_dict = model.state_dict()
pretrained_dict = torch.load(model_path, map_location=device)
a = {}
for k, v in pretrained_dict.items():
try:
if np.shape(model_dict[k]) == np.shape(v):
a[k]=v
except:
pass
model_dict.update(a)
model.load_state_dict(model_dict)
print('Finished!')
```
**问:我要怎么不使用预训练权重啊?
答:把载入预训练权重的代码注释了就行。**
**问:为什么我不使用预训练权重效果这么差啊?
答:因为随机初始化的权值不好,提取的特征不好,也就导致了模型训练的效果不好,预训练权重还是非常重要的。**
### g、视频检测问题与摄像头检测问题
**问:怎么用摄像头检测呀?
predict.py修改参数可以进行摄像头检测也有视频详细解释了摄像头检测的思路。**
**问:怎么用视频检测呀?
答:同上**
### h、从0开始训练问题
**问怎么在模型上从0开始训练
在算力不足与调参能力不足的情况下从0开始训练毫无意义。模型特征提取能力在随机初始化参数的情况下非常差。没有好的参数调节能力和算力无法使得网络正常收敛。**
如果一定要从0开始那么训练的时候请注意几点
- 不载入预训练权重。
- 不要进行冻结训练,注释冻结模型的代码。
**问:为什么我不使用预训练权重效果这么差啊?
答:因为随机初始化的权值不好,提取的特征不好,也就导致了模型训练的效果不好,预训练权重还是非常重要的。**
### i、保存问题
**问:检测完的图片怎么保存?
一般目标检测用的是Image所以查询一下PIL库的Image如何进行保存。详细看看predict.py文件的注释。**
**问:怎么用视频保存呀?
详细看看predict.py文件的注释。**
### j、遍历问题
**问:如何对一个文件夹的图片进行遍历?
一般使用os.listdir先找出文件夹里面的所有图片然后根据predict.py文件里面的执行思路检测图片就行了详细看看predict.py文件的注释。**
**问:如何对一个文件夹的图片进行遍历?并且保存。
遍历的话一般使用os.listdir先找出文件夹里面的所有图片然后根据predict.py文件里面的执行思路检测图片就行了。保存的话一般目标检测用的是Image所以查询一下PIL库的Image如何进行保存。如果有些库用的是cv2那就是查一下cv2怎么保存图片。详细看看predict.py文件的注释。**
### k、路径问题No such file or directory
**问:我怎么出现了这样的错误呀:**
```python
FileNotFoundError: 【Errno 2】 No such file or directory
……………………………………
……………………………………
```
**答去检查一下文件夹路径查看是否有对应文件并且检查一下2007_train.txt其中文件路径是否有错。**
关于路径有几个重要的点:
**文件夹名称中一定不要有空格。
注意相对路径和绝对路径。
多百度路径相关的知识。**
**所有的路径问题基本上都是根目录问题,好好查一下相对目录的概念!**
### l、FPS问题检测速度问题
**问你这个FPS可以到达多少可以到 XX FPS么
FPS和机子的配置有关配置高就快配置低就慢。**
**问为什么论文中说速度可以达到XX但是这里却没有
检查是否正确安装了tensorflow-gpu或者pytorch的gpu版本如果已经正确安装可以去利用time.time()的方法查看detect_image里面哪一段代码耗时更长不仅只有网络耗时长其它处理部分也会耗时如绘图等。有些论文还会使用多batch进行预测我并没有去实现这个部分。**
### m、预测图片不显示问题
**问:为什么你的代码在预测完成后不显示图片?只是在命令行告诉我有什么目标。
答:给系统安装一个图片查看器就行了。**
### n、算法评价问题miou
**问怎么计算miou
参考视频里的miou测量部分。**
**问怎么计算Recall、Precision指标。
答:现有的代码还无法获得,需要各位同学理解一下混淆矩阵的概念,然后自行计算一下。**
### o、模型优化模型修改问题
**问up我修改了网络预训练权重还能用吗
修改了主干的话如果不是用的现有的网络基本上预训练权重是不能用的要么就自己判断权值里卷积核的shape然后自己匹配要么只能自己预训练去了修改了后半部分的话前半部分的主干部分的预训练权重还是可以用的如果是pytorch代码的话需要自己修改一下载入权值的方式判断shape后载入如果是keras代码直接by_name=True,skip_mismatch=True即可。**
权值匹配的方式可以参考如下:
```python
# 加快模型训练的效率
print('Loading weights into state dict...')
device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')
model_dict = model.state_dict()
pretrained_dict = torch.load(model_path, map_location=device)
a = {}
for k, v in pretrained_dict.items():
try:
if np.shape(model_dict[k]) == np.shape(v):
a[k]=v
except:
pass
model_dict.update(a)
model.load_state_dict(model_dict)
print('Finished!')
```
**问up怎么修改模型啊我想发个小论文
建议看看目标检测中yolov4的论文作为一个大型调参现场非常有参考意义使用了很多tricks。我能给的建议就是多看一些经典模型然后拆解里面的亮点结构并使用。常用的tricks如注意力机制什么的可以试试。**
### p、部署问题
我没有具体部署到手机等设备上过,所以很多部署问题我并不了解……
## 5、交流群问题
**问up有没有QQ群啥的呢
没有没有我没有时间管理QQ群……**
## 6、怎么学习的问题
**问up你的学习路线怎么样的我是个小白我要怎么学
答:这里有几点需要注意哈
1、我不是高手很多东西我也不会我的学习路线也不一定适用所有人。
2、我实验室不做深度学习所以我很多东西都是自学自己摸索正确与否我也不知道。
3、我个人觉得学习更靠自学**
学习路线的话我是先学习了莫烦的python教程从tensorflow、keras、pytorch入门入门完之后学的SSDYOLO然后了解了很多经典的卷积网后面就开始学很多不同的代码了我的学习方法就是一行一行的看了解整个代码的执行流程特征层的shape变化等花了很多时间也没有什么捷径就是要花时间吧。