gpt4 book ai didi

c++ - OpenMP 嵌套 for 循环(使用 Qt)

转载 作者:行者123 更新时间:2023-11-28 03:38:01 25 4
gpt4 key购买 nike

我正在编写一个程序 (C++) 来合并图像 (QPainter)。以顺序方式,它工作得很好,但我必须将它与 OpenMP 并行化。我怎样才能做到这一点?我认为可能的问题是内存分配或嵌套循环。这是我的第一个问题,在此先感谢:)

int width = (x2-x1)+1;
int height = (y2-y1)+1;

//every image is 256x256
QImage mapa = QImage(256*width, 256*height, QImage::Format_ARGB32_Premultiplied);
QPainter painter(&mapa);

painter.setCompositionMode(QPainter::CompositionMode_SourceOver);

int x=0;
int y=0;


#pragma omp parallel
{
char *kawalek;

#pragma omp parallel for lastprivate(i) firstprivate(j) shared(x1, x2, y1, y2, painter) reduction(+:y, x)
for(i=y1; i<=y2; i++){
x=0;
#pragma omp parallel for shared(x1, x2, i, y, painter) reduction(+:x)
for(j=x1; j<=x2; j++){
{
kawalek = (char*) malloc(snprintf(NULL, 0, "pobrane/%d_%d.png", j, i)+1);
sprintf(kawalek, "pobrane/%d_%d.png", j, i);
//cout << "czesc: " << kawalek << endl;
QImage fragment(kawalek);
painter.drawImage(x, y, fragment);

//cout << "wspolrzedne czesci x: " << x << "y: " << y << endl;
}
x+=256;
}
y+=256;
}
}

painter.end();

mapa.save(filename);

@Riateche,谢谢 ;)

我的下一个问题是为什么这个循环没有加速......

#pragma omp parallel for private(i) shared(ile)
for(i=0; i<ile; i++){
results[i].load(sciezki[i]);
}

最佳答案

您不能同时从多个线程写入变量 mapa(通过绘制)。

如果您要使用 Qt 线程,我建议您使用信号和槽将计算结果传递给主线程。另一种方法是在主线程中创建结果数组。每个线程只会将自己的结果写入数组的一个单元格。所有线程完成后,主线程必须读取结果并绘制它们。

并考虑使用 QImage::load() 加载 png 文件。它比您的代码更简单。

关于c++ - OpenMP 嵌套 for 循环(使用 Qt),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10268341/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com