mirror of
https://github.com/opencv/opencv.git
synced 2025-01-12 15:49:32 +08:00
02385472b6
Objc binding * Initial work on Objective-C wrapper * Objective-C generator script; update manually generated wrappers * Add Mat tests * Core Tests * Imgproc wrapper generation and tests * Fixes for Imgcodecs wrapper * Miscellaneous fixes. Swift build support * Objective-C wrapper build/install * Add Swift wrappers for videoio/objdetect/feature2d * Framework build;iOS support * Fix toArray functions;Use enum types whenever possible * Use enum types where possible;prepare test build * Update test * Add test runner scripts for iOS and macOS * Add test scripts and samples * Build fixes * Fix build (cmake 3.17.x compatibility) * Fix warnings * Fix enum name conflicting handling * Add support for document generation with Jazzy * Swift/Native fast accessor functions * Add Objective-C wrapper for calib3d, dnn, ml, photo and video modules * Remove IntOut/FloatOut/DoubleOut classes * Fix iOS default test platform value * Fix samples * Revert default framework name to opencv2 * Add converter util functions * Fix failing test * Fix whitespace * Add handling for deprecated methods;fix warnings;define __OPENCV_BUILD * Suppress cmake warnings * Reduce severity of "jazzy not found" log message * Fix incorrect #include of compatibility header in ios.h * Use explicit returns in subscript/get implementation * Reduce minimum required cmake version to 3.15 for Objective-C/Swift binding
43 lines
2.0 KiB
Swift
43 lines
2.0 KiB
Swift
//
|
|
// MomentsTest.swift
|
|
//
|
|
// Created by Giles Payne on 2020/02/10.
|
|
//
|
|
|
|
import XCTest
|
|
import OpenCV
|
|
|
|
class MomentsTest: XCTestCase {
|
|
|
|
func testAll() {
|
|
let data = Mat(rows: 3,cols: 3, type: CvType.CV_8UC1, scalar: Scalar(1))
|
|
data.row(1).setTo(scalar: Scalar(5))
|
|
let res = Imgproc.moments(array: data)
|
|
XCTAssertEqual(res.m00, 21.0, accuracy: OpenCVTestCase.EPS);
|
|
XCTAssertEqual(res.m10, 21.0, accuracy: OpenCVTestCase.EPS);
|
|
XCTAssertEqual(res.m01, 21.0, accuracy: OpenCVTestCase.EPS);
|
|
XCTAssertEqual(res.m20, 35.0, accuracy: OpenCVTestCase.EPS);
|
|
XCTAssertEqual(res.m11, 21.0, accuracy: OpenCVTestCase.EPS);
|
|
XCTAssertEqual(res.m02, 27.0, accuracy: OpenCVTestCase.EPS);
|
|
XCTAssertEqual(res.m30, 63.0, accuracy: OpenCVTestCase.EPS);
|
|
XCTAssertEqual(res.m21, 35.0, accuracy: OpenCVTestCase.EPS);
|
|
XCTAssertEqual(res.m12, 27.0, accuracy: OpenCVTestCase.EPS);
|
|
XCTAssertEqual(res.m03, 39.0, accuracy: OpenCVTestCase.EPS);
|
|
XCTAssertEqual(res.mu20, 14.0, accuracy: OpenCVTestCase.EPS);
|
|
XCTAssertEqual(res.mu11, 0.0, accuracy: OpenCVTestCase.EPS);
|
|
XCTAssertEqual(res.mu02, 6.0, accuracy: OpenCVTestCase.EPS);
|
|
XCTAssertEqual(res.mu30, 0.0, accuracy: OpenCVTestCase.EPS);
|
|
XCTAssertEqual(res.mu21, 0.0, accuracy: OpenCVTestCase.EPS);
|
|
XCTAssertEqual(res.mu12, 0.0, accuracy: OpenCVTestCase.EPS);
|
|
XCTAssertEqual(res.mu03, 0.0, accuracy: OpenCVTestCase.EPS);
|
|
XCTAssertEqual(res.nu20, 0.031746031746031744, accuracy: OpenCVTestCase.EPS);
|
|
XCTAssertEqual(res.nu11, 0.0, accuracy: OpenCVTestCase.EPS);
|
|
XCTAssertEqual(res.nu02, 0.013605442176870746, accuracy: OpenCVTestCase.EPS);
|
|
XCTAssertEqual(res.nu30, 0.0, accuracy: OpenCVTestCase.EPS);
|
|
XCTAssertEqual(res.nu21, 0.0, accuracy: OpenCVTestCase.EPS);
|
|
XCTAssertEqual(res.nu12, 0.0, accuracy: OpenCVTestCase.EPS);
|
|
XCTAssertEqual(res.nu03, 0.0, accuracy: OpenCVTestCase.EPS);
|
|
}
|
|
|
|
}
|