图像处理中实现 C++ 和 Python 的高效通信——ZeroMQ protobuf

在开发需要 C++ 和 Python 交互的应用程序时,特别是对于图像处理等任务,建立有效的通信机制至关重要。将图像向量从 C++ 应用程序传输到 Python 应用程序进行推理,使用 ZeroMQ 进行进程间通信 (IPC),使用协议缓冲区 (protobuf) 进行序列化。

概述

解决方案涉及三个主要步骤:

  • 使用 protobuf 在 C++ 中序列化图像数据。
  • 使用 ZeroMQ 传输序列化数据。
  • 在 Python 中对图像数据进行反序列化和处理。

这种方法可确保高效的数据传输、同步和完整性,使其适用于实时或高性能应用程序。

1、 搭建 C++ 和 Python 开发环境

a. 安装 ZeroMQ 库

对于 C++,安装 ZeroMQ 库 (libzmq) 和 C++ 绑定 (cppzmq):

sudo apt install libzmq3-dev

对于 Python,安装 pyzmq 库:

pip install pyzmq

b. 协议缓冲区(protobuf)

为 C++ 和 Python 安装 protobuf 库,安装 protobuf 编译器 (protoc):

sudo apt install -y libprotobuf-dev protobuf-compiler
pip install protobuf

2、详细步骤

2.1 使用 Protobuf 在 C++ 中进行序列化

a. 定义 Protobuf 消息

首先,定义一个 protobuf 消息来表示一张图片和一个图片向量。将此定义保存在名为 image_vector.proto 的文件中:

// image_vector.proto
syntax = "proto3";message Image {bytes data = 1;int32 width = 2;int32 height = 3;int32 channels = 4;
}message ImageVector {repeated Image images = 1;
}
b. 生成 Protobuf 类

使用 protobuf 编译器从 .proto 文件生成 C++ 和 Python 类:

protoc --cpp_out=. image_vector.proto
protoc --python_out=. image_vector.proto
c. 在 C++ 中序列化图像

在您的 C++ 应用程序中,使用生成的 protobuf 类序列化图像向量。

2.2 使用 ZeroMQ 传输数据

ZeroMQ 简化了 C++ 和 Python 应用程序之间的数据传输。在这里,我们实现了一个 C++ 客户端和一个 Python 服务器。

a. C++ 客户端

C++ 客户端将图像序列化并发送到服务器:

#include <zmq.hpp>
#include <opencv2/opencv.hpp>
#include <fstream>
#include "image_vector.pb.h"void send_images(const std::vector<cv::Mat>& images, zmq::socket_t& socket) {ImageVector image_vector;for (const auto& img : images) {Image* image = image_vector.add_images();image->set_data(img.data, img.total() * img.elemsize());image->set_width(img.cols);image->set_height(img.rows);image->set_channels(img.channels());}std::string serialized_data;image_vector.SerializeToString(&serialized_data);zmq::message_t request(serialized_data.size());memcpy(request.data(), serialized_data.data(), serialized_data.size());socket.send(request, zmq::send_flags::none);zmq::message_t reply;socket.recv(reply, zmq::recv_flags::none);std::string reply_str(static_cast<char*>(reply.data()), reply.size());std::cout << "Received reply: " << reply_str << std::endl;
}int main() {zmq::context_t context(1);zmq::socket_t socket(context, ZMQ_REQ);socket.connect("tcp://localhost:5555");std::vector<cv::Mat> images = ...; // Your vector of imagessend_images(images, socket);return 0;
}
b. Python 服务器

Python 服务器接收序列化的图像、对其进行反序列化、处理并返回响应:

import zmq
import cv2
import numpy as np
from image_vector_pb2 import ImageVectordef process_images(images):processed_images = [cv2.cvtColor(img, cv2.COLOR_BGR2GRAY) for img in images]return processed_imagesdef main():context = zmq.Context()socket = context.socket(zmq.REP)socket.bind("tcp://*:5555")while True:message = socket.recv()image_vector = ImageVector()image_vector.ParseFromString(message)images = []for image in image_vector.images:img_array = np.frombuffer(image.data, dtype=np.uint8)img = img_array.reshape((image.height, image.width, image.channels))images.append(img)processed_images = process_images(images)response = "Processed {} images".format(len(processed_images))socket.send_string(response)if __name__ == "__main__":main()

