-
Notifications
You must be signed in to change notification settings - Fork 611
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Fix Deformable Convolutional Op Support #179 #1129
Fix Deformable Convolutional Op Support #179 #1129
Conversation
Check out this pull request on You'll be able to see Jupyter notebook diff and discuss changes. Powered by ReviewNB. |
This comment has been minimized.
This comment has been minimized.
This comment has been minimized.
This comment has been minimized.
This comment has been minimized.
This comment has been minimized.
We used black to format some files in the master branch. To avoid future conflicts, I updated your pull request. Please do |
@smallsunsun1 when swapping where |
Thanks for you suggestion, I will align |
I think I have already finish all the work. Can any one review this PR and give some comments. @seanpmorgan @Squadrick |
@smallsunsun1 Can you pull from Also, please take a look at #1328, we've changed our testing procedure. Sorry about the delay, I'll review the PR soon. |
@mdv3101 This is quite a massive PR, it'll take me a while to review and test its correctness. If you want it immediately, you can clone @smallsunsun1's repo and test it out yourself (in case there's any issues you can report back). Also, any help with reviews would be much appreciated too. |
Hi bro, |
It is |
DeformableConv2D: serialization fixes
Any progress on this ? |
It would be nice to use deformable convolutions with tensorflow. When do you think it will be merged ? |
deformable_conv2d.py serialization fix
We found a Contributor License Agreement for you (the sender of this pull request), but were unable to find agreements for all the commit author(s) or Co-authors. If you authored these, maybe you used a different email address in the git commits than was used to sign the CLA (login here to double check)? If these were authored by someone else, then they will need to sign a CLA as well, and confirm that they're okay with these being contributed to Google. ℹ️ Googlers: Go here for more info. |
This PR is quite stale. I would recommend that we can split kernels/layers and example into different PR to help us review faster. Also, there are many code segments that can be directly reused from core TF such as |
It is appreciate if you can help deal with these. I don't have much time to update this PR now. |
Sure, then I'll open a new PR and ping you. |
Thanks for the nice PR. However, when I test DeformableConv2D on Scaled MNIST, the results are very variable depending on the im2col parameter. I also found this implementation very similar to yours: https://github.com/BIGKnight/deformable_conv2d_v2_tensorflow In this repository, the author mentions that it is necessary to make a swapaxis if we want to use im2col > 1. In the file deformable_conv2d_op/deformable_conv2d.cc line 333, you can even see which line the author has planned to do it (https://github.com/BIGKnight/deformable_conv2d_v2_tensorflow/blob/e0491b3bae08561a6a932000e535759c605b0837/deformable_conv2d_op/deformable_conv2d.cc#L333); however I don't see any trace of swapaxis in your code. Thank you in advance for your answer |
When im2col > 1, current implementation is wrong.
The c++ part of DeformableConv2D is largely based on this repo(https://github.com/BIGKnight/deformable_conv2d_v2_tensorflow,DeformablePSRoIAlign code mainly based on official Pytorch version. I think the Parameter im2col do nothing with the speed of kernel execution, when im2col not equal to 1, current implemention does not work. at first I want to add assertion in python code to ensure and tell users im2col always to be 1, but finally I forgot it.
…------------------ 原始邮件 ------------------
发件人: "tensorflow/addons" <notifications@github.com>;
发送时间: 2020年7月22日(星期三) 凌晨0:38
收件人: "tensorflow/addons"<addons@noreply.github.com>;
抄送: "sss"<975759105@qq.com>;"Mention"<mention@noreply.github.com>;
主题: Re: [tensorflow/addons] Fix Deformable Convolutional Op Support #179 (#1129)
Hi @smallsunsun1
Thanks for the nice PR.
I merged your PR locally and I was able to run DeformableConv2D without any major problems.
However, when I test DeformableConv2D on Scaled MNIST, the results are very variable depending on the im2col parameter.
When im2col = 1 and batch_size=32 the results are rather good (accuracy > 95% in 5 epochs) ; but when im2col = 32 with batch_size=32, the results are very bad (accuracy < 50% in 5 epochs).
Is this drop in accuracy normal? If so, can you explain me the reasons?
I also found this implementation very similar to yours: https://github.com/BIGKnight/deformable_conv2d_v2_tensorflow
In this repository, the author mentions that it is necessary to make a swapaxis if we want to use im2col > 1. In the file deformable_conv2d_op/deformable_conv2d.cc line 333, you can even see which line the author has planned to do it (https://github.com/BIGKnight/deformable_conv2d_v2_tensorflow/blob/e0491b3bae08561a6a932000e535759c605b0837/deformable_conv2d_op/deformable_conv2d.cc#L333); however I don't see any trace of swapaxis in your code.
Can you explain to me why you removed the swapaxis? Isn't that the reason for bad learning when im2col > 1 ?
Thank you in advance for your answer
—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub, or unsubscribe.
|
Thanks for your quick reply.
This corresponds to my observation; thanks for your confirmation.
I thought so. There's a lot of identical code between your two repositories. But why didn't you mention that anywhere? I didn't see any reference to his work in your code.
I'm not sure about that statement, what do you base it on? From what I've seen from BIGKnight's code but also from the original code, Thanks in advance for your answer |
My previous conclusion is wrong. I read the code now, confirmed that there will be less times to call gpu and cpu kernel function if im2col become larger. maybe at first implentation, I just guarantee the cpu and gpu implementation are right, to be honest, this repo is my first time to write PR and so large cpp code, there always to have some problem..... you can update the code to make im2col work both in cpu and gpu mode.
…---Original---
From: "oubathAI"<notifications@github.com>
Date: Wed, Jul 22, 2020 03:33 AM
To: "tensorflow/addons"<addons@noreply.github.com>;
Cc: "Mention"<mention@noreply.github.com>;"smallsunsun1"<975759105@qq.com>;
Subject: Re: [tensorflow/addons] Fix Deformable Convolutional Op Support #179 (#1129)
Thanks for your quick reply.
when im2col not equal to 1, current implemention does not work
This corresponds to my observation; thanks for your confirmation.
The c++ part of DeformableConv2D is largely based on this repo (https://github.com/BIGKnight/deformable_conv2d_v2_tensorflow
I thought so. There's a lot of identical code between your two repositories. But why didn't you mention that anywhere? I didn't see any reference to his work in your code.
I think the Parameter im2col do nothing with the speed of kernel execution,
I'm not sure about that statement, what do you base it on?
The code you rely on is itself an adaptation of the code repository Deformable-ConvNets.
It is clearly stated in the FAQ of the original code that im2col can enhance performance; I quote "The updated operator is significantly faster than the existing one when the image batch size is large".
This seems logical when you look at the code; indeed in the PR you submitted, if you look at the file deformable_conv_op.cc line 1017 you can see that the loop for (int32_t n = 0; n < num_ / im2col_step_; ++n) depends on im2col; the greater im2col will be, the less loops will be; therefore the calculation will be faster.
From what I've seen from BIGKnight's code but also from the original code, swapaxis is necessary to perform the operations with im2col (even if I didn't understand why). I guess the reason you didn't include swapaxis in your code is because you couldn't port it?
Thanks in advance for your answer
—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub, or unsubscribe.
|
Hi, I tried to run the PR on tensorflow 2.3 and had the following errors: I thought I'd let you know so it can be fixed before the PR is merged :-). |
Looking forward to it! Do you have any news about the progress of this PR? |
I don't think we have the bandwidth to maintain this custom ops. If you are still interested please contribute the python layer to https://github.com/keras-team/keras-cv. |
Add cpu and gpu implementation for Deformable Conv2d and DeformablePSROIAlign according to https://arxiv.org/abs/1811.11168, EquiConv according to https://arxiv.org/pdf/1903.08094.pdf.
The original #1056 has closed because of use wrong email-address in commit history.