欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 新闻 > 资讯 > 图像处理中实现 C++ 和 Python 的高效通信——Boost.Interprocess mmap

图像处理中实现 C++ 和 Python 的高效通信——Boost.Interprocess mmap

2025/1/13 22:06:48 来源:https://blog.csdn.net/old_power/article/details/145028559  浏览:    关键词:图像处理中实现 C++ 和 Python 的高效通信——Boost.Interprocess mmap

使用 Boost.Interprocess 在 C++ 端创建共享内存,并使用 Python 的 mmap 模块进行读写操作。


整体流程

  1. C++ 端

    • 创建共享内存并写入原始图像数据。
    • 等待 Python 端处理完成。
    • 从共享内存中读取处理后的图像数据。
  2. Python 端

    • 读取共享内存中的原始图像数据。
    • 处理图像(例如转换为灰度图)。
    • 将处理后的图像数据写回共享内存。

C++ 端代码

C++ 端负责创建共享内存、写入原始图像数据,并读取 Python 处理后的图像数据。

#include <boost/interprocess/shared_memory_object.hpp>
#include <boost/interprocess/mapped_region.hpp>
#include <opencv2/opencv.hpp>
#include <iostream>using namespace boost::interprocess;int main() {// 读取原始图像cv::Mat image = cv::imread("input.jpg", cv::IMREAD_COLOR);if (image.empty()) {std::cerr << "Failed to load image!" << std::endl;return -1;}// 共享内存名称const std::string shm_name = "SharedImageMemory";// 创建共享内存对象shared_memory_object shm(open_or_create, shm_name.c_str(), read_write);// 设置共享内存大小(原始图像 + 处理后的图像)size_t image_size = image.total() * image.elemSize();shm.truncate(image_size * 2);  // 两倍大小,分别存储原始图像和处理后的图像// 映射共享内存mapped_region region(shm, read_write);// 将原始图像数据写入共享内存的前半部分std::memcpy(region.get_address(), image.data, image_size);std::cout << "Original image data written to shared memory." << std::endl;// 等待 Python 端处理完成std::cout << "Waiting for Python to process the image..." << std::endl;std::cin.get();// 从共享内存的后半部分读取处理后的图像数据cv::Mat processed_image(image.size(), image.type());std::memcpy(processed_image.data, static_cast<char*>(region.get_address()) + image_size, image_size);// 保存处理后的图像cv::imwrite("output_processed.jpg", processed_image);std::cout << "Processed image saved to output_processed.jpg." << std::endl;// 清理共享内存shared_memory_object::remove(shm_name.c_str());return 0;
}

Python 端代码

Python 端负责读取共享内存中的原始图像数据,处理图像,并将处理后的图像数据写回共享内存。

import mmap
import numpy as np
import cv2# 共享内存名称(与 C++ 端一致)
SHARED_MEMORY_NAME = "SharedImageMemory"# 图像尺寸和类型(需要与 C++ 端一致)
IMAGE_WIDTH = 640  # 图像的宽度
IMAGE_HEIGHT = 480  # 图像的高度
IMAGE_CHANNELS = 3  # 图像的通道数(例如,3 表示 RGB 图像)# 计算图像的总字节数
image_size = IMAGE_WIDTH * IMAGE_HEIGHT * IMAGE_CHANNELS# 打开共享内存
with mmap.mmap(-1, image_size * 2, tagname=SHARED_MEMORY_NAME, access=mmap.ACCESS_WRITE) as shm:# 读取原始图像数据(共享内存的前半部分)image_data = shm.read(image_size)image_array = np.frombuffer(image_data, dtype=np.uint8)original_image = image_array.reshape((IMAGE_HEIGHT, IMAGE_WIDTH, IMAGE_CHANNELS))# 处理图像(例如转换为灰度图)processed_image = cv2.cvtColor(original_image, cv2.COLOR_BGR2GRAY)# 将处理后的图像数据写回共享内存的后半部分shm.seek(image_size)  # 移动到共享内存的后半部分shm.write(processed_image.tobytes())print("Processed image data written back to shared memory.")

运行步骤

  1. C++ 端

    • 编译并运行 C++ 程序。程序会将原始图像写入共享内存,并等待 Python 端处理。
  2. Python 端

    • 运行 Python 脚本。脚本会读取共享内存中的原始图像,处理图像,并将处理后的图像写回共享内存。
  3. C++ 端

    • 在 Python 端处理完成后,按 Enter 键继续运行 C++ 程序。程序会从共享内存中读取处理后的图像并保存。

关键点说明

  1. 共享内存布局
    • 共享内存的前半部分存储原始图像,后半部分存储处理后的图像。
  2. 同步机制
    • 示例中使用简单的 std::cin.get() 等待用户输入作为同步机制。在实际应用中,可以使用更复杂的同步机制(如信号量或互斥锁)。
  3. 共享内存清理
    • C++ 端在程序结束前调用 shared_memory_object::remove 清理共享内存。
  4. 共享内存名称
    • C++ 和 Python 必须使用相同的共享内存名称(如 SharedImageMemory)。
  5. 图像尺寸和类型
    • Python 端需要知道图像的宽度、高度和通道数,以便正确解析共享内存中的数据。
  6. 共享内存大小
    • C++ 端通过 shm.truncate() 设置共享内存的大小,Python 端需要确保读取的字节数与 C++ 端一致。
  7. 数据格式
    • 共享内存中的数据是原始的字节流,Python 端需要使用 np.frombuffer 将其转换为 NumPy 数组,并重塑为图像形状。
  8. 同步
    • 在实际应用中,可能需要额外的同步机制(如信号量或互斥锁)来确保 C++ 和 Python 之间的数据一致性。

注意事项

  • 确保 C++ 和 Python 端的图像尺寸、通道数和数据类型一致。
  • 在实际应用中,可能需要处理更复杂的图像数据(如多通道、浮点类型等)。
  • 如果需要更高的性能,可以考虑使用 ZeroMQ 或 gRPC 等网络通信方式。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com