大恒相机开发(2)—Python软触发调用采集图像
大恒相机开发(2)—Python软触发调用采集图像
- 完整代码
- 详细解读和功能说明
- 扩展学习
这段代码是一个Python程序,用于从大恒相机采集图像,通过软件触发来采集图像。
完整代码
咱们直接上python的完整代码:
# version:1.0.1905.9071
import gxipy as gx
import time
from PIL import Imagedef acq_color(device, num):""":brief acquisition function of color device:param device: device object[Device]:param num: number of acquisition images[int]"""for i in range(num):time.sleep(0.1)# send software trigger commanddevice.TriggerSoftware.send_command()# get raw imageraw_image = device.data_stream[0].get_image()if raw_image is None:print("Getting image failed.")continue# get RGB image from raw imagergb_image = raw_image.convert("RGB")if rgb_image is None:continue# create numpy array with data from raw imagenumpy_image = rgb_image.get_numpy_array()if numpy_image is None:continue# show acquired imageimg = Image.fromarray(numpy_image, 'RGB')img.show()# print height, width, and frame ID of the acquisition imageprint("Frame ID: %d Height: %d Width: %d"% (raw_image.get_frame_id(), raw_image.get_height(), raw_image.get_width()))def acq_mono(device, num):""":brief acquisition function of mono device:param device: device object[Device]:param num: number of acquisition images[int]"""for i in range(num):time.sleep(0.1)# send software trigger commanddevice.TriggerSoftware.send_command()# get raw imageraw_image = device.data_stream[0].get_image()if raw_image is None:print("Getting image failed.")continue# create numpy array with data from raw imagenumpy_image = raw_image.get_numpy_array()if numpy_image is None:continue# show acquired imageimg = Image.fromarray(numpy_image, 'L')img.show()# print height, width, and frame ID of the acquisition imageprint("Frame ID: %d Height: %d Width: %d"% (raw_image.get_frame_id(), raw_image.get_height(), raw_image.get_width()))def main():# print the demo informationprint("")print("-------------------------------------------------------------")print("Sample to show how to acquire mono or color image by soft trigger ""and show acquired image.")print("-------------------------------------------------------------")print("")print("Initializing......")print("")# create a device managerdevice_manager = gx.DeviceManager()dev_num, dev_info_list = device_manager.update_device_list()if dev_num is 0:print("Number of enumerated devices is 0")return# open the first devicecam = device_manager.open_device_by_index(1)# set exposurecam.ExposureTime.set(10000)# set gaincam.Gain.set(10.0)if dev_info_list[0].get("device_class") == gx.GxDeviceClassList.USB2:# set trigger modecam.TriggerMode.set(gx.GxSwitchEntry.ON)else:# set trigger mode and trigger sourcecam.TriggerMode.set(gx.GxSwitchEntry.ON)cam.TriggerSource.set(gx.GxTriggerSourceEntry.SOFTWARE)# start data acquisitioncam.stream_on()# camera is color cameraif cam.PixelColorFilter.is_implemented() is True:acq_color(cam, 1)# camera is mono cameraelse:acq_mono(cam, 1)# stop acquisitioncam.stream_off()# close devicecam.close_device()if __name__ == "__main__":main()
详细解读和功能说明
下面是代码的详细解读和功能说明:
-
导入必要的库:
gxipy
:大恒相机的SDK,用于控制相机。time
:用于在采集图像之间添加延迟。PIL
(Python Imaging Library):用于图像处理,这里用于显示图像。
-
定义采集函数:
acq_color(device, num)
:用于彩色相机的采集函数。acq_mono(device, num)
:用于单色相机的采集函数。
-
采集函数的共同步骤:
- 循环
num
次,每次采集一幅图像。 time.sleep(0.1)
:在每次采集之间添加0.1秒的延迟。device.TriggerSoftware.send_command()
:发送软件触发命令,告诉相机现在可以采集图像。raw_image = device.data_stream[0].get_image()
:从相机的第一个数据流中获取原始图像。- 如果
raw_image
为None
,则打印错误信息并继续下一次循环。 - 对于彩色相机,
rgb_image = raw_image.convert("RGB")
:将原始图像转换为RGB格式。 - 对于单色相机,直接使用
raw_image
。 numpy_image = rgb_image.get_numpy_array()
或numpy_image = raw_image.get_numpy_array()
:将图像数据转换为numpy数组。- 如果
numpy_image
为None
,则跳过当前循环。 img = Image.fromarray(numpy_image, 'RGB')
或img = Image.fromarray(numpy_image, 'L')
:将numpy数组转换为PIL图像对象,'RGB’用于彩色图像,'L’用于单色图像。img.show()
:显示采集到的图像。- 打印采集图像的帧ID、高度和宽度。
- 循环
-
定义
main
函数:- 打印程序信息和初始化步骤。
- 创建设备管理对象
device_manager
。 - 枚举设备并检查是否有设备连接。
- 打开第一个设备
cam
。 - 设置曝光时间
cam.ExposureTime.set(10000)
和增益cam.Gain.set(10.0)
。 - 根据设备类型设置触发模式,对于USB2设备,只设置触发模式为开启;对于其他设备,还需要设置触发源为软件触发。
- 开始数据采集
cam.stream_on()
。 - 检查相机是否为彩色相机,并调用相应的采集函数。
- 停止数据采集
cam.stream_off()
。 - 关闭设备
cam.close_device()
。
-
程序入口:
if __name__ == "__main__":
:确保当脚本被直接运行时,才执行main
函数。
这个程序的主要功能是初始化大恒相机,设置曝光时间和增益,然后通过软件触发采集一幅图像,并显示采集到的图像。程序还根据相机的类型(彩色或单色)调用不同的采集函数。最后,程序停止数据采集并关闭相机设备。
的一些信息,如帧ID和帧率。
扩展学习
使用大恒相机进行图像采集时,以下是一些性能优化技巧:
-
合理设置相机参数:
- 根据应用需求合理设置分辨率、曝光时间、增益等参数,以达到最佳的图像质量和采集速度。
-
使用软件触发:
- 通过软件触发来控制图像采集,可以更精确地控制采集时机,减少不必要的图像数据。
-
图像格式转换和预处理:
- 利用大恒相机SDK提供的功能,对图像进行格式转换(如Bayer转RGB)和预处理(如红蓝转换、垂直镜像等),以减少后续处理的负担。
-
利用回调采集提高效率:
- 使用回调采集方式,当图像就绪时自动触发处理,这样可以避免轮询检查图像是否就绪的开销,提高采集效率。
-
图像增强功能:
- 通过图像增强功能,如坏点校正、锐化、对比度、亮度调节等,可以在采集阶段就优化图像质量,减少后续处理的复杂度。
-
流对象属性控制:
- 通过流对象控制相机采集相关的属性和统计信息,可以更精细地管理采集过程,提高性能。
-
多相机采集稳定性:
- 对于多相机系统,使用支持多路I/O输入/输出信号和丰富图像预处理功能的图像采集卡,可以提高多相机采集的稳定性和效率。
-
使用高速接口:
- 如果相机支持,使用高速接口如CoaXPress或千兆网接口,可以显著提高数据传输速度,减少传输延迟。
-
优化代码逻辑:
- 在图像采集的代码中,避免不必要的图像复制和转换操作,直接在相机端进行必要的处理,可以减少CPU占用率,提高整体性能。
-
合理管理资源:
- 及时释放不再使用的资源,如关闭数据流、注销事件回调等,可以避免资源泄露,保持系统的稳定性和性能。
通过上述技巧,可以有效地提升大恒相机在图像采集过程中的性能和效率。
相关文章:

