极坐标想必学过高中数学的人都听过,一般的坐标系中用(x, y)值来描述一个点的位置,而在极坐标系中,则使用到原点的距离ρ和夹角θ来描述该点的位置。

我很早就接触了Photoshop,知道Photoshop里面有个极坐标的扭曲滤镜,如下图:

明白了极坐标(正向、反向)的大致效果是:能将矩形图案变成圆形(环形)图案,或者反过来。

例如制作这种超现实的特效:

Photoshop中的“极坐标”滤镜的原理是:以右上角为圆心,旋转以后生成的是一个长宽都是画布两倍的图形,然后将此图形压缩至二分之一,最后将圆心移到画面中央。(注意下面三个图形之间的相对位置)

Halcon中极坐标的处理可能为了使用方便,将内部算法经过了优化,所以外在表现形式略有不同。

Halcon中与极坐标变换相关的算子共有7个,不过polar_trans_image已经过时,官方不建议使用,可以看到Halcon对Image、Region、XLD都可以运用极坐标变换和反变换

Halcon示例程序中关于极坐标的例子有: inspect_bottle_mouth.hdev。下面的代码亦是根据这个例子精简而来,完整代码如下(注意看注释):

 *说明:本例由Halcon示例程序 inspect_bottle_mouth.hdev 精简而成,可先参考示例程序再阅读本代码。

 dev_set_draw ('margin')
dev_set_line_width ()
set_font (, '-Courier New-16-*-*-*-*-1-') list_files ('C:/Users/Administrator/Desktop/bottle', ['files','follow_links','recursive'], ImageFiles)
tuple_regexp_select (ImageFiles, ['\\.(tif|tiff|gif|bmp|jpg|jpeg|jp2|png|pcx|pgm|ppm|pbm|xwd|ima|hobj)$','ignore_case'], ImageFiles) for Index := to |ImageFiles| - by
read_image (Image, ImageFiles[Index])
get_image_size (Image, Width, Height)
threshold (Image, Region, , )
fill_up (Region, RegionFillUp)
opening_circle (RegionFillUp, RegionOpening, 8.5)
smallest_circle (RegionOpening, Row0, Column0, Radius0) *下面这个函数是自己写的抓圆的函数,细节不表。你也可以用fit_circle_contour_xld gen_circle_contour_xld实现类似功能
find_circle (Image, PartCircleXLD, Regions, Cross, Circle, Row0, Column0, Radius0 + , , , , , , , , 'negative', 'first', 'inner', , 'circle', RowCenter, ColCenter, Radius)
dev_display (Image)
dev_display (Circle) *该算子对一个图像的圆弧区域进行极坐标变换,圆弧外径是Radius,内径是Radius - ,即圆弧厚度是100
*同理,圆弧展开成矩形后,矩形宽度应该是外弧圆圈的周长,即6.28319 * Radius(周长 = 2π × r) ;矩形高度应该是圆弧厚度,即100
polar_trans_image_ext (Image, PolarTransImage, RowCenter, ColCenter, , 6.28319, Radius - , Radius, 6.28319 * Radius, , 'nearest_neighbor') *下面这句仅用于观察image的反向极坐标变换,生成的图片的宽高还是设置为最原始图像的Width, Height
polar_trans_image_inv (PolarTransImage, XYTransImage, RowCenter, ColCenter, , 6.28319, Radius - , Radius, Width, Height, 'nearest_neighbor') *mean_image选择主要沿水平方向进行模糊,动态阈值的'not_equal'参数同时筛选出了跟周围比过亮和过暗的区域(因为过暗和过亮都是缺陷)
mean_image (PolarTransImage, ImageMean, , )
dyn_threshold (PolarTransImage, ImageMean, Region1, , 'not_equal') fill_up_shape (Region1, RegionFillUp1, 'area', , )
*开运算去掉细小干扰
opening_circle (RegionFillUp1, RegionOpening1, 1.5)
connection (RegionOpening1, ConnectedRegions) *之所以要进行极坐标转换,就是为了这里用'height'来筛选,这是本例使用极坐标变换最关键的原因
select_shape (ConnectedRegions, SelectedRegions, 'height', 'and', , )
polar_trans_region_inv (SelectedRegions, XYTransRegion, RowCenter, ColCenter, , 6.28319, Radius - , Radius, 6.28319 * Radius, , Width, Height, 'nearest_neighbor')
dev_display (Image)
dev_display (XYTransRegion) stop ()
endfor
虽然极坐标变换是本例中的核心思路,但是仍有三句非常巧妙的代码,仔细想想为什么这三句代码很巧妙:

31     mean_image (PolarTransImage, ImageMean, 500, 3)
32 dyn_threshold (PolarTransImage, ImageMean, Region1, 30, 'not_equal')
40     select_shape (ConnectedRegions, SelectedRegions, 'height', 'and', 10, 99999)

该图极坐标转换后的图像为:

部分处理效果图如下:

