HALCON+PCL混合編程

在這里插入圖片描述

HALCON與PCL的混合編程基礎

HALCON和PCL(Point Cloud Library)都是處理3D數據的強大工具,但它們有著不同的設計目標和數據結構。HALCON專注于機器視覺應用,提供了豐富的圖像處理和分析功能;而PCL則是專門為點云處理設計的開源庫。

要實現兩者的混合編程,關鍵在于如何在它們的數據結構之間進行轉換,并合理設計處理流程。下面我將介紹實現這一目標的基本方法。

數據結構轉換

HALCON使用其專有的數據結構如HObjectHTuple來表示圖像和點云,而PCL使用pcl::PointCloud類。以下是它們之間的轉換示例:

#include <HALCONCpp.h>
#include <pcl/point_cloud.h>
#include <pcl/point_types.h>// 將HALCON的3D點云數據轉換為PCL點云
pcl::PointCloud<pcl::PointXYZ>::Ptr HalconToPCL(const HALCONCpp::HObject& halconPointCloud)
{HALCONCpp::HTuple row, col, z;// 從HALCON點云中提取坐標數據GetObjectModel3dCoord(halconPointCloud, "all", &row, &col, &z);// 創建PCL點云對象pcl::PointCloud<pcl::PointXYZ>::Ptr pclCloud(new pcl::PointCloud<pcl::PointXYZ>);// 獲取點的數量int numPoints = row.Length();// 調整PCL點云的大小pclCloud->resize(numPoints);// 填充PCL點云數據for (int i = 0; i < numPoints; ++i){pclCloud->points[i].x = col[i].D();pclCloud->points[i].y = row[i].D();pclCloud->points[i].z = z[i].D();}return pclCloud;
}// 將PCL點云轉換為HALCON的3D點云數據
HALCONCpp::HObject PCLToHalcon(const pcl::PointCloud<pcl::PointXYZ>::Ptr pclCloud)
{HALCONCpp::HObject halconPointCloud;// 創建HALCON點云所需的坐標元組HALCONCpp::HTuple row, col, z;// 準備數據存儲row.GenTupleArray(pclCloud->size(), 0.0);col.GenTupleArray(pclCloud->size(), 0.0);z.GenTupleArray(pclCloud->size(), 0.0);// 從PCL點云提取數據for (size_t i = 0; i < pclCloud->size(); ++i){row[i] = pclCloud->points[i].y;col[i] = pclCloud->points[i].x;z[i] = pclCloud->points[i].z;}// 創建HALCON點云對象GenObjectModel3d("point", row, col, z, &halconPointCloud);return halconPointCloud;
}

混合處理流程設計

設計一個同時使用HALCON和PCL的處理流程時,通常有兩種模式:

  1. HALCON主導模式:使用HALCON進行主要的處理流程,僅在需要特定PCL算法時切換到PCL。
  2. PCL主導模式:使用PCL進行主要的點云處理,僅在需要特定HALCON功能時切換到HALCON。

以下是一個HALCON主導模式的處理流程示例:

