当前位置: 首页 > news >正文

Halcon 极坐标变换

(1)极坐标的展开:polar_trans_image_ext(Image : PolarTransImage : Row, Column, AngleStart, AngleEnd, RadiusStart, RadiusEnd, Width, Height, Interpolation : )

(2)极坐标的逆变换:polar_trans_image_inv(PolarImage : XYTransImage : Row, Column, AngleStart, AngleEnd, RadiusStart, RadiusEnd, Width, Height, Interpolation : )

其中:Row, Column分别为圆环的中心行列坐标, AngleStart, AngleEnd为起始和终止的角度值,RadiusStart, RadiusEnd为起始和终止的半径角度值, Width, Height为输出图片的宽和高。

极坐标的基本概念

简单地说,极坐标就是:用角度和长度描述位置的坐标系。结合上图明确这三点:

  • 以原点 O 为起点的射线作为参考系, 称O 为极点,这条射线为极轴
  • 点 P 到原点的距离记为 OP¯=r(≥0),称为极径
  • 从参考系射线出发逆时针旋转到OP 所经过的角度记为 θ∈[0,2π),称为极角
从计算的角度上讲θ 的取值范围也可以根据实际问题灵活处理。比如可以写为 θ∈[−π,π) 等。下文会有相应例子。

有了上述三个要素,空间中任意一点都可以用序对 (r,θ) 表示

极坐标和直角坐标的相互转换

(O-1){x=rcosθy=rsinθ⇔{r=x2+y2θ=arcsin⁡yr=arcsin⁡yx2+y2

但是要特别注意:上式中 θ 的值仅对(P在第I象限)成立(此时θ∈[0,π2],同时该点不能为原点)。对于其它象限则需要根据具体情况进行处理

案例:

read_image (Image33, 'E:/Halcon数据/资源图片/11.jpg')

get_image_size (Image33, Width, Height)
R:=Height/2
C:=Width/2
dev_close_window ()
dev_open_window (0, 0, 2*Width, 2*Height, 'black', WindowHandle)
dev_display (Image33)
dev_set_draw ('margin')
gen_rectangle1 (ROI_0, 17.25, 7.75, 222.75, 221.75)

reduce_domain (Image33, ROI_0, ImageReduced)
rgb1_to_gray (ImageReduced, GrayImage)
threshold (GrayImage, Region, 0, 80)
connection (Region, ConnectedRegions)
select_shape (ConnectedRegions, SelectedRegions, 'area', 'and', 15000, 29999)
smallest_circle (SelectedRegions, OuterRow, OuterColumn, OuterRadius)
gen_circle_contour_xld (OuterCircle, OuterRow, OuterColumn, OuterRadius, 0, 6.28318, 'positive', 1)
dev_display (Image33)
dev_display (OuterCircle)

InnerRow:=OuterRow
InnerColumn:=OuterColumn
InnerRadius:=OuterRadius-45
gen_circle_contour_xld (InnerCircle, InnerRow, InnerColumn, InnerRadius, 0, 6.28318, 'positive', 1)
dev_set_color ('green')
dev_set_draw ('margin')
dev_set_line_width (3)
dev_display (Image33)
dev_display (OuterCircle)
dev_display (InnerCircle)

WidthPolar := OuterRadius*6.28318
HeightPolar := round(OuterRadius - InnerRadius )
polar_trans_image_ext (Image33, PolarTransImage, InnerRow, InnerColumn, rad(240), -rad(120), OuterRadius , InnerRadius , WidthPolar, HeightPolar, 'bilinear')
dev_close_window ()
dev_open_window (0, 0, 3*WidthPolar, 3*HeightPolar, 'black', WindowHandle)
dev_display (PolarTransImage)

invert_image (PolarTransImage, ImageInvert)

gen_rectangle1 (ROI_0, 7, 13.6749, 42.6667, 467.273)

polar_trans_region_inv (ROI_0, CodeRegionCircular, InnerRow, InnerColumn, rad(240), -rad(120), OuterRadius, InnerRadius, WidthPolar, HeightPolar, Width, Height, 'nearest_neighbor')
dev_close_window ()
dev_open_window (0, 0, 2*Width, 2*Height, 'black', WindowHandle)
dev_display (Image33)
dev_display (CodeRegionCircular)

http://www.lryc.cn/news/460054.html

相关文章:

  • JavaScript进阶--深入面向对象
  • Python列表专题:list与in
  • 利用Microsoft Entra Application Proxy在无公网IP条件下安全访问内网计算机
  • 【IEEE独立出版 | 厦门大学主办】第四届人工智能、机器人和通信国际会议(ICAIRC 2024)
  • C++ 内存布局 - Part5: 继承关系中 构造析构与vptr的调整
  • BUG-AttributeError: ‘EnforcedForest‘ object has no attribute ‘node‘
  • Spring Boot 3 配置 Redis 兼容单例和集群
  • unsat钱包签名算法解析
  • mysql删除唯一索引
  • 学习之面试题:偏函数
  • 面试技术点
  • 基础sql
  • Jenkins整合Docker实现CICD自动化部署(若依项目)
  • kali chrome 安装 hackbar
  • 一文了解 Linux 系统的文件权限管理
  • Spark:DataFrame介绍及使用
  • Linux系统:本机(物理主机)访问不了虚拟机中的apache服务问题的解决方案
  • 望繁信科技成功签约国显科技 流程挖掘助力制造业智造未来
  • 枚举在Java体系中的作用
  • 『气泡水』Web官网 案例赏析
  • 【前端】制作一个简单的网页(2)
  • OpenAI Canvas:提升编程与写作效率的全新工作界面
  • 将SpringBoot的Maven项目打成jar包和war包
  • 【Iceberg分析】Spark与Iceberg集成之常用存储过程
  • [旧日谈]关于Qt的刷新事件频率,以及我们在Qt的框架上做实时的绘制操作时我们该关心什么。
  • 云上考场小程序+ssm论文源码调试讲解
  • 城域网——IP城域网、城域以太网、光城域网
  • 华为Eth-trunk链路聚合加入到E-trunk实现跨设备的链路聚合
  • 【网络安全】JSONP劫持原理及攻击实战
  • VR全景摄影的拍摄和编辑软件推荐