1

boost::gil 的数字扩展包含如下算法:

template <typename Channel1,typename Channel2,typename ChannelR>
struct channel_plus_t : public std::binary_function<Channel1,Channel2,ChannelR> {
   ChannelR operator()(typename channel_traits<Channel1>::const_reference ch1,
                       typename channel_traits<Channel2>::const_reference ch2) const {
      return ChannelR(ch1)+ChannelR(ch2);
   }
};

当填充两个 uint8 通道值时,如果 ChannelR 也是 uint8,则会发生溢出。

我认为计算应该

  • 使用不同的类型进行处理(如何从模板化通道类型派生?)
  • 将结果剪辑到 ChannelR 类型的范围以获得饱和结果(使用boost::gil::channel_traits<ChannelR>::min_value()/ ... max_value()?)

如何以允许性能优化结果的方式做到这一点?

  • 转换为最大可能的类型?听起来适得其反……
  • 提供模板专业化库?有更好的主意吗?
4

1 回答 1

0

我不明白这里有什么问题......我的反应是“所以不要将 ChannelR 设置为 uint8,如果这会中断”

你似乎在做相当于争论这样的代码

  uint8 a=128;
  uint8 b=128;
  uint8 c=a+b;  // Uh-Oh...

应该做一些聪明的事情(例如饱和算术)。

我建议解决方案是使用更高的精度,或者channel_saturating_plus_t用你需要的行为定义你自己的,就像我建议的解决方案一样

uint16 c=uint16(a)+uint16(b)

或者

uint8 c=saturating_add(a,b);

感谢 GIL 的创建者甚至考虑将结果类型作为单独的类型参数公开;那里有很多库不会!

于 2012-06-21T22:00:59.557 回答