PyTorch的自适应池化Adaptive Pooling实例


Posted in Python onJanuary 03, 2020

简介

自适应池化Adaptive Pooling是PyTorch含有的一种池化层,在PyTorch的中有六种形式:

自适应最大池化Adaptive Max Pooling:

torch.nn.AdaptiveMaxPool1d(output_size)
torch.nn.AdaptiveMaxPool2d(output_size)
torch.nn.AdaptiveMaxPool3d(output_size)

自适应平均池化Adaptive Average Pooling:

torch.nn.AdaptiveAvgPool1d(output_size)
torch.nn.AdaptiveAvgPool2d(output_size)
torch.nn.AdaptiveAvgPool3d(output_size)

具体可见官方文档。

官方给出的例子:
>>> # target output size of 5x7
>>> m = nn.AdaptiveMaxPool2d((5,7))
>>> input = torch.randn(1, 64, 8, 9)
>>> output = m(input)
>>> output.size()
torch.Size([1, 64, 5, 7])

>>> # target output size of 7x7 (square)
>>> m = nn.AdaptiveMaxPool2d(7)
>>> input = torch.randn(1, 64, 10, 9)
>>> output = m(input)
>>> output.size()
torch.Size([1, 64, 7, 7])

>>> # target output size of 10x7
>>> m = nn.AdaptiveMaxPool2d((None, 7))
>>> input = torch.randn(1, 64, 10, 9)
>>> output = m(input)
>>> output.size()
torch.Size([1, 64, 10, 7])

Adaptive Pooling特殊性在于,输出张量的大小都是给定的output_size output\_sizeoutput_size。例如输入张量大小为(1, 64, 8, 9),设定输出大小为(5,7),通过Adaptive Pooling层,可以得到大小为(1, 64, 5, 7)的张量。

原理

PyTorch的自适应池化Adaptive Pooling实例

>>> inputsize = 9
>>> outputsize = 4

>>> input = torch.randn(1, 1, inputsize)
>>> input
tensor([[[ 1.5695, -0.4357, 1.5179, 0.9639, -0.4226, 0.5312, -0.5689, 0.4945, 0.1421]]])

>>> m1 = nn.AdaptiveMaxPool1d(outputsize)
>>> m2 = nn.MaxPool1d(kernel_size=math.ceil(inputsize / outputsize), stride=math.floor(inputsize / outputsize), padding=0)
>>> output1 = m1(input)
>>> output2 = m2(input)

>>> output1
tensor([[[1.5695, 1.5179, 0.5312, 0.4945]]]) torch.Size([1, 1, 4])
>>> output2
tensor([[[1.5695, 1.5179, 0.5312, 0.4945]]]) torch.Size([1, 1, 4])

通过实验发现:

PyTorch的自适应池化Adaptive Pooling实例

下面是Adaptive Average Pooling的c++源码部分。

template <typename scalar_t>
 static void adaptive_avg_pool2d_out_frame(
      scalar_t *input_p,
      scalar_t *output_p,
      int64_t sizeD,
      int64_t isizeH,
      int64_t isizeW,
      int64_t osizeH,
      int64_t osizeW,
      int64_t istrideD,
      int64_t istrideH,
      int64_t istrideW)
 {
  int64_t d;
 #pragma omp parallel for private(d)
  for (d = 0; d < sizeD; d++)
  {
   /* loop over output */
   int64_t oh, ow;
   for(oh = 0; oh < osizeH; oh++)
   {
    int istartH = start_index(oh, osizeH, isizeH);
    int iendH  = end_index(oh, osizeH, isizeH);
    int kH = iendH - istartH;

    for(ow = 0; ow < osizeW; ow++)
    {
     int istartW = start_index(ow, osizeW, isizeW);
     int iendW  = end_index(ow, osizeW, isizeW);
     int kW = iendW - istartW;

     /* local pointers */
     scalar_t *ip = input_p  + d*istrideD + istartH*istrideH + istartW*istrideW;
     scalar_t *op = output_p + d*osizeH*osizeW + oh*osizeW + ow;

     /* compute local average: */
     scalar_t sum = 0;
     int ih, iw;
     for(ih = 0; ih < kH; ih++)
     {
      for(iw = 0; iw < kW; iw++)
      {
       scalar_t val = *(ip + ih*istrideH + iw*istrideW);
       sum += val;
      }
     }

     /* set output to local average */
     *op = sum / kW / kH;
    }
   }
  }
}

