我正在处理RGB
图像并对每个通道(R+G+B)做同样的事情,所以我一直在寻找可以帮助我改进代码并更快地运行它(3*?)的并行函数。现在我使用forEach
这样的功能:
unsigned char lut[256];
for (int i = 0; i < 256; i++)
lut[i] = cv::saturate_cast<uchar>(pow((float)(i / 255.0), fGamma) * 255.0f); //pow: power exponent
dst.forEach<cv::Vec3b> //dst is an RGB image
(
[&lut](cv::Vec3b &pixel, const int* po) -> void
{
pixel[0] = lut[(pixel[0])];
pixel[1] = lut[(pixel[1])];
pixel[2] = lut[(pixel[2])];
}
);
但是当我使用htop
查看运行的线程数时,我只发现一两个线程在..
我做错了什么还是forEach
不应该继续运行multi-threading
?你有什么资源可以帮助我进行multi-threading
计算吗?
我在 ubuntu 上运行我的代码:
g++ -std=c++1z -Wall -Ofast -march=native test3.cpp -o test3 `pkg-config --cflags --libs opencv`