c++ - 浮点值的范围分析?

标签 c++ c image-processing floating-point fixed-point

我有一个使用浮点计算的图像处理程序。但是,我需要将它移植到一个不支持浮点的处理器上。因此,我必须更改程序以使用定点计算。为此,我需要对这些 float 进行适当的缩放,为此我需要知道所有值的范围,包括浮点计算的中间值。

有没有一种方法,我只要运行程序,它就会自动给我程序中所有浮点计算的范围?尝试手动找出范围太麻烦了,所以如果有某种工具可以做到这一点,那就太棒了!

最佳答案

您可以使用一些“测量”替换您的 float 类型,沿着这些线(live example):

template<typename T>
class foo
{
    T val;

    using lim = std::numeric_limits<int>;

    static int& min_val() { static int e = lim::max(); return e; }
    static int& max_val() { static int e = lim::min(); return e; }

    static void sync_min(T e) { if (e < min_val()) min_val() = int(e); }
    static void sync_max(T e) { if (e > max_val()) max_val() = int(e); }

    static void sync(T v)
    {
        v = std::abs(v);
        T e = v == 0 ? T(1) : std::log10(v);
        sync_min(std::floor(e)); sync_max(std::ceil(e));
    }

public:
    foo(T v = T()) : val(v) { sync(v); }
    foo& operator=(T v) { val = v; sync(v); return *this; }

    template<typename U> foo(U v) : foo(T(v)) {}
    template<typename U> foo& operator=(U v) { return *this = T(v); }

    operator T&() { return val; }
    operator const T&() const { return val; }

    static int min() { return min_val(); }
    static int max() { return max_val(); }
};

像这样使用

int main ()
{
    using F = foo<float>;
    F x;

    for (F e = -10.2; e <= 30.4; e += .2)
        x = std::pow(10, e);

    std::cout << F::min() << " " << F::max() << std::endl;  // -11 31
}

这意味着您需要为您的 float 类型(Floatfloat)定义一个别名(比如 double),并在您的程序中始终如一地使用它。这可能会带来不便,但最终可能会证明是有益的(因为那样您的程序就更通用了)。如果您的代码已经在 float 类型上进行了模板化,那就更好了。

在此参数化之后,您可以通过定义 Float 将程序切换到“测量”或“释放”模式要么是foo<T>T , 其中T是你的 floatdouble .

好处是您不需要外部工具,您自己的代码会执行测量。不好的是,按照目前的设计,它不会捕获所有中间结果。您必须在 foo 上定义所有(例如算术)运算符为了这。这是可以做到的,但需要做更多的工作。

关于c++ - 浮点值的范围分析?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23154717/

相关文章:

c - 汇编 - 为什么 %rsp 递减这么多,为什么参数存储在堆栈的顶部?

c - 如何读取c中的原始内存

c - 如何在C中获取数组参数的实际大小?

opencv - 如何使用 opencv 正确地重新定向单个字符图像

ASP.net 和 MS Office Project 集成并将其导出为图像

php - 我想将来自 UE4 c++ 游戏的请求发送到我的 php 脚本,以便它与 mysql 数据库交互

c++ - 优化数学计算(乘法和求和)

c++ - 使用 clang 内置函数与标准函数的好处

c++ - 在Linux上,如何将文本绘制到位图?

ruby-on-rails - 回形针更改默认路径和 HashMap 像名称