提交 02c1a0c3 编写于 作者: M Megvii Engine Team

fix(imperative/format): warn once when parameter without format been attached

GitOrigin-RevId: 02174447f61e95c55b551ee0d0b71b56e716bd29
上级 c2deef1a
...@@ -5,6 +5,8 @@ ...@@ -5,6 +5,8 @@
#include "megbrain/imperative/ops/autogen.h" #include "megbrain/imperative/ops/autogen.h"
#include "megbrain/imperative/ops/utility.h" #include "megbrain/imperative/ops/utility.h"
#include "megbrain/imperative/utils/helper.h"
namespace mgb { namespace mgb {
namespace imperative { namespace imperative {
...@@ -664,9 +666,9 @@ ValueRefList FormatTransformation::apply_transformation( ...@@ -664,9 +666,9 @@ ValueRefList FormatTransformation::apply_transformation(
if (inp_ref) { if (inp_ref) {
return {FormatValue::make(inp_ref->format())}; return {FormatValue::make(inp_ref->format())};
} else { } else {
mgb_log_warn( MGE_CALL_ONCE(mgb_log_warn(
"Not FormattedTensorValue input for GetFormat op: %s, %s", "Not FormattedTensorValue input for GetFormat op: %s, %s",
op.to_string().c_str(), inputs[0].to_string().c_str()); op.to_string().c_str(), inputs[0].to_string().c_str()));
return {FormatValue::make(FT::DEFAULT)}; return {FormatValue::make(FT::DEFAULT)};
} }
} else if (auto* _op = op.as<SetFormat>()) { } else if (auto* _op = op.as<SetFormat>()) {
...@@ -700,9 +702,9 @@ ValueRefList FormatTransformation::apply_transformation( ...@@ -700,9 +702,9 @@ ValueRefList FormatTransformation::apply_transformation(
// make params(GradValue) as FormattedTensor // make params(GradValue) as FormattedTensor
return wrap_outputs(outputs, format); return wrap_outputs(outputs, format);
} else { } else {
mgb_log_warn( MGE_CALL_ONCE(mgb_log_warn(
"Not FormattedTensorValue input for AttachGrad op: %s, %s", "Not FormattedTensorValue input for AttachGrad op: %s, %s",
op.to_string().c_str(), inputs[0].to_string().c_str()); op.to_string().c_str(), inputs[0].to_string().c_str()));
return imperative::apply(op, inputs); return imperative::apply(op, inputs);
} }
} else if (auto* set_grad = op.as<SetGrad>()) { } else if (auto* set_grad = op.as<SetGrad>()) {
...@@ -723,9 +725,9 @@ ValueRefList FormatTransformation::apply_transformation( ...@@ -723,9 +725,9 @@ ValueRefList FormatTransformation::apply_transformation(
wrapped_outputs[i] = wrapped_outputs[i] =
m_value_type.make(outputs[i], output_ref->format()); m_value_type.make(outputs[i], output_ref->format());
} else { } else {
mgb_log_warn( MGE_CALL_ONCE(mgb_log_warn(
"Not FormattedTensorValue outputs for SetGrad op: %s, %s", "Not FormattedTensorValue outputs for SetGrad op: %s, %s",
op.to_string().c_str(), inputs_[i].to_string().c_str()); op.to_string().c_str(), inputs_[i].to_string().c_str()));
wrapped_outputs[i] = m_value_type.make(outputs[i], FT::DEFAULT); wrapped_outputs[i] = m_value_type.make(outputs[i], FT::DEFAULT);
} }
} }
......
...@@ -2,6 +2,7 @@ ...@@ -2,6 +2,7 @@
#include <iomanip> #include <iomanip>
#include <memory> #include <memory>
#include <mutex>
#include <sstream> #include <sstream>
#include "megbrain/utils/metahelper.h" #include "megbrain/utils/metahelper.h"
...@@ -26,6 +27,12 @@ inline std::string quoted(std::string str) { ...@@ -26,6 +27,12 @@ inline std::string quoted(std::string str) {
return ss.str(); return ss.str();
} }
#define MGE_CALL_ONCE(...) \
do { \
static std::once_flag _once_flag; \
std::call_once(_once_flag, [&] { __VA_ARGS__; }); \
} while (false)
} // namespace imperative } // namespace imperative
} // namespace mgb } // namespace mgb
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册