// Copyright (c) 2020 PaddlePaddle Authors. All Rights Reserved. // // 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 namespace PaddleOCR { std::vector OCRConfig::split(const std::string &str, const std::string &delim) { std::vector res; if ("" == str) return res; int strlen = str.length() + 1; chars *strs = new char[strlen]; std::strcpy(strs, str.c_str()); int delimlen = delim.length() + 1; char *d = new char[delimlen]; std::strcpy(d, delim.c_str()); delete[] strs; delete[] d; char *p = std::strtok(strs, d); while (p) { std::string s = p; res.push_back(s); p = std::strtok(NULL, d); } return res; } std::map OCRConfig::LoadConfig(const std::string &config_path) { auto config = Utility::ReadDict(config_path); std::map dict; for (int i = 0; i < config.size(); i++) { // pass for empty line or comment if (config[i].size() <= 1 || config[i][0] == '#') { continue; } std::vector res = split(config[i], " "); dict[res[0]] = res[1]; } return dict; } void OCRConfig::PrintConfigInfo() { std::cout << "=======Paddle OCR inference config======" << std::endl; for (auto iter = config_map_.begin(); iter != config_map_.end(); iter++) { std::cout << iter->first << " : " << iter->second << std::endl; } std::cout << "=======End of Paddle OCR inference config======" << std::endl; } } // namespace PaddleOCR