C++ 卤化物:计划无内联的多级管道

C++ 卤化物:计划无内联的多级管道,c++,halide,C++,Halide,我正在尝试编写一个模块化的多阶段处理管道,但在调度它时遇到了困难 代码结构如下: #include <halide/Halide.h> Halide::Var x, y, c; Halide::Func producer(Halide::Func in) { Halide::Func producer("producer"); producer(x, y, c) = in(x, y, c); return producer; } Halide::Func

我正在尝试编写一个模块化的多阶段处理管道,但在调度它时遇到了困难

代码结构如下:

#include <halide/Halide.h>

Halide::Var x, y, c;

Halide::Func producer(Halide::Func in) {
    Halide::Func producer("producer");
    producer(x, y, c) = in(x, y, c);
    return producer;
}

Halide::Func rectification(Halide::Func in, const Halide::Image<float>& rectificationMapBuffer)
{
    // Fractional pixel positions according to rectification map
    Halide::Expr x_in_frac("x_in_frac");
    Halide::Expr y_in_frac("y_in_frac");
    x_in_frac = rectificationMapBuffer(x * 2 + 0, y);
    y_in_frac = rectificationMapBuffer(x * 2 + 1, y);

    // Cast fractions down to integers. This allows to address the pixels
    // surrounding the fractional position
    Halide::Expr x_in("x_in");
    Halide::Expr y_in("y_in");
    x_in = Halide::cast(Halide::Int(32), x_in_frac);
    y_in = Halide::cast(Halide::Int(32), y_in_frac);

    // Linearly interpolate pixel values
    Halide::Func interpolate("interpolate");
    interpolate(x, y, c) =
        Halide::lerp(Halide::lerp(in(x_in + 0, y_in + 0, c), in(x_in + 1, y_in + 0, c),
                                  Halide::fract(x_in_frac)),
                     Halide::lerp(in(x_in + 0, y_in + 1, c), in(x_in + 1, y_in + 1, c),
                                  Halide::fract(x_in_frac)),
                     Halide::fract(y_in_frac));

    Halide::Func rectification("rectification");
    rectification(x, y, c) = Halide::cast(Halide::UInt(8), interpolate(x, y, c));

    return rectification;
}

Halide::Func schedule(const Halide::Image<uint8_t>& image, const Halide::Image<float>& rectificationMap) {
    Halide::Func clamped;
    clamped = Halide::BoundaryConditions::repeat_edge(image);

    Halide::Func producerFunc;
    producerFunc = producer(clamped);

    Halide::Func consumerFunc;
    consumerFunc = rectification(producerFunc, rectificationMap);

    producerFunc.compute_root();

    consumerFunc.compile_jit();

    return consumerFunc;
}

int main(int argc, char *argv[])
{
    int width = 100;
    int height = 100;
    int channels = 3;
    Halide::Image<uint8_t> input(width, height, channels);
    Halide::Image<float> rectificationMap(width * 2, height);
    Halide::Buffer output(Halide::UInt(8), width, height, channels, 0);

    Halide::Func f = schedule(input, rectificationMap);
    f.realize(output);
    return 0;
}
当我删除compute_根部分时,producer函数是内联的,我没有看到任何问题


我尝试在schedule函数中添加.bound约束,但没有帮助。有人能帮我弄清楚这个错误是什么意思吗?

我无法重现这个错误。如果我在末尾添加:int main(int argc,const char**argv){Halide::Image test(100100,3);schedule(test).realize(100100,3);}并修复consumer中未终止的字符串,它将编译并运行。你将图像传递给schedule调用的是什么?哈,在我看到这一点之前,我用完全相同的图像大小尝试了相同的事情,得到了相同的结果。我将代码列表更改为我正在尝试的实际操作。问题似乎来自校正中的插值函数
The pure definition of Function rectification calls function producer in an 
unbounded way in dimension 0