mirror of
https://github.com/opencv/opencv.git
synced 2025-01-12 07:42:32 +08:00
416bf3253d
* attempt to add 0d/1d mat support to OpenCV * revised the patch; now 1D mat is treated as 1xN 2D mat rather than Nx1. * a step towards 'green' tests * another little step towards 'green' tests * calib test failures seem to be fixed now * more fixes _core & _dnn * another step towards green ci; even 0D mat's (a.k.a. scalars) are now partly supported! * * fixed strange bug in aruco/charuco detector, not sure why it did not work * also fixed a few remaining failures (hopefully) in dnn & core * disabled failing GAPI tests - too complex to dig into this compiler pipeline * hopefully fixed java tests * trying to fix some more tests * quick followup fix * continue to fix test failures and warnings * quick followup fix * trying to fix some more tests * partly fixed support for 0D/scalar UMat's * use updated parseReduce() from upstream * trying to fix the remaining test failures * fixed [ch]aruco tests in Python * still trying to fix tests * revert "fix" in dnn's CUDA tensor * trying to fix dnn+CUDA test failures * fixed 1D umat creation * hopefully fixed remaining cuda test failures * removed training whitespaces
129 lines
4.7 KiB
Java
129 lines
4.7 KiB
Java
package org.opencv.test.calib;
|
|
|
|
import java.util.ArrayList;
|
|
|
|
import org.opencv.cv3d.Cv3d;
|
|
import org.opencv.calib.Calib;
|
|
import org.opencv.core.Core;
|
|
import org.opencv.core.CvType;
|
|
import org.opencv.core.Mat;
|
|
import org.opencv.core.MatOfDouble;
|
|
import org.opencv.core.MatOfPoint2f;
|
|
import org.opencv.core.MatOfPoint3f;
|
|
import org.opencv.core.Point;
|
|
import org.opencv.core.Scalar;
|
|
import org.opencv.core.Size;
|
|
import org.opencv.test.OpenCVTestCase;
|
|
import org.opencv.imgproc.Imgproc;
|
|
|
|
public class CalibTest extends OpenCVTestCase {
|
|
|
|
Size size;
|
|
|
|
@Override
|
|
protected void setUp() throws Exception {
|
|
super.setUp();
|
|
|
|
size = new Size(3, 3);
|
|
}
|
|
|
|
public void testFindChessboardCornersMatSizeMat() {
|
|
Size patternSize = new Size(9, 6);
|
|
MatOfPoint2f corners = new MatOfPoint2f();
|
|
Calib.findChessboardCorners(grayChess, patternSize, corners);
|
|
assertFalse(corners.empty());
|
|
}
|
|
|
|
public void testFindChessboardCornersMatSizeMatInt() {
|
|
Size patternSize = new Size(9, 6);
|
|
MatOfPoint2f corners = new MatOfPoint2f();
|
|
Calib.findChessboardCorners(grayChess, patternSize, corners, Calib.CALIB_CB_ADAPTIVE_THRESH + Calib.CALIB_CB_NORMALIZE_IMAGE
|
|
+ Calib.CALIB_CB_FAST_CHECK);
|
|
assertFalse(corners.empty());
|
|
}
|
|
|
|
public void testFind4QuadCornerSubpix() {
|
|
Size patternSize = new Size(9, 6);
|
|
MatOfPoint2f corners = new MatOfPoint2f();
|
|
Size region_size = new Size(5, 5);
|
|
Calib.findChessboardCorners(grayChess, patternSize, corners);
|
|
Calib.find4QuadCornerSubpix(grayChess, corners, region_size);
|
|
assertFalse(corners.empty());
|
|
}
|
|
|
|
public void testFindCirclesGridMatSizeMat() {
|
|
int size = 300;
|
|
Mat img = new Mat(size, size, CvType.CV_8U);
|
|
img.setTo(new Scalar(255));
|
|
Mat centers = new Mat();
|
|
|
|
assertFalse(Calib.findCirclesGrid(img, new Size(5, 5), centers));
|
|
|
|
for (int i = 0; i < 5; i++)
|
|
for (int j = 0; j < 5; j++) {
|
|
Point pt = new Point(size * (2 * i + 1) / 10, size * (2 * j + 1) / 10);
|
|
Imgproc.circle(img, pt, 10, new Scalar(0), -1);
|
|
}
|
|
|
|
assertTrue(Calib.findCirclesGrid(img, new Size(5, 5), centers));
|
|
|
|
assertEquals(1, centers.rows());
|
|
assertEquals(25, centers.cols());
|
|
assertEquals(CvType.CV_32FC2, centers.type());
|
|
}
|
|
|
|
public void testFindCirclesGridMatSizeMatInt() {
|
|
int size = 300;
|
|
Mat img = new Mat(size, size, CvType.CV_8U);
|
|
img.setTo(new Scalar(255));
|
|
Mat centers = new Mat();
|
|
|
|
assertFalse(Calib.findCirclesGrid(img, new Size(3, 5), centers, Calib.CALIB_CB_CLUSTERING
|
|
| Calib.CALIB_CB_ASYMMETRIC_GRID));
|
|
|
|
int step = size * 2 / 15;
|
|
int offsetx = size / 6;
|
|
int offsety = (size - 4 * step) / 2;
|
|
for (int i = 0; i < 3; i++)
|
|
for (int j = 0; j < 5; j++) {
|
|
Point pt = new Point(offsetx + (2 * i + j % 2) * step, offsety + step * j);
|
|
Imgproc.circle(img, pt, 10, new Scalar(0), -1);
|
|
}
|
|
|
|
assertTrue(Calib.findCirclesGrid(img, new Size(3, 5), centers, Calib.CALIB_CB_CLUSTERING
|
|
| Calib.CALIB_CB_ASYMMETRIC_GRID));
|
|
|
|
assertEquals(1, centers.rows());
|
|
assertEquals(15, centers.cols());
|
|
assertEquals(CvType.CV_32FC2, centers.type());
|
|
}
|
|
|
|
public void testConstants()
|
|
{
|
|
// calib3d.hpp: some constants have conflict with constants from 'fisheye' namespace
|
|
assertEquals(1, Calib.CALIB_USE_INTRINSIC_GUESS);
|
|
assertEquals(2, Calib.CALIB_FIX_ASPECT_RATIO);
|
|
assertEquals(4, Calib.CALIB_FIX_PRINCIPAL_POINT);
|
|
assertEquals(8, Calib.CALIB_ZERO_TANGENT_DIST);
|
|
assertEquals(16, Calib.CALIB_FIX_FOCAL_LENGTH);
|
|
assertEquals(32, Calib.CALIB_FIX_K1);
|
|
assertEquals(64, Calib.CALIB_FIX_K2);
|
|
assertEquals(128, Calib.CALIB_FIX_K3);
|
|
assertEquals(0x0800, Calib.CALIB_FIX_K4);
|
|
assertEquals(0x1000, Calib.CALIB_FIX_K5);
|
|
assertEquals(0x2000, Calib.CALIB_FIX_K6);
|
|
assertEquals(0x4000, Calib.CALIB_RATIONAL_MODEL);
|
|
assertEquals(0x8000, Calib.CALIB_THIN_PRISM_MODEL);
|
|
assertEquals(0x10000, Calib.CALIB_FIX_S1_S2_S3_S4);
|
|
assertEquals(0x40000, Calib.CALIB_TILTED_MODEL);
|
|
assertEquals(0x80000, Calib.CALIB_FIX_TAUX_TAUY);
|
|
assertEquals(0x100000, Calib.CALIB_USE_QR);
|
|
assertEquals(0x200000, Calib.CALIB_FIX_TANGENT_DIST);
|
|
assertEquals(0x100, Calib.CALIB_FIX_INTRINSIC);
|
|
assertEquals(0x200, Calib.CALIB_SAME_FOCAL_LENGTH);
|
|
assertEquals(0x400, Calib.CALIB_ZERO_DISPARITY);
|
|
assertEquals((1 << 17), Calib.CALIB_USE_LU);
|
|
assertEquals((1 << 22), Calib.CALIB_USE_EXTRINSIC_GUESS);
|
|
}
|
|
}
|