MomentsTest.swift 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. //
  2. // MomentsTest.swift
  3. //
  4. // Created by Giles Payne on 2020/02/10.
  5. //
  6. import XCTest
  7. import OpenCV
  8. class MomentsTest: XCTestCase {
  9. func testAll() {
  10. let data = Mat(rows: 3,cols: 3, type: CvType.CV_8UC1, scalar: Scalar(1))
  11. data.row(1).setTo(scalar: Scalar(5))
  12. let res = Imgproc.moments(array: data)
  13. XCTAssertEqual(res.m00, 21.0, accuracy: OpenCVTestCase.EPS);
  14. XCTAssertEqual(res.m10, 21.0, accuracy: OpenCVTestCase.EPS);
  15. XCTAssertEqual(res.m01, 21.0, accuracy: OpenCVTestCase.EPS);
  16. XCTAssertEqual(res.m20, 35.0, accuracy: OpenCVTestCase.EPS);
  17. XCTAssertEqual(res.m11, 21.0, accuracy: OpenCVTestCase.EPS);
  18. XCTAssertEqual(res.m02, 27.0, accuracy: OpenCVTestCase.EPS);
  19. XCTAssertEqual(res.m30, 63.0, accuracy: OpenCVTestCase.EPS);
  20. XCTAssertEqual(res.m21, 35.0, accuracy: OpenCVTestCase.EPS);
  21. XCTAssertEqual(res.m12, 27.0, accuracy: OpenCVTestCase.EPS);
  22. XCTAssertEqual(res.m03, 39.0, accuracy: OpenCVTestCase.EPS);
  23. XCTAssertEqual(res.mu20, 14.0, accuracy: OpenCVTestCase.EPS);
  24. XCTAssertEqual(res.mu11, 0.0, accuracy: OpenCVTestCase.EPS);
  25. XCTAssertEqual(res.mu02, 6.0, accuracy: OpenCVTestCase.EPS);
  26. XCTAssertEqual(res.mu30, 0.0, accuracy: OpenCVTestCase.EPS);
  27. XCTAssertEqual(res.mu21, 0.0, accuracy: OpenCVTestCase.EPS);
  28. XCTAssertEqual(res.mu12, 0.0, accuracy: OpenCVTestCase.EPS);
  29. XCTAssertEqual(res.mu03, 0.0, accuracy: OpenCVTestCase.EPS);
  30. XCTAssertEqual(res.nu20, 0.031746031746031744, accuracy: OpenCVTestCase.EPS);
  31. XCTAssertEqual(res.nu11, 0.0, accuracy: OpenCVTestCase.EPS);
  32. XCTAssertEqual(res.nu02, 0.013605442176870746, accuracy: OpenCVTestCase.EPS);
  33. XCTAssertEqual(res.nu30, 0.0, accuracy: OpenCVTestCase.EPS);
  34. XCTAssertEqual(res.nu21, 0.0, accuracy: OpenCVTestCase.EPS);
  35. XCTAssertEqual(res.nu12, 0.0, accuracy: OpenCVTestCase.EPS);
  36. XCTAssertEqual(res.nu03, 0.0, accuracy: OpenCVTestCase.EPS);
  37. }
  38. }