3、结论

该解决方案利用 ZeroMQ 的高性能功能进行 IPC 和 protobuf 进行高效序列化,从而实现 C++ 和 Python 应用程序之间的无缝通信和同步。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/67703.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

什么是数据湖?大数据架构的未来趋势

&#x1f496; 欢迎来到我的博客&#xff01; 非常高兴能在这里与您相遇。在这里&#xff0c;您不仅能获得有趣的技术分享&#xff0c;还能感受到轻松愉快的氛围。无论您是编程新手&#xff0c;还是资深开发者&#xff0c;都能在这里找到属于您的知识宝藏&#xff0c;学习和成长…

【Leetcode·中等·数组】59. 螺旋矩阵 II(spiral matrix ii)

题目描述 英文版描述 Given a positive integer n, generate an n x n matrix filled with elements from 1 to n(2) in spiral order. Example 1: Input: n 3 Output: [[1,2,3],[8,9,4],[7,6,5]] 提示&#xff1a; 1 < n < 20 英文版地址 https://leetcode.com…

Open WebUI 与 AnythingLLM 安装部署

在前文 Ollama私有化部署大语言模型LLM&#xff08;上&#xff09;-CSDN博客 中通过Ollama来搭建运行私有化大语言模型&#xff0c;但缺少用户交互的界面&#xff0c;特别是Web可视化界面。 对此&#xff0c;本文以Open WebUI和AnythingLLM为例分别作为Ollama的前端Web可视化界…

论文导读 | 数据库系统中基于机器学习的基数估计方法

背景 基数估计任务是在一个查询执行之前预测其基数&#xff0c;基于代价的查询优化器&#xff08;Cost Based Optimizer&#xff09;将枚举所有可能的执行计划&#xff0c;并利用估计的基数选出期望执行代价最小的计划&#xff0c;从而完成查询优化的任务。 然而&#xff0c;…

3D扫描建模有哪些优势和劣势?

3D扫描建模作为一种先进的数字化手段&#xff0c;在多个领域展现出了巨大的潜力和价值&#xff0c;但同时也存在一些劣势。以下是对3D扫描建模优势和劣势的详细分析&#xff1a; 3D扫描建模的优势 高精度数据采集&#xff1a; 三维扫描技术能够以极高的精度获取物体的三维数…

网络安全 信息收集入门

1.信息收集定义 信息收集是指收集有关目标应用程序和系统的相关信息。这些信息可以帮助攻击者了解目标系统的架构、技术实现细节、运行环境、网络拓扑结构、安全措施等方面的信息&#xff0c;以便我们在后续的渗透过程更好的进行。 2.收集方式-主动和被动收集 ①收集方式不同…

MBM指尖六维力触觉传感器:高灵敏度、低漂移,精准掌控力学世界

MBM指尖六维力触觉传感器是一种专为机器人设计的高性能传感器。它通过集成三轴力和三轴力矩的感知能力&#xff0c;能够精准捕捉复杂的力学信息。传感器采用MEMS与应变体复合测量技术&#xff0c;具备数字输出功能&#xff0c;显著降低漂移并减少安装偏移的影响。其紧凑轻便的设…

用 Python 绘制可爱的招财猫

✨个人主页欢迎您的访问 ✨期待您的三连 ✨ ✨个人主页欢迎您的访问 ✨期待您的三连 ✨ ✨个人主页欢迎您的访问 ✨期待您的三连✨ ​​​​​ ​​​​​​​​​ ​​​​ 招财猫&#xff0c;也被称为“幸运猫”&#xff0c;是一种象征财富和好运的吉祥物&#xff0c;经常…

docker常用命令及dockerfile编写

docker常用命令及dockerfile编写 1.docker常用命令1.1镜像相关1.2容器相关1.3数据卷1.4网络模式 2.Dockerfile3.Dockerfile示例 1.docker常用命令 1.1镜像相关 镜像相当于是一个模板&#xff0c;可以实例化出很多个容器&#xff1b; #查看docker版本 docker -v#查看docker默…

