/** * 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 ACL_GRAPH_PARSE_UTIL_ #define ACL_GRAPH_PARSE_UTIL_ #include #include #include #include #include "framework/omg/parser/parser_types.h" #include "register/register_error_codes.h" #include "graph/utils/graph_utils.h" namespace ge { using google::protobuf::Message; class AclGrphParseUtil { public: AclGrphParseUtil() {} virtual ~AclGrphParseUtil() {} domi::Status LoadOpsProtoLib(); void SaveCustomCaffeProtoPath(); domi::Status AclParserInitialize(const std::map &options); domi::Status SetDefaultOutputNode(ge::Graph &graph); private: bool parser_initialized = false; domi::Status GetOutputLeaf(NodePtr node, std::vector> &output_nodes_info); void GetOutputNodesNameAndIndex(std::vector> &output_nodes_info, std::vector &output_nodes_name); }; namespace parser { /// /// @ingroup: domi_common /// @brief: get length of file /// @param [in] input_file: path of file /// @return long: File length. If the file length fails to be obtained, the value -1 is returned. /// extern long GetFileLength(const std::string &input_file); /// /// @ingroup domi_common /// @brief Absolute path for obtaining files. /// @param [in] path of input file /// @param [out] Absolute path of a file. If the absolute path cannot be obtained, an empty string is returned /// std::string RealPath(const char *path); /// /// @ingroup domi_common /// @brief Obtains the absolute time (timestamp) of the current system. /// @return Timestamp, in microseconds (US) /// /// uint64_t GetCurrentTimestamp(); /// /// @ingroup domi_common /// @brief Reads all data from a binary file. /// @param [in] file_name path of file /// @param [out] buffer Output memory address, which needs to be released by the caller. /// @param [out] length Output memory size /// @return false fail /// @return true success /// bool ReadBytesFromBinaryFile(const char *file_name, char **buffer, int &length); /// /// @ingroup domi_common /// @brief proto file in bianary format /// @param [in] file path of proto file /// @param [out] proto memory for storing the proto file /// @return true success /// @return false fail /// bool ReadProtoFromBinaryFile(const char *file, Message *proto); /// /// @ingroup domi_common /// @brief Reads the proto structure from an array. /// @param [in] data proto data to be read /// @param [in] size proto data size /// @param [out] proto Memory for storing the proto file /// @return true success /// @return false fail /// bool ReadProtoFromArray(const void *data, int size, Message *proto); /// /// @ingroup domi_proto /// @brief Reads the proto file in the text format. /// @param [in] file path of proto file /// @param [out] message Memory for storing the proto file /// @return true success /// @return false fail /// bool ReadProtoFromText(const char *file, google::protobuf::Message *message); bool ReadProtoFromMem(const char *data, int size, google::protobuf::Message *message); /// /// @brief get the Original Type of FrameworkOp /// @param [in] node /// @param [out] type /// @return Status /// domi::Status GetOriginalType(const ge::NodePtr &node, string &type); /// /// @ingroup domi_common /// @brief Check whether the file path meets the whitelist verification requirements. /// @param [in] filePath file path /// @param [out] result /// bool ValidateStr(const std::string &filePath, const std::string &mode); /// /// @ingroup domi_common /// @brief Obtains the current time string. /// @return Time character string in the format: %Y%m%d%H%M%S, eg: 20171011083555 /// std::string CurrentTimeInStr(); } // namespace parser } // namespace ge /*lint --emacro((773),GE_TIMESTAMP_START)*/ /*lint -esym(773,GE_TIMESTAMP_START)*/ #define PARSER_TIMESTAMP_START(stage) uint64_t startUsec_##stage = ge::parser::GetCurrentTimestamp() #define PARSER_TIMESTAMP_END(stage, stage_name) \ do { \ uint64_t endUsec_##stage = ge::parser::GetCurrentTimestamp(); \ GELOGI("[GEPERFTRACE] The time cost of %s is [%lu] micro second.", (stage_name), \ (endUsec_##stage - startUsec_##stage)); \ } while (0); #define PARSER_TIMESTAMP_EVENT_END(stage, stage_name) \ do { \ uint64_t endUsec_##stage = ge::parser::GetCurrentTimestamp(); \ GEEVENT("[GEPERFTRACE] The time cost of %s is [%lu] micro second.", (stage_name), \ (endUsec_##stage - startUsec_##stage)); \ } while (0); #endif // ACL_GRAPH_PARSE_UTIL_