seg_standard_config.h 2.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. // Copyright (c) 2021 PaddlePaddle Authors. All Rights Reserved.
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. //
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS,
  11. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. // See the License for the specific language governing permissions and
  13. // limitations under the License.
  14. #pragma once
  15. #include <vector>
  16. #include <string>
  17. #include <iostream>
  18. #include "yaml-cpp/yaml.h"
  19. namespace PaddleDeploy {
  20. void SegNormalize(const YAML::Node& src, YAML::Node* dst) {
  21. std::vector<float> mean({0.5, 0.5, 0.5});
  22. std::vector<float> std({0.5, 0.5, 0.5});
  23. if (src["mean"].IsDefined()) {
  24. mean = src["mean"].as<std::vector<float>>();
  25. }
  26. if (src["std"].IsDefined()) {
  27. std = src["std"].as<std::vector<float>>();
  28. }
  29. for (auto i = 0; i < mean.size(); ++i) {
  30. (*dst)["transforms"]["Normalize"]["mean"].push_back(mean[i]);
  31. (*dst)["transforms"]["Normalize"]["std"].push_back(std[i]);
  32. }
  33. }
  34. void SegResize(const YAML::Node& src, YAML::Node* dst) {
  35. std::vector<int> target_size{512, 512};
  36. int interp = 1;
  37. if (src["target_size"].IsDefined()) {
  38. target_size = src["target_size"].as<std::vector<int>>();
  39. }
  40. if (src["interp"].IsDefined()) {
  41. interp = src["interp"].as<int>();
  42. }
  43. (*dst)["transforms"]["Resize"]["width"] = target_size[0];
  44. (*dst)["transforms"]["Resize"]["height"] = target_size[1];
  45. (*dst)["transforms"]["Resize"]["interp"] = interp;
  46. }
  47. void SegPadding(const YAML::Node& src, YAML::Node* dst) {
  48. assert(src["target_size"].IsDefined());
  49. assert(src["target_size"].IsScalar() || src["target_size"].IsSequence());
  50. std::vector<int> target_size = src["target_size"].as<std::vector<int>>();
  51. std::vector<float> im_padding_value({127.5, 127.5, 127.5});
  52. if (src["im_padding_value"].IsDefined()) {
  53. im_padding_value = src["im_padding_value"].as<std::vector<float>>();
  54. }
  55. int w = 0;
  56. int h = 0;
  57. if (src["target_size"].IsScalar()) {
  58. w = src["target_size"].as<int>();
  59. h = src["target_size"].as<int>();
  60. } else if (src["target_size"].IsSequence()) {
  61. w = src["target_size"].as<std::vector<int>>()[0];
  62. h = src["target_size"].as<std::vector<int>>()[1];
  63. }
  64. (*dst)["transforms"]["Padding"]["width"] = w;
  65. (*dst)["transforms"]["Padding"]["height"] = h;
  66. (*dst)["transforms"]["Padding"]["im_padding_value"] = im_padding_value;
  67. }
  68. } // namespace PaddleDeploy