ubutnu16.04+caffe+cuda8.0+NVIDIA TX2环境下,Faster RCNN 训练中的一些问题及解决办法

3 篇文章 0 订阅
1 篇文章 0 订阅

之前实验室购买了NVIDIA-jetson-TX2系类的嵌入式开发板,就迫不及待的在上面配好了caffe 和py-faster rcnn。当时没配散热器,无法在上面训练测试,只是跑了demo,demo跑起来还是很顺畅的,基本没修改代码,也没有所谓的numpy版本问题。不知道具体在嵌入式环境下的准确率效果怎样。今天买的散热器到了,装好后来训练。

好,废话不多说,先贴一张在nvidia jetson tx2上的demo效果图和检测时间:


检测时间(使用的是作者提供的ZF模型):

**************************************我是萌萌哒的分割线************************************

今天使用Faster RCNN训练自己的数据的时候,出现了一些因为boost或者是numpy版本不兼容导致的问题,经过各种查资料和求助大神,总算是顺利把网络跑起来了。下面内容都是今天亲测出现的问题并与其对应的解决方案,和大家一起分享,也便于我以后查看。

训练方法:在配置好Faster RCNN之后,准备好自己的数据,修改网络的配置文件和相应的训练脚本满,使用end to end 的训练方法,在$py-faster-rcnn的根目录下执行:./experiments/scripts/faster_rcnn_end2end.sh 0 ZF pascal_voc 。以下都是执行该脚本后出现的问题。

 特别提醒:这里推荐解决完一个问题后立马运行测试,或许你没有接下来的问题,不用修改代码。

下面的错误是在用自己的数据集的话容易出的错误,我用VOC2007训练时候只出现了问题2,其他问题都没有出现。

问题1

TypeError: slice indices must be integers or None or have an __index__ method

这里还是因为numpy版本的原因,最好的解决办法还是换numpy版本(我换numpy版本还是包这些错,无效。使用如下方法)
修改 /home/lzx/py-faster-rcnn/lib/rpn/proposal_target_layer.py,转到123行:

for ind in inds:
        cls = clss[ind]
        start = 4 * cls
        end = start + 4
        bbox_targets[ind, start:end] = bbox_target_data[ind, 1:]
        bbox_inside_weights[ind, start:end] = cfg.TRAIN.BBOX_INSIDE_WEIGHTS
    return bbox_targets, bbox_inside_weights

这里的ind,start,end都是 numpy.int 类型,这种类型的数据不能作为索引,所以必须对其进行强制类型转换,转换成为int类型,转化结果如下:

for ind in inds:
        ind = int(ind)
        cls = clss[ind]
        start = int(4 * cls)
        end = int(start + 4)
        bbox_targets[ind, start:end] = bbox_target_data[ind, 1:]
        bbox_inside_weights[ind, start:end] = cfg.TRAIN.BBOX_INSIDE_WEIGHTS
    return bbox_targets, bbox_inside_weights

以上内容是我刚刚在训练自己的datasets时候出现的一些问题,参考了一些其他博客的解决方法。

在这里需要提醒的是,我重装numpy,升级或者降级都无法解决问题,可以先按博客修改,修改好了没问题就不用改变numpy的版本。大部分还是因为Faster RCNN 发布的时候使用的一些库现在都升级了,所以需要对代码中一些细节进行修改。


问题2

AttributeError: 'module' object has no attributetext_format'

解决方法:在/home/xxx/py-faster-rcnn/lib/fast_rcnn/train.py的头文件导入部分加上 :import google.protobuf.text_format


问题3

TypeError: 'numpy.float64' object cannot be interpreted as an index 


修改的位置如下(xxx为你的用户名):这里我的是nvidia

1) /home/nvidia/py-faster-rcnn/lib/roi_data_layer/minibatch.py

查看第26行:fg_rois_per_image = np.round(cfg.TRAIN.FG_FRACTION * rois_per_image)
改为:fg_rois_per_image = np.round(cfg.TRAIN.FG_FRACTION * rois_per_image).astype(np.int)

2) /home/nvidia/py-faster-rcnn/lib/datasets/ds_utils.py

查看第12行:hashes = np.round(boxes * scale).dot(v)
改为:hashes = np.round(boxes * scale).dot(v).astype(np.int)

3) /home/nvidia/py-faster-rcnn/lib/fast_rcnn/test.py

查看第129行: hashes = np.round(blobs['rois'] * cfg.DEDUP_BOXES).dot(v)
改为: hashes = np.round(blobs['rois'] * cfg.DEDUP_BOXES).dot(v).astype(np.int)

4) /home/nvidia/py-faster-rcnn/lib/rpn/proposal_target_layer.py

查看第60行:fg_rois_per_image = np.round(cfg.TRAIN.FG_FRACTION * rois_per_image)
改为:fg_rois_per_image = np.round(cfg.TRAIN.FG_FRACTION * rois_per_image).astype(np.int)

最后再贴一张训练时候的情况:

当然,速度很慢,实际训练我也不是在这个上面训练,实际用实验室的服务器进行训练,在这里只是来测试下网络的map等结果。

总结:很多博客都说这里是因为numpy版本不兼容导致的问题,最好的解决办法是卸载你的numpy,安装numpy1.11.0。但是我实际使用发现,不管是pip升级/降级numpy还是先卸载完全后,再重新安装,都会出现上面的问题。demo也跑不起来,而且报ImportError: No module named numpy.core.multiarray的错误,但实际上直接import的时候是通过的!!!!很坑爹,最后还是妥协了,不改变原来numpy的版本,而是改变代码中的内容。

如果想修改numpy的版本的话,可以执行:sudo pip install -U numpy==1.11.0,更换numpy的版本

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值