更新标定参数,添加aruco参数分析
This commit is contained in:
parent
1763cec954
commit
e2aecbc985
51
aruco 参数分析.md
Normal file
51
aruco 参数分析.md
Normal file
@ -0,0 +1,51 @@
|
||||
# aruco 参数分析
|
||||
|
||||
aruco.cpp
|
||||
在287行有一个DetectInitialCandidatesParallel
|
||||
在这里面有并行操作,用于对图像进行二值化,之后检测二值化后的图像中是否存在marker。
|
||||
|
||||
其循环次数直接和adaptiveThreshWinSizeMin adaptiveThreshWinSizeMax adaptiveThreshWinSizeStep相关。默认情况下分别是3 23 10,也就是会循环三次分别用3 13 23的二值化系数,其中数字越大,二值化以后的边缘越粗。实测认为23太大,循环为为3 6 9 即可。
|
||||
至于adaptiveThreshConstant暂时觉得没有什么贡献,这个数值越高,二值化以后的图中孤立的噪声点越少,默认是7,可调为20。
|
||||
adaptiveThreshWinSize参数没有用到,删了。
|
||||
|
||||
函数传入了Range就是adaptiveThreshWinSizeMin adaptiveThreshWinSizeMax 之间循环的次数。
|
||||
|
||||
minMarkerPerimeterRate是限制了图像中marker的最小边长尺寸,将这个修改为0.5会发现很多小的marker检测不出来。
|
||||
|
||||
程序通过findContours查找闭合边缘,然后先
|
||||
根据min/maxMarkerPerimeterRate挑选出适合长度的区域
|
||||
|
||||
检查矩形以及凸型 使用approxPolyDP函数 输入一组点,输出该该点集的拟合图形,其中拟合偏差度由accuracyRate决定,其越小,拟合的越精确。默认是0.05,如果改为0.01则找出的区域在边角跳动很剧烈,因为阈值太严格,每张图像多多少少有噪声,这些噪声会直接影响结果。所以保持默认的0.05.
|
||||
通过检查拟合出来的点集的size是否为4来筛选出矩形。通过isContourConvex来判断是否是凸集。
|
||||
|
||||
minCornerDistance没有用,取代的是minCornerDistanceRate。他表示approxPolyDP输出的四个点,两两之间计算图像上的距离,寻找最小的那个距离,之后这个距离必须大于findContours找到的闭合边缘的百分比,理所应当的是这个参数要小于0.25,默认是0.05,我改为0.15可以消除很多斜视的情况!
|
||||
|
||||
minDistanceToBorder是值找出来的图形距离图像边缘的阈值,默认是3,其实和adaptiveThreshWinSizeMin 有关,这里就用默认值3
|
||||
|
||||
至此_detectInitialCandidates函数任务完成。输出了一批候选marker
|
||||
|
||||
之后是 _identifyCandidates 要计算出marker的id号。
|
||||
markerBorderBits在生成marker是就决定了,这里是1
|
||||
|
||||
之后是_filterTooCloseCandidates,将特别靠近的marker去除掉。minMarkerDistance参数没有用删除,minMarkerDistanceRate保持默认值。
|
||||
|
||||
doCornerRefinement是使用亚像素级角点检测,可以不使用。
|
||||
|
||||
至此检测所有的marker结束之后就是位姿估计。
|
||||
|
||||
|
||||
|
||||
```sh
|
||||
export ANDROID_SDK=
|
||||
export PATH=$ANDROID_SDK/tools:$PATH
|
||||
source ~/.bashrc
|
||||
|
||||
```
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
```text
|
||||
|
||||
```
|
||||
@ -24,3 +24,27 @@
|
||||
| p2 | 0.008645251405539 |
|
||||
| k3 | 1.267624998722697e+05 |
|
||||
|
||||
## code
|
||||
|
||||
```java
|
||||
if (model == Model.MATRICE_300_RTK) {
|
||||
cameraMatrix = new Mat(3, 3, CvType.CV_64FC1) {
|
||||
{
|
||||
put(0, 0, 6.138149733734280e+03, 0, 7.244878111512812e+02);
|
||||
put(1, 0, 0, 6.651309839828123e+03, 5.358189824761293e+02);
|
||||
put(2, 0, 0, 0, 1);
|
||||
}
|
||||
};
|
||||
distCoeffs = new Mat(5, 1, CvType.CV_64FC1) {
|
||||
{
|
||||
put(0, 0, 15.417476643365749);
|
||||
put(1, 0, -2.543897784820708e+03);
|
||||
put(2, 0, 0.006416193049765);
|
||||
put(3, 0, 0.008645251405539);
|
||||
put(4, 0, 1.267624998722697e+05);
|
||||
}
|
||||
};
|
||||
}
|
||||
|
||||
```
|
||||
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user