opencv/modules/imgproc/misc/objc/test/MomentsTest.swift
Giles Payne 02385472b6
Merge pull request #17165 from komakai:objc-binding
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
2020-06-08 18:32:53 +00:00

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);
}
}