pytorch 计算Parameter和FLOP的操作
程序员文章站
2022-06-16 09:47:16
深度学习中,模型训练完后,查看模型的参数量和浮点计算量,在此记录下:1 thop在pytorch中有现成的包thop用于计算参数数量和flop,首先安装thop:pip install thop注意安...
深度学习中,模型训练完后,查看模型的参数量和浮点计算量,在此记录下:
1 thop
在pytorch中有现成的包thop用于计算参数数量和flop,首先安装thop:
pip install thop
注意安装thop时可能出现如下错误:
解决方法:
pip install --upgrade git+https://github.com/lyken17/pytorch-opcounter.git # 下载源码安装
使用方法如下:
from torchvision.models import resnet50 # 引入resnet50模型 from thop import profile model = resnet50() flops, params = profile(model, input_size=(1, 3, 224,224)) # profile(模型,输入数据)
对于自己构建的函数也一样,例如shufflenetv2
from thop import profile from utils.shufflenetv2 import shufflenetv2 # 导入shufflenet2 模块 import torch model_shuffle = shufflenetv2(width_mult=0.5) model = torch.nn.dataparallel(model_shuffle) # 调用shufflenet2 模型,该模型为自己定义的 flop, para = profile(model, input_size=(1, 3, 224, 224),) print("%.2fm" % (flop/1e6), "%.2fm" % (para/1e6))
更多细节,可参考thop github链接: https://github.com/lyken17/pytorch-opcounter
2 计算参数
pytorch本身带有计算参数的方法
from thop import profile from utils.shufflenetv2 import shufflenetv2 # 导入shufflenet2 模块 import torch model_shuffle = shufflenetv2(width_mult=0.5) model = torch.nn.dataparallel(model_shuffle) total = sum([param.nelement() for param in model.parameters()]) print("number of parameter: %.2fm" % (total / 1e6))
补充:pytorch: 计算网络模型的计算量(flops)和参数量(params)
计算量:
flops,flop时指浮点运算次数,s是指秒,即每秒浮点运算次数的意思,考量一个网络模型的计算量的标准。
参数量:
params,是指网络模型中需要训练的参数总数。
第一步:安装模块(thop)
pip install thop
第二步:计算
import torch from thop import profile net = model() # 定义好的网络模型 input = torch.randn(1, 3, 112, 112) flops, params = profile(net, (inputs,)) print('flops: ', flops, 'params: ', params)
注意:
输入input的第一维度是批量(batch size),批量的大小不回影响参数量, 计算量是batch_size=1的倍数
profile(net, (inputs,))的 (inputs,)中必须加上逗号,否者会报错
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。如有错误或未考虑完全的地方,望不吝赐教。
推荐阅读
-
Pytorch反向传播中的细节-计算梯度时的默认累加操作
-
pytorch中state_dict()和named_parameters()的差别,以及model.buffer/model.parameter
-
R语言-计算频数和频率的操作
-
pytorch 计算Parameter和FLOP的操作
-
JS检测用户打开和关闭浏览器操作,计算当前访客数的高兼容性方案
-
pytorch中state_dict()和named_parameters()的差别,以及model.buffer/model.parameter
-
pytorch 计算Parameter和FLOP的操作
-
R语言-计算频数和频率的操作
-
JS检测用户打开和关闭浏览器操作,计算当前访客数的高兼容性方案
-
Pytorch反向传播中的细节-计算梯度时的默认累加操作