Calibration_3D学习

*
* Initialize the program
dev_close_window ()    //关闭图形窗口
dev_open_window (0, 0, 768, 576, ‘black‘, WindowHandle)   //打开一个原点在(0,0)的宽为768,高为576,背景为黑色的图形窗口;
dev_update_off ()
dev_set_draw (‘margin‘)   //定义区域的填充模式,margin显示边缘,fill填充全部区域

dev_set_line_width (3)     //定义线宽为3
set_display_font (WindowHandle, 14, ‘mono‘, ‘true‘, ‘false‘) //设置显示字体(窗口句柄,字体大小,字体,是否加粗,是否斜体)

*
* Calibrate the camera
*
CalTabDescrFile := ‘caltab_big.descr‘   //标定板描述文件
StartCamPar := [0.008,0,0.0000086,0.0000086,384,288,768,576] //相机参数(焦距,畸变,像素尺寸宽,像素尺寸高,中心点坐标宽,中心点坐标高,图片宽,图片高)
create_calib_data (‘calibration_object‘, 1, 1, CalibDataID)  //创建标定数据模型,即标定的数据将存放于CalibDataID中。
set_calib_data_cam_param (CalibDataID, 0, ‘area_scan_division‘, StartCamPar) //设定相机的初始化参数(标定数据模型句柄,相机索引,相机类型,相机参数)
set_calib_data_calib_object (CalibDataID, 0, CalTabDescrFile) //在标定模型中设定标定对象(对象句柄,标定对象索引,3D标定板文件名)
NumImages := 10
for I := 1 to NumImages by 1
    read_image (Image, ‘calib/calib-3d-coord-‘ + I$‘02d‘) //读取图像(输出对象,文件名)
    dev_display (Image)//显示图片,类似matlab中的imshow
    Message := ‘Find calibration plate in\nall calibration images (‘ + I + ‘/‘ + NumImages + ‘)‘//
    disp_message (WindowHandle, Message, ‘window‘, 12, 12, ‘black‘, ‘true‘)//显示消息(窗口句柄,要显示的字符,当前的坐标系统,窗口显示的起始坐标,字体颜色,是否要显示白色底纹)
    * Find the calibration plate
    find_calib_object (Image, CalibDataID, 0, 0, I - 1, [], [])//(输入图像,标定数据模型句柄,相机索引,标定对象索引,标定对象位置索引,通用参数名称,通用参数值)
    get_calib_data (CalibDataID, ‘camera‘, 0, ‘init_params‘, StartCamPar)//获取标定数据(标定数据模型句柄,标定数据项的类型,影响项目索引,查询数据名称,响应数据)(依靠索引号和数据名称来返回输出的数据值。可查询与模型相关的数据,与相机相关的数据(包括相机的内外参数),与标定对象相关的数据,与标定对象的姿态相关的数据。控制输出是要查询的标定数据)
    get_calib_data_observ_points (CalibDataID, 0, 0, I - 1, Row, Column, Index, Pose)//获取观察点数据(标定数据模型句柄,相机索引,标定对象索引,位姿索引,检测点行号,检测点列号,检测点对应到标定对象观察点索引,粗略的位姿数据(相对相机))
    get_calib_data_observ_contours (Contours, CalibDataID, ‘caltab‘, 0, 0, I - 1)//获取校准数据轮廓(输出轮廓,标定数据模型句柄,轮廓名,相机索引,标定对象索引,位姿索引)
    gen_cross_contour_xld (Cross, Row, Column, 6, 0.785398)//为每个输入点生成一个十字形(生成XLD轮廓,输入点集行号,输入点集列号,十字形长度,十字形方向)
    dev_set_color (‘green‘)//用于定义显示区域颜色,这个设置到下一个dev_set_color才会被改变;
    dev_display (Contours)//显示对象
    dev_set_color (‘yellow‘)//
    dev_display (Cross)//
