parent
04398cf88e
commit
a9e30a96db
@ -0,0 +1,120 @@
|
|||||||
|
/**
|
||||||
|
* Copyright 2020 Huawei Technologies Co., Ltd
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "debug/trace_base.h"
|
||||||
|
|
||||||
|
#include <iostream>
|
||||||
|
#include <fstream>
|
||||||
|
#include <map>
|
||||||
|
#include <unordered_map>
|
||||||
|
#include <vector>
|
||||||
|
#include <string>
|
||||||
|
#include <sstream>
|
||||||
|
#include <utility>
|
||||||
|
#include <stack>
|
||||||
|
#include <algorithm>
|
||||||
|
|
||||||
|
#include "utils/graph_utils.h"
|
||||||
|
|
||||||
|
namespace mindspore {
|
||||||
|
// namespace to support debug trace infomation
|
||||||
|
namespace trace {
|
||||||
|
std::vector<DebugInfoPtr> GetSourceCodeDebugInfoVec(DebugInfoPtr debug_info) {
|
||||||
|
std::vector<DebugInfoPtr> debug_with_loc_vec;
|
||||||
|
while (debug_info != nullptr) {
|
||||||
|
if (debug_info->location() != nullptr) {
|
||||||
|
debug_with_loc_vec.push_back(debug_info);
|
||||||
|
}
|
||||||
|
if (debug_info->trace_info() != nullptr) {
|
||||||
|
debug_info = debug_info->trace_info()->debug_info();
|
||||||
|
} else {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return debug_with_loc_vec;
|
||||||
|
}
|
||||||
|
|
||||||
|
DebugInfoPtr GetSourceCodeDebugInfo(const DebugInfoPtr &info) {
|
||||||
|
auto debug_with_loc_vec = GetSourceCodeDebugInfoVec(info);
|
||||||
|
if (debug_with_loc_vec.size() > 0) {
|
||||||
|
return debug_with_loc_vec[0];
|
||||||
|
} else {
|
||||||
|
return info;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
std::string GetDebugInfo(const DebugInfoPtr &info, SourceLineTip tip) {
|
||||||
|
if (info == nullptr) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
auto src_info = GetSourceCodeDebugInfo(info);
|
||||||
|
if (src_info->location() != nullptr) {
|
||||||
|
return src_info->location()->ToString(tip);
|
||||||
|
}
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
// a trace info identifies a node transform, so we can trace the node transform through
|
||||||
|
// a link of trace info and debug info
|
||||||
|
std::string GetInfoWithAction(const std::vector<DebugInfoPtr> &info_vec, SourceLineTip tip) {
|
||||||
|
if (info_vec.size() < 1) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
if (info_vec.size() == 1) {
|
||||||
|
return info_vec[0]->location()->ToString(tip);
|
||||||
|
}
|
||||||
|
std::string traced_info = info_vec[0]->location()->ToString(tip);
|
||||||
|
for (size_t i = 1; i < info_vec.size(); i++) {
|
||||||
|
auto action_name = info_vec[i - 1]->trace_info()->GetActionBetweenNode(info_vec[i]);
|
||||||
|
if (action_name == "") {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
traced_info = traced_info + action_name + info_vec[i]->location()->ToString(tip);
|
||||||
|
}
|
||||||
|
return traced_info;
|
||||||
|
}
|
||||||
|
|
||||||
|
std::string GetTracedDebugInfo(const DebugInfoPtr &info, SourceLineTip tip) {
|
||||||
|
if (info == nullptr) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
auto info_vec = GetSourceCodeDebugInfoVec(info);
|
||||||
|
if (info_vec.size() == 0) {
|
||||||
|
return "";
|
||||||
|
} else if (info_vec.size() == 1) {
|
||||||
|
return info_vec[0]->location()->ToString(tip);
|
||||||
|
} else if (info_vec.size() > 1) {
|
||||||
|
return GetInfoWithAction(info_vec, tip);
|
||||||
|
}
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
std::string GetDebugInfo(const DebugInfoPtr &info, const std::string &prefix, SourceLineTip tip) {
|
||||||
|
std::ostringstream oss;
|
||||||
|
if (info == nullptr) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
auto debug_info = GetTracedDebugInfo(info, tip);
|
||||||
|
if (tip == kSourceLineTipDiscard) {
|
||||||
|
std::replace(debug_info.begin(), debug_info.end(), '\r', '/');
|
||||||
|
std::replace(debug_info.begin(), debug_info.end(), '\n', '/');
|
||||||
|
}
|
||||||
|
oss << prefix << debug_info;
|
||||||
|
return oss.str();
|
||||||
|
}
|
||||||
|
} // namespace trace
|
||||||
|
} // namespace mindspore
|
@ -0,0 +1,39 @@
|
|||||||
|
/**
|
||||||
|
* Copyright 2020 Huawei Technologies Co., Ltd
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
#ifndef MINDSPORE_CCSRC_DEBUG_TRACE_BASE_H_
|
||||||
|
#define MINDSPORE_CCSRC_DEBUG_TRACE_BASE_H_
|
||||||
|
|
||||||
|
#include <fstream>
|
||||||
|
#include <memory>
|
||||||
|
#include <string>
|
||||||
|
#include <vector>
|
||||||
|
#include <utility>
|
||||||
|
#include <stack>
|
||||||
|
|
||||||
|
#include "debug/info.h"
|
||||||
|
#include "ir/anf.h"
|
||||||
|
#include "ir/func_graph.h"
|
||||||
|
#include "utils/any.h"
|
||||||
|
|
||||||
|
namespace mindspore {
|
||||||
|
namespace trace {
|
||||||
|
std::string GetDebugInfo(const DebugInfoPtr &info, SourceLineTip tip = kSourceLineTipNextLine);
|
||||||
|
std::string GetDebugInfo(const DebugInfoPtr &info, const std::string &prefix,
|
||||||
|
SourceLineTip tip = kSourceLineTipNextLine);
|
||||||
|
} // namespace trace
|
||||||
|
} // namespace mindspore
|
||||||
|
|
||||||
|
#endif // MINDSPORE_CCSRC_DEBUG_TRACE_BASE_H_
|
@ -0,0 +1,28 @@
|
|||||||
|
/**
|
||||||
|
* Copyright 2020 Huawei Technologies Co., Ltd
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "utils/base_ref_extends.h"
|
||||||
|
|
||||||
|
namespace mindspore {
|
||||||
|
bool PyObjectRef::operator==(const BaseRef &other) const {
|
||||||
|
if (!utils::isa<PyObjectRef>(other)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return *this == utils::cast<PyObjectRef>(other);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool PyObjectRef::operator==(const PyObjectRef &other) const { return object_ == other.object_; }
|
||||||
|
} // namespace mindspore
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in new issue