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.

prim.h 7.1 kB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181
  1. /**
  2. * This is the C++ adaptation and derivative work of Myia (https://github.com/mila-iqia/myia/).
  3. *
  4. * Copyright 2019-2021 Huawei Technologies Co., Ltd
  5. *
  6. * Licensed under the Apache License, Version 2.0 (the "License");
  7. * you may not use this file except in compliance with the License.
  8. * You may obtain a copy of the License at
  9. *
  10. * http://www.apache.org/licenses/LICENSE-2.0
  11. *
  12. * Unless required by applicable law or agreed to in writing, software
  13. * distributed under the License is distributed on an "AS IS" BASIS,
  14. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  15. * See the License for the specific language governing permissions and
  16. * limitations under the License.
  17. */
  18. #ifndef MINDSPORE_CCSRC_PIPELINE_JIT_STATIC_ANALYSIS_PRIM_H_
  19. #define MINDSPORE_CCSRC_PIPELINE_JIT_STATIC_ANALYSIS_PRIM_H_
  20. #include <algorithm>
  21. #include <memory>
  22. #include <string>
  23. #include <vector>
  24. #include "utils/hash_map.h"
  25. #include "pipeline/jit/static_analysis/evaluator.h"
  26. #include "abstract/primitive_infer_map.h"
  27. namespace mindspore {
  28. namespace abstract {
  29. class StandardPrimEvaluator final : public TrivialPrimEvaluator {
  30. public:
  31. StandardPrimEvaluator(const PrimitivePtr &primitive, const StandardPrimitiveImplReg &eval_impl)
  32. : TrivialPrimEvaluator("StandardPrimEvaluator"), prim_(primitive), eval_impl_(eval_impl) {}
  33. ~StandardPrimEvaluator() override = default;
  34. MS_DECLARE_PARENT(StandardPrimEvaluator, TrivialPrimEvaluator);
  35. EvalResultPtr EvalPrim(const AnalysisEnginePtr &engine, const AbstractBasePtrList &args) override;
  36. PrimitivePtr prim() { return prim_; }
  37. std::string ToString() const override { return identifier_ + prim_->name(); }
  38. private:
  39. EvalResultPtr EvalPyCheckPrim(const AnalysisEnginePtr &engine, const AbstractBasePtrList &args);
  40. EvalResultPtr RunPyInferValue(const AnalysisEnginePtr &engine, const AbstractBasePtr &abs_base,
  41. const AbstractBasePtrList &args);
  42. PrimitivePtr prim_;
  43. const StandardPrimitiveImplReg eval_impl_;
  44. };
  45. using StandardPrimEvaluatorPtr = std::shared_ptr<StandardPrimEvaluator>;
  46. class PythonPrimEvaluator final : public TrivialPrimEvaluator {
  47. public:
  48. explicit PythonPrimEvaluator(const PrimitivePyPtr primitive)
  49. : TrivialPrimEvaluator("PythonPrimEvaluator"), prim_py_(primitive) {}
  50. ~PythonPrimEvaluator() override = default;
  51. MS_DECLARE_PARENT(PythonPrimEvaluator, TrivialPrimEvaluator);
  52. EvalResultPtr EvalPrim(const AnalysisEnginePtr &engine, const AbstractBasePtrList &args) override;
  53. PrimitivePtr prim() { return dyn_cast<Primitive>(prim_py_); }
  54. std::string ToString() const override { return identifier_ + prim_py_->name(); }
  55. private:
  56. PrimitivePyPtr prim_py_;
  57. };
  58. class DoSignatureEvaluator final : public Evaluator {
  59. public:
  60. explicit DoSignatureEvaluator(const PrimitivePtr primitive) : Evaluator("DoSignatureEvaluator"), prim_(primitive) {}
  61. ~DoSignatureEvaluator() override = default;
  62. MS_DECLARE_PARENT(DoSignatureEvaluator, Evaluator);
  63. EvalResultPtr Run(AnalysisEnginePtr engine, const ConfigPtrList &argrefs,
  64. const AnfNodeConfigPtr &out_config = nullptr) override;
  65. EvalResultPtr Eval(AnalysisEnginePtr, const AbstractBasePtrList &, const AnfNodeConfigPtr &) override {
  66. MS_LOG(EXCEPTION) << "Eval() should not be called, Run() method should be called";
  67. }
  68. private:
  69. PrimitivePtr prim_;
  70. };
  71. class UnpackGraphEvaluator final : public Evaluator {
  72. public:
  73. explicit UnpackGraphEvaluator(const PrimitivePtr primitive) : Evaluator("UnpackGraphEvaluator"), prim_(primitive) {}
  74. ~UnpackGraphEvaluator() override = default;
  75. MS_DECLARE_PARENT(UnpackGraphEvaluator, Evaluator);
  76. EvalResultPtr Run(AnalysisEnginePtr engine, const ConfigPtrList &argrefs,
  77. const AnfNodeConfigPtr &out_config = nullptr) override;
  78. EvalResultPtr Eval(AnalysisEnginePtr, const AbstractBasePtrList &, const AnfNodeConfigPtr &) override {
  79. MS_LOG(EXCEPTION) << "Eval() should not be called, Run() method should be called";
  80. }
  81. private:
  82. PrimitivePtr prim_;
  83. };
  84. class MixedPrecisionCastEvaluator final : public Evaluator {
  85. public:
  86. explicit MixedPrecisionCastEvaluator(const PrimitivePtr primitive)
  87. : Evaluator("MixedPrecisionCastEvaluator"), prim_(primitive) {}
  88. ~MixedPrecisionCastEvaluator() override = default;
  89. MS_DECLARE_PARENT(MixedPrecisionCastEvaluator, Evaluator);
  90. EvalResultPtr Run(AnalysisEnginePtr engine, const ConfigPtrList &argrefs,
  91. const AnfNodeConfigPtr &out_config = nullptr) override;
  92. EvalResultPtr Eval(AnalysisEnginePtr, const AbstractBasePtrList &, const AnfNodeConfigPtr &) override {
  93. MS_LOG(EXCEPTION) << "Eval() should not be called, Run() method should be called";
  94. }
  95. private:
  96. PrimitivePtr prim_;
  97. };
  98. bool IsInWhiteList(const PrimitivePtr &primitive);
  99. using ValuePtrList = std::vector<ValuePtr>;
  100. using PrimitiveImpl = ValuePtr (*)(const ValuePtrList &);
  101. class UniformPrimEvaluator final : public TrivialPrimEvaluator {
  102. public:
  103. UniformPrimEvaluator(const FunctionPtr func_desc, PrimitiveImpl impl, bool eval_value, const TypePtr specify_out_type)
  104. : TrivialPrimEvaluator("UniformPrimEvaluator"),
  105. impl_(impl),
  106. eval_value_(eval_value),
  107. func_desc_(func_desc),
  108. nargs_(func_desc_->args().size()),
  109. return_value_type_(func_desc_->retval()),
  110. specify_out_type_(specify_out_type) {
  111. for (size_t i = 0; i < nargs_; ++i) {
  112. TypePtr type = func_desc_->args()[i];
  113. if (type_map_[type]) {
  114. type_map_[type]->push_back(i);
  115. } else {
  116. type_map_[type] = std::make_shared<std::vector<size_t>>();
  117. type_map_[type]->push_back(i);
  118. }
  119. }
  120. }
  121. ~UniformPrimEvaluator() override = default;
  122. MS_DECLARE_PARENT(UniformPrimEvaluator, TrivialPrimEvaluator);
  123. EvalResultPtr EvalPrim(const AnalysisEnginePtr &engine, const AbstractBasePtrList &args) override;
  124. ValuePtr RunImpl(const ValuePtrList &args) const;
  125. // If eval_value_ is False, return broadened arguments.
  126. AbstractBasePtrList NormalizeArgs(const AbstractBasePtrList &args_spec_list) const override {
  127. if (!eval_value_) {
  128. AbstractBasePtrList broadened_args_spec_list;
  129. (void)std::transform(args_spec_list.begin(), args_spec_list.end(), std::back_inserter(broadened_args_spec_list),
  130. [](const AbstractBasePtr &arg) -> AbstractBasePtr { return arg->Broaden(); });
  131. return broadened_args_spec_list;
  132. }
  133. return args_spec_list;
  134. }
  135. private:
  136. PrimitiveImpl impl_;
  137. bool eval_value_;
  138. const FunctionPtr func_desc_;
  139. const std::size_t nargs_;
  140. const TypePtr return_value_type_;
  141. const TypePtr specify_out_type_;
  142. mindspore::HashMap<TypePtr, std::shared_ptr<std::vector<size_t>>, TypeHasher, TypeEqual> type_map_;
  143. };
  144. PrimEvaluatorMap &GetPrimEvaluatorConstructors();
  145. // Check whether type x is a subtype of model.
  146. bool IsSubtype(const AbstractBasePtr x, const TypePtr model);
  147. void ClearPrimEvaluatorMap();
  148. py::dict ConvertAbstractToPython(const AbstractBasePtr &abs_base);
  149. } // namespace abstract
  150. } // namespace mindspore
  151. #endif // MINDSPORE_CCSRC_PIPELINE_JIT_STATIC_ANALYSIS_PRIM_H_