faster-rcnn系列assert (boxes[:, 2] = boxes[:, 0]).all()和loss偶尔为nan的问题
生活随笔
收集整理的這篇文章主要介紹了
faster-rcnn系列assert (boxes[:, 2] = boxes[:, 0]).all()和loss偶尔为nan的问题
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
問問題綜述
這些問題的根源都是faster-rcnn系列在處理生成pascal voc數(shù)據集時,為了使像素以0為起點,每個bbox的左上 右下坐標都減1,如果你的數(shù)據里有坐標為0,一般是x1或y1,這時x1 = 0-1 = 65535,就會出現(xiàn)下面的問題1,2。 # 代碼在$faster-rcnn-root/lib/datasets/pascal.py # Make pixel indexes 0-based x1 = float(bbox.find('xmin').text) - 1 y1 = float(bbox.find('ymin').text) - 1 x2 = float(bbox.find('xmax').text) - 1 y2 = float(bbox.find('ymax').text) - 1- 1
- 2
- 3
- 4
- 5
- 6
- 7
問題1解釋
# 終端提示 File "/py-faster-rcnn/tools/../lib/datasets/imdb.py", line 112, in append_flipped_imagesassert (boxes[:, 2] >= boxes[:, 0]).all() AssertionError- 1
- 2
- 3
- 4
- 1
- 2
- 3
- 4
- 5
- 6
問題綜述里說明過了如果你的坐標里有0,那么oldx1就會為65535,boxes[:, 2]就會小于boxes[:, 0],assert就會Error
問題2解釋
訓練時loss偶爾出現(xiàn)nan(不是不收斂那種情況) # 網上很多教程說在 boxes[:, 2] = widths[i] - oldx1 - 1加下面代碼 # 但是治標不治本,只是在這里不提示錯誤了,但是你的x1還是65533,在計算loss時 # 就會出現(xiàn)很大偏差,出現(xiàn)nan的情況,為什么偶爾出現(xiàn),因為你的數(shù)據里偶爾有0啊 哈哈哈 for b in range(len(boxes)):if boxes[b][2]< boxes[b][0]:boxes[b][0] = 0- 1
- 2
- 3
- 4
- 5
- 6
最終解決方案
找到文章開頭說的根源所在 # 代碼在$faster-rcnn-root/lib/datasets/pascal.py # Make pixel indexes 0-based # 根據你的數(shù)據情況選擇減不減1,一般都是左上角的(x1,y1)可能為0 x1 = float(bbox.find('xmin').text) #- 1 注釋掉你數(shù)據里不能減1的地方 y1 = float(bbox.find('ymin').text) #- 1 x2 = float(bbox.find('xmax').text) - 1 y2 = float(bbox.find('ymax').text) - 1- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
來自爆米花好美踩過的坑 哈哈
與50位技術專家面對面20年技術見證,附贈技術全景圖總結
以上是生活随笔為你收集整理的faster-rcnn系列assert (boxes[:, 2] = boxes[:, 0]).all()和loss偶尔为nan的问题的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Anaconda2安装时出现问题
- 下一篇: Caffe学习(十)protobuf及c