2025新年源码免费送

2025很开门很开门的源码免费传递。不需要馒头就能获取4套大开门源码。 听泉偷宝&#xff0c;又进来偷我源码啦&#x1f44a;&#x1f44a;&#x1f44a;。欢迎偷源码 &#x1f525;&#x1f525;&#x1f525; 获取免费源码以及更多源码&#xff0c;可以私信联系我 我们常常…

springboot + vue+elementUI图片上传流程

1.实现背景 前端上传一张图片&#xff0c;存到后端数据库&#xff0c;并将图片回显到页面上。上传组件使用现成的elementUI的el-upload。、 2.前端页面 <el-uploadclass"upload-demo"action"http://xxxx.xxx.xxx:9090/file/upload" :show-file-list&q…

如何用 ESP32-CAM 做一个实时视频流服务器

文章目录 ESP32-CAM 概述ESP32-S 处理器内存Camera 模块MicroSD 卡槽天线板载 LED 和闪光灯其他数据手册和原理图ESP32-CAM 功耗 ESP32-CAM 引脚参考引脚排列GPIO 引脚哪些 GPIO 可以安全使用&#xff1f;GPIO 0 引脚MicroSD 卡引脚 ESP32-CAM 的烧录方式使用 ESP32-CAM-MB 编程…

Virgo:增强慢思考推理能力的多模态大语言模型

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗&#xff1f;订阅我们的简报&#xff0c;深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同&#xff0c;从行业内部的深度分析和实用指南中受益。不要错过这个机会&#xff0c;成为AI领…

照片做成图书小程序开发制作介绍

照片做成图书小程序系统&#xff0c;主要是让用户直接通过小程序选择需要做成书的类型和照片排版布局模板&#xff0c;以及上传照片的数量。照片上传完成后&#xff0c;生成模板图片样式进行预览或编辑修改。修改完成全部保存。保存后生成完整的照片书进行预览没问题&#xff0…

《Spring Framework实战》10:4.1.4.2.详细的依赖和配置

欢迎观看《Spring Framework实战》视频教程 集合 <list/>、<set/>、<map/>和<props/>元素分别设置Java集合类型list、set、map和properties的属性和参数。以下示例显示了如何使用它们&#xff1a; <bean id"moreComplexObject" class&qu…

花生好坏缺陷识别数据集,7262张图片,支持yolo,coco json,pasical voc xml格式的标注,识别准确率在95.7%

花生好坏缺陷识别数据集,7262张图片&#xff0c;支持yolo&#xff0c;coco json&#xff0c;pasical voc xml格式的标注&#xff0c;识别准确率在95.7% 数据集分割 训练组87&#xff05; 6353图片 有效集8% 606图片 测试集4% 303图片 预处理 自动定…

WebLogic安全基线

WebLogic安全基线 一、 用户权限1 、检查weblogic 的启动用户2 、用户权限整改3 、使用普通用户重启weblogic 二、账户共用1 、检查weblogic 控制台的账户2 、账户共用整改3 、测试登录weblogic 控制台新账户 三、 账户清理1 、检查weblogic 控制台的账户2 、帐户清理整改 四、…

react-quill 富文本组件编写和应用

index.tsx文件 import React, { useRef, useState } from react; import { Modal, Button } from antd; import RichEditor from ./RichEditor;const AnchorTouchHistory: React.FC () > {const editorRef useRef<any>(null);const [isModalVisible, setIsModalVis…

TDv2:一种用于离线数学表达式识别的新型树形结构解码器

TDv2:一种用于离线数学表达式识别的新型树形结构解码器 本文提出了一种针对手写数学表达式识别(HMER)任务的新型树形解码器(TDv2) ,旨在充分利用数学表达式的树结构标签进行更有效的建模和预测。相较于传统的LaTeX字符串解码器,该模型通过采用一个节点分类模块和一个分…

银行信贷管理系统flask

完整源码项目包获取→点击文章末尾名片&#xff01;