#pragma once #include #include #include #include "OptimizerConfig.pb.h" #include "paddle/utils/Logging.h" #include "tensor.h" namespace paddle { namespace optimizer { inline unsigned CalStateSize(int* state_len) { return 0; } template unsigned CalStateSize(const HEAD& head, const TAIL&... tail) { if (std::is_fundamental::value) { return sizeof head + CalStateSize(tail...); } else { return sizeof(head[0]) * head->size() + CalStateSize(tail...); } } static void TensorToProto(const Tensor& tensor, TensorProto* proto) { proto->set_data_type(TensorProto::PADDLE_ELEMENT_TYPE_FLOAT32); proto->set_size(tensor.size()); std::stringstream os; for (size_t i = 0; i < tensor.size(); ++i) { os << tensor[i]; proto->add_content(os.str()); os.clear(); } } static void ProtoToTensor(const TensorProto& proto, Tensor* tensor) { CHECK(proto.size() == tensor->size()) << "unmatch shape of proto and tensor"; std::stringstream sin; for (auto i = 0; i < proto.content_size(); ++i) { sin << proto.content(i); sin >> (*tensor)[i]; sin.clear(); } } } // namespace optimizer } // namespace paddle