aboutsummaryrefslogtreecommitdiff
path: root/tests/Types.h
blob: 407de8de1e6fc4aaf5ef28e38e8c6c392b2b4397 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
/*
 * Copyright (c) 2017-2018 ARM Limited.
 *
 * SPDX-License-Identifier: MIT
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this software and associated documentation files (the "Software"), to
 * deal in the Software without restriction, including without limitation the
 * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
 * sell copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in all
 * copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
 * SOFTWARE.
 */
#ifndef __ARM_COMPUTE_TEST_TYPES_H__
#define __ARM_COMPUTE_TEST_TYPES_H__

#include "arm_compute/core/Types.h"

#include <vector>

namespace arm_compute
{
/** Gradient dimension type. */
enum class GradientDimension
{
    GRAD_X,  /**< x gradient dimension */
    GRAD_Y,  /**< y gradient dimension */
    GRAD_XY, /**< x and y gradient dimension */
};

/** Min and max values and locations */
template <typename MinMaxType>
struct MinMaxLocationValues
{
    MinMaxType                 min{};     /**< Min value */
    MinMaxType                 max{};     /**< Max value */
    std::vector<Coordinates2D> min_loc{}; /**< Min value location */
    std::vector<Coordinates2D> max_loc{}; /**< Max value location */
};

/** Parameters of Optical Flow algorithm. */
struct OpticalFlowParameters
{
    OpticalFlowParameters(Termination termination,
                          float       epsilon,
                          size_t      num_iterations,
                          size_t      window_dimension,
                          bool        use_initial_estimate)
        : termination{ std::move(termination) },
          epsilon{ std::move(epsilon) },
          num_iterations{ std::move(num_iterations) },
          window_dimension{ std::move(window_dimension) },
          use_initial_estimate{ std::move(use_initial_estimate) }
    {
    }

    Termination termination;
    float       epsilon;
    size_t      num_iterations;
    size_t      window_dimension;
    bool        use_initial_estimate;
};

/** Internal keypoint class for Lucas-Kanade Optical Flow */
struct InternalKeyPoint
{
    float x{ 0.f };                 /**< x coordinate of the keypoint */
    float y{ 0.f };                 /**< y coordinate of the keypoint */
    bool  tracking_status{ false }; /**< the tracking status of the keypoint */
};

} // namespace arm_compute
#endif /* __ARM_COMPUTE_TEST_TYPES_H__ */