以上这篇PyTorch的自适应池化Adaptive Pooling实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python中的ctime()方法使用教程
May 22 Python
举例讲解Python的lambda语句声明匿名函数的用法
Jul 01 Python
python解决汉字编码问题:Unicode Decode Error
Jan 19 Python
对python中两种列表元素去重函数性能的比较方法
Jun 29 Python
python与caffe改变通道顺序的方法
Aug 04 Python
python实现单链表中删除倒数第K个节点的方法
Sep 28 Python
Python中的Socket 与 ScoketServer 通信及遇到问题解决方法
Apr 01 Python
Python实现中值滤波去噪方式
Dec 18 Python
pyinstaller还原python代码过程图解
Jan 08 Python
python 解决flask 图片在线浏览或者直接下载的问题
Jan 09 Python
使用keras框架cnn+ctc_loss识别不定长字符图片操作
Jun 29 Python
django教程如何自学
Jul 31 Python
pytorch torch.nn.AdaptiveAvgPool2d()自适应平均池化函数详解
Jan 03 #Python
pytorch AvgPool2d函数使用详解
Jan 03 #Python
使用pyhon绘图比较两个手机屏幕大小(实例代码)
Jan 03 #Python
Python基础之函数原理与应用实例详解
Jan 03 #Python
对Pytorch中Tensor的各种池化操作解析
Jan 03 #Python
Python基础之高级变量类型实例详解
Jan 03 #Python
关于Pytorch MaxUnpool2d中size操作方式
Jan 03 #Python
You might like
PHP中的数组处理函数实例总结
2016/01/09 PHP
PHP的邮件群发系统phplist配置方法详细总结
2016/03/30 PHP
PHP 进度条函数的简单实例
2017/09/19 PHP
Laravel jwt 多表(多用户端)验证隔离的实现
2019/12/18 PHP
Aster vs Newbee BO5 第三场2.19
2021/03/10 DOTA
JavaScript 面向对象的 私有成员和公开成员
2010/05/13 Javascript
jQuery UI Autocomplete 1.8.16 中文输入修正代码
2012/04/16 Javascript
使用jquery解析XML的方法
2014/09/05 Javascript
JavaScript中String.prototype用法实例
2015/05/20 Javascript
JavaScript清空数组元素的两种方法简单比较
2015/07/10 Javascript
谈谈JavaScript中function多重理解
2015/08/28 Javascript
详解AngularJS实现表单验证
2015/12/10 Javascript
javascript实现移动端上的触屏拖拽功能
2016/03/04 Javascript
Node.js的Express框架使用上手指南
2016/03/12 Javascript
JavaScript面试题(指针、帽子和女朋友)
2016/11/23 Javascript
jQuery Json数据格式排版高亮插件json-viewer.js使用方法详解
2017/06/12 jQuery
使用mixins实现elementUI表单全局验证的解决方法
2019/04/02 Javascript
微信小程序实现页面分享onShareAppMessage
2019/08/12 Javascript
Antd表格滚动 宽度自适应 不换行的实例
2020/10/27 Javascript
[37:45]2014 DOTA2国际邀请赛中国区预选赛5.21 DT VS Orenda
2014/05/22 DOTA
Python利用带权重随机数解决抽奖和游戏爆装备问题
2016/06/16 Python
SQLite3中文编码 Python的实现
2017/01/11 Python
浅谈Python生成器generator之next和send的运行流程(详解)
2017/05/08 Python
python编程羊车门问题代码示例
2017/10/25 Python
关于python字符串方法分类详解
2019/08/20 Python
docker django无法访问redis容器的解决方法
2019/08/21 Python
python使用sklearn实现决策树的方法示例
2019/09/12 Python
python字符串格式化方式解析
2019/10/19 Python
python编写微信公众号首图思路详解
2019/12/13 Python
python实现输入三角形边长自动作图求面积案例
2020/04/12 Python
python+selenium小米商城红米K40手机自动抢购的示例代码
2021/03/24 Python
革命英雄事迹演讲稿
2014/09/13 职场文书
学生会招新宣传语
2015/07/13 职场文书
基于Python实现将列表数据生成折线图
2022/03/23 Python
游戏《东方异文石:爱亚利亚黎明》正式版发布
2022/04/03 其他游戏
Python Matplotlib绘制等高线图与渐变色扇形图
2022/04/14 Python