#include <HALCONCpp.h>
#include <pcl/point_cloud.h>
#include <pcl/point_types.h>
#include <pcl/filters/voxel_grid.h>
#include <pcl/segmentation/sac_segmentation.h>
#include <pcl/ModelCoefficients.h>// HALCON主導的混合處理流程示例
void HybridProcessingExample()
{try{// HALCON部分:加載點云數據HALCONCpp::HObject halconPointCloud;ReadObjectModel3d("point_cloud_data.ply", "m", 0, 0, &halconPointCloud);// HALCON部分:預處理SmoothObjectModel3d(halconPointCloud, "gaussian", 1.0, &halconPointCloud);// 轉換到PCL進行特定處理pcl::PointCloud<pcl::PointXYZ>::Ptr pclCloud = HalconToPCL(halconPointCloud);// PCL部分:降采樣pcl::VoxelGrid<pcl::PointXYZ> sor;sor.setInputCloud(pclCloud);sor.setLeafSize(0.01f, 0.01f, 0.01f);sor.filter(*pclCloud);// PCL部分:平面分割pcl::ModelCoefficients::Ptr coefficients(new pcl::ModelCoefficients);pcl::PointIndices::Ptr inliers(new pcl::PointIndices);pcl::SACSegmentation<pcl::PointXYZ> seg;seg.setOptimizeCoefficients(true);seg.setModelType(pcl::SACMODEL_PLANE);seg.setMethodType(pcl::SAC_RANSAC);seg.setDistanceThreshold(0.01);seg.setInputCloud(pclCloud);seg.segment(*inliers, *coefficients);// 轉換回HALCON進行后續處理halconPointCloud = PCLToHalcon(pclCloud);// HALCON部分:特征提取與分析HALCONCpp::HTuple features;GetObjectModel3dParams(halconPointCloud, "all", "surface_area", &features);// 顯示結果HALCONCpp::HWindow w(0, 0, 800, 600);DisplayObjectModel3d(halconPointCloud, w, "visible", "color", "blue", 0);}catch (const HALCONCpp::HException& ex){std::cerr << "HALCON錯誤: " << ex.ErrorMessage() << std::endl;}catch (const std::exception& ex){std::cerr << "PCL錯誤: " << ex.what() << std::endl;}
}

編譯和鏈接配置

要成功編譯HALCON和PCL的混合程序,需要正確配置編譯選項和鏈接庫。以下是一個典型的CMakeLists.txt示例:

cmake_minimum_required(VERSION 3.10)
project(HALCON_PCL_Hybrid)# 設置C++標準
set(CMAKE_CXX_STANDARD 11)# 查找HALCON
find_package(HALCON REQUIRED)
include_directories(${HALCON_INCLUDE_DIRS})
link_directories(${HALCON_LIBRARY_DIRS})# 查找PCL
find_package(PCL 1.8 REQUIRED COMPONENTS common filters segmentation)
include_directories(${PCL_INCLUDE_DIRS})
link_directories(${PCL_LIBRARY_DIRS})
add_definitions(${PCL_DEFINITIONS})# 添加可執行文件
add_executable(hybrid_processing main.cpp)# 鏈接庫
target_link_libraries(hybrid_processing ${HALCON_LIBRARIES}${PCL_LIBRARIES}
)

性能考慮

在混合編程時,數據轉換是性能瓶頸。應盡量減少HALCON和PCL之間的數據轉換次數,例如:

  1. 在進行多次PCL處理時,保持數據在PCL格式中
  2. 在進行多次HALCON處理時,保持數據在HALCON格式中
  3. 考慮實現自定義數據結構,直接支持兩種庫的操作

通過合理設計處理流程和數據結構,可以有效提高HALCON和PCL混合編程的效率。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/914560.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/914560.shtml
英文地址,請注明出處:http://en.pswp.cn/news/914560.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

JavaScript書寫基礎和基本數據類型

JavaScript書寫基礎和基本數據類型 jarringslee js書寫基礎和規范 js是一種在客戶端&#xff08;瀏覽器&#xff09;運行的編程語言&#xff0c;可實現人機交互的效果。js組成&#xff1a; js由兩部分組成&#xff1a; ECMAScript&#xff1a;js的語言基礎&#xff0c;js遵循其…

CSS個人筆記分享【僅供學習交流】

1、調整透明度 .text{ background-color: rgba(0, 0, 0, 0.08); }解釋&#xff1a;rgba&#xff08;rgb三元素&#xff0c;透明度取值從0~1&#xff09; 2、文字和圖片對齊方式 長用于頭像旁邊的昵稱居中顯示<img src"img/hua" alt"">華仔</img&g…

24.找到列表中最大或最小值的索引

找到列表中最大或最小值的索引 在 Python 中,如果你想找出某個列表中最小或最大值的位置(索引),你可以通過兩步快速實現: 使用 min() 或 max() 獲取目標值使用 .index() 獲取目標值在列表中的索引位置? 基礎實現 def min_element_index(arr):return arr.index(min(arr)

如何解決pip安裝報錯ModuleNotFoundError: No module named ‘pandas’問題

【Python系列Bug修復PyCharm控制臺pip install報錯】如何解決pip安裝報錯ModuleNotFoundError: No module named ‘pandas’問題 摘要 在使用 PyCharm 的 Python 控制臺或終端執行 pip install pandas 后&#xff0c;仍然出現 ModuleNotFoundError: No module named ‘pandas…

【env環境】rtthread5.1.0使用fal組件

配置 board/Kconfigconfig BSP_USING_ON_CHIP_FLASHbool "Enable On Chip Flash"default ncp rt-thread/components/fal/samples/porting/fal_cfg.h board/fal_cfg.h /** Copyright (c) 2006-2018, RT-Thread Development Team** SPDX-License-Identifier: Apache-2.…

C++20 協程參考手冊詳解 - 源自 cppreference.com

C20 協程參考手冊詳解 - 源自 cppreference.com 人話版 先說“人說”&#xff0c;簡化版本&#xff0c;更易理解。 宏觀概念&#xff1a;協程是一個可以暫定和恢復執行的函數。&#xff08;普通函數是線程相關的&#xff0c;函數的調用依賴于線程棧&#xff0c;而協程的運行…

AI大模型訓練的云原生實踐:如何用Kubernetes指揮千卡集群?

當你的團隊還在手動拼裝顯卡集群時&#xff0c;聰明人早已教會Kubernetes自動調度千卡。就像交響樂團需要指揮家&#xff0c;萬級GPU需要云原生調度藝術。深夜的機房&#xff0c;硬件工程師老張盯著監控屏上跳動的紅色警報——手工組裝的千卡集群再次因單點故障崩潰。而隔壁團隊…

java 在k8s中的部署流程

1.寫Docker文件FROM ubuntu:22.04ENV LANGC.UTF-8 LC_ALLC.UTF-8RUN apt-get update \&& DEBIAN_FRONTENDnoninteractive apt-get install -y --no-install-recommends tzdata curl ca-certificates fontconfig locales binutils \&& echo "C.UTF-8 UTF-8…

靜電式 vs UV 光解:哪種油煙凈化技術更適合你的餐廳?

在餐飲行業&#xff0c;油煙凈化是維持廚房環境、保障周邊空氣質量的關鍵環節。靜電式與 UV 光解作為兩種主流凈化技術&#xff0c;各有其適用范圍與局限性。選擇時需結合餐廳的烹飪類型、油煙特點及環保要求&#xff0c;而非盲目追求技術先進或價格高低。一、技術原理&#xf…

Java全棧工程師面試實錄:從電商系統到AIGC的層層遞進

場景&#xff1a;互聯網大廠Java面試官 vs 搞笑程序員小曾 第一輪提問 面試官&#xff1a;小曾&#xff0c;我們公司正在重構一個高并發的電商系統&#xff0c;需要使用Spring Cloud Alibaba進行服務拆分。你能描述一下如何用Nacos進行服務注冊與發現&#xff0c;并解決服務雪崩…

C++ CRTP

C CRTP&#xff08;奇異遞歸模板模式&#xff09;CRTP 是什么&#xff1f; 一句話總結&#xff1a;CRTP 就是讓子類把自己作為模板參數傳遞給父類。 聽起來有點繞&#xff0c;直接上代碼就明白了&#xff1a; template <typename Derived> class Base {// ... };class De…

21.映射字典的值

有時候你會希望保留字典的鍵不變,但將每個鍵對應的值應用一個函數進行轉換,比如提取字段、做數學運算、格式化等。 ? 基本用法 你可以使用 dict.items() 搭配字典推導式或生成器表達式來實現。 def map_values(obj, fn):return dict((k, fn(v)

【算法】貪心算法:擺動序列C++

文章目錄前言題目解析算法原理代碼示例策略證明前言 題目的鏈接&#xff0c;大家可以先試著去做一下再來看一下思路。376. 擺動序列 - 力扣&#xff08;LeetCode&#xff09; 題目解析 將題目有用的信息劃出來&#xff0c;結合示例認真閱讀&#xff0c;去理解題目。 我們的擺…

【DOCKER】-6 docker的資源限制與監控

文章目錄1、docker的資源限制1.1 容器資源限制的介紹1.2 OOM1.3 容器的內存限制1.3.1 內存限制的相關選項1.4 容器的CPU限制介紹2、docker的監控插件2.1 cadvisor2.2 portainer1、docker的資源限制 1.1 容器資源限制的介紹 默認情況下&#xff0c;容器沒有資源的使用限制&…

gcc 源碼分析--gimple 關鍵數據結構

gimple 操作碼&#xff0c;支持這些&#xff1a;DEFGSCODE(GIMPLE_symbol, printable name, GSS_symbol). */ DEFGSCODE(GIMPLE_ERROR_MARK, "gimple_error_mark", GSS_BASE) DEFGSCODE(GIMPLE_COND, "gimple_cond", GSS_WITH_OPS) DEFGSCODE(GIMPLE_DEBU…

TDengine GREATEST 和 LEAST 函數用戶手冊

TDengine GREATEST 和 LEAST 函數用戶手冊 1. 需求背景 1.1 問題描述 在實際生產過程中&#xff0c;客戶經常需要計算三相電流、電壓的最大值和最小值。傳統的實現方式需要使用復雜的 CASE WHEN 語句&#xff0c;例如&#xff1a; -- 傳統方式&#xff1a;計算三相電流最大…

Redis 與數據庫不一致問題及解決方案

一、不一致的原因分析 1. 緩存更新策略不當 先更新數據庫后刪除緩存:刪除緩存失敗會導致不一致 先刪除緩存后更新數據庫:并發請求可能導致不一致 緩存穿透:大量請求直接打到數據庫,繞過緩存 2. 并發操作問題 讀寫并發:讀請求獲取舊緩存時,寫請求更新了數據庫但未更新緩存…

iOS 加固工具使用經驗與 App 安全交付流程的實戰分享

在實際開發中&#xff0c;iOS App不僅要安全&#xff0c;還要能被穩定、快速、無誤地交付。這在外包、B端項目、渠道分發、企業自用系統等場景中尤為常見。 然而&#xff0c;許多開發者在引入加固工具后會遇到以下困擾&#xff1a; 混淆后App運行異常、不穩定&#xff1b;資源路…

Windows 下 Visual Studio 開發 C++ 項目的部署流程

在Windows環境中使用Visual Studio&#xff08;以下簡稱VS&#xff09;開發C項目時&#xff0c;“部署”是確保程序能在目標設備上正常運行的關鍵環節。部署的核心目標是&#xff1a;將編譯生成的可執行文件&#xff08;.exe&#xff09;、依賴的動態鏈接庫&#xff08;.dll&am…

yolo8+聲紋識別(實時字幕)

現在已經完成了人臉識別跟蹤 ?&#xff0c;接下來要&#xff1a; ? 加入「聲紋識別&#xff08;說話人識別&#xff09;」功能&#xff0c;識別誰在講話&#xff0c;并在視頻中“這個人”的名字旁邊加上「正在講話」。 這屬于多模態識別&#xff08;視覺 音頻&#xff09;&a…