您好,登錄后才能下訂單哦!
在Linux環境下,使用C++和多線程可以有效地加速圖像處理任務
#include <iostream>
#include <vector>
#include <thread>
#include <mutex>
#include <condition_variable>
#include <opencv2/opencv.hpp>
std::vector<cv::Mat> images; // 存儲圖像
std::vector<std::thread> threads; // 存儲線程
std::mutex mtx; // 互斥鎖
std::condition_variable cv; // 條件變量
bool done = false; // 標記所有線程是否完成
void processImage(int start, int end) {
// 在這里執行圖像處理任務
// 例如,將圖像轉換為灰度圖
cv::Mat &image = images[start];
cv::cvtColor(image, image, cv::COLOR_BGR2GRAY);
// 處理完成后通知主線程
std::unique_lock<std::mutex> lock(mtx);
cv.notify_one();
}
int main() {
// 讀取圖像并存儲到vector中
cv::Mat image1 = cv::imread("image1.jpg");
cv::Mat image2 = cv::imread("image2.jpg");
images.push_back(image1);
images.push_back(image2);
// 創建線程并分配任務
int num_threads = std::thread::hardware_concurrency(); // 獲取系統支持的線程數
int images_per_thread = images.size() / num_threads;
for (int i = 0; i < num_threads; ++i) {
int start = i * images_per_thread;
int end = (i == num_threads - 1) ? images.size() : (i + 1) * images_per_thread;
threads.emplace_back(processImage, start, end);
}
// 等待所有線程完成
{
std::unique_lock<std::mutex> lock(mtx);
cv.wait(lock, []{ return done; });
}
// 處理后的圖像存儲到vector中
std::vector<cv::Mat> processed_images;
for (auto &t : threads) {
t.join();
}
// 將處理后的圖像保存到文件
for (size_t i = 0; i < processed_images.size(); ++i) {
cv::imwrite("processed_image" + std::to_string(i) + ".jpg", processed_images[i]);
}
return 0;
}
這個示例中,我們首先讀取圖像并將它們存儲到一個vector中。然后,我們創建一個線程池,并根據硬件并發級別將圖像處理任務分配給每個線程。每個線程處理其分配的圖像子集,并在完成后通知主線程。最后,主線程等待所有線程完成,并將處理后的圖像保存到文件。
注意:這個示例僅用于演示目的,實際圖像處理任務可能需要根據具體需求進行調整。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。