随着深度学习模型日益复杂,准确评估模型的计算复杂度变得越来越重要。FLOPs(浮点运算次数)是衡量模型计算复杂度的重要指标之一。本文将介绍一个强大的FLOPs计算工具 - calflops,它可以方便地计算各种PyTorch神经网络模型的FLOPs、MACs和参数数量。
calflops是一个专门用于计算PyTorch模型理论FLOPs、MACs(乘加运算次数)和参数数量的Python库。它具有以下主要特点:
支持各种神经网络结构,包括Linear、CNN、RNN、GCN、Transformer等。
可计算大语言模型(如BERT、LLaMA等)的FLOPs。
支持自定义模型,只要基于PyTorch实现。
可打印每个子模块的FLOPs、参数等详细信息。
支持在线计算Hugging Face模型的FLOPs,无需下载完整权重。
calflops可以通过pip安装:
pip install --upgrade calflops
基本使用示例:
from calflops import calculate_flops from torchvision import models model = models.alexnet() batch_size = 1 input_shape = (batch_size, 3, 224, 224) flops, macs, params = calculate_flops(model=model, input_shape=input_shape, output_as_string=True) print(f"AlexNet FLOPs:{flops} MACs:{macs} Params:{params}")
这将输出AlexNet模型的FLOPs、MACs和参数数量。
对于Transformer类模型,calflops提供了更便捷的使用方式:
from calflops import calculate_flops from transformers import AutoModel, AutoTokenizer model_name = "bert-base-uncased" model = AutoModel.from_pretrained(model_name) tokenizer = AutoTokenizer.from_pretrained(model_name) flops, macs, params = calculate_flops(model=model, input_shape=(1, 128), transformer_tokenizer=tokenizer) print(f"BERT FLOPs:{flops} MACs:{macs} Params:{params}")
通过传入transformer_tokenizer
,calflops可以自动生成合适的输入数据。
calflops还支持直接计算Hugging Face上的模型,无需下载完整权重:
from calflops import calculate_flops_hf model_name = "meta-llama/Llama-2-7b" flops, macs, params = calculate_flops_hf(model_name=model_name, input_shape=(1, 128)) print(f"{model_name} FLOPs:{flops} MACs:{macs} Params:{params}")
这对于计算大型语言模型的FLOPs特别有用。
calflops可以打印每个子模块的详细计算结果:
flops, macs, params = calculate_flops(model, input_shape=(1,3,224,224), print_results=True, print_detailed=True)
这将输出类似下面的详细信息:
-------------------------------- Detailed Calculated FLOPs Results --------------------------------
Each module caculated is listed after its name in the following order:
params, percentage of total params, MACs, percentage of total MACs, FLOPS, percentage of total FLOPs
AlexNet(
61.1 M = 100% Params, 715.51 MMACs = 100% MACs, 1.43 GFLOPS = 50% FLOPs
(features): Sequential(
2.47 M = 4.04% Params, 666.52 MMACs = 93.15% MACs, 1.33 GFLOPS = 46.58% FLOPs
(0): Conv2d(23.3 K = 0.04% Params, 105.71 MMACs = 14.77% MACs, 211.41 MFLOPS = 7.39% FLOPs, 3, 64, kernel_size=(11, 11), stride=(4, 4), padding=(2, 2))
(1): ReLU(0 = 0% Params, 0.29 MMACs = 0.04% MACs, 0.58 MFLOPS = 0.02% FLOPs, inplace=True)
(2): MaxPool2d(0 = 0% Params, 0.29 MMACs = 0.04% MACs, 0.58 MFLOPS = 0.02% FLOPs, kernel_size=3, stride=2, padding=0, dilation=1, ceil_mode=False)
...
)
(avgpool): AdaptiveAvgPool2d(0 = 0% Params, 0.01 MMACs = 0% MACs, 0.03 MFLOPS = 0% FLOPs, output_size=(6, 6))
(classifier): Sequential(
58.63 M = 95.96% Params, 48.98 MMACs = 6.85% MACs, 97.96 MFLOPS = 3.42% FLOPs
(0): Dropout(0 = 0% Params, 0 MACs = 0% MACs, 0 FLOPS = 0% FLOPs, p=0.5, inplace=False)
(1): Linear(37.75 M = 61.79% Params, 37.75 MMACs = 5.28% MACs, 75.5 MFLOPS = 2.64% FLOPs, in_features=9216, out_features=4096, bias=True)
(2): ReLU(0 = 0% Params, 0 MACs = 0% MACs, 0.01 MFLOPS = 0% FLOPs, inplace=True)
...
)
)
这种详细输出可以帮助我们更好地理解模型中各部分的计算复杂度分布。
除了基本的FLOPs计算,calflops还提供了一些高级功能:
计算反向传播的FLOPs:
flops, macs, params = calculate_flops(model, input_shape=(1,3,224,224), include_backPropagation=True)
忽略特定模块:
flops, macs, params = calculate_flops(model, input_shape=(1,3,224,224), ignore_modules=[nn.ReLU, nn.Dropout])
计算模型生成过程的FLOPs:
flops, macs, params = calculate_flops(model, input_shape=(1,128), forward_mode="generate")
calflops是一个功能强大且易用的工具,可以帮助研究人员和工程师快速评估PyTorch模型的计算复杂度。无论是传统的CNN模型还是最新的大语言模型,calflops都能提供准确的FLOPs、MACs和参数统计。通过使用calflops,我们可以更好地理解和优化深度学习模型的计算效率。
在实际应用中,准确计算模型的FLOPs可以帮助我们:
总之,calflops为PyTorch模型的性能分析提供了一个简单而强大的工具,值得每个深度学习从业者掌握和使用。
最强AI数据分析助手
小浣熊家族Raccoon,您的AI智能助手,致力于通过先进的人工智能技术,为用户提供高效、便捷的智能服务。无论是日常咨询还是专业问题解答,小浣熊都能以快速、准确的响应满足您的需求,让您的生活更加智能便捷。
像人一样思考的AI智能体
imini 是一款超级AI智能体,能根据人类指令,自主思考、自主完成、并且交付结果的AI智能体。
AI数字人视频创作平台
Keevx 一款开箱即用的AI数字人视频创作平台,广泛适用于电商广告、企业培训与社媒宣传,让全球企业与个人创作者无需拍摄剪辑,就能快速生成多语言、高质量的专业视频。
一站式AI创作平台
提供 AI 驱动的图片、视频生成及数字人等功能,助力创意创作
AI办公助手,复杂任务高效处理
AI办公助手,复杂任务高效处理。办公效率低?扣子空间AI助手支持播客生成、PPT制作、网页开发及报告写作,覆盖科研、商业、舆情等领域的专家Agent 7x24小时响应,生活工作无缝切换,提升50%效率!
AI辅助编程,代码自动修复
Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。
AI小说写作助手,一站式润色、改写、扩写
蛙蛙写作—国内先进的AI写作平台,涵盖小说、学术、社交媒体等多场景。提供续写、改写、润色等功能,助力创作者高效优化写作流程。界面简洁,功能全面,适合各类写作者提升内容品质和工作效率。
全能AI智能助手,随时解答生活与工作的多样问题
问小白,由元石科技研发的AI智能助手,快速准确地解答各种生活和工作问题,包括但不限于搜索、规划和社交互动,帮助用户在日常生活中提高效率,轻松管理个人事务。
实时语音翻译/同声传译工具
Transly是一个多场景的AI大语言模型驱动的同声传译、专业翻译助手,它拥有超精准的音频识别翻译能力,几乎零延迟的使用体验和支持多国语言可以让你带它走遍全球,无论你是留学生、商务人士、韩剧美剧爱好者,还是出国游玩、多国会议、跨国追星等等,都可以满足你所有需要同传的场景需求,线上线下通用,扫除语言障碍,让全世界的语言交流不再有国界。
一键生成PPT和Word,让学习生活更轻松
讯飞智文是一个利用 AI 技术的项目,能够帮助用户生成 PPT 以及各类文档。无论是商业领域的市场分析报告、年度目标制定,还是学生群体的职业生涯规划、实习避坑指南,亦或是活动策划、旅游攻略等内容,它都能提供支持,帮助用户精准表达,轻松呈现各种信息。
最新AI工具、AI资讯
独家AI资源、AI项目落地
微信扫一扫关注公众号