大恒相机开发(2)—Python软触发调用采集图像
大恒相机开发(2)—Python软触发调用采集图像 完整代码详细解读和功能说明扩展学习 这段代码是一个Python程序,用于从大恒相机采集图像,通过软件触发来采集图像。 完整代码 咱们直接上python的完整代码: # version:…...

QT的前景与互联网岗位发展
qt是用来干什么的 --》桌面应用开发(做电脑的应用程序,面对客户端)。 主要用于开发跨平台的应用程序和用户界面(UI)。它是一个全面的C库集合,提供了构建软件应用所需的各种工具和功能。 客户端开发的重…...

青藤入选工信部“2024年网络安全技术应用典型案例拟支持项目名单”
近日,工业和信息化部公示了“2024年网络安全技术应用典型案例拟支持项目名单”,青藤云安全联合某股份制银行共同申报的主机威胁狩猎平台项目凭借其技术先进性及行业示范性成功入选。 网络安全技术应用试点示范工作是由工业和信息化部、国家互联网信息办公…...
NVIDIA GPU 内部架构介绍
NVIDIA GPU 架构 NVIDIA GPU 的 SM(Streaming Multiprocessor) 和 GPC(Graphics Processing Cluster) 是 GPU 架构中的关键组成部分。它们决定了 GPU 的计算能力和性能,以下是对这两个参数的详细介绍: 1. …...

