-
Notifications
You must be signed in to change notification settings - Fork 10
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
conv pruning issue #7
Comments
my model structure :
BatchNorm2d prune info
|
如果我运行main.py的slimprune会报这个错 |
如果 fpn 各层是 sum 的,可以在 "shortcuts" 配置里手动加一组 fpn 的 bn 名字 {
"names": [
"fpn.norm1",
"fpn.norm2",
"fpn.norm3"
],
"method": "or"
}, 或者只剪 backbone 部分 |
如果fpn没有bn层呢,你可以看一下我上面的网络结构,两个四层的block,都是conv。如果不剪fpn,那每个resnet的剪过的层输出怎么给没变化的fpn各层 |
resnet 每个 stage 最后一层 bn 前的 conv,在配置里把 "next_bn" 改成空字符串,这样输出的 channel 就不会变 |
你好,请问怎么设置只裁剪backbone部分? |
初始化 |
感谢回答,我尝试了你的建议,修改了各个downsample前一层的next_bn,但是downsampling里面的batchnorm并未改变,请问该怎么做? 之前的: 改了之后的: (layer1): ResLayer( |
感谢您的回答!现在我已可以跑通整个模型结构,是更改了fpn的输入尺寸和resnet的4个layer输出尺寸相同即可,然后还有一点疑问,就是slimpruner这个工具的参数移植在哪呀,而且我部分修改的网络从哪里进行筛选需要转移的参数,我知道需要大模型的剪枝部分的参数移植才能恢复较高的精度。 |
你好,请问你是直接修改了json文件里面的fpn的next_bn吗? |
不用,删除json里fpn的4个256-->256的layer_block(注意inner_block不要删)和包含conv的rpn的结构(linear的不要删),然后在pns.py的218行左右的isinstance(module,Conv2d)后面增加判断条件筛选不需要剪枝的部分,比如 and name != 'backbone.fpn.layer_blocks.0'的四个以及rpn的三个,意思就是这些部分都不剪,总共只改输入的fpn的inner_layer的输入尺寸
…------------------ 原始邮件 ------------------
发件人: ***@***.***>;
发送时间: 2021年9月30日(星期四) 上午10:17
收件人: ***@***.***>;
抄送: ***@***.***>; ***@***.***>;
主题: Re: [Sanster/pytorch-network-slimming] conv pruning issue (#7)
感谢您的回答!现在我已可以跑通整个模型结构,是更改了fpn的输入尺寸和resnet的4个layer输出尺寸相同即可,然后还有一点疑问,就是slimpruner这个工具的参数移植在哪呀,而且我部分修改的网络从哪里进行筛选需要转移的参数,我知道需要大模型的剪枝部分的参数移植才能恢复较高的精度。
你好,请问你是直接修改了json文件里面的fpn的next_bn吗?
—
You are receiving this because you authored the thread.
Reply to this email directly, view it on GitHub, or unsubscribe.
Triage notifications on the go with GitHub Mobile for iOS or Android.
|
|
感谢你的建议,模型能剪枝成功了,但是在跑推理的时候出现了size_mismatch的问题,应该是全连接层那里出错了,请问你有遇到这个错误吗? |
是的,4 里面的 pruned_model 直接finetune,然后保存到你喜欢的地方。5 是加载 finetune 好的剪枝模型的步骤,pruned_state_dict 需要你自己加载 4 里面 finetune 好的参数 |
之前报了size_mismatch问题,我去掉了对fc层的剪枝,然后跑推理,速度提升了20%,但是mAP全部为0,请问你那边性能如何? |
|
如果只剪 backbone 的话,稀疏化训练的正则也应该只应用到 backbone 的参数上,这里可能要改下。你是 finetune 了多少步呢?我之前是训 DBNet,语义分割作文本检测,0.5 的剪枝率(backbone+fpn+head都剪了)基本是无损的 |
请问你一开始一定是稀疏化训练的吗?我是直接拿训练好的网络剪枝的 |
。。。一定要稀疏化训练的 |
感谢回答,主要我是在mmdet上改的,请问你当时dbnet是在mmocr上改的还是在官方的上面改的啊? |
detectron2。业务上用的话其实剪枝前可以直接试试mobilenet v3,可能就能满足需求了 。。 |
好像这个不能够真正生成小模型,从创建模型开始。实际上是创建了大模型然后赋值了保存的小模型的参数,好像不能实际部署啊 |
部署有两种选择
|
我想要的是直接创建小型的模型结构,而不是通过apply_pruning_result置零的方式,如何去通过index创建小模型结构有什么建议吗 |
apply_pruning_result 不是置零,是真的修改了conv 的权重
|
嗯嗯,我知道实际修改了,但有没有可以直接在第一次创建模型的时候,在apply之前就是小模型的方法呢 |
这样做目的是为了什么呢?据我所知没有,只能转 onnx,torchscript 这种。 |
就是如果第一次就直接创建大模型,然后在线prune就不太符合我的要求,想要的是直接创建小的模型,然后直接加载参数就够了,不需要prune_result这样的文件去加载和在线剪枝。我可以根据尺寸在创建模型的时候就直接创建独特的小模型吧 |
可以的,要改 build 网络的代码,把每层 Conv/BN 的 channel 数传进去,类似原作者的 pytorch 实现 link defaultcfg = {
11 : [64, 'M', 128, 'M', 256, 256, 'M', 512, 512, 'M', 512, 512],
13 : [64, 64, 'M', 128, 128, 'M', 256, 256, 'M', 512, 512, 'M', 512, 512],
16 : [64, 64, 'M', 128, 128, 'M', 256, 256, 256, 'M', 512, 512, 512, 'M', 512, 512, 512],
19 : [64, 64, 'M', 128, 128, 'M', 256, 256, 256, 256, 'M', 512, 512, 512, 512, 'M', 512, 512, 512, 512],
}
class vgg(nn.Module):
def __init__(self, dataset='cifar10', depth=19, init_weights=True, cfg=None):
super(vgg, self).__init__()
if cfg is None:
cfg = defaultcfg[depth]
self.feature = self.make_layers(cfg, True) |
好的,感谢您耐心的讲解!!! |
Thanks for your work, i have pruning my two-stage detection model faster rcnn with the resnet50+fpn backbone, while running the gen_schema.py, i met a conv pruned issue, becuase the model isn't the classification task, is there anything i need to change,
Traceback (most recent call last): File "gen_schema.py", line 86, in <module> pruner.run(0.6) File "model_compression/src/pns/pns.py", line 311, in run self.bn2d_modules[conv2d.next_bn_name] if conv2d.next_bn_name else None, File "model_compression/src/pns/pns.py", line 53, in prune next_bn.keep_idxes if next_bn else None, File "model_compression/src/pns/functional.py", line 97, in prune_conv2d module.bias = torch.nn.Parameter(module.bias.data[out_keep_idxes]) RuntimeError: CUDA error: device-side assert triggered
My email is [email protected] and my wechat is 13773273112.Looking forward to your reply, thanks!
The text was updated successfully, but these errors were encountered: