ReDet icon indicating copy to clipboard operation
ReDet copied to clipboard

Inference with CPU only

Open DangChuong-DC opened this issue 3 years ago • 9 comments

Hello @csuhan, Thank you very much for sharing your great work! I am wondering if ReDet is supporting inference with only CPU?

If it is supporting, how should we do it? If not, will you consider to support it in the future?

DangChuong-DC avatar Dec 15 '21 12:12 DangChuong-DC

ReDet supports cpu inference. Try to set device='cpu' in https://github.com/csuhan/ReDet/blob/0b9addf3c2734659fd6ffc7824f2e659fde4419c/demo_large_image.py#L91

csuhan avatar Dec 16 '21 02:12 csuhan

Hi @csuhan, Thank you very much for your prompt response! Running inference with GPU(s) works totally fine. However, when I tried your suggestion for running inference with cpu only, there is an error, it seems like some piece of the model is still in 'cuda:0' I provided the screen shot of the error, do you have any thoughts on this? Screenshot from 2021-12-16 13-33-31

DangChuong-DC avatar Dec 16 '21 04:12 DangChuong-DC

@csuhan i have the similar prombles too , i try to run inference with cuda:4 but there is the same error. 2~E7A$W3L0K1Y%)N5V0$_TV

yinnengzhong avatar Dec 16 '21 07:12 yinnengzhong

@jigongbao your problem can be solved by changing the code in mmdet/models/anchor_head.py as below, I guess but not sure just change the device variable in anchor_generator to match with device of your input& model weights Screenshot from 2021-12-16 17-33-31

@csuhan For my problem with CPU inference, I modified a bit and it comes to this error of those files in mmdet/models/ops since those .cpp and .cu scripts have condition of being CUDA Tensor. Do you have any thoughts to resolve this? -> I can try And thanks for your earlier suggestions Screenshot from 2021-12-16 17-39-38

DangChuong-DC avatar Dec 16 '21 08:12 DangChuong-DC

@DangChuong-DC You are right. The codebase of ReDet is a rather early version of mmdet, and some ops do not suport running on cpu. I suggest to use corresponding ops in mmcv which support cpu inference. For example, RoIAlign: https://github.com/open-mmlab/mmcv/blob/master/mmcv/ops/roi_align.py RoIAlign Rotated: https://github.com/open-mmlab/mmcv/blob/master/mmcv/ops/roi_align_rotated.py

But for our RiRoIAlign, I have no time to implement the cpu version. If you still want to use it, please refer to: https://github.com/csuhan/ReDet/blob/master/mmdet/ops/riroi_align/src/riroi_align_kernel.cu https://github.com/open-mmlab/mmcv/blob/master/mmcv/ops/csrc/pytorch/cpu/roi_align_rotated.cpp I think it would not be hard to implement the cpu version.

csuhan avatar Dec 16 '21 12:12 csuhan

@DangChuong-DC i tried , but there is a new error.... but thanks image

yinnengzhong avatar Dec 16 '21 13:12 yinnengzhong

@jigongbao , try nms_cpu instead. https://github.com/csuhan/ReDet/blob/0b9addf3c2734659fd6ffc7824f2e659fde4419c/mmdet/ops/nms/nms_wrapper.py#L48-L51

csuhan avatar Dec 16 '21 18:12 csuhan

@csuhan thanks image image image i try to change some code in other place and it works correctly.

yinnengzhong avatar Dec 17 '21 05:12 yinnengzhong

@csuhan Thanks a lot for your explanations, I will have a look on it

DangChuong-DC avatar Dec 17 '21 08:12 DangChuong-DC