重温设计模式----装饰模式
文章目录 装饰模式定义UML 图其主要优点包括:装饰模式的主要角色有:C 代码示例总结 装饰模式定义 动态的给一个对象添加一些额外的职责,就增加功能来说,装饰模式必生成子类更加灵活 装饰模式(Decorator Pattern&…...

第十六章 C++ 字符串
C 字符串 C 提供了以下两种类型的字符串表示形式: C 风格字符串C 引入的 string 类类型 C 风格字符串 C 风格的字符串起源于 C 语言,并在 C 中继续得到支持。字符串实际上是使用 null 字符 终止的一维字符数组。因此,一个以 null 结尾的…...
MySQL中Seconds_Behind_Master是怎么计算的
目录 1.Seconds_Behind_Master计算方式2.Seconds_Behind_Master 计算方式会存在什么问题3.更好的方式3.1 实现方法3.2 优点在MySQL中,Seconds_Behind_Master是一个用于表示从库(Slave)落后于主库(Master)的时间(以秒为单位)的指标。 1.Seconds_Behind_Master计算方式 其…...
React Native 集成原生Android功能
React Native 集成原生功能完整指南 前言 在 React Native 开发中,我们经常需要使用设备的原生功能,比如蓝牙、打印机等。本文将以集成打印机功能为例,详细介绍如何在 React Native 项目中集成 Android 原生功能。 集成步骤概述 创建原生…...
Mac mini m4安装PD和Crack和关闭SIP
文章目录 说明PD下载地址Crack下载地址PD版本补丁版本说明SIP简介SIP关闭方法启用 SIP:补充说明 说明 参考文章地址 PD下载地址 PD20.0.0 PD20.0.1 PD20.1.0 PD20.1.1 PD20.1.2 PD20.1.3 Crack下载地址 Parallels Desktop Activation Tool PD版本补丁版本…...
详解C语言中的关键词:extern以及它需要注意的事项
extern 是C语言中一个非常重要的关键字,用于声明变量或函数的 外部链接性,即在当前文件中使用另一个文件中定义的变量或函数。以下是 extern 的作用和使用场景: 1. extern 的作用 跨文件访问: extern 告诉编译器,某个…...

框架程序设计-简答以及论述
目录 maven的pom作用: Pointcut("execution(*com.example.dome.*.*(……))") 缓存的作用,redis配置过程 Redis配置过程: SpringBoot缓存配置过程: AOP的五种增强注解: 论述题:包结构作用、…...

ce第六次作业
1、判断当前磁盘剩余空间是否有20G,如果小于20G,则将报警邮件发送给管理员,每天检查一次磁盘剩余空间。 [rootServer ~]# yum install -y mailx [rootServer ~]# yum -y install bind-utils [rootServer ~]# vim /etc/mail.rc set from15339…...
为何页面搜索应避免左模糊和全模糊查询???
前言 在构建高效且可扩展的Web应用程序时,数据库查询的性能是影响用户体验的关键因素之一。特别是对于涉及大量数据的页面搜索功能,选择正确的查询方式不仅可以提升应用的速度,还能显著改善用户交互体验。 B-Tree索引与最左前缀匹配特性 1…...

AI可信论坛亮点:合合信息分享视觉内容安全技术前沿
前言 在当今科技迅猛发展的时代,人工智能(AI)技术正以前所未有的速度改变着我们的生活与工作方式。作为AI领域的重要盛会,CSIG青年科学家会议AI可信论坛汇聚了众多青年科学家与业界精英,共同探讨AI技术的最新进展、挑…...

在 Mac M2 上安装 PyTorch 并启用 MPS 加速的详细教程与性能对比
1. 安装torch 在官网上可以查看安装教程,Start Locally | PyTorch 作者安装了目前最新的torch版本2.5.1,需要提前安装python3.9及以上版本,作者python版本是python3.11最新版本 使用conda安装torch,在终端进入要安装的环境&…...
生成式人工智能在生产型企业中的应用
生成式人工智能(Generative AI)是指使用人工智能来创建新内容,如文本、图像、音乐、音频和视频等。生成式人工智能在生产型企业中的应用涵盖了内容创作与自动化、数据分析与决策支持、生产流程优化、产品设计与开发、客户服务与沟通、员工培训…...

Linux逻辑卷管理
目录 实验要求 实验操作 1、 为Linux新添加一块SCSI磁盘/dev/sdc,容量为1024MB。在该磁盘上创建三个分区sdc1、sdc2、sdc3,大小为128MB,标识为Linux native分区。 2、 在三个分区上创建物理卷;将三个物理卷加入VolGroup00卷组&…...

机器人加装电主轴【铣削、钻孔、打磨、去毛刺】更高效
机器人加装电主轴进行铣削、钻孔、打磨、去毛刺等作业,展现出显著的优势,并能实现高效加工。 1. 高精度与高效率 电主轴特点:高速电主轴德国SycoTec的产品,转速可达100000rpm,功率范围广,精度≤1μm&#…...

opencv sdk for java中提示无stiching模块接口的问题
1、问题介绍 安卓项目中有新的需求,在 jni 中增加 stiching_detail.cpp 中全景拼接的实现。 但是在编译时,出现大量报错,如下截图所示 实际上,其他opencv的接口函数 例如 core dnn等都能正常使用,直觉上初步怀疑 ope…...

今天最新早上好问候语精选大全,每天问候,相互牵挂,彼此祝福
1、朋友相伴,友谊真诚永不变!彼此扶持绿树荫,共度快乐雨后天!一同分享的表情,愿我们友情长存,一生相伴永相连! 2、人生几十年,苦累伴酸甜,风华不再茂,雄心非当…...

测试微信模版消息推送
进入“开发接口管理”--“公众平台测试账号”,无需申请公众账号、可在测试账号中体验并测试微信公众平台所有高级接口。 获取access_token: 自定义模版消息: 关注测试号:扫二维码关注测试号。 发送模版消息: import requests da…...

css实现圆环展示百分比,根据值动态展示所占比例
代码如下 <view class""><view class"circle-chart"><view v-if"!!num" class"pie-item" :style"{background: conic-gradient(var(--one-color) 0%,#E9E6F1 ${num}%),}"></view><view v-else …...
【JavaSE】绘图与事件入门学习笔记
-Java绘图坐标体系 坐标体系-介绍 坐标原点位于左上角,以像素为单位。 在Java坐标系中,第一个是x坐标,表示当前位置为水平方向,距离坐标原点x个像素;第二个是y坐标,表示当前位置为垂直方向,距离坐标原点y个像素。 坐标体系-像素 …...

vue3+vite项目中使用.env文件环境变量方法
vue3vite项目中使用.env文件环境变量方法 .env文件作用命名规则常用的配置项示例使用方法注意事项在vite.config.js文件中读取环境变量方法 .env文件作用 .env 文件用于定义环境变量,这些变量可以在项目中通过 import.meta.env 进行访问。Vite 会自动加载这些环境变…...

如何理解 IP 数据报中的 TTL?
目录 前言理解 前言 面试灵魂一问:说说对 IP 数据报中 TTL 的理解?我们都知道,IP 数据报由首部和数据两部分组成,首部又分为两部分:固定部分和可变部分,共占 20 字节,而即将讨论的 TTL 就位于首…...

初学 pytest 记录
安装 pip install pytest用例可以是函数也可以是类中的方法 def test_func():print()class TestAdd: # def __init__(self): 在 pytest 中不可以使用__init__方法 # self.cc 12345 pytest.mark.api def test_str(self):res add(1, 2)assert res 12def test_int(self):r…...

《Docker》架构
文章目录 架构模式单机架构应用数据分离架构应用服务器集群架构读写分离/主从分离架构冷热分离架构垂直分库架构微服务架构容器编排架构什么是容器,docker,镜像,k8s 架构模式 单机架构 单机架构其实就是应用服务器和单机服务器都部署在同一…...

AxureRP-Pro-Beta-Setup_114413.exe (6.0.0.2887)
Name:3ddown Serial:FiCGEezgdGoYILo8U/2MFyCWj0jZoJc/sziRRj2/ENvtEq7w1RH97k5MWctqVHA 注册用户名:Axure 序列号:8t3Yk/zu4cX601/seX6wBZgYRVj/lkC2PICCdO4sFKCCLx8mcCnccoylVb40lP...

云原生安全实战:API网关Envoy的鉴权与限流详解
🔥「炎码工坊」技术弹药已装填! 点击关注 → 解锁工业级干货【工具实测|项目避坑|源码燃烧指南】 一、基础概念 1. API网关 作为微服务架构的统一入口,负责路由转发、安全控制、流量管理等核心功能。 2. Envoy 由Lyft开源的高性能云原生…...
在Spring Boot中集成RabbitMQ的完整指南
前言 在现代微服务架构中,消息队列(Message Queue)是实现异步通信、解耦系统组件的重要工具。RabbitMQ 是一个流行的消息中间件,支持多种消息协议,具有高可靠性和可扩展性。 本博客将详细介绍如何在 Spring Boot 项目…...