-
Notifications
You must be signed in to change notification settings - Fork 568
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
create the block of eca in Dev 1.x #737
base: main
Are you sure you want to change the base?
Conversation
* init * delete github action * test * Update version.py * Update version.py
* delete UT * revert * update * Update test.yml
* update * fix lint * update ut * fix * Update dota.py * Update dota.py * Update anchor_generator.py * Update dota.py * Update registry.py * update metric * add format ut * add merge_patches in DOTAMetric * Update dota_metric.py * Update mmrotate/datasets/dota.py Co-authored-by: RangiLyu <[email protected]> * Update mmrotate/evaluation/metrics/dota_metric.py Co-authored-by: RangiLyu <[email protected]> * Update dota_metric.py Co-authored-by: RangiLyu <[email protected]>
* init * Update default_runtime.py
#450) * Initialize RotatedBoxes and QuadriBoxes * Move all box modes into Structures, Add docstring * Update docstring * Upload UT * Fix comments * Update inplace operations * Update * Update * Update * Update * Updata rotate and project UT * Update * Update * Update * Update * update * Update from_instance_masks
* add * add * Update dota_metric.py * update * fix lint * remove hrsc metric * fix typo * Update dota_metric.py * Update mmrotate/datasets/hrsc.py Co-authored-by: RangiLyu <[email protected]> * Update mmrotate/datasets/hrsc.py Co-authored-by: RangiLyu <[email protected]> * Update hrsc.py * Update hrsc.py Co-authored-by: RangiLyu <[email protected]>
* init * fix lint
* init * fix lint * update * add UT * fix lint * update coder * Update mmrotate/core/bbox/iou_calculators/rotate_iou2d_calculator.py Co-authored-by: RangiLyu <[email protected]> * fix docstring Co-authored-by: RangiLyu <[email protected]>
* init * fix lint * update * update coder * init * fix lint * fix bug in DOTA metric * Update delta_xywht_hbbox_coder.py * support tensor input when coder.decode. In two stage detectors and refine single stage detectors, the bboxes can be Tensor. * Update rotated_retinanet_obb_r50_fpn_1x_dota_le90.py * support use_box_type in coder * fix bug * fix
* init * fix lint * update * update coder * init * update * update ut * fix lint * Update delta_xywht_hbbox_coder.py * Update delta_xywht_hbbox_coder.py * update ut * fix docstring * fix * update * fix * add UT * Create cascade_s2anet_r50_fpn_1x_dota_le135.py * Update refine_single_stage.py * Update refine_single_stage.py * fix bug when run demo image * Update refine_single_stage.py * fix bug * Update refine_single_stage.py * fix docstring
* update * Update test_two_stage.py * Update s2anet_r50_fpn_fp16_1x_dota_le135.py * add UT * Update test_delta_midpointoffset_rbbox_coder.py * update * Update oriented_rcnn_r50_fpn_fp16_1x_dota_le90.py
* Refactor oriented rcnn (#515) * update * Update test_two_stage.py * Update s2anet_r50_fpn_fp16_1x_dota_le135.py * add UT * Update test_delta_midpointoffset_rbbox_coder.py * update * Update oriented_rcnn_r50_fpn_fp16_1x_dota_le90.py * update * update * fix lint * Update re_resnet.py * Update re_resnet.py
* init * add UT * fix lint * Update rotated_reppoints_head.py * Update rotated_reppoints_r50_fpn_1x_dota_qbox.py * fix
* init * fix bug * add UT * fix lint * fix docstring * update * fix
* add UT * fix lint * init * fix * Update oriented_reppoints_head.py * update * Update test_oriented_reppoints.py * fix error when train * fix UT * update docstring * Update mmrotate/models/dense_heads/oriented_reppoints_head.py Co-authored-by: RangiLyu <[email protected]> * Update mmrotate/models/dense_heads/oriented_reppoints_head.py Co-authored-by: RangiLyu <[email protected]> * Update mmrotate/models/dense_heads/oriented_reppoints_head.py Co-authored-by: RangiLyu <[email protected]> * Update oriented_reppoints_head.py * upgrade pre-commit-hook Co-authored-by: RangiLyu <[email protected]>
* add UT * fix lint * update * Update test_oriented_reppoints.py * fix UT * init * Update angle_branch_retina_head.py * add ut * Update test_angle_coder.py * add UT * Update test_angle_branch_retina_head.py * fix * fix
ABCs were moved from collections to collections.abc in 3.3. Since 3.10, ABCs cannot be imported directly from collections.
1. Removed invalid `score_threshold` arg in `nms_rotated` call 2. Passed `--color-theme` to `plot_confusion_matrix`
* fcos for 1.x * update config * add test * fix config * fix * fix * fix * remove useless class
* add UT * fix lint * update * Update test_oriented_reppoints.py * fix UT * init * fix * add UT * fix lint * update * fix
* Update s2anet_r50_fpn_fp16_1x_dota_le135.py * add UT * Update test_delta_midpointoffset_rbbox_coder.py * update * fix lint * update * update * add rbox version * fix * add UT * fix lint
* old version * delete fake atss * add ut * Update UT * update docstring
* delete 0.x docs * init new en/docs * fix lint * fix docs error * Update changelog_v0.x.md * update get_started.py * Update get_started.md * Update docs/en/conf.py Co-authored-by: RangiLyu <[email protected]> * update en * update zh_CN * Update conf.py * fix Co-authored-by: RangiLyu <[email protected]>
* update * fix lint * update * update * fix ut * Update test_angle_coder.py * fix * Update __init__.py * fix * fix ut bugs
* update * update * fix lint * update * update * Update gliding-vertex-rbox_r50_fpn_1x_dota.py * update ms configs * update hrsc configs * fix lint * Update configs/redet/README.md Co-authored-by: RangiLyu <[email protected]> Co-authored-by: RangiLyu <[email protected]>
* Add Rotated COCO Metric * Fix Co-authored-by: Yue Zhou <[email protected]>
* update issue template * Update .github/ISSUE_TEMPLATE/1-bug-report.yml Co-authored-by: RangiLyu <[email protected]> Co-authored-by: RangiLyu <[email protected]>
* update * update citation * update * update * update * update
* update * Update README.md
…#731) * init headet * feat: add train and test * feat:update readme * feat: add h180 * docs: update readme * feat: update readme * feat: add datatsets * docs: update h180 comments * feat: add configs-ic19-obb-obb configs * feat: update metric * feat: update metric * feat: delete unnecessary * feat: init rtmdet * feat: update datasets * feat: update local_visualizer comments * feat: add benchmark.py * docs: update * docs: update * feat: update angle h180 in rtmdet * feat: add roi_trans * feat: add 180 * docs: update RotatedBoxes * feat: add r_l1_loss * feat: add rl1 loss config * feat: update checkpoint hook * feat: change the weight * feat: update the loss weight 5 * fix: reletive import * feat: fix the APH metric * fix: fix the regularize_boxes * fix: fix the edge_swap=False * feat: init the tests in headet * feat: strict the loss * update interval * feat: update logger config * feat: support rtmdet 360 * feat: delete unnecessery comment * feat: init the ic19 datasets * feat: init ic19 datasets * feat: add rotated_rtmdet_x3 * feat: add rotated_rtmdet_x3_r * feat: update rtmdet * feat: add a1l1 loss * docs: update readme * rename headet to RR360 Det * feat: refactor the config * docs: update readme * fix: headet to RR360 * fix: delete unuse * add test script * feat: update readme * fdocs: update script * docs: update * docs: update * docs: update * docs: update * docs: update * remove the configs180 * docs: update * delete the unuse * delete the unuse * delete the unuse * feat: delete the unuse * docs: delete the unuse * delete unuse * delete the unuse * delete the unuse * fix: replace h180 with r360 * feat: delete the Unnecessary Comments * feat: add rotated_retinanet * fix: DOTAHeadMetric to DOTAR360Metric * fix: hangle_thr to angle_thr * fix: ORLocalVisualizer to RR360LocalVisualizer * fix: delete the mmcls.models * fix: delete the benckmark * fix: pre-commit * fix: delete unuse * fix: dota_head_metric to dota_r360_metric * fix: AP(T<xxxx) * [Fix]: mAPH to mAP * docs: update readme * docs: update * fix: ICDAR2019_MTD_HOQ to TRR360D * fix: delete the unuse a l1 loss * fix: delete the unuse model import * docs: update * fix: disable wandb * feat: add without l1_loss * docs: update en docs * docs: update the datasets link * docs: add todo
* Update hrsid.py * Update configs/_base_/datasets/hrsid.py Co-authored-by: RangiLyu <[email protected]> --------- Co-authored-by: RangiLyu <[email protected]>
* LSKNet implementation * passed by pre-commit * update configs * Update lsknet.py * Update projects/LSKNet/README.md Co-authored-by: Yue Zhou <[email protected]> * Update projects/LSKNet/README.md Co-authored-by: Yue Zhou <[email protected]> * Update projects/LSKNet/README.md Co-authored-by: Yue Zhou <[email protected]> * Update projects/LSKNet/README.md Co-authored-by: Yue Zhou <[email protected]> * Update projects/LSKNet/README.md Co-authored-by: Yue Zhou <[email protected]> * update * update ckpt download link * update ckpt links * update pretrained weight link * update pretrained weight link * update pretrained weight link * update pretrained weight link * pre-commit checked --------- Co-authored-by: Yue Zhou <[email protected]>
* update * Update dota_coco.py * update * fix
* [doc]:add more social network links * [doc]:add more social network links
Hi @wqe123321 !We are grateful for your efforts in helping improve this open-source project during your personal time. Welcome to join OpenMMLab Special Interest Group (SIG) private channel on Discord, where you can share your experiences, ideas, and build connections with like-minded peers. To join the SIG channel, simply message moderator— OpenMMLab on Discord or briefly share your open-source contributions in the #introductions channel and we will assist you. Look forward to seeing you there! Join us :https://discord.gg/UjgXkPWNqA Thank you again for your contribution❤ |
* Support H2RBox-v2 * Update README * Add figure in README * Update figure in README * Fix README lint problem
* [doc]:add more social network links * [doc]:add more social network links * [Feature] support semi-automatic annotation base Label-Studio * [fix] change the name and url to mmrotate * [fix] resolve conflict
* fix lsknet * fix some comment
* fix confusion_matrix * fix opencv error
There seems to be a lack of indentation, resulting in an assignment bug when square classes are not processed.
* [Fix] Fix nan loss in RotatedIoULoss when using AmpOptimizer * Fix lint
* update version in __init__.py * update version in mminstall.txt * update version in en faq.md * update version in zh_cn faq.md
Update NIPS information of h2rbox-v2
Thanks for your contribution and we appreciate it a lot. The following instructions would make your pull request more healthy and more easily get feedback. If you do not understand some items, don't worry, just make the pull request and seek help from maintainers.
Motivation
I want to add an attention module to the Neck part, in order to enhance the attention to features.
Modification
code is following:
import torch.nn as nn
import torch.nn.functional as F
from mmcv.cnn import ConvModule
from mmcv.runner import BaseModule, auto_fp16
from ..builder import NECKS
from mmrotate.models.builder import ROTATED_NECKS
class eca_layer(nn.Module):#eca注意力
def init(self, channel, k_size=3):
super(eca_layer, self).init() # super类的作用是继承的时候,调用含super的哥哥的基类__init__函数。
self.avg_pool = nn.AdaptiveAvgPool2d(1) # 全局平均池化
self.max_pool = nn.AdaptiveMaxPool2d(1)
self.conv = nn.Conv1d(1, 1, kernel_size=k_size,
padding=(k_size - 1) // 2, bias=False) # 基于1*1卷积学习通道之间的信息
self.sigmoid = nn.Sigmoid() # 激活函数
@ROTATED_NECKS.register_module()
class ECA(BaseModule): #eca注意力
def init(self,
in_channels,
out_channels,
num_outs,
start_level=0,
end_level=-1,
add_extra_convs=False,
relu_before_extra_convs=False,
no_norm_on_lateral=False,
conv_cfg=None,
norm_cfg=None,
act_cfg=None,
upsample_cfg=dict(mode='nearest'),
init_cfg=dict(
type='Xavier', layer='Conv2d', distribution='uniform')):
super(FPN_eca, self).init(init_cfg)
assert isinstance(in_channels, list)
self.in_channels = in_channels
self.out_channels = out_channels
self.num_ins = len(in_channels)
self.num_outs = num_outs
self.relu_before_extra_convs = relu_before_extra_convs
self.no_norm_on_lateral = no_norm_on_lateral
self.fp16_enabled = False
self.upsample_cfg = upsample_cfg.copy()
#包含了每一个特征图的操作
# add extra conv layers (e.g., RetinaNet)
extra_levels = num_outs - self.backbone_end_level + self.start_level
if self.add_extra_convs and extra_levels >= 1:
for i in range(extra_levels):
if i == 0 and self.add_extra_convs == 'on_input':
in_channels = self.in_channels[self.backbone_end_level - 1]
else:
in_channels = out_channels
extra_fpn_conv = ConvModule(
in_channels,
out_channels,
3,
stride=2,
padding=1,
conv_cfg=conv_cfg,
norm_cfg=norm_cfg,
act_cfg=act_cfg,
inplace=False)
self.fpn_convs.append(extra_fpn_conv)