stop()
endfor
disp_continue_message (WindowHandle, ‘black‘, ‘true‘)// 等待用户操作是否继续
stop ()
calibrate_cameras (CalibDataID, Error)// 通过最小化过程确定相机的参数
get_calib_data (CalibDataID, ‘camera‘, 0, ‘params‘, CamParam)//
*
* Perform measurements
*
for I := 1 to NumImages by 1
    read_image (Image, ‘calib/calib-3d-coord-‘ + I$‘02d‘) //
    *
    * Now, measure the size of the black border of the plate
    get_measure_positions (Image, PlateRegion, CalibDataID, I, Distance, Phi, RowCenter, ColumnCenter)//
    gen_rectangle2_contour_xld (Rectangle, RowCenter, ColumnCenter, Phi, Distance * 0.52, 8)//
    gen_measure_rectangle2 (RowCenter, ColumnCenter, Phi, Distance * 0.52, 8, 768, 576, ‘nearest_neighbor‘, MeasureHandle)//产生测量句柄,准备提取和矩形主轴垂直的直边缘
    *
    measure_pos (Image, MeasureHandle, 1, 40, ‘all‘, ‘all‘, RowEdge, ColumnEdge, Amplitude, Distance1)//提取和矩形或弧垂直的边缘线
    close_measure (MeasureHandle)//
    Rows := [RowEdge[0],RowEdge[|RowEdge| - 1]]//
    Columns := [ColumnEdge[0],ColumnEdge[|RowEdge| - 1]]//
    gen_cross_contour_xld (Cross, Rows, Columns, 16, Phi)//
    *
    * Transform the two border points into the world coordinate system
    get_calib_data (CalibDataID, ‘calib_obj_pose‘, [0,I - 1], ‘pose‘, Pose)//
    image_points_to_world_plane (CamParam, Pose, Rows, Columns, ‘m‘, SX, SY)//
    distance_pp (SY[0], SX[0], SY[1], SX[1], Width)//
    *
    * Display results of width measurement
    dev_display (Image)//
    dev_set_color (‘white‘)//
    dev_set_line_width (3)//
    dev_display (Rectangle)//
    dev_set_color (‘green‘)//
    dev_set_draw (‘fill‘)//
    dev_set_line_width (2)//
    dev_display (Cross)//
    dev_set_draw (‘margin‘)//
    disp_message (WindowHandle, ‘Width = ‘ + (Width * 100)$‘8.3f‘ + ‘cm‘, ‘window‘, 12, 12, ‘black‘, ‘true‘)//
    disp_continue_message (WindowHandle, ‘black‘, ‘true‘)//
    stop ()
    *
    * Now, measure the size of the calibration marks
    *
    * Extract the ellipses in the image 提取图像中的椭圆
    erosion_circle (PlateRegion, ROI, 17.5)//生成一个圆形结构膨胀元素(,腐蚀区域,元素结构尺寸)
    reduce_domain (Image, ROI, ImageReduced)//选取图像中感兴趣的区域
    edges_sub_pix (ImageReduced, Edges, ‘canny‘, 1, 20, 60)//使用滤波器来精确检测边缘
    select_contours_xld (Edges, SelectedEdges, ‘contour_length‘, 20, 99999999, -0.5, 0.5)//根据一些特征选择XLD轮廓(contour)
    * Fit ellipses to extracted edges
    fit_ellipse_contour_xld (SelectedEdges, ‘fitzgibbon‘, -1, 2, 0, 200, 3, 2, Row, Column, Phi, Radius1, Radius2, StartPhi, EndPhi, PointOrder)//根据椭圆和椭圆弧近似提取XLD轮廓
    MeanRadius1 := mean(Radius1)//
    MeanRadius2 := mean(Radius2)//
    DevRadius1 := deviation(Radius1)//
    DevRadius2 := deviation(Radius2)//
    * Transform the ellipses to world coordinates, where they should be circles
    * and convert the circles from meters to millimeters so that we can see them.
    contour_to_world_plane_xld (SelectedEdges, WorldCircles, CamParam, Pose, ‘mm‘)//
    * Fit ellipses to the circles in world coordinates
    fit_ellipse_contour_xld (WorldCircles, ‘fitzgibbon‘, -1, 2, 0, 200, 3, 2, Row, Column, Phi, RadiusW1, RadiusW2, StartPhi, EndPhi, PointOrder)//
    MeanRadiusW1 := mean(RadiusW1)//
    MeanRadiusW2 := mean(RadiusW2)//
    DevRadiusW1 := deviation(RadiusW1)//
    DevRadiusW2 := deviation(RadiusW2)//
    *
    * Display results of ellipse measurement
    dev_display (Image)//
    dev_set_color (‘yellow‘)//
    dev_set_line_width (3)//
    dev_display (SelectedEdges)//
    Message := ‘Measured dimensions of the ellipses‘//
    Message[0] := ‘                    Mean Radius1; Mean Radius2; (Standard deviations [%])‘//
    Message[1] := ‘Image coordinates:       ‘ + MeanRadius1$‘5.2f‘ + ‘px; ‘ + MeanRadius2$‘5.2f‘ + ‘px            (‘ + (DevRadius1 / MeanRadius1 * 100)$‘4.2f‘ + ‘, ‘ + (DevRadius2 / MeanRadius2 * 100)$‘4.2f‘ + ‘)‘//
    Message[2] := ‘World coordinates:       ‘ + (MeanRadiusW1 / 10)$‘5.2f‘ + ‘cm; ‘ + (MeanRadiusW2 / 10)$‘5.2f‘ + ‘cm            (‘ + (DevRadiusW1 / MeanRadiusW1 * 100)$‘4.2f‘ + ‘, ‘ + (DevRadiusW2 / MeanRadiusW2 * 100)$‘4.2f‘ + ‘)‘//
    disp_message (WindowHandle, Message, ‘window‘, 12, 12, ‘black‘, ‘true‘)//
    if (I < 10)
        disp_continue_message (WindowHandle, ‘black‘, ‘true‘)//
        stop ()
    endif
endfor
clear_calib_data (CalibDataID)//

时间: 2024-08-05 07:06:24

Calibration_3D学习的相关文章

