欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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时可能出现如下错误:

pytorch 计算Parameter和FLOP的操作

解决方法:

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,)中必须加上逗号,否者会报错

以上为个人经验,希望能给大家一个参考,也希望大家多多支持。如有错误或未考虑完全的地方,望不吝赐教。