channel-pruning

channel-pruning

通道剪枝技术加速深度神经网络

Channel Pruning 项目开发了一种通道剪枝技术,用于加速深度神经网络。该技术显著提高了 VGG-16、ResNet-50 等模型的推理速度,同时保持了较高准确率。项目还包含针对 Faster R-CNN 的剪枝方法,为计算机视觉任务提供了高效解决方案。具体实现了 VGG-16 模型 4 倍和 5 倍的加速,ResNet-50 模型 2 倍加速,以及 Faster R-CNN 2 倍和 4 倍加速。这些优化后的模型在 ImageNet 分类和目标检测任务上仍保持了较高性能。项目提供了代码和预训练模型,方便研究者复现实验结果。

Channel Pruning神经网络加速模型压缩深度学习计算机视觉Github开源项目

通道剪枝以加速超深度神经网络

图片

GitHub - yihui-he/channel-pruning: 通道剪枝以加速超深度神经网络 (ICCV'17)

通道剪枝以加速超深度神经网络

ICCV 2017, 作者:何宜晖张祥雨孙剑

请查看我们在压缩深度模型方面的新作品:

在这个代码库中,我们发布了以下模型的代码:

模型加速比准确率
https://github.com/yihui-he/channel-pruning/releases/tag/channel_pruning_5x5倍88.1 (Top-5), 67.8 (Top-1)
https://github.com/yihui-he/channel-pruning/releases/tag/VGG-16_3C4x4倍89.9 (Top-5), 70.6 (Top-1)
https://github.com/yihui-he/channel-pruning/releases/tag/ResNet-50-2X2倍90.8 (Top-5), 72.3 (Top-1)
https://github.com/yihui-he/channel-pruning/releases/tag/faster-RCNN-2X4X2倍36.7 (AP@.50:.05:.95)
https://github.com/yihui-he/channel-pruning/releases/tag/faster-RCNN-2X4X4倍35.1 (AP@.50:.05:.95)

3C方法结合了空间分解(使用低秩展开加速卷积神经网络)和通道分解(加速用于分类和检测的超深度卷积网络)(在4.1.2节中提到)

引用

如果您在研究中发现这些代码有用,请考虑引用:

@InProceedings{He_2017_ICCV,
author = {He, Yihui and Zhang, Xiangyu and Sun, Jian},
title = {Channel Pruning for Accelerating Very Deep Neural Networks},
booktitle = {The IEEE International Conference on Computer Vision (ICCV)},
month = {Oct},
year = {2017}
}

要求

  1. 您可能没有的Python3包:scipysklearneasydict,使用sudo pip3 install安装。
  2. 对于128批量大小的微调,需要4个GPU(约11G内存)

安装(足够运行演示)

  1. 克隆代码库

    # 确保使用--recursive克隆 git clone --recursive https://github.com/yihui-he/channel-pruning.git
  2. 构建我的Caffe分支(支持双三次插值和将图像较短边调整为256然后裁剪到224x224)

    cd caffe # 如果您熟悉Caffe并已安装所有要求,只需执行: make all -j8 && make pycaffe # 或按照Caffe安装说明进行操作: # http://caffe.berkeleyvision.org/installation.html # 如果您之前已经有了caffe,可能需要将pycaffe添加到PYTHONPATH
  3. 下载ImageNet分类数据集 http://www.image-net.org/download-images

  4. temp/vgg.prototxt中指定imagenet source路径(第12行和第36行)

通道剪枝

为了快速测试,您可以直接下载已剪枝的模型。请参见[下一节](https://github.com/ethanhe42/channel-pruning/blob/master/about:blank#pruned-models-for-download 1. 下载原始VGG-16模型 http://www.robots.ox.ac.uk/~vgg/software/very_deep/caffe/VGG_ILSVRC_16_layers.caffemodel 将其移动到temp/vgg.caffemodel(或创建一个软链接)

  1. 开始通道剪枝
python3 train.py -action c3 -caffe [GPU0] # 或者使用 ./run.sh python3 train.py -action c3 -caffe [GPU0] 进行日志记录 # 将 [GPU0] 替换为实际的 GPU 设备,如 0、1 或 2
  1. 合并一些分解后的层以进一步压缩,并计算加速比。将 temp/cb_3c_3C4x_mem_bn_vgg.prototxt 中的 ImageData 层替换为 [temp/vgg.prototxt 中的相应部分。执行 Shell ./combine.sh | xargs ./calflop.sh

  2. 微调

caffe train -solver temp/solver.prototxt -weights temp/cb_3c_vgg.caffemodel -gpu [GPU0,GPU1,GPU2,GPU3] # 将 [GPU0,GPU1,GPU2,GPU3] 替换为实际的 GPU 设备,如 0,1,2,3
  1. 测试

虽然在微调过程中会进行测试,但你可以随时使用以下命令进行测试:

caffe test -model path/to/prototxt -weights path/to/caffemodel -iterations 5000 -gpu [GPU0] # 将 [GPU0] 替换为实际的 GPU 设备,如 0、1 或 2

剪枝模型(可下载)

为快速测试,你可以直接从发布页面下载剪枝后的模型:VGG-16 3C 4XVGG-16 5XResNet-50 2X。或者使用百度网盘下载链接

使用以下命令进行测试:

caffe test -model channel_pruning_VGG-16_3C4x.prototxt -weights channel_pruning_VGG-16_3C4x.caffemodel -iterations 5000 -gpu [GPU0]
# 将 [GPU0] 替换为实际的 GPU 设备,如 0、1 或 2

剪枝 Faster RCNN

为快速测试,你可以直接从发布页面下载剪枝后的模型。或者你可以:1. 克隆我的 py-faster-rcnn 仓库:https://github.com/yihui-he/py-faster-rcnn 2. 使用本仓库中的剪枝模型来训练 Faster RCNN 2X、4X,solver prototxt 文件在 https://github.com/yihui-he/py-faster-rcnn/tree/master/models/pascal_voc

常见问题

你可以在我们的 Github wiki 中找到一些常见问题的答案,或者直接创建新的 issue

编辑推荐精选

TRAE编程

TRAE编程

AI辅助编程,代码自动修复

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
商汤小浣熊

商汤小浣熊

最强AI数据分析助手

小浣熊家族Raccoon,您的AI智能助手,致力于通过先进的人工智能技术,为用户提供高效、便捷的智能服务。无论是日常咨询还是专业问题解答,小浣熊都能以快速、准确的响应满足您的需求,让您的生活更加智能便捷。

imini AI

imini AI

像人一样思考的AI智能体

imini 是一款超级AI智能体,能根据人类指令,自主思考、自主完成、并且交付结果的AI智能体。

Keevx

Keevx

AI数字人视频创作平台

Keevx 一款开箱即用的AI数字人视频创作平台,广泛适用于电商广告、企业培训与社媒宣传,让全球企业与个人创作者无需拍摄剪辑,就能快速生成多语言、高质量的专业视频。

即梦AI

即梦AI

一站式AI创作平台

提供 AI 驱动的图片、视频生成及数字人等功能,助力创意创作

扣子-AI办公

扣子-AI办公

AI办公助手,复杂任务高效处理

AI办公助手,复杂任务高效处理。办公效率低?扣子空间AI助手支持播客生成、PPT制作、网页开发及报告写作,覆盖科研、商业、舆情等领域的专家Agent 7x24小时响应,生活工作无缝切换,提升50%效率!

蛙蛙写作

蛙蛙写作

AI小说写作助手,一站式润色、改写、扩写

蛙蛙写作—国内先进的AI写作平台,涵盖小说、学术、社交媒体等多场景。提供续写、改写、润色等功能,助力创作者高效优化写作流程。界面简洁,功能全面,适合各类写作者提升内容品质和工作效率。

AI辅助写作AI工具蛙蛙写作AI写作工具学术助手办公助手营销助手AI助手
问小白

问小白

全能AI智能助手,随时解答生活与工作的多样问题

问小白,由元石科技研发的AI智能助手,快速准确地解答各种生活和工作问题,包括但不限于搜索、规划和社交互动,帮助用户在日常生活中提高效率,轻松管理个人事务。

热门AI助手AI对话AI工具聊天机器人
Transly

Transly

实时语音翻译/同声传译工具

Transly是一个多场景的AI大语言模型驱动的同声传译、专业翻译助手,它拥有超精准的音频识别翻译能力,几乎零延迟的使用体验和支持多国语言可以让你带它走遍全球,无论你是留学生、商务人士、韩剧美剧爱好者,还是出国游玩、多国会议、跨国追星等等,都可以满足你所有需要同传的场景需求,线上线下通用,扫除语言障碍,让全世界的语言交流不再有国界。

讯飞智文

讯飞智文

一键生成PPT和Word,让学习生活更轻松

讯飞智文是一个利用 AI 技术的项目,能够帮助用户生成 PPT 以及各类文档。无论是商业领域的市场分析报告、年度目标制定,还是学生群体的职业生涯规划、实习避坑指南,亦或是活动策划、旅游攻略等内容,它都能提供支持,帮助用户精准表达,轻松呈现各种信息。

AI办公办公工具AI工具讯飞智文AI在线生成PPTAI撰写助手多语种文档生成AI自动配图热门
下拉加载更多