Vue.js学习笔记:属性绑定 v-bind

v-bind  主要用于属性绑定,Vue官方提供了一个简写方式 :bind,例如: <!-- 完整语法 --> <a v-bind:href="url"></a> <!-- 缩写 --> <a :href="url"></a> 绑定HTML Class 一.对象语法: 我们可以给v-bind:class 一个对象,以动态地切换class.注意:v-bind:class指令可以与普通的class特

Java多线程学习(吐血超详细总结)

林炳文Evankaka原创作品.转载请注明出处http://blog.csdn.net/evankaka 目录(?)[-] 一扩展javalangThread类 二实现javalangRunnable接口 三Thread和Runnable的区别 四线程状态转换 五线程调度 六常用函数说明 使用方式 为什么要用join方法 七常见线程名词解释 八线程同步 九线程数据传递 本文主要讲了java中多线程的使用方法.线程同步.线程数据传递.线程状态及相应的一些线程函数用法.概述等. 首先讲一下进程和线程

微信小程序学习总结(2)------- 之for循环,绑定点击事件

最近公司有小程序的项目,本人有幸参与其中,一个项目做下来感觉受益匪浅,与大家做下分享,欢迎沟通交流互相学习. 先说一下此次项目本人体会较深的几个关键点:微信地图.用户静默授权.用户弹窗授权.微信充值等等. 言归正传,今天分享我遇到的关于wx:for循环绑定数据的一个tips:  1. 想必大家的都知道wx:for,如下就不用我啰嗦了: <view class="myNew" wx:for="{{list}}">{{item.title}}<view

【安全牛学习笔记】

弱点扫描 ╋━━━━━━━━━━━━━━━━━━━━╋ ┃发现弱点                                ┃ ┃发现漏洞                                ┃ ┃  基于端口五福扫描结果版本信息(速度慢)┃ ┃  搜索已公开的漏洞数据库(数量大)      ┃ ┃  使用弱点扫描器实现漏洞管理            ┃ ╋━━━━━━━━━━━━━━━━━━━━╋ [email protected]:~# searchsploit Usage:

winform学习日志(二十三)---------------socket(TCP)发送文件

一:由于在上一个随笔的基础之上拓展的所以直接上代码,客户端: using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Windows.Forms; using System.Net.Sockets; using Sys

零基础的人该怎么学习JAVA

对于JAVA有所兴趣但又是零基础的人,该如何学习JAVA呢?对于想要学习开发技术的学子来说找到一个合适自己的培训机构是非常难的事情,在选择的过程中总是 因为这样或那样的问题让你犹豫不决,阻碍你前进的步伐,今天就让小编为您推荐培训机构新起之秀--乐橙谷Java培训机构,助力你成就好未来. 选择java培训就到乐橙谷 北京有什么好的Java培训机构?来乐橙谷北京学Java,零基础走起,乐橙谷Java基础班授课老师经验非常丰富,课程内容安排合理,适合于有一点点Java基础甚至一点都不会Java的同学学

最全解析如何正确学习JavaScript指南,必看!

划重点 鉴于时不时,有同学私信问我:怎么学前端的问题.这里统一回复一下,如下次再遇到问我此问题同学,就直接把本文链接地址发给你了. "前端怎么学"应该因人而异,别人的方法未必适合自己.就说说我的学习方法吧:我把大部分时间放在学习js上了.因为这个js的学习曲线,先平后陡.项目实践和练习啥的,我不说了,主要说下工作之外的时间利用问题.我是怎么学的呢,看书,分析源码.个人这几天统计了一下,前端书籍目前看了50多本吧,大部分都是js的.市面上的书基本,差不多都看过. 第一个问题:看书有啥好处

轻松学习C语言编程的秘诀:总结+灵感

目前在准备一套C语言的学习教程,所以我这里就以C语言编程的学习来讲.注意,讲的是"轻松学习",那种不注重方法,拼命玩命的方式也有其效果,但不是我提倡的.我讲究的是在方式方法对头.适合你.减轻你学习负担和心里压力的前提下,才适当的抓紧时间. 因此,探索一种很好的学习方法就是我所研究的主要内容. 众所周知,学习C语言并非易事,要学好它更是难上加难.这和你期末考试背会几个题目的答案考上满分没多大关系,也就是说你考试满分也说明不了你学好.学精通了C语言.那么怎么才算学精通C语言?闭着眼睛对自己

开始我的Python爬虫学习之路

因为工作需要经常收集一些数据,我就想通过学爬虫来实现自动化完成比较重复的任务. 目前我Python的状况,跟着敲了几个教程,也算是懂点基础,具体比较深入的知识,是打算从做项目中慢慢去了解学习. 我是觉得如果一开始就钻细节的话,是很容易受到打击而放弃的,做点小项目让自己获得点成就感路才更容易更有信心走下去. 反正遇到不懂的就多查多问就对了. 知乎上看了很多关于入门Python爬虫的问答,给自己总结出了大概的学习方向. 基础: HTML&CSS,JOSN,HTTP协议(这些要了解,不太需要精通) R