出错原因:torch._C.nn.nll_loss(input, target)的target是LongTensor格式,也就是分类的标签要是LongTensor格式,不能是FloatTensor。修改的话data.long()就可以了。
后面的可以不用看了,都是自己比较啰嗦的记录。
=================================================================
最近在复现PointNet,习惯在源文件上修修改改调试,改的多了就不知道自己改了什么,最后运行的时候往往就会出错。这次运行train_segmentation的时候,在计算损失loss = F.nll_loss(pred, target)的时候出现了错误
发现是下面dataset.py这个代码中,也就是生成target(seg)的代码中,seg我之前添了个astype(np.float32),跟源码对比了一下,这个是没有的,应该是我之前乱加的,删掉就没有问题了。
原因应该是,torch._C.nn.nll_loss(input, target)
的target要是LongTensor格式,而我不小心把它改成了FloatTensor。
还有一个也是不小心乱删的地方,之前把上面这个图片的
point_set = np.loadtxt(fn[1]).astype(np.float32)中的astype(np.float32)注释掉了。
就出现了下面这个问题。
RuntimeError: Expected object of scalar type Double but got scalar type Float for argument #3 ‘mat1’ in call to th_addmm
参考的这里才发现自己把上面的内容注释掉的
哎,归根结底还是基本功不行,在这些小地方都要调来调去。。。