- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
假设我需要为 0...255 个值创建一个包含预先计算的位计数值(数字中 1 位的计数)的 LUT:
int CB_LUT[256] = {0, 1, 1, 2, ... 7, 8};
如果我不想使用硬编码值,我可以使用漂亮的模板解决方案 How to count the number of set bits in a 32-bit integer?
template <int BITS>
int CountBits(int val)
{
return (val & 0x1) + CountBits<BITS-1>(val >> 1);
}
template<>
int CountBits<1>(int val)
{
return val & 0x1;
}
int CB_LUT[256] = {CountBits<8>(0), CountBits<8>(1) ... CountBits<8>(255)};
这个数组是在编译时完全计算的。有没有办法避免长列表,并使用某种模板甚至宏(抱歉!)生成这样的数组,例如:
Generate(CB_LUT, 0, 255); // array declaration
...
cout << CB_LUT[255]; // should print 8
注释。这个问题不是关于计算数字中的 1 位,它仅用作示例。我想在代码中完全生成这样的数组,而不使用外部代码生成器。数组必须在编译时生成。
编辑。为了克服编译器限制,我找到了以下解决方案,基于Bartek Banachewicz` 代码:
#define MACRO(z,n,text) CountBits<8>(n)
int CB_LUT[] = {
BOOST_PP_ENUM(128, MACRO, _)
};
#undef MACRO
#define MACRO(z,n,text) CountBits<8>(n+128)
int CB_LUT2[] = {
BOOST_PP_ENUM(128, MACRO, _)
};
#undef MACRO
for(int i = 0; i < 256; ++i) // use only CB_LUT
{
cout << CB_LUT[i] << endl;
}
我知道这可能是UB...
最佳答案
使用宏(我最近为我的代码重新发现)Boost.Preprocessor 会相当容易 - 我不确定它是否属于“不使用外部代码生成器”。
PP_ENUM
版本感谢@TemplateRex BOOST_PP_ENUM
,正如我所说,我在 PP 方面还不是很有经验 :)
#include <boost/preprocessor/repetition/enum.hpp>
// with ENUM we don't need a comma at the end
#define MACRO(z,n,text) CountBits<8>(n)
int CB_LUT[256] = {
BOOST_PP_ENUM(256, MACRO, _)
};
#undef MACRO
与 PP_ENUM
的主要区别在于它会自动在每个元素后添加逗号并去掉最后一个。
PP_REPEAT
版本#include <boost/preprocessor/repetition/repeat.hpp>
#define MACRO(z,n,data) CountBits<8>(n),
int CB_LUT[256] = {
BOOST_PP_REPEAT(256, MACRO, _)
};
#undef MACRO
它实际上非常简单易用,但是否接受宏由您决定。我个人一直在努力使用 Boost.MPL 和模板技术,以找到易于阅读、简短而强大的 PP 解决方案,尤其是对于像这样的枚举。 PP 相对于 TMP 的另一个重要优势是编译时间。
至于末尾的逗号,所有合理的编译器都应该支持它,但如果您的编译器不支持,只需将重复次数更改为 255 并手动添加最后一个大小写即可。
您可能还想将 MACRO
重命名为有意义的名称以避免可能的重新定义。
关于c++ - 在编译时生成 BitCount LUT,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17831460/
我需要将 LUT 从 Android 应用程序传递到 fragment 着色器以进行颜色校正。我发现了一些将 LUT 作为位图传递的示例 GLES20.glBindTexture(GLES20.GL_
import numpy as np, itertools x1 = np.linspace(0.1, 3.5, 3) x2 = np.arange(5, 24, 3) x3 = np.arange(
假设我有 8 个表,每张表有 16 个值: uint32_t lut[8][16]; 我想用值填充这些表,以便组合(add、eor 等等)八个表中每个表中的一个条目将产生一个唯一的 32 位值 - 与
目前我计算日志如下: #define MAXLOG 1001 double myloglut[MAXLOG]; void MyLogCreate() { int i; double e
我们正在尝试编写一种方法来从 LUT 的链表实现中删除具有特定键的节点。 我写的代码总结: public void delete (String k) { Node currNode = li
void LUT(InputArray src, InputArray lut, OutputArray dst, int interpolation=0 ) 根据查找表在8位数组中进行替换,并将结果
我正在生成一个 LUT,将 0-2PI 分成 512 个片段,然后找到这些值的正弦并将它们存储为 Q1.31 值。 例子: LUT[0] = 0 LUT[1] = sin((1/512) * 2*PI
我正在编写一些颜色管理代码,并且正在处理 LUT(查找表)。 我可以读取颜色配置文件 LUT 并转换我的值...但是,我该如何进行逆运算?也许,是否有一个好的算法来生成 LUT 的“逆”? 最佳答案
在我正在编写的 C++ CPU 绑定(bind)模拟中,我通过程序中的 valgrind 将瓶颈追踪到 cmath::exp。它目前占用了我 40% 以上的模拟时间。我可以将输入绑定(bind)到一个
假设我需要为 0...255 个值创建一个包含预先计算的位计数值(数字中 1 位的计数)的 LUT: int CB_LUT[256] = {0, 1, 1, 2, ... 7, 8}; 如果我不想使用
我的问题与这些术语之间的区别和关系有关: LUT 逻辑单元 逻辑元件(LE) 系统门 我知道这在很大程度上取决于 FPGA 生产商,但例如 FPGA 供应商将其产品之一描述为:具有 100.000 S
我有 500 个帧,我将每个帧的长度存储在数组中,因为帧按升序排列。 const char header_length = {23,34, 45, 12, 23,56,......,2,4}; 这里帧
我需要对图像中的所有像素执行幂指数运算。这是一个非常繁重的过程。指数是常量( float ),底数是 uint32_t(乘以 2 uint16_t 的结果)我正在尝试弄清楚我是否可以编写一个 LUT,
我目前正致力于在 C 语言中建立一个框架,以便在多个微 Controller 之间使用。该框架必须承载所有设备特定代码,因此应用程序仅包含外设的抽象用法(如 SerialPort_Read、write
我的程序中需要一个查找表来描述不同类型的大小。现在我明白了: typedef struct{ APP_InterfaceType_t Type; //This is just an enu
我有一些代码可以创建一个看起来大致像这样的 HSV 掩码(取自 this Japanese-language page ): void colorExtraction(const cv::gpu::G
需要对图像的颜色 channel 应用一些快速转换。 1)我已经在列表中存储了相应的输出值: ListaVred = [0]*255 for i in range(0,255): ListaV
对于我的工作,我需要将 JPG 中的伪彩色 RGB 值替换为灰度以进行处理。 “颜色”图像具有特定范围的 RGB 颜色(20 或 255,取决于来源)需要链接到灰度值以便对输出图像进行一些测量。使用原
我正在尝试编写一个快速的 3D lut 查找函数并注意到大多数 lut 是 33x33x33 或 17x17x17。 为什么是 33 或 17?用 32 或 16 代替数学不是更快吗?所以你可以做一些
我是图像处理的新手。 我想使用 JavaScript 对使用 LUT(查找表)或相应的查找 PNG 的图像应用效果,如下所示: 我在谷歌上搜索了很多,但找不到一篇文章或任何资源来描述使用 LUT 进行
我是一名优秀的程序员,十分优秀!