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项目发布为exe可执行程序过程分享
Oct 23 Python
python九九乘法表的实例
Sep 26 Python
Python使用Selenium+BeautifulSoup爬取淘宝搜索页
Feb 24 Python
使用python3实现操作串口详解
Jan 01 Python
Python中遍历列表的方法总结
Jun 27 Python
pyenv与virtualenv安装实现python多版本多项目管理
Aug 17 Python
使用TensorFlow对图像进行随机旋转的实现示例
Jan 20 Python
jupyter notebook 重装教程
Apr 16 Python
Django获取model中的字段名和字段的verbose_name方式
May 19 Python
浅谈Keras中shuffle和validation_split的顺序
Jun 19 Python
python+openCV对视频进行截取的实现
Nov 27 Python
Python基础 括号()[]{}的详解
Nov 07 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 读取shell管道传输过来的内容
2010/03/01 PHP
解析php中array_merge与array+array的区别
2013/06/21 PHP
Laravel中使用FormRequest进行表单验证方法及问题汇总
2016/06/19 PHP
PHP AjaxForm提交图片上传并显示图片源码
2016/11/29 PHP
jQuery 类twitter的文本字数限制带提示效果插件
2010/04/16 Javascript
js判断IE6/IE7/FF的代码[XMLHttpRequest]
2011/02/16 Javascript
js实现的复制兼容chrome和IE
2014/04/03 Javascript
js取整数、取余数的方法
2014/05/11 Javascript
js中自定义方法实现停留几秒sleep
2014/07/11 Javascript
jQuery实现Twitter的自动文字补齐特效
2014/11/28 Javascript
JS解析XML实例分析
2015/01/30 Javascript
jQuery插件expander实现图片翻转特效
2015/05/21 Javascript
js实现上传文件添加和删除文件选择框
2016/10/24 Javascript
easyui form validate总是返回false的原因及解决方法
2016/11/07 Javascript
jQuery+SpringMVC中的复选框选择与传值实例
2018/01/08 jQuery
jQuery实现列表的增加和删除功能
2018/06/14 jQuery
vue axios数据请求及vue中使用axios的方法
2018/09/10 Javascript
JS 验证码功能的三种实现方式
2018/11/26 Javascript
JavaScript 俄罗斯方块游戏实现方法与代码解释
2020/04/08 Javascript
Python中使用item()方法遍历字典的例子
2014/08/26 Python
跟老齐学Python之画圈还不简单吗?
2014/09/20 Python
基于pycharm实现批量修改变量名
2020/06/02 Python
容易被忽略的Python内置类型
2020/09/03 Python
Django Model层F,Q对象和聚合函数原理解析
2020/11/12 Python
video实现有声音自动播放的实现方法
2020/05/20 HTML / CSS
如何进行有效的自我评价
2013/09/27 职场文书
留学推荐信写作指南
2014/01/25 职场文书
金融保险专业求职信
2014/09/03 职场文书
运动会铅球比赛加油稿
2014/09/26 职场文书
暑期社会实践证明书
2014/11/17 职场文书
2014年纳税评估工作总结
2014/12/23 职场文书
会计求职自荐信
2015/03/26 职场文书
社区节水倡议书
2015/04/29 职场文书
开场白怎么写
2015/06/01 职场文书
Python 快速验证代理IP是否有效的方法实现
2021/07/15 Python
Redis+AOP+自定义注解实现限流
2022/06/28 Redis