Tensara Logo

tensara

1D Average Pooling

EASY

Perform 1D average pooling on an input tensor:

output[i]=1km=0k1input[Si+mP]\text{output}[i] = \frac{1}{k}\sum_{m=0}^{k-1} \text{input}[S \cdot i + m - P]

The average pooling operation slides a window of size kk over the input tensor with stride SS and padding PP, computing the average value within each window position.

Input:

  • Matrix input of size H\text{H} (input tensor)
  • kernel_size (kk): Size of the pooling window
  • stride (SS): Step size between window positions
  • padding (PP): Number of zero-padding elements added on all sides

Output:

  • Matrix output of size Hout\text{H}_{\text{out}} where: Hout=H+2PkS+1\text{H}_{\text{out}} = \left\lfloor\frac{\text{H} + 2P - k}{S} + 1\right\rfloor

Notes:

  • Zero padding is applied when specified by the padding parameter
  • For values outside the input boundaries (after padding), use zero values in the average computation
  • The denominator (kk) should always be the full kernel size, even when some elements are outside the input boundaries
  • This problem is adapted from KernelBench

GPU Type

Language

Data Type

Loading...

Loading editor...

CUDA C++ environment

Sample Run Results

Hit "Run" to test your code with sample inputs

Desktop Required for Code Submission

For the best coding experience, please switch to a desktop device to write and submit your solution.