勇哥的视觉实验:畸变图像的校正


校正前的畸变图像

image.png

校正后的图像

image.png


read_image(Image, 'pioneer')
get_image_size(Image, Width, Height)

CamParIn:=[0.00219846,-78129.2,5.46495e-06,5.5e-06,318.206,236.732,Width,Height]

*依照测定的径向畸变决定相机的新参数
*算子参数: 输入样式,相机内参,输入径向畸变,输出修正后的参数
change_radial_distortion_cam_par('adaptive', CamParIn, 0, CamParamOut)
*改变径向畸变图像
change_radial_distortion_image(Image,Image , ImageRectified, CamParIn, CamParamOut)


再来一个例程:

vLf0HKQNOL.gif

set_system ('clip_region', 'false')
read_image (Image, 'pioneer')
get_image_pointer1 (Image, Pointer, Type, Width, Height)
dev_close_window ()
dev_open_window (0, 0, Width, Height, 'white', WindowHandle)
rgb1_to_gray (Image, GrayImage)
gen_cam_par_area_scan_division (0.00219846, -78129.2, 5.46495e-06, 5.5e-06, 318.206, 236.732, 640, 480, CamParOriginal)
* extract edges in the original image
dev_set_color ('red')
edges_sub_pix (GrayImage, Edges, 'lanser2', 0.5, 20, 40)
dev_set_color ('green')
disp_continue_message (WindowHandle, 'black', 'true')
stop ()
* Eliminating radial distortions from the extracted edges
* Change the radial distortion: set kappa to 0
CamParVirtualFixed := CamParOriginal
set_cam_par_data (CamParVirtualFixed, 'kappa', 0, CamParVirtualFixed)
* Alternatively, the operator change_radial_distortion_cam_par can be used
change_radial_distortion_cam_par ('fixed', CamParOriginal, 0, CamParVirtualFixed)
change_radial_distortion_contours_xld (Edges, EdgesRectifiedFixed, CamParOriginal, CamParVirtualFixed)
dev_display (GrayImage)
dev_display (EdgesRectifiedFixed)
disp_continue_message (WindowHandle, 'black', 'true')
stop ()
* Change the radial distortion: mode 'fullsize'
change_radial_distortion_cam_par ('fullsize', CamParOriginal, 0, CamParVirtualFullsize)
change_radial_distortion_contours_xld (Edges, EdgesRectifiedFullsize, CamParOriginal, CamParVirtualFullsize)
dev_display (GrayImage)
dev_display (EdgesRectifiedFullsize)
disp_continue_message (WindowHandle, 'black', 'true')
stop ()
* Change the radial distortion: mode 'adaptive'
change_radial_distortion_cam_par ('adaptive', CamParOriginal, 0, CamParVirtualAdaptive)
change_radial_distortion_contours_xld (Edges, EdgesRectifiedAdaptive, CamParOriginal, CamParVirtualAdaptive)
dev_display (GrayImage)
dev_display (EdgesRectifiedAdaptive)
disp_continue_message (WindowHandle, 'black', 'true')
stop ()
* Change the radial distortion: mode 'preserve_resolution'
change_radial_distortion_cam_par ('preserve_resolution', CamParOriginal, 0, CamParVirtualPreservedResolution)
change_radial_distortion_contours_xld (Edges, EdgesRectifiedPreservedResolution, CamParOriginal, CamParVirtualPreservedResolution)
dev_display (GrayImage)
dev_display (EdgesRectifiedPreservedResolution)
disp_continue_message (WindowHandle, 'black', 'true')
stop ()
* Eliminating radial distortions from the image
* Change the radial distortion: set kappa to 0
gen_radial_distortion_map (MapFixed, CamParOriginal, CamParVirtualFixed, 'bilinear')
map_image (GrayImage, MapFixed, ImageRectifiedFixed)
disp_continue_message (WindowHandle, 'black', 'true')
stop ()
* In case, only one image has to be rectified, the operator
* change_radial_distortion_image can be used instead of the operators
* gen_radial_distortion_map together with map_image.
get_cam_par_data (CamParVirtualFullsize, 'image_width', WidthVirtualFullsize)
get_cam_par_data (CamParVirtualFullsize, 'image_height', HeightVirtualFullsize)
gen_rectangle1 (ROI, 0, 0, HeightVirtualFullsize - 1, WidthVirtualFullsize - 1)
change_radial_distortion_image (GrayImage, ROI, ImageRectifiedFullsize, CamParOriginal, CamParVirtualFullsize)
dev_clear_window ()
dev_display (ImageRectifiedFullsize)
disp_continue_message (WindowHandle, 'black', 'true')
stop ()
get_cam_par_data (CamParVirtualAdaptive, 'image_width', WidthVirtualAdaptive)
get_cam_par_data (CamParVirtualAdaptive, 'image_height', HeightVirtualAdaptive)
gen_rectangle1 (ROI, 0, 0, HeightVirtualAdaptive - 1, WidthVirtualAdaptive - 1)
change_radial_distortion_image (GrayImage, ROI, ImageRectifiedAdaptive, CamParOriginal, CamParVirtualAdaptive)
dev_clear_window ()
dev_display (ImageRectifiedAdaptive)
disp_continue_message (WindowHandle, 'black', 'true')
stop ()
get_cam_par_data (CamParVirtualPreservedResolution, 'image_width', WidthVirtualPreservedResolution)
get_cam_par_data (CamParVirtualPreservedResolution, 'image_height', HeightVirtualPreservedResolution)
gen_rectangle1 (ROI, 0, 0, HeightVirtualPreservedResolution - 1, WidthVirtualPreservedResolution - 1)
change_radial_distortion_image (GrayImage, ROI, ImageRectifiedPreservedResolution, CamParOriginal, CamParVirtualPreservedResolution)
dev_clear_window ()
dev_display (ImageRectifiedPreservedResolution)


本文出自勇哥的网站《少有人走的路》wwww.skcircle.com,转载请注明出处!讨论可扫码加群:
  • 评论列表:

发表评论:

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

会员中心
搜索
«    2024年4月    »
1234567
891011121314
15161718192021
22232425262728
2930
网站分类
标签列表
最新留言
    热门文章 | 热评文章 | 随机文章
文章归档
友情链接
  • 订阅本站的 RSS 2.0 新闻聚合
  • 扫描加本站机器视觉QQ群,验证答案为:halcon勇哥的机器视觉
  • 点击查阅微信群二维码
  • 扫描加勇哥的非标自动化群,验证答案:C#/C++/VB勇哥的非标自动化群
  • 扫描加站长微信:站长微信:abc496103864
  • 扫描加站长QQ:
  • 扫描赞赏本站:
  • 留言板:

Powered By Z-BlogPHP 1.7.2

Copyright Your skcircle.com Rights Reserved.

鄂ICP备18008319号


站长QQ:496103864 微信:abc496103864