Photoshop和Halcon中的极坐标变换的更多相关文章

  1. HALCON中的算子大全(中英对照)

    HALCON中的算子大全(中英对照) Chapter 1 :Classification1.1 Gaussian-Mixture-Models1.add_sample_class_gmm功能:把一个训 ...

  2. Halcon中的坐标系特点及XLD的镜像转换

    我们知道,Halcon中的坐标系的原点在左上角,而一般二维平面坐标系的原点在左下角.那么Halcon中坐标系和一般的二维坐标系有什么区别呢?我通过下面这个例子来分析. gen_image_const ...

  3. Python: PS 滤镜-- 极坐标变换到平面坐标

    本文用 Python 实现 PS 中的一种滤镜 极坐标变换到平面坐标,具体的算法原理和效果可以参考之前的博客: http://blog.csdn.net/matrix_space/article/de ...

  4. OpenCV图像变换二 投影变换与极坐标变换实现圆形图像修正

    投影变换 在放射变换中,物体是在二维空间中变换的.如果物体在三维空间中发生了旋转,那么这种变换就成为投影变换,在投影变换中就会出现阴影或者遮挡,我们可以运用二维投影对三维投影变换进行模块化,来处理阴影 ...

  5. ARCore中Pose类变换点的算法实现

    ARCore中Pose类变换点的算法实现,主要分为两步,分别是平移和旋转. 1. 旋转向量:通过四元数计算旋转后的向量 参数列表:q表示四元数, v是长度为4的float数组,表示待旋转的向量,   ...

  6. Halcon中缩放Region或XLD的方法研究

    在Halcon中,Region和XLD之间可以彼此转换.但这种转换并不是“无损”的,XLD可以是不闭合的,但是Region一定是闭合的.因此,如果将不闭合的XLD转为Region,然后再转回XLD,那 ...

  7. ReactiveCocoa 中 RACSignal 所有变换操作底层实现分析(上)

    前言 在上篇文章中,详细分析了RACSignal是创建和订阅的详细过程.看到底层源码实现后,就能发现,ReactiveCocoa这个FRP的库,实现响应式(RP)是用Block闭包来实现的,而并不是用 ...

  8. [UWP-小白日记16]UWP中的3D变换API

    原文:[UWP-小白日记16]UWP中的3D变换API 还没开始 好久没写博客了,再来开坑. 正文 Transform3D:“这个和CSS的3D好像的说” PerspectiveTransform3D ...

  9. OpenGL中的空间变换

    OpenGL中的空间变换          在使用OpenGL的三维虚拟程序中.当我们指定了模型的顶点之后.在屏幕上显示它们之前,一共会发生3种类型的变换:视图变换.模型变换.投影变换.        ...

随机推荐

  1. git本地项目上传远程

    Git的安装就不说了. 原文:https://blog.csdn.net/zamamiro/article/details/70172900 github官网说明: …or create a new ...

  2. Java技术栈

    内容: 1.Java基础(JavaSE) 2.数据结构与算法与设计模式 3.计算机理论知识 4.数据库 5.Java web(JavaEE) 6.消息队列 7.Linux及服务器相关 8.分布式相关 ...

  3. Mysql-两表的连接,copy表,select的各种用法

    -- 连接:外连接,内连接 两个表之间 外连接:right join    left join -- left join 左标为主 一般以值少的为主 select * from table1 left ...

  4. MVC,MVP 和 MVVM 模式如何选择?

    转摘:http://www.linuxidc.com/Linux/2015-10/124622.htm 前言 做客户端开发.前端开发对MVC.MVP.MVVM这些名词不了解也应该大致听过,都是为了解决 ...

  5. 20.Scrapy日常练手

    1.创建爬虫项目: scrapy  startproject tutorial 2.创建 spider cd tutorial scrapy  genspider quotes quotes.tosc ...

  6. 5. jdk路径配置

    path , classpath 的配置及作用? 1) PATH环境变量.作用是指定命令搜索路径,在i命令行下面执行命令如javac编译java程序时,它会到PATH变量所指定的路径中查找看是否能找到 ...

  7. canal 监控数据库表 快速使用

    https://github.com/alibaba/canal 快速开始 https://github.com/alibaba/canal/wiki/QuickStart 注意 1. vim con ...

  8. 17 网络编程 C/S架构介绍

    1.什么是C/S架构 C指的是client(客户端软件),S指的是Server(服务器软件),本章的重点是教大家写一个C/S架构的软件,实现服务端软件与客户端软件基于网络通信. 2.计算机基础的知识- ...

  9. Linux 如何将一个文件夹的所有内容授权给某一个用户

    我们可以使用chown命令,ch这里代表change(改变)的意思,own代表英文单词的owner(拥有者),连在一起就是 change owner ,改变某个文件或者文件夹的拥有者. 一般只有roo ...

  10. 第三方苹果开发库之ASIHTTPRequest

    转载于:http://www.dreamingwish.com/dream-2011/apples-third-party-development-libraries-asihttprequest.h ...