知微传感Dkam系列3D相机SDK例程篇:点云数据后处理

2023-10-27 18:50

本文主要是介绍知微传感Dkam系列3D相机SDK例程篇:点云数据后处理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

3D相机点云数据后处理

写在前面

  • 本人从事机器视觉细分的3D相机行业。编写此系列文章主要目的有:
    • 1、便利他人应用3D相机,本系列文章包含公司所出售相机的SDK的使用例程及详细注释;
    • 2、促进行业发展及交流。
  • 知微传感Dkam系列3D相机可以应用于定位分拣、焊接引导、逆向建模、检测测量等领域
  • 欢迎与我深入交流:微信号:liu_zhisensor

点云后处理及API说明

点云后处理说明
  • 知微传感为其3D相机输出的点云准备了后处理API
  • 点云后处理功能会用到点云计算过程中的数据,因此在相机端完成
  • 点云后处理功能如果不开启,则默认不做处理,开启后由3D相机传输到上位机的点云是处理后的
  • 后处理模式包括
    • 平滑:点云平滑处理,例如拍摄平面数据时,该模式可以让平面的点云方差变小
    • 正规:让点云按照理论像素位置排列
    • 黑白纹理:改善点云在颜色突变位置的跳动问题,例如棋盘格黑白方格交界区域的跳动,使跳动变小
  • 后处理模式在连接相机后,采集点云前设置
相关API
  • SetPointCloudPostProcessMode 设置后处理
    • int SetPointCloudPostProcessMode (Camera_Object_C* camera_obj, int mode)
    • 函数功能:用于设置点云后处理模式
    • 参数: camera_obj:相机的结构体指针 int mode: 0:不处理 (默认);1:平滑 ;2:正规;3:平滑+正规;4:黑白纹理 ;5:平滑+黑白纹理;6:正规+黑白纹理;7:平滑+正规+黑白纹理
    • 返回值:0 设置成功 非 0 设置失败
  • GetPointCloudPostProcessMode 获取3D相机当前后处理的模式
    • int GetPointCloudPostProcessMode (Camera_Object_C* camera_obj)
    • 函数功能:用于获取点云后处理模式
    • 参数: camera_obj:相机的结构体指针 返回值: 0:不处理 (默认);1:平滑 ;2:正规;3:平滑+正规;4:黑白纹理 ;5:平滑+黑白纹理;6:正规+黑白纹理;7:平滑+正规+黑白纹理

例程及注释

  • 本例程基于WIN10+VisualStudio2019+DkamSDK_1.6.71,采用C++语言
  • DkamSDK的配置方法请参考SDK说明书
  • 本例程在D132S型相机上验证
