# AvgPool {#openvino_docs_ops_pooling_AvgPool_1} @sphinxdirective **Versioned name**: *AvgPool-1* **Category**: *Pooling* **Short description**: `Reference `__ **Detailed description**: `Reference `__ . Average Pool is a pooling operation that performs down-sampling by dividing the input into pooling regions of size specified by kernel attribute and computing the average values of each region. Output shape is calculated as follows: ``H_out = (H + pads_begin[0] + pads_end[0] - kernel[0] / strides[0]) + 1`` ``W_out = (H + pads_begin[1] + pads_end[1] - kernel[1] / strides[1]) + 1`` ``D_out = (H + pads_begin[2] + pads_end[2] - kernel[2] / strides[2]) + 1`` **Attributes**: *Pooling* attributes are specified in the ``data`` node, which is a child of the layer node. * *strides* * **Description**: *strides* is a distance (in pixels) to slide the window on the feature map over the (z, y, x) axes for 3D poolings and (y, x) axes for 2D poolings. For example, *strides* equal "4,2,1" means sliding the window 4 pixel at a time over depth dimension, 2 over height dimension and 1 over width dimension. * **Range of values**: integer values starting from 0 * **Type**: int[] * **Required**: *yes* * *pads_begin* * **Description**: *pads_begin* is a number of pixels to add to the beginning along each axis. For example, *pads_begin* equal "1,2" means adding 1 pixel to the top of the input and 2 to the left of the input. * **Range of values**: integer values starting from 0 * **Type**: int[] * **Required**: *yes* * **Note**: the attribute is ignored when *auto_pad* attribute is specified. * *pads_end* * **Description**: *pads_end* is a number of pixels to add to the ending along each axis. For example, *pads_end* equal "1,2" means adding 1 pixel to the bottom of the input and 2 to the right of the input. * **Range of values**: integer values starting from 0 * **Type**: int[] * **Required**: *yes* * **Note**: the attribute is ignored when *auto_pad* attribute is specified. * *kernel* * **Description**: *kernel* is a size of each filter. For example, *kernel* equal (2, 3) means that each filter has height equal to 2 and width equal to 3. * **Range of values**: integer values starting from 1 * **Type**: int[] * **Required**: *yes* * *exclude-pad* * **Description**: *exclude-pad* is a type of pooling strategy for values in the padding area. For example, if *exclude-pad* is "true", then zero-values that came from padding are not included in averaging calculation. * **Range of values**: true or false * **Type**: boolean * **Required**: *yes* * *rounding_type* * **Description**: *rounding_type* is a type of rounding to be applied. * **Range of values**: * *ceil* * *floor* * **Type**: string * **Default value**: *floor* * **Required**: *no* * *auto_pad* * **Description**: *auto_pad* how the padding is calculated. Possible values: * *explicit*: use explicit padding values from `pads_begin` and `pads_end`. * *same_upper (same_lower)* the input is padded to match the output size. In case of odd padding value an extra padding is added at the end (at the beginning). * *valid* - do not use padding. * **Type**: string * **Default value**: *explicit* * **Required**: *no* * **Note**: *pads_begin* and *pads_end* attributes are ignored when *auto_pad* is specified. **Inputs**: * **1**: 3D, 4D or 5D input tensor. **Required.** **Outputs**: * **1**: Input shape can be either ``[N,C,H]``, ``[N,C,H,W]`` or ``[N,C,H,W,D]``. Then the corresponding output shape is ``[N,C,H_out]``, ``[N,C,H_out,W_out]`` or ``[N,C,H_out,W_out,D_out]``. **Mathematical Formulation** .. math:: output_{j} = \frac{\sum_{i = 0}^{n}x_{i}}{n} **Examples** .. code-block:: cpp 1 3 32 32 1 3 32 32 1 3 32 32 1 3 32 32 1 3 32 32 1 3 10 10 1 3 32 32 1 3 15 15 1 3 32 32 1 3 14 14 @endsphinxdirective