Ocean
Loading...
Searching...
No Matches
TestFrameConverterYUV24.h
Go to the documentation of this file.
1/*
2 * Copyright (c) Meta Platforms, Inc. and affiliates.
3 *
4 * This source code is licensed under the MIT license found in the
5 * LICENSE file in the root directory of this source tree.
6 */
7
8#ifndef META_OCEAN_TEST_TESTCV_TEST_FRAME_CONVERTER_YUV_24_H
9#define META_OCEAN_TEST_TESTCV_TEST_FRAME_CONVERTER_YUV_24_H
10
13
14#include "ocean/base/Worker.h"
15
17
19
20namespace Ocean
21{
22
23namespace Test
24{
25
26namespace TestCV
27{
28
29/**
30 * This class implements a YUV 24bit frame converter test.
31 * @ingroup testcv
32 */
33class OCEAN_TEST_CV_EXPORT TestFrameConverterYUV24
34{
35 public:
36
37 /**
38 * Tests all YUV 24 bit frame conversion functions.
39 * @param width The width of the original frame in pixel, with range [1, infinity)
40 * @param height The height of the original frame in pixel, with range [1, infinity)
41 * @param testDuration Number of seconds for each test, with range (0, infinity)
42 * @param worker The worker object
43 * @param selector The test selector to control which tests to run
44 * @return True, if succeeded
45 */
46 static bool test(const unsigned int width, const unsigned int height, const double testDuration, Worker& worker, const TestSelector& selector = TestSelector());
47
48 /**
49 * Tests the YUV24 to BGR24 conversion.
50 * @param width The width of the original frame in pixel, with range [1, infinity)
51 * @param height The height of the original frame in pixel, with range [1, infinity)
52 * @param flag The conversion flag that has been applied during conversion
53 * @param testDuration Number of seconds for each test, with range (0, infinity)
54 * @param worker The worker object
55 * @return True, if succeeded
56 */
57 static bool testYUV24ToBGR24(const unsigned int width, const unsigned int height, const CV::FrameConverter::ConversionFlag flag, const double testDuration, Worker& worker);
58
59 /**
60 * Tests the YUV24 to BGRA32 conversion with 6 bit precision.
61 * @param width The width of the original frame in pixel, with range [1, infinity)
62 * @param height The height of the original frame in pixel, with range [1, infinity)
63 * @param flag The conversion flag that has been applied during conversion
64 * @param testDuration Number of seconds for each test, with range (0, infinity)
65 * @param worker The worker object
66 * @return True, if succeeded
67 */
68 static bool testYUV24ToBGRA32Precision6Bit(const unsigned int width, const unsigned int height, const CV::FrameConverter::ConversionFlag flag, const double testDuration, Worker& worker);
69
70 /**
71 * Tests the YUV24 to RGB24 conversion.
72 * @param width The width of the original frame in pixel, with range [1, infinity)
73 * @param height The height of the original frame in pixel, with range [1, infinity)
74 * @param flag The conversion flag that has been applied during conversion
75 * @param testDuration Number of seconds for each test, with range (0, infinity)
76 * @param worker The worker object
77 * @return True, if succeeded
78 */
79 static bool testYUV24ToRGB24(const unsigned int width, const unsigned int height, const CV::FrameConverter::ConversionFlag flag, const double testDuration, Worker& worker);
80
81 /**
82 * Tests the YUV24 to RGB24 conversion with 6 bit precision.
83 * @param width The width of the original frame in pixel, with range [1, infinity)
84 * @param height The height of the original frame in pixel, with range [1, infinity)
85 * @param flag The conversion flag that has been applied during conversion
86 * @param testDuration Number of seconds for each test, with range (0, infinity)
87 * @param worker The worker object
88 * @return True, if succeeded
89 */
90 static bool testYUV24ToRGB24Precision6Bit(const unsigned int width, const unsigned int height, const CV::FrameConverter::ConversionFlag flag, const double testDuration, Worker& worker);
91
92 /**
93 * Tests the YUV24 to Y8 conversion.
94 * @param width The width of the original frame in pixel, with range [1, infinity)
95 * @param height The height of the original frame in pixel, with range [1, infinity)
96 * @param testDuration Number of seconds for each test, with range (0, infinity)
97 * @param flag The conversion flag that has been applied during conversion
98 * @param worker The worker object
99 * @return True, if succeeded
100 */
101 static bool testYUV24ToY8(const unsigned int width, const unsigned int height, const CV::FrameConverter::ConversionFlag flag, const double testDuration, Worker& worker);
102
103 /**
104 * Tests the YUV24 to YVU24 conversion.
105 * @param width The width of the original frame in pixel, with range [1, infinity)
106 * @param height The height of the original frame in pixel, with range [1, infinity)
107 * @param testDuration Number of seconds for each test, with range (0, infinity)
108 * @param flag The conversion flag that has been applied during conversion
109 * @param worker The worker object
110 * @return True, if succeeded
111 */
112 static bool testYUV24ToYVU24(const unsigned int width, const unsigned int height, const CV::FrameConverter::ConversionFlag flag, const double testDuration, Worker& worker);
113
114 /**
115 * Tests the YUV24 to YUV24 conversion.
116 * @param width The width of the original frame in pixel, with range [1, infinity)
117 * @param height The height of the original frame in pixel, with range [1, infinity)
118 * @param testDuration Number of seconds for each test, with range (0, infinity)
119 * @param flag The conversion flag that has been applied during conversion
120 * @param worker The worker object
121 * @return True, if succeeded
122 */
123 static bool testYUV24ToYUV24(const unsigned int width, const unsigned int height, const CV::FrameConverter::ConversionFlag flag, const double testDuration, Worker& worker);
124
125 /**
126 * Tests the YUV24 to Y_U_V12 conversion.
127 * @param width The width of the original frame in pixel, with range [1, infinity)
128 * @param height The height of the original frame in pixel, with range [1, infinity)
129 * @param flag The conversion flag that has been applied during conversion
130 * @param testDuration Number of seconds for each test, with range (0, infinity)
131 * @param worker The worker object
132 * @return True, if succeeded
133 */
134 static bool testYUV24ToY_U_V12(const unsigned int width, const unsigned int height, const CV::FrameConverter::ConversionFlag flag, const double testDuration, Worker& worker);
135
136 protected:
137
138 /**
139 * Extracts one pixel from a Y_U_V12 source frame.
140 * @param frame The frame from which the pixel will be extracted, must be valid
141 * @param x The horizontal pixel location within the frame, with range [0, frame.width() - 1]
142 * @param y The vertical pixel location within the frame, with range [0, frame.height() - 1]
143 * @param conversionFlag The conversion flag that will be applied, must be valid
144 * @return The vector holding the frame's color value at the specified location
145 */
146 static MatrixD pixelFunctionYUV24ForY_U_V12(const Frame& frame, const unsigned int x, const unsigned int y, const CV::FrameConverter::ConversionFlag conversionFlag);
147
148 /**
149 * Extracts one pixel from a Y_U_V12 source frame.
150 * @param frame The frame from which the pixel will be extracted, must be valid
151 * @param x The horizontal pixel location within the frame, with range [0, frame.width() - 1]
152 * @param y The vertical pixel location within the frame, with range [0, frame.height() - 1]
153 * @param conversionFlag The conversion flag that will be applied, must be valid
154 * @return The vector holding the frame's color value at the specified location
155 */
156 static MatrixD pixelFunctionY_U_V12(const Frame& frame, const unsigned int x, const unsigned int y, const CV::FrameConverter::ConversionFlag conversionFlag);
157};
158
159}
160
161}
162
163}
164
165#endif // META_OCEAN_TEST_TESTCV_TEST_FRAME_CONVERTER_YUV_24_H
ConversionFlag
Definition of individual conversion flags.
Definition FrameConverter.h:39
This class implements Ocean's image class.
Definition Frame.h:1879
This class implements a matrix with arbitrary size.
Definition Matrix.h:63
This class implements a YUV 24bit frame converter test.
Definition TestFrameConverterYUV24.h:34
static bool testYUV24ToYVU24(const unsigned int width, const unsigned int height, const CV::FrameConverter::ConversionFlag flag, const double testDuration, Worker &worker)
Tests the YUV24 to YVU24 conversion.
static bool testYUV24ToBGR24(const unsigned int width, const unsigned int height, const CV::FrameConverter::ConversionFlag flag, const double testDuration, Worker &worker)
Tests the YUV24 to BGR24 conversion.
static bool testYUV24ToRGB24Precision6Bit(const unsigned int width, const unsigned int height, const CV::FrameConverter::ConversionFlag flag, const double testDuration, Worker &worker)
Tests the YUV24 to RGB24 conversion with 6 bit precision.
static bool testYUV24ToYUV24(const unsigned int width, const unsigned int height, const CV::FrameConverter::ConversionFlag flag, const double testDuration, Worker &worker)
Tests the YUV24 to YUV24 conversion.
static MatrixD pixelFunctionYUV24ForY_U_V12(const Frame &frame, const unsigned int x, const unsigned int y, const CV::FrameConverter::ConversionFlag conversionFlag)
Extracts one pixel from a Y_U_V12 source frame.
static bool testYUV24ToBGRA32Precision6Bit(const unsigned int width, const unsigned int height, const CV::FrameConverter::ConversionFlag flag, const double testDuration, Worker &worker)
Tests the YUV24 to BGRA32 conversion with 6 bit precision.
static bool testYUV24ToY8(const unsigned int width, const unsigned int height, const CV::FrameConverter::ConversionFlag flag, const double testDuration, Worker &worker)
Tests the YUV24 to Y8 conversion.
static bool testYUV24ToY_U_V12(const unsigned int width, const unsigned int height, const CV::FrameConverter::ConversionFlag flag, const double testDuration, Worker &worker)
Tests the YUV24 to Y_U_V12 conversion.
static MatrixD pixelFunctionY_U_V12(const Frame &frame, const unsigned int x, const unsigned int y, const CV::FrameConverter::ConversionFlag conversionFlag)
Extracts one pixel from a Y_U_V12 source frame.
static bool testYUV24ToRGB24(const unsigned int width, const unsigned int height, const CV::FrameConverter::ConversionFlag flag, const double testDuration, Worker &worker)
Tests the YUV24 to RGB24 conversion.
static bool test(const unsigned int width, const unsigned int height, const double testDuration, Worker &worker, const TestSelector &selector=TestSelector())
Tests all YUV 24 bit frame conversion functions.
This class implements a test selector that parses test function strings and determines which tests sh...
Definition TestSelector.h:51
This class implements a worker able to distribute function calls over different threads.
Definition Worker.h:33
The namespace covering the entire Ocean framework.
Definition Accessor.h:15