#include <iostream>
#include <cstring>
//DkamSDK
#include"dkam_discovery.h"
#include"dkam_gige_camera.h"
#include"dkam_gige_stream.h"int main()
{std::cout << "Hello Zhisensor!" << std::endl;std::cout << "Hello liu_sensor!" << std::endl;std::vector<DiscoveryInfo> discovery_info;Discovery discovery;GigeCamera camera;GigeStream* pointgigestream = NULL;GigeStream* graygigestream = NULL;GigeStream* rgbgigestream = NULL;std::vector<DiscoveryInfo>().swap(discovery_info);//********************************************查询相机****************************************************//查询局域网内的3D相机int camer_num = discovery.DiscoverCamera(&discovery_info);std::cout << "局域网内共有" << camer_num << "台相机" << std::endl;//显示局域网内相机的IPfor (int i = 0; i < camer_num; i++){std::cout << "局域网内相机的IP为:" << discovery.ConvertIpIntToString(discovery_info[i].camera_ip) << std::endl;}//********************************************连接相机****************************************************//选定相机int k = -1;for (int i = 0; i < camer_num; i++){if (strcmp((discovery.ConvertIpIntToString(discovery_info[i].camera_ip)), "192.168.30.35") == 0){k = i;std::cout << "将连接第" << k + 1 << "台相机" << std::endl;}else{std::cout << "局域网内无该IP的相机" << std::endl;}}//********************************************采集数据****************************************************int connect = camera.CameraConnect(&discovery_info[k]);if (connect == 0){//获取当前红外相机的宽和高int width = -1;int height = -1;std::cout << "获取相机红外图的宽和高。。。" << std::endl;int height_gray = camera.GetCameraHeight(&height, 0);int width_gray = camera.GetCameraWidth(&width, 0);std::cout << "camera  Grey width:" << width << "---Grey height:" << height << std::endl;//获取当前RGB相机的宽和高,如相机不支持则无此项int width_RGB = -1;int height_RGB = -1;std::cout << "获取相机RGB图的宽和高。。。" << std::endl;int height_rgb = camera.GetCameraHeight(&height_RGB, 1);int width_rgb = camera.GetCameraWidth(&width_RGB, 1);std::cout << "camera RGB width:" << width_RGB << "-----RGB height:" << height_RGB << std::endl;//定义点云数据大小PhotoInfo* point_data = new PhotoInfo;point_data->pixel = new char[width * height * 6];memset(point_data->pixel, 0, width * height * 6);//********************************************配置后处理****************************************************int PoProMoTag = -1;PoProMoTag = camera.SetPointCloudPostProcessMode(2);	//设置后处理模式为:正规if (PoProMoTag == 0){std::cout << "后处理模式设置成功!" << std::endl;}else{std::cout << "后处理模式设置失败!!!" << std::endl;}//查询后处理模式int PostProcessNum = -1;PostProcessNum = camera.GetPointCloudPostProcessMode();switch (PostProcessNum){case 0:std::cout << "后处理模式被设置为:不处理" << std::endl;break;case 1:std::cout << "后处理模式被设置为:平滑" << std::endl;break;case 2:std::cout << "后处理模式被设置为:正规" << std::endl;break;case 3:std::cout << "后处理模式被设置为:平滑+正规" << std::endl;break;case 4:std::cout << "后处理模式被设置为:黑白纹理" << std::endl;break;case 5:std::cout << "后处理模式被设置为:平滑+黑白纹理" << std::endl;break;case 6:std::cout << "后处理模式被设置为:正规+黑白纹理" << std::endl;break;case 7:std::cout << "后处理模式被设置为:平滑+正规+黑白纹理" << std::endl;break;default:std::cout << "超出范围,请联系官方确认该型号功能或相机固件版本的功能!" << std::endl;break;}//**********************************************打开数据通道****************************************************//开启数据流通道(0:红外 1:点云 2:RGB)int stream_point = camera.StreamOn(1, &pointgigestream);if (stream_point == 0){std::cout << "点云通道打开成功!" << std::endl;}else{std::cout << "点云通道打开失败!!!" << std::endl;}//开始接受数据int acquistion = camera.AcquisitionStart();if (acquistion == 0){std::cout << "可以开始接受数据!" << std::endl;}//刷新缓冲区数据pointgigestream->FlushBuffer();graygigestream->FlushBuffer();rgbgigestream->FlushBuffer();//**********************************************等待相机上传数据***************************************//采集点云int capturePoint = -1;capturePoint = pointgigestream->TimeoutCapture(point_data, 3000000);if (capturePoint == 0){std::cout << "点云接收成功!" << std::endl;}else{std::cout << "点云接收失败!!!" << std::endl;std::cout << "失败代号:" << capturePoint << std::endl;}//保存原始点云int savepoint = camera.SavePointCloudToPcd(*point_data, (char*)"PointCloud.pcd");if (savepoint == 0){std::cout << "原始点云保存成功!" << std::endl;}else{std::cout << "原始点云保存失败!!!" << std::endl;}//**********************************************结束工作***************************************memset(point_data->pixel, 0, width* height * 6);//释放内存delete[] point_data->pixel;delete point_data;//关闭数据流通道 int streamoff_point = camera.StreamOff(1, pointgigestream);//断开相机连接int disconnect = camera.CameraDisconnect();std::cout << "工作结束!!!!!!" << std::endl;}else{std::cout << "相机连接失败!!!" << std::endl;std::cout << "请排查原因,代号:"<< connect << std::endl;}return (0);
}

运行结果

在这里插入图片描述

结果对比

  • 原始数据
    在这里插入图片描述

  • 正规处理
    在这里插入图片描述

  • 可以看出,原始数据存在的点云缺失,经过正规处理后消失

