#pragma once #include #include #include #include "megbrain/imperative/backtrace.h" #include "megbrain/imperative/op_def.h" #include "megbrain/imperative/utils/to_string.h" #include "megbrain/tensor.h" #include "./stack_manager.h" #include "./tensor_info.h" namespace mgb::imperative { namespace interpreter::intl { struct TensorInfo; class InterpreterProfiler; struct Put { TensorInfo* dest; HostTensorND value; bool no_cache = false; template void get_props(TFunctor&& functor) const { functor("dest", dest); functor("no_cache", no_cache); // functor("value", value); } const char* get_name() const { return "Put"; } }; struct ApplyOp { uint64_t id; // used by profiler to identify unique apply std::shared_ptr op; SmallVector inputs; SmallVector outputs; bool validated = false; BackTraceInfoPtr bt = nullptr; template void get_props(TFunctor&& functor) const { functor("op", op); functor("inputs", inputs); functor("outputs", outputs); } const char* get_name() const { return "ApplyOp"; } }; struct Del { TensorInfo* dest; template void get_props(TFunctor&& functor) const { functor("dest", dest); } const char* get_name() const { return "Del"; } }; struct GetValue { TensorInfo* dest; template void get_props(TFunctor&& functor) const { functor("dest", dest); } const char* get_name() const { return "GetValue"; } }; struct Drop { TensorInfo* dest; template void get_props(TFunctor&& functor) const { functor("dest", dest); } const char* get_name() const { return "Drop"; } }; struct SetOption { std::string key; size_t value; template void get_props(TFunctor&& functor) const { functor("key", key); functor("value", value); } const char* get_name() const { return "SetOption"; } }; struct StartProfile { std::unordered_set capture_tensors; template void get_props(TFunctor&& functor) const {} const char* get_name() const { return "StartProfile"; } }; struct StopProfile { std::unordered_set escape_tensors; template void get_props(TFunctor&& functor) const {} const char* get_name() const { return "StopProfile"; } }; struct StopStep { template void get_props(TFunctor&& functor) const {} const char* get_name() const { return "StopStep"; } }; struct PushScope { std::string scope_name; template void get_props(TFunctor&& functor) const { functor("scope_name", scope_name); } const char* get_name() const { return "PushScope"; } }; struct PopScope { std::string scope_name; template void get_props(TFunctor&& functor) const { functor("scope_name", scope_name); } const char* get_name() const { return "PopScope"; } }; struct StartRegen { TensorInfo* dest; template void get_props(TFunctor&& functor) const { functor("dest", dest); } const char* get_name() const { return "StartRegen"; } }; struct StopRegen { TensorInfo* dest; template void get_props(TFunctor&& functor) const { functor("dest", dest); } const char* get_name() const { return "StopRegen"; } }; using CommandData = std::variant< Put, ApplyOp, Del, GetValue, Drop, SetOption, StartProfile, StopProfile, StopStep, PushScope, PopScope, StartRegen, StopRegen>; struct Command { uint64_t id; CommandData data; StackManager::Trace trace; }; // using IdentifiedCommand = std::pair; } // namespace interpreter::intl template <> struct ToStringTrait { std::string operator()(const interpreter::intl::Command& cmd) const { std::string content = std::visit( [](const auto& cmd) { std::string result = cmd.get_name(); result += "{"; cmd.get_props([&](const char* key, auto&& value) { result += key; result += ": "; result += to_string(value); result += ","; }); result += "}"; return result; }, cmd.data); return content; } }; } // namespace mgb::imperative