You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

deduce_layout_proxy.h 3.3 kB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. /**
  2. * \file dnn/test/common/deduce_layout_proxy.h
  3. * MegEngine is Licensed under the Apache License, Version 2.0 (the "License")
  4. *
  5. * Copyright (c) 2014-2021 Megvii Inc. All rights reserved.
  6. *
  7. * Unless required by applicable law or agreed to in writing,
  8. * software distributed under the License is distributed on an
  9. * "AS IS" BASIS, WITHOUT ARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  10. */
  11. #pragma once
  12. #include "megdnn/basic_types.h"
  13. #include "test/common/utils.h"
  14. namespace megdnn {
  15. namespace test {
  16. template <typename Opr, size_t Arity, bool can_deduce_layout>
  17. struct DeduceLayoutProxy;
  18. template <typename Opr, size_t Arity>
  19. struct DeduceLayoutProxy<Opr, Arity, false> {
  20. static void deduce_layout(Opr*, TensorLayoutArray&) {}
  21. };
  22. template <typename Opr>
  23. struct DeduceLayoutProxy<Opr, 2, true> {
  24. static void deduce_layout(Opr* opr, TensorLayoutArray& layouts) {
  25. megdnn_assert(layouts.size() == 2);
  26. opr->deduce_layout(layouts[0], layouts[1]);
  27. }
  28. };
  29. template <typename Opr>
  30. struct DeduceLayoutProxy<Opr, 3, true> {
  31. static void deduce_layout(Opr* opr, TensorLayoutArray& layouts) {
  32. megdnn_assert(layouts.size() == 3);
  33. opr->deduce_layout(layouts[0], layouts[1], layouts[2]);
  34. }
  35. };
  36. template <typename Opr>
  37. struct DeduceLayoutProxy<Opr, 4, true> {
  38. static void deduce_layout(Opr* opr, TensorLayoutArray& layouts) {
  39. megdnn_assert(layouts.size() == 4);
  40. opr->deduce_layout(layouts[0], layouts[1], layouts[2], layouts[3]);
  41. }
  42. };
  43. template <typename Opr>
  44. struct DeduceLayoutProxy<Opr, 5, true> {
  45. static void deduce_layout(Opr* opr, TensorLayoutArray& layouts) {
  46. megdnn_assert(layouts.size() == 5);
  47. opr->deduce_layout(layouts[0], layouts[1], layouts[2], layouts[3], layouts[4]);
  48. }
  49. };
  50. template <typename Opr>
  51. struct DeduceLayoutProxy<Opr, 5, false> {
  52. static void deduce_layout(Opr*, TensorLayoutArray&) {}
  53. };
  54. template <typename Opr>
  55. struct DeduceLayoutProxy<Opr, 6, false> {
  56. static void deduce_layout(Opr*, TensorLayoutArray&) {}
  57. };
  58. template <typename Opr>
  59. struct DeduceLayoutProxy<Opr, 6, true> {
  60. static void deduce_layout(Opr* opr, TensorLayoutArray& layouts) {
  61. megdnn_assert(layouts.size() == 6);
  62. opr->deduce_layout(
  63. layouts[0], layouts[1], layouts[2], layouts[3], layouts[4], layouts[5]);
  64. }
  65. };
  66. template <typename Opr>
  67. struct DeduceLayoutProxy<Opr, 7, false> {
  68. static void deduce_layout(Opr*, TensorLayoutArray&) {}
  69. };
  70. template <typename Opr>
  71. struct DeduceLayoutProxy<Opr, 8, true> {
  72. static void deduce_layout(Opr* opr, TensorLayoutArray& layouts) {
  73. megdnn_assert(layouts.size() == 8);
  74. opr->deduce_layout(
  75. layouts[0], layouts[1], layouts[2], layouts[3], layouts[4], layouts[5],
  76. layouts[6], layouts[7]);
  77. }
  78. };
  79. template <typename Opr>
  80. struct DeduceLayoutProxy<Opr, 9, true> {
  81. static void deduce_layout(Opr* opr, TensorLayoutArray& layouts) {
  82. megdnn_assert(layouts.size() == 9);
  83. opr->deduce_layout(
  84. layouts[0], layouts[1], layouts[2], layouts[3], layouts[4], layouts[5],
  85. layouts[6], layouts[7], layouts[8]);
  86. }
  87. };
  88. } // namespace test
  89. } // namespace megdnn
  90. // vim: syntax=cpp.doxygen