后记

  • D200型号不具备后处理功能
  • D330序列,如D330XS、D33XSW、D330M、D330L的后处理模式只有0和1,即只有不处理和平滑两种后处理模式
  • 知微传感Dkam系列3D相机可以应用于定位分拣、焊接引导、逆向建模、检测测量等领域
  • 如有问题,欢迎与我深入交流:微信号:liu_zhisensor

这篇关于知微传感Dkam系列3D相机SDK例程篇:点云数据后处理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/287655

相关文章

MySQL InnoDB引擎ibdata文件损坏/删除后使用frm和ibd文件恢复数据

《MySQLInnoDB引擎ibdata文件损坏/删除后使用frm和ibd文件恢复数据》mysql的ibdata文件被误删、被恶意修改,没有从库和备份数据的情况下的数据恢复,不能保证数据库所有表数据... 参考:mysql Innodb表空间卸载、迁移、装载的使用方法注意!此方法只适用于innodb_fi

mysql通过frm和ibd文件恢复表_mysql5.7根据.frm和.ibd文件恢复表结构和数据

《mysql通过frm和ibd文件恢复表_mysql5.7根据.frm和.ibd文件恢复表结构和数据》文章主要介绍了如何从.frm和.ibd文件恢复MySQLInnoDB表结构和数据,需要的朋友可以参... 目录一、恢复表结构二、恢复表数据补充方法一、恢复表结构(从 .frm 文件)方法 1:使用 mysq

mysql8.0无备份通过idb文件恢复数据的方法、idb文件修复和tablespace id不一致处理

《mysql8.0无备份通过idb文件恢复数据的方法、idb文件修复和tablespaceid不一致处理》文章描述了公司服务器断电后数据库故障的过程,作者通过查看错误日志、重新初始化数据目录、恢复备... 周末突然接到一位一年多没联系的妹妹打来电话,“刘哥,快来救救我”,我脑海瞬间冒出妙瓦底,电信火苲马扁.

golang获取prometheus数据(prometheus/client_golang包)

《golang获取prometheus数据(prometheus/client_golang包)》本文主要介绍了使用Go语言的prometheus/client_golang包来获取Prometheu... 目录1. 创建链接1.1 语法1.2 完整示例2. 简单查询2.1 语法2.2 完整示例3. 范围值

javaScript在表单提交时获取表单数据的示例代码

《javaScript在表单提交时获取表单数据的示例代码》本文介绍了五种在JavaScript中获取表单数据的方法:使用FormData对象、手动提取表单数据、使用querySelector获取单个字... 方法 1:使用 FormData 对象FormData 是一个方便的内置对象,用于获取表单中的键值

Rust中的BoxT之堆上的数据与递归类型详解

《Rust中的BoxT之堆上的数据与递归类型详解》本文介绍了Rust中的BoxT类型,包括其在堆与栈之间的内存分配,性能优势,以及如何利用BoxT来实现递归类型和处理大小未知类型,通过BoxT,Rus... 目录1. Box<T> 的基础知识1.1 堆与栈的分工1.2 性能优势2.1 递归类型的问题2.2

Python使用Pandas对比两列数据取最大值的五种方法

《Python使用Pandas对比两列数据取最大值的五种方法》本文主要介绍使用Pandas对比两列数据取最大值的五种方法,包括使用max方法、apply方法结合lambda函数、函数、clip方法、w... 目录引言一、使用max方法二、使用apply方法结合lambda函数三、使用np.maximum函数

如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解

《如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解》:本文主要介绍如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别的相关资料,描述了如何使用海康威视设备网络SD... 目录前言开发流程问题和解决方案dll库加载不到的问题老旧版本sdk不兼容的问题关键实现流程总结前言作为

Redis的数据过期策略和数据淘汰策略

《Redis的数据过期策略和数据淘汰策略》本文主要介绍了Redis的数据过期策略和数据淘汰策略,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录一、数据过期策略1、惰性删除2、定期删除二、数据淘汰策略1、数据淘汰策略概念2、8种数据淘汰策略

轻松上手MYSQL之JSON函数实现高效数据查询与操作

《轻松上手MYSQL之JSON函数实现高效数据查询与操作》:本文主要介绍轻松上手MYSQL之JSON函数实现高效数据查询与操作的相关资料,MySQL提供了多个JSON函数,用于处理和查询JSON数... 目录一、jsON_EXTRACT 提取指定数据二、JSON_UNQUOTE 取消双引号三、JSON_KE