api_gen_utils.h 5.4 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17
/* 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 "paddle/phi/api/include/tensor.h"
W
wanghuancoder 已提交
18
#include "paddle/phi/backends/all_context.h"
19 20
#include "paddle/phi/core/compat/convert_utils.h"
#include "paddle/phi/core/dense_tensor.h"
21 22 23
#include "paddle/phi/core/distributed/auto_parallel/dist_attr.h"
#include "paddle/phi/core/distributed/auto_parallel/dist_meta_tensor.h"
#include "paddle/phi/core/distributed/auto_parallel/dist_tensor.h"
24 25 26 27
#include "paddle/phi/core/meta_tensor.h"
#include "paddle/phi/core/selected_rows.h"
#include "paddle/phi/core/sparse_coo_tensor.h"
#include "paddle/phi/core/sparse_csr_tensor.h"
J
Jack Zhou 已提交
28
#include "paddle/phi/core/string_tensor.h"
29 30 31 32

namespace paddle {
namespace experimental {

J
Jack Zhou 已提交
33
enum class TensorType { DENSE_TENSOR, SPARSE_CSR, SPARSE_COO, STRING_TENSOR };
34 35 36 37 38

/* ------------------ for input ----------------------- */

std::shared_ptr<phi::DenseTensor> TensorToDenseTensor(const Tensor& tensor);

39
paddle::optional<phi::DenseTensor> TensorToDenseTensor(
40 41
    const paddle::optional<Tensor>& tensor);

42
std::unique_ptr<std::vector<phi::DenseTensor*>> TensorToDenseTensor(
43 44
    const std::vector<Tensor>& tensors);

45 46 47 48 49 50 51
std::vector<const phi::DenseTensor*> TensorToConstDenseTensorPtr(
    const std::vector<Tensor>& tensors);

paddle::optional<std::vector<const phi::DenseTensor*>>
TensorToConstDenseTensorPtr(
    const paddle::optional<std::vector<Tensor>>& tensors);

52 53
std::shared_ptr<phi::SelectedRows> TensorToSelectedRows(const Tensor& tensor);

54 55
paddle::optional<phi::SelectedRows> TensorToSelectedRows(
    const paddle::optional<Tensor>& tensor);
56

J
Jack Zhou 已提交
57 58
std::shared_ptr<phi::StringTensor> TensorToStringTensor(const Tensor& tensor);

Z
zhangkaihuo 已提交
59 60
std::shared_ptr<phi::SparseCooTensor> TensorToSparseCooTensor(
    const Tensor& tensor);
61 62
/* ----------------- for infer_meta --------------------- */

63
phi::MetaTensor MakeMetaTensor(const phi::TensorBase& tensor);
64

65 66
phi::MetaTensor MakeMetaTensor(
    const paddle::optional<phi::DenseTensor>& tensor);
Z
zyfncg 已提交
67

68
std::vector<phi::MetaTensor> MakeMetaTensor(
69
    const std::vector<const phi::DenseTensor*>& tensors);
70

71 72 73
std::vector<phi::MetaTensor> MakeMetaTensor(
    const std::vector<phi::DenseTensor*>& tensors);

Y
YuanRisheng 已提交
74 75 76
std::vector<phi::MetaTensor> MakeMetaTensor(
    const std::vector<const phi::SelectedRows*>& tensors);

77 78
phi::MetaTensor MakeMetaTensor(
    const paddle::optional<phi::SelectedRows>& tensor);
Z
zyfncg 已提交
79

Z
zhangkaihuo 已提交
80 81 82 83 84 85
phi::MetaTensor MakeMetaTensor(
    const paddle::optional<phi::SparseCooTensor>& tensor);

phi::MetaTensor MakeMetaTensor(
    const paddle::optional<phi::SparseCsrTensor>& tensor);

86 87 88
std::vector<phi::MetaTensor> MakeMetaTensor(
    const paddle::optional<std::vector<const phi::DenseTensor*>>& tensors);

Y
YuanRisheng 已提交
89 90 91
std::vector<phi::MetaTensor> MakeMetaTensor(
    const std::vector<const phi::TensorBase*>& tensors);

92 93
/* ------------------ for output ----------------------- */

Z
zyfncg 已提交
94
phi::DenseTensor* SetKernelOutput(Tensor* out);
95 96 97 98

std::vector<phi::DenseTensor*> SetKernelOutput(size_t out_size,
                                               std::vector<Tensor>* out);

99
std::vector<phi::DenseTensor*> SetInplaceVectorKernelOutput(
Z
zyfncg 已提交
100
    size_t out_size, std::vector<Tensor>* out);
101 102

std::vector<phi::DenseTensor*> SetInplaceOptionalVectorKernelOutput(
Z
zyfncg 已提交
103
    size_t out_size, const paddle::optional<std::vector<Tensor>>& out);
104

105 106 107
// For backward api
std::vector<phi::DenseTensor*> SetKernelOutput(std::vector<Tensor*>* out);

Z
zyfncg 已提交
108
phi::SelectedRows* SetSelectedRowsKernelOutput(Tensor* out);
109 110 111

phi::TensorBase* SetSparseKernelOutput(Tensor* out, TensorType type);

Z
zyfncg 已提交
112
phi::TensorBase* SetStringsKernelOutput(Tensor* out, TensorType type);
J
Jack Zhou 已提交
113

W
wanghuancoder 已提交
114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132
phi::DenseTensor* ProcessStrideBackup(phi::DenseTensor** tensor);

std::vector<phi::DenseTensor*> ProcessStrideBackup(
    std::vector<phi::DenseTensor*>* tensor);

phi::SelectedRows* ProcessStrideBackup(phi::SelectedRows** tensor);

void TransStride(phi::DeviceContext* dev_ctx,
                 phi::DenseTensor* from,
                 phi::DenseTensor* to);

void TransStride(phi::DeviceContext* dev_ctx,
                 const std::vector<phi::DenseTensor*>& from,
                 const std::vector<phi::DenseTensor*>& to);

void TransStride(phi::DeviceContext* dev_ctx,
                 phi::SelectedRows* from,
                 phi::SelectedRows* to);

133 134 135 136
void TransStrideLegacy(phi::DeviceContext* dev_ctx,
                       phi::DenseTensor* from,
                       phi::DenseTensor* to);

137 138
/* ------------------ for auto parallel ----------------------- */

139 140 141 142 143 144 145 146
phi::distributed::DistMetaTensor MakeDistMetaTensor(
    const phi::TensorBase& tensor);

phi::distributed::DistTensor* SetKernelDistOutput(
    Tensor* out,
    const phi::distributed::TensorDistAttr& dist_attr =
        phi::distributed::TensorDistAttr());

147 148
std::vector<phi::distributed::DistTensor*> SetKernelDistOutput(
    std::vector<Tensor*> out);
149

150 151
std::vector<phi::distributed::DistTensor*> SetKernelDistOutput(
    size_t out_size, std::vector<Tensor>* out);
152

153 154
}  // namespace experimental
}  // namespace paddle