blob: b30ef49c445c18cd24bff72b98838418c2f2e73a [file] [log] [blame]
Anthony Barbier6ff3b192017-09-04 18:44:23 +01001/*
2 * Copyright (c) 2016, 2017 ARM Limited.
3 *
4 * SPDX-License-Identifier: MIT
5 *
6 * Permission is hereby granted, free of charge, to any person obtaining a copy
7 * of this software and associated documentation files (the "Software"), to
8 * deal in the Software without restriction, including without limitation the
9 * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
10 * sell copies of the Software, and to permit persons to whom the Software is
11 * furnished to do so, subject to the following conditions:
12 *
13 * The above copyright notice and this permission notice shall be included in all
14 * copies or substantial portions of the Software.
15 *
16 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
19 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
21 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
22 * SOFTWARE.
23 */
24#ifndef __ARM_COMPUTE_NEFASTCORNERSKERNEL_H__
25#define __ARM_COMPUTE_NEFASTCORNERSKERNEL_H__
26
27#include "arm_compute/core/NEON/INEKernel.h"
28#include "arm_compute/core/Types.h"
29
30#include <cstdint>
31
32namespace arm_compute
33{
34class ITensor;
35using IImage = ITensor;
36
37/** NEON kernel to perform fast corners */
38class NEFastCornersKernel : public INEKernel
39{
40public:
41 /** Constructor */
42 NEFastCornersKernel();
43 /** Prevent instances of this class from being copied (As this class contains pointers) */
44 NEFastCornersKernel(const NEFastCornersKernel &) = delete;
45 /** Prevent instances of this class from being copied (As this class contains pointers) */
46 NEFastCornersKernel &operator=(const NEFastCornersKernel &) = delete;
47 /** Allow instances of this class to be moved */
48 NEFastCornersKernel(NEFastCornersKernel &&) = default;
49 /** Allow instances of this class to be moved */
50 NEFastCornersKernel &operator=(NEFastCornersKernel &&) = default;
51 /** Initialise the kernel.
52 *
53 * @param[in] input Source image. Data type supported: U8.
54 * @param[out] output Output image. Data type supported: U8.
55 * @param[in] threshold Threshold on difference between intensity of the central pixel and pixels on Bresenham's circle of radius 3.
56 * @param[in] non_max_suppression True if non-maxima suppresion is applied, false otherwise.
57 * @param[in] border_undefined True if the border mode is undefined. False if it's replicate or constant.
58 */
59 void configure(const IImage *input, IImage *output, uint8_t threshold, bool non_max_suppression, bool border_undefined);
60
61 // Inherited methods overridden:
62 void run(const Window &window) override;
63 BorderSize border_size() const override;
64
65private:
66 const IImage *_input; /**< source image */
67 IImage *_output; /**< inermediate results */
68 uint8_t _threshold; /**< threshold on difference between intensity */
69 bool _non_max_suppression; /** true if non-maxima suppression is applied in the next stage */
70};
71}
Anthony Barbierac69aa12017-07-03 17:39:37 +010072#endif /* __ARM_COMPUTE_NEFASTCORNERSKERNEL_H__ */