Arguments.cpp 4.3 KB
Newer Older
Y
Yu Yang 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14
/* Copyright (c) 2016 PaddlePaddle Authors. All Rights Reserve.

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. */

Y
Yu Yang 已提交
15
#include "PaddleCAPIPrivate.h"
Y
Yu Yang 已提交
16
#include "arguments.h"
Y
Yu Yang 已提交
17

Y
Yu Yang 已提交
18 19 20 21
using paddle::capi::cast;

#define castArg(v) cast<paddle::capi::CArguments>(v)
#define castIVec(v) cast<paddle::capi::CIVector>(v)
Y
Yu Yang 已提交
22 23

extern "C" {
Y
Stash  
Yu Yang 已提交
24 25 26
paddle_arguments paddle_arguments_create_none() {
  return new paddle::capi::CArguments();
}
Y
Yu Yang 已提交
27

Y
Stash  
Yu Yang 已提交
28
paddle_error paddle_arguments_destroy(paddle_arguments args) {
Y
Yu Yang 已提交
29 30 31
  if (args == nullptr) return kPD_NULLPTR;
  delete castArg(args);
  return kPD_NO_ERROR;
Y
Yu Yang 已提交
32 33
}

Y
Stash  
Yu Yang 已提交
34
paddle_error paddle_arguments_size(paddle_arguments args, uint64_t* size) {
Y
Yu Yang 已提交
35 36 37
  if (args == nullptr || size == nullptr) return kPD_NULLPTR;
  *size = castArg(args)->args.size();
  return kPD_NO_ERROR;
Y
Yu Yang 已提交
38 39
}

Y
Stash  
Yu Yang 已提交
40
paddle_error paddle_arguments_resize(paddle_arguments args, uint64_t size) {
Y
Yu Yang 已提交
41 42 43
  if (args == nullptr) return kPD_NULLPTR;
  castArg(args)->args.resize(size);
  return kPD_NO_ERROR;
Y
Yu Yang 已提交
44 45
}

Y
Stash  
Yu Yang 已提交
46 47 48
paddle_error paddle_arguments_set_value(paddle_arguments args,
                                        uint64_t ID,
                                        paddle_matrix mat) {
Y
Yu Yang 已提交
49
  if (args == nullptr || mat == nullptr) return kPD_NULLPTR;
Y
Yu Yang 已提交
50
  auto m = paddle::capi::cast<paddle::capi::CMatrix>(mat);
Y
Yu Yang 已提交
51 52 53
  if (m->mat == nullptr) return kPD_NULLPTR;
  auto a = castArg(args);
  if (ID >= a->args.size()) return kPD_OUT_OF_RANGE;
Y
Yu Yang 已提交
54
  a->args[ID].value = m->mat;
Y
Yu Yang 已提交
55
  return kPD_NO_ERROR;
Y
Yu Yang 已提交
56 57
}

Y
Stash  
Yu Yang 已提交
58 59 60
paddle_error paddle_arguments_value(paddle_arguments args,
                                    uint64_t ID,
                                    paddle_matrix mat) {
Y
Yu Yang 已提交
61
  if (args == nullptr || mat == nullptr) return kPD_NULLPTR;
Y
Yu Yang 已提交
62
  auto m = paddle::capi::cast<paddle::capi::CMatrix>(mat);
Y
Yu Yang 已提交
63 64
  auto a = castArg(args);
  if (ID >= a->args.size()) return kPD_OUT_OF_RANGE;
Y
Yu Yang 已提交
65
  m->mat = a->args[ID].value;
Y
Yu Yang 已提交
66 67 68
  return kPD_NO_ERROR;
}

Y
Stash  
Yu Yang 已提交
69 70 71
paddle_error paddle_arguments_ids(paddle_arguments args,
                                  uint64_t ID,
                                  paddle_ivector ids) {
Y
Yu Yang 已提交
72 73 74 75 76 77
  if (args == nullptr || ids == nullptr) return kPD_NULLPTR;
  auto iv = castIVec(ids);
  auto a = castArg(args);
  if (ID >= a->args.size()) return kPD_OUT_OF_RANGE;
  iv->vec = a->args[ID].ids;
  return kPD_NO_ERROR;
Y
Yu Yang 已提交
78
}
Y
Yu Yang 已提交
79

Y
Stash  
Yu Yang 已提交
80 81 82
paddle_error paddle_arguments_set_ids(paddle_arguments args,
                                      uint64_t ID,
                                      paddle_ivector ids) {
Y
Yu Yang 已提交
83
  //! TODO(lizhao): Complete this method.
L
livc 已提交
84 85 86 87 88 89 90
  if (args == nullptr || ids == nullptr) return kPD_NULLPTR;
  auto iv = paddle::capi::cast<paddle::capi::CIVector>(ids);
  if (iv->vec == nullptr) return kPD_NULLPTR;
  auto a = castArg(args);
  if (ID >= a->args.size()) return kPD_OUT_OF_RANGE;
  a->args[ID].ids = iv->vec;
  return kPD_NO_ERROR;
Y
Yu Yang 已提交
91 92
}

Y
Stash  
Yu Yang 已提交
93 94
paddle_error paddle_arguments_set_sequence_start_pos(paddle_arguments args,
                                                     uint64_t ID,
Y
Yu Yang 已提交
95
                                                     uint32_t nestedLevel,
Y
Stash  
Yu Yang 已提交
96
                                                     paddle_ivector seqPos) {
L
livc 已提交
97 98 99 100
  if (args == nullptr || seqPos == nullptr) return kPD_NULLPTR;
  auto iv = paddle::capi::cast<paddle::capi::CIVector>(seqPos);
  if (iv->vec == nullptr) return kPD_NULLPTR;
  auto a = castArg(args);
Y
Yu Yang 已提交
101 102 103
  return a->accessSeqPos(ID, nestedLevel, [&iv](paddle::ICpuGpuVectorPtr& ptr) {
    ptr = std::make_shared<paddle::ICpuGpuVector>(iv->vec);
  });
Y
Yu Yang 已提交
104 105
}

Y
Stash  
Yu Yang 已提交
106 107
paddle_error paddle_arguments_sequence_start_pos(paddle_arguments args,
                                                 uint64_t ID,
Y
Yu Yang 已提交
108
                                                 uint32_t nestedLevel,
Y
Stash  
Yu Yang 已提交
109
                                                 paddle_ivector seqPos) {
L
livc 已提交
110
  if (args == nullptr || seqPos == nullptr) return kPD_NULLPTR;
Y
Yu Yang 已提交
111
  auto iv = paddle::capi::cast<paddle::capi::CIVector>(seqPos);
L
livc 已提交
112
  auto a = castArg(args);
Y
Yu Yang 已提交
113 114 115
  return a->accessSeqPos(ID, nestedLevel, [&iv](paddle::ICpuGpuVectorPtr& ptr) {
    iv->vec = ptr->getMutableVector(false);
  });
Y
Yu Yang 已提交
116
}
Y
Yu Yang 已提交
117
}