Blame view

3rdparty/opencv_4_1/include/opencv2/gapi/gcompoundkernel.hpp 3.02 KB
09c2d08c   Hu Chunming   arm交付版
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
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
  // This file is part of OpenCV project.
  // It is subject to the license terms in the LICENSE file found in the top-level directory
  // of this distribution and at http://opencv.org/license.html.
  //
  // Copyright (C) 2018-2019 Intel Corporation
  
  
  #ifndef OPENCV_GAPI_GCOMPOUNDKERNEL_HPP
  #define OPENCV_GAPI_GCOMPOUNDKERNEL_HPP
  
  #include <opencv2/gapi/opencv_includes.hpp>
  #include <opencv2/gapi/gcommon.hpp>
  #include <opencv2/gapi/gkernel.hpp>
  #include <opencv2/gapi/garg.hpp>
  
  namespace cv {
  namespace gapi
  {
  namespace compound
  {
      // FIXME User does not need to know about this function
      // Needs that user may define compound kernels(as cpu kernels)
      GAPI_EXPORTS cv::gapi::GBackend backend();
  } // namespace compound
  } // namespace gapi
  
  namespace detail
  {
  
  struct GCompoundContext
  {
      explicit GCompoundContext(const GArgs& in_args);
      template<typename T>
      const T& inArg(int input) { return m_args.at(input).get<T>(); }
  
      GArgs m_args;
      GArgs m_results;
  };
  
  class GAPI_EXPORTS GCompoundKernel
  {
  // Compound kernel must use all of it's inputs
  public:
      using F = std::function<void(GCompoundContext& ctx)>;
  
      explicit GCompoundKernel(const F& f);
      void apply(GCompoundContext& ctx);
  
  protected:
      F m_f;
  };
  
  template<typename T> struct get_compound_in
  {
      static T get(GCompoundContext &ctx, int idx) { return ctx.inArg<T>(idx); }
  };
  
  template<typename U> struct get_compound_in<cv::GArray<U>>
  {
      static cv::GArray<U> get(GCompoundContext &ctx, int idx)
      {
          auto array = cv::GArray<U>();
          ctx.m_args[idx] = GArg(array);
          return array;
      }
  };
  
  template<typename, typename, typename>
  struct GCompoundCallHelper;
  
  template<typename Impl, typename... Ins, typename... Outs>
  struct GCompoundCallHelper<Impl, std::tuple<Ins...>, std::tuple<Outs...> >
  {
      template<int... IIs, int... OIs>
      static void expand_impl(GCompoundContext &ctx, detail::Seq<IIs...>, detail::Seq<OIs...>)
      {
          auto result = Impl::expand(get_compound_in<Ins>::get(ctx, IIs)...);
          auto tuple_return = tuple_wrap_helper<decltype(result)>::get(std::move(result));
          ctx.m_results = { cv::GArg(std::get<OIs>(tuple_return))... };
      }
  
      static void expand(GCompoundContext &ctx)
      {
          expand_impl(ctx,
                      typename detail::MkSeq<sizeof...(Ins)>::type(),
                      typename detail::MkSeq<sizeof...(Outs)>::type());
      }
  };
  
  template<class Impl, class K>
  class GCompoundKernelImpl: public cv::detail::GCompoundCallHelper<Impl, typename K::InArgs, typename K::OutArgs>,
                             public cv::detail::KernelTag
  {
      using P = cv::detail::GCompoundCallHelper<Impl, typename K::InArgs, typename K::OutArgs>;
  
  public:
      using API = K;
  
      static cv::gapi::GBackend backend() { return cv::gapi::compound::backend(); }
      static GCompoundKernel    kernel()  { return GCompoundKernel(&P::expand);   }
  };
  
  } // namespace detail
  #define GAPI_COMPOUND_KERNEL(Name, API) struct Name: public cv::detail::GCompoundKernelImpl<Name, API>
  
  } // namespace cv
  
  #endif // OPENCV_GAPI_GCOMPOUNDKERNEL_HPP