- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我开始了解如何实现片段着色器来执行 1D LUT,但我正在努力寻找任何好的资源来告诉您如何在 C++ 中制作 1D LUT,然后对其进行纹理处理。
所以对于一个简单的例子,给出下面的 1D lut:
我会用以下数据创建一个数组吗?
int colorLUT[255] = {255,
254,
253,
...,
...,
...,
3,
2,
1,
0};
或 unsigned char
我想是因为我要对其进行纹理处理。
如果这是创建 LUT 的方法,那么我将如何将其转换为纹理?我应该使用 glTexImage1D
吗?还是有更好的方法来做到这一点?我真的在这里不知所措,任何建议都会有所帮助
很抱歉这么简短,但我还没有看到任何关于如何实际制作和链接 LUT 的教程,每个关于 GLSL 的教程只告诉你着色器,他们总是忽略链接部分。
我的最终目标是我想知道如何采用如下所示的不同 1D LUT,并将它们全部应用于图像。
最佳答案
是的,您可以使用一维纹理作为查找表。
您可以使用 glTexImage1D()
将数据加载到一维纹理中。使用 GL_R8
作为内部纹理格式,并在将数据传递给 glTexImage1D()
时将数据指定为 GL_UNSIGNED_BYTE
,如果是 8 位,是您的最佳选择的精度足以获得值(value)。您的调用将如下所示,lutData
是指向 GLubyte
数据的指针/数组,lutSize
是您的 LUT 的大小:
glTexImage1D(GL_TEXTURE_1D, 0, GL_R8, lutSize, 0, GL_RED, GL_UNSIGNED_BYTE, lutData);
如果您需要比 8 位更高的精度,您可以使用 GL_R16
或 GL_R32F
等格式。
确保您还正确设置了纹理参数,例如对于查找表中的值之间的线性采样:
glTexParameteri(GL_TEXTURE_1D, GL_TEXTURE_MIN_FILTER, GL_LINEAR);
glTexParameteri(GL_TEXTURE_1D, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
然后您将纹理绑定(bind)到着色器中的 sampler1D
制服,并使用常规纹理采样函数来检索新值。请记住,纹理坐标在 0.0 到 1.0 范围内,因此在将其传递给纹理采样函数之前,您需要将原始值的范围映射到 [0.0, 1.0]。您从纹理采样函数收到的新值也将在 [0.0, 1.0] 范围内。
请注意,只要您的查找是一个相对简单的函数,在着色器中计算该函数可能会更有效。但是,如果 LUT 可以包含完全任意的映射,则使用 1D 纹理是一个不错的方法。
在没有一维纹理的 OpenGL 变体中,例如 OpenGL ES,您可以使用高度设置为 1 的二维纹理。
如果您需要大于支持的最大纹理大小的查找表,您还可以查看缓冲区纹理,正如 Andon 在他的评论中所建议的那样。
关于c++ - 如何在 C++ 中为 GLSL 制作一维 lut,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24176767/
我需要将 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 进行
我是一名优秀的程序员,十分优秀!