File: expanding_reduction.cpp

package info (click to toggle)
halide 21.0.0-4
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 55,752 kB
  • sloc: cpp: 289,334; ansic: 22,751; python: 7,486; makefile: 4,299; sh: 2,508; java: 1,549; javascript: 282; pascal: 207; xml: 127; asm: 9
file content (33 lines) | stat: -rw-r--r-- 791 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
#include "Halide.h"
#include <stdio.h>

using namespace Halide;

int main(int argc, char **argv) {
    Func f, g;
    Var x, y;
    RDom r(0, 100);

    // This reduction recursively expands its bounds. The
    // initialization step will evaluate y from -1 to 101, and the
    // update step will use y from 0 to 100. Faulty bounds inference
    // might get this wrong.

    // This behavior is now disallowed, so this test has been moved
    // into the error category.
    ImageParam input(Int(32), 2);
    f(x, y) = input(x, y);
    f(r, y) = f(r, y - 1) + f(r, y + 1);

    f.compute_root();

    g(x, y) = f(x, y);

    g.infer_input_bounds({100, 100});

    Buffer<int> in(input.get());
    assert(in.height() == 102 && in.width() == 100);

    printf("Success!\n");
    return 0;
}