property.h 3.0 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93
// Copyright (c) 2022 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.

#pragma once

#include <algorithm>
#include <atomic>
#include <string>
#include <vector>

#include "paddle/fluid/jit/property.pb.h"

namespace paddle {
namespace jit {

class Property {
 public:
  Property() {}

  // Explicitly implement the copy constructor for auto parallel
  explicit Property(const Property &other)
      : property_(other.property_), original_id_(other.original_id_) {}

  Property &operator=(const Property &other) {
    property_ = other.property_;
    original_id_ = other.original_id_;
    return *this;
  }

  proto::PropertyVals *Proto() { return &property_; }

  const proto::PropertyVals *Proto() const { return &property_; }

  int Size() const;

  void SetFloat(const float &f);
  void SetFloat(const std::string &name, const float &f);

  void SetFloats(const std::vector<float> &v);
  void SetFloats(const std::string &name, const std::vector<float> &v);

  float GetFloat(const std::string &name) const;
  float GetFloat(const int &idx) const;

  void SetInt64(const int64_t &i);
  void SetInt64(const std::string &name, const int64_t &i);

  void SetInt64s(const std::vector<int64_t> &v);
  void SetInt64s(const std::string &name, const std::vector<int64_t> &v);

  void SetString(const std::string &s);
  void SetString(const std::string &name, const std::string &s);

  void SetStrings(const std::vector<std::string> &v);
  void SetStrings(const std::string &name, const std::vector<std::string> &v);

  // The Id() and OriginalId() are only used for auto parallel.
  uint64_t Id() const { return id_; }
  uint64_t OriginalId() const { return original_id_; }
  void SetOriginalId(uint64_t original_id) { original_id_ = original_id; }

 private:
  proto::PropertyVals property_;

  // This thread-safe implementation seems to be redudent since the neural
  // networks are usually constructed in a single thread.
  static uint64_t GenerateId() {
    static std::atomic<std::uint64_t> uid{0};
    return ++uid;
  }

  // Note: the id_ is unique for all Property (only for auto parallel).
  uint64_t id_ = GenerateId();
  // Note: the orignal_id_ is used for referring to the original Property
  // that the current Property is built from (only for auto parallel).
  // The default original_id_ is same as the id_, which means the
  // current Property is not built from the other one.
  uint64_t original_id_ = id_;
};

}  // namespace jit
}  // namespace paddle