__init__.py 12.0 KB
Newer Older
1
# Copyright (c) 2016 PaddlePaddle Authors. All Rights Reserved
Z
zhangjinchao01 已提交
2 3 4 5 6 7 8 9 10 11 12 13
#
# 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.
C
Chengmo 已提交
14

15 16 17 18 19
import os
from paddle.check_import_scipy import check_import_scipy

check_import_scipy(os.name)

Y
Yancey 已提交
20
try:
21 22
    from paddle.version import full_version as __version__
    from paddle.version import commit as __git_commit__
23

Y
Yancey 已提交
24 25
except ImportError:
    import sys
26
    sys.stderr.write('''Warning with import paddle: you should not
Y
Yancey 已提交
27 28
     import paddle from the source directory; please install paddlepaddle*.whl firstly.'''
                     )
29

30 31 32
import paddle.reader
import paddle.dataset
import paddle.batch
Z
zhangchunle 已提交
33
batch = batch.batch
34 35 36 37
from .fluid import monkey_patch_variable
from .fluid.dygraph import monkey_patch_math_varbase
monkey_patch_variable()
monkey_patch_math_varbase()
38 39 40
import paddle.framework
from .framework import VarBase as Tensor
from .framework import ComplexVariable as ComplexTensor
M
minqiyang 已提交
41
import paddle.compat
42
import paddle.distributed
43
import paddle.sysconfig
44
import paddle.tensor
45
import paddle.distribution
C
Chengmo 已提交
46
import paddle.nn
47
import paddle.distributed.fleet
H
hong 已提交
48 49
import paddle.optimizer
import paddle.metric
50
import paddle.device
51
import paddle.incubate.complex as complex
52

C
Chengmo 已提交
53
# TODO: define alias in tensor and framework directory
54

55
from .tensor.random import randperm
L
Leo Chen 已提交
56
from .tensor.random import bernoulli
57

58 59
from .tensor.attribute import rank  #DEFINE_ALIAS
from .tensor.attribute import shape  #DEFINE_ALIAS
60
from .tensor.creation import to_tensor  #DEFINE_ALIAS
61 62
from .tensor.creation import crop_tensor  #DEFINE_ALIAS
from .tensor.creation import diag  #DEFINE_ALIAS
63
from .tensor.creation import eye  #DEFINE_ALIAS
64
from .tensor.creation import fill_constant  #DEFINE_ALIAS
65
# from .tensor.creation import get_tensor_from_selected_rows        #DEFINE_ALIAS
66
from .tensor.creation import linspace  #DEFINE_ALIAS
67 68 69 70
from .tensor.creation import ones  #DEFINE_ALIAS
from .tensor.creation import ones_like  #DEFINE_ALIAS
from .tensor.creation import zeros  #DEFINE_ALIAS
from .tensor.creation import zeros_like  #DEFINE_ALIAS
71
from .tensor.creation import arange  #DEFINE_ALIAS
72
from .tensor.creation import eye  #DEFINE_ALIAS
W
wangchaochaohu 已提交
73
from .tensor.creation import full  #DEFINE_ALIAS
P
Pei Yang 已提交
74
from .tensor.creation import full_like  #DEFINE_ALIAS
75 76
from .tensor.creation import triu  #DEFINE_ALIAS
from .tensor.creation import tril  #DEFINE_ALIAS
S
suytingwan 已提交
77
from .tensor.creation import meshgrid  #DEFINE_ALIAS
78 79 80 81 82 83 84 85 86 87 88
from .tensor.linalg import matmul  #DEFINE_ALIAS
from .tensor.linalg import dot  #DEFINE_ALIAS
# from .tensor.linalg import einsum        #DEFINE_ALIAS
from .tensor.linalg import norm  #DEFINE_ALIAS
from .tensor.linalg import transpose  #DEFINE_ALIAS
from .tensor.linalg import dist  #DEFINE_ALIAS
from .tensor.linalg import t  #DEFINE_ALIAS
from .tensor.linalg import cross  #DEFINE_ALIAS
from .tensor.linalg import cholesky  #DEFINE_ALIAS
# from .tensor.linalg import tensordot        #DEFINE_ALIAS
from .tensor.linalg import bmm  #DEFINE_ALIAS
Q
Qi Li 已提交
89
from .tensor.linalg import histogram  #DEFINE_ALIAS
90
from .tensor.logic import equal  #DEFINE_ALIAS
91 92 93
from .tensor.logic import greater_equal  #DEFINE_ALIAS
from .tensor.logic import greater_than  #DEFINE_ALIAS
from .tensor.logic import is_empty  #DEFINE_ALIAS
J
Jack Zhou 已提交
94
#from .tensor.logic import isfinite  #DEFINE_ALIAS
95 96 97 98 99 100 101 102 103
from .tensor.logic import less_equal  #DEFINE_ALIAS
from .tensor.logic import less_than  #DEFINE_ALIAS
from .tensor.logic import logical_and  #DEFINE_ALIAS
from .tensor.logic import logical_not  #DEFINE_ALIAS
from .tensor.logic import logical_or  #DEFINE_ALIAS
from .tensor.logic import logical_xor  #DEFINE_ALIAS
from .tensor.logic import not_equal  #DEFINE_ALIAS
from .tensor.logic import reduce_all  #DEFINE_ALIAS
from .tensor.logic import reduce_any  #DEFINE_ALIAS
Z
Zhen Wang 已提交
104
from .tensor.logic import allclose  #DEFINE_ALIAS
W
wawltor 已提交
105
from .tensor.logic import equal_all  #DEFINE_ALIAS
106 107 108 109
# from .tensor.logic import isnan        #DEFINE_ALIAS
from .tensor.manipulation import cast  #DEFINE_ALIAS
from .tensor.manipulation import concat  #DEFINE_ALIAS
from .tensor.manipulation import expand  #DEFINE_ALIAS
L
lilong12 已提交
110
from .tensor.manipulation import broadcast_to  #DEFINE_ALIAS
111
from .tensor.manipulation import expand_as  #DEFINE_ALIAS
L
lilong12 已提交
112
from .tensor.manipulation import tile  #DEFINE_ALIAS
113 114
from .tensor.manipulation import flatten  #DEFINE_ALIAS
from .tensor.manipulation import gather  #DEFINE_ALIAS
115
from .tensor.manipulation import gather_nd  #DEFINE_ALIAS
116
from .tensor.manipulation import reshape  #DEFINE_ALIAS
Y
yaoxuefeng 已提交
117
from .tensor.manipulation import flip as reverse  #DEFINE_ALIAS
118
from .tensor.manipulation import scatter  #DEFINE_ALIAS
119 120 121
from .tensor.manipulation import scatter_nd_add  #DEFINE_ALIAS
from .tensor.manipulation import scatter_nd  #DEFINE_ALIAS
from .tensor.manipulation import shard_index  #DEFINE_ALIAS
122 123 124 125 126 127 128
from .tensor.manipulation import slice  #DEFINE_ALIAS
from .tensor.manipulation import split  #DEFINE_ALIAS
from .tensor.manipulation import squeeze  #DEFINE_ALIAS
from .tensor.manipulation import stack  #DEFINE_ALIAS
from .tensor.manipulation import strided_slice  #DEFINE_ALIAS
from .tensor.manipulation import transpose  #DEFINE_ALIAS
from .tensor.manipulation import unique  #DEFINE_ALIAS
129
from .tensor.manipulation import unique_with_counts  #DEFINE_ALIAS
130 131 132
from .tensor.manipulation import unsqueeze  #DEFINE_ALIAS
from .tensor.manipulation import unstack  #DEFINE_ALIAS
from .tensor.manipulation import flip  #DEFINE_ALIAS
133
from .tensor.manipulation import unbind  #DEFINE_ALIAS
134
from .tensor.manipulation import roll  #DEFINE_ALIAS
135
from .tensor.manipulation import chunk  #DEFINE_ALIAS
136 137 138
from .tensor.math import abs  #DEFINE_ALIAS
from .tensor.math import acos  #DEFINE_ALIAS
from .tensor.math import asin  #DEFINE_ALIAS
139
from .tensor.math import atan  #DEFINE_ALIAS
140 141
from .tensor.math import ceil  #DEFINE_ALIAS
from .tensor.math import cos  #DEFINE_ALIAS
142
from .tensor.math import cosh  #DEFINE_ALIAS
143 144 145 146 147 148 149 150 151
from .tensor.math import cumsum  #DEFINE_ALIAS
from .tensor.math import elementwise_add  #DEFINE_ALIAS
from .tensor.math import elementwise_div  #DEFINE_ALIAS
from .tensor.math import elementwise_floordiv  #DEFINE_ALIAS
from .tensor.math import elementwise_mod  #DEFINE_ALIAS
from .tensor.math import elementwise_pow  #DEFINE_ALIAS
from .tensor.math import elementwise_sub  #DEFINE_ALIAS
from .tensor.math import exp  #DEFINE_ALIAS
from .tensor.math import floor  #DEFINE_ALIAS
152
from .tensor.math import increment  #DEFINE_ALIAS
153
from .tensor.math import log  #DEFINE_ALIAS
154
from .tensor.math import multiplex  #DEFINE_ALIAS
155
from .tensor.math import pow  #DEFINE_ALIAS
156 157 158 159 160 161 162 163 164
from .tensor.math import reciprocal  #DEFINE_ALIAS
from .tensor.math import reduce_max  #DEFINE_ALIAS
from .tensor.math import reduce_min  #DEFINE_ALIAS
from .tensor.math import reduce_prod  #DEFINE_ALIAS
from .tensor.math import reduce_sum  #DEFINE_ALIAS
from .tensor.math import round  #DEFINE_ALIAS
from .tensor.math import rsqrt  #DEFINE_ALIAS
from .tensor.math import scale  #DEFINE_ALIAS
from .tensor.math import sign  #DEFINE_ALIAS
165
from .tensor.math import sin  #DEFINE_ALIAS
166
from .tensor.math import sinh  #DEFINE_ALIAS
167
from .tensor.math import sqrt  #DEFINE_ALIAS
168 169
from .tensor.math import square  #DEFINE_ALIAS
from .tensor.math import stanh  #DEFINE_ALIAS
170
from .tensor.math import sum  #DEFINE_ALIAS
171
from .tensor.math import sums  #DEFINE_ALIAS
172
from .tensor.math import tanh  #DEFINE_ALIAS
173
from .tensor.math import elementwise_sum  #DEFINE_ALIAS
174
from .tensor.math import max  #DEFINE_ALIAS
175
from .tensor.math import maximum  #DEFINE_ALIAS
176
from .tensor.math import min  #DEFINE_ALIAS
177
from .tensor.math import minimum  #DEFINE_ALIAS
178
from .tensor.math import mm  #DEFINE_ALIAS
179 180 181 182 183
from .tensor.math import divide  #DEFINE_ALIAS
from .tensor.math import floor_divide  #DEFINE_ALIAS
from .tensor.math import remainder  #DEFINE_ALIAS
from .tensor.math import mod  #DEFINE_ALIAS
from .tensor.math import floor_mod  #DEFINE_ALIAS
184
from .tensor.math import multiply  #DEFINE_ALIAS
185
from .tensor.math import add  #DEFINE_ALIAS
186
from .tensor.math import atan  #DEFINE_ALIAS
187
from .tensor.math import logsumexp  #DEFINE_ALIAS
188
from .tensor.math import inverse  #DEFINE_ALIAS
189
from .tensor.math import log1p  #DEFINE_ALIAS
190
from .tensor.math import erf  #DEFINE_ALIAS
B
Bai Yifan 已提交
191
from .tensor.math import addcmul  #DEFINE_ALIAS
192
from .tensor.math import addmm  #DEFINE_ALIAS
Y
Yang Zhang 已提交
193
from .tensor.math import clip  #DEFINE_ALIAS
L
Li Fuchen 已提交
194
from .tensor.math import trace  #DEFINE_ALIAS
195
from .tensor.math import kron  #DEFINE_ALIAS
J
Jack Zhou 已提交
196 197 198
from .tensor.math import isfinite  #DEFINE_ALIAS
from .tensor.math import isinf  #DEFINE_ALIAS
from .tensor.math import isnan  #DEFINE_ALIAS
G
guofei 已提交
199
from .tensor.math import prod  #DEFINE_ALIAS
200 201
from .tensor.random import standard_normal
from .tensor.random import normal
P
pangyoki 已提交
202
from .tensor.random import uniform  #DEFINE_ALIAS
203 204 205 206 207
from .tensor.random import shuffle  #DEFINE_ALIAS
from .tensor.random import randn  #DEFINE_ALIAS
from .tensor.random import rand  #DEFINE_ALIAS
from .tensor.random import randint  #DEFINE_ALIAS
from .tensor.random import randperm  #DEFINE_ALIAS
208
from .tensor.search import argmax  #DEFINE_ALIAS
209 210 211 212
from .tensor.search import argmin  #DEFINE_ALIAS
from .tensor.search import argsort  #DEFINE_ALIAS
from .tensor.search import has_inf  #DEFINE_ALIAS
from .tensor.search import has_nan  #DEFINE_ALIAS
213
from .tensor.search import masked_select  #DEFINE_ALIAS
214
from .tensor.search import topk  #DEFINE_ALIAS
G
GaoWei8 已提交
215
from .tensor.search import where  #DEFINE_ALIAS
216 217
from .tensor.search import index_select  #DEFINE_ALIAS
from .tensor.search import nonzero  #DEFINE_ALIAS
218
from .tensor.search import sort  #DEFINE_ALIAS
0
0YuanZhang0 已提交
219
from .framework.random import manual_seed  #DEFINE_ALIAS
220 221
from .framework import Variable  #DEFINE_ALIAS
from .framework import ParamAttr  #DEFINE_ALIAS
H
hong 已提交
222 223 224 225 226
from .framework import create_global_var  #DEFINE_ALIAS
from .framework import create_parameter  #DEFINE_ALIAS
from .framework import CPUPlace  #DEFINE_ALIAS
from .framework import CUDAPlace  #DEFINE_ALIAS
from .framework import CUDAPinnedPlace  #DEFINE_ALIAS
227 228 229 230 231 232

from .framework import to_variable  #DEFINE_ALIAS
from .framework import grad  #DEFINE_ALIAS
from .framework import no_grad  #DEFINE_ALIAS
from .framework import save  #DEFINE_ALIAS
from .framework import load  #DEFINE_ALIAS
233
from .framework import SaveLoadConfig  #DEFINE_ALIAS
234 235 236 237 238 239 240 241 242
from .framework import DataParallel  #DEFINE_ALIAS

from .framework import NoamDecay  #DEFINE_ALIAS
from .framework import PiecewiseDecay  #DEFINE_ALIAS
from .framework import NaturalExpDecay  #DEFINE_ALIAS
from .framework import ExponentialDecay  #DEFINE_ALIAS
from .framework import InverseTimeDecay  #DEFINE_ALIAS
from .framework import PolynomialDecay  #DEFINE_ALIAS
from .framework import CosineDecay  #DEFINE_ALIAS
243 244
from .framework import set_default_dtype  #DEFINE_ALIAS
from .framework import get_default_dtype  #DEFINE_ALIAS
245

246 247 248 249 250
from .tensor.search import index_sample  #DEFINE_ALIAS
from .tensor.stat import mean  #DEFINE_ALIAS
from .tensor.stat import reduce_mean  #DEFINE_ALIAS
from .tensor.stat import std  #DEFINE_ALIAS
from .tensor.stat import var  #DEFINE_ALIAS
H
hong 已提交
251
from .fluid.data import data
252
from .tensor.stat import numel  #DEFINE_ALIAS
253
from .device import get_cudnn_version
254 255 256
from .device import set_device
from .device import get_device
# from .tensor.tensor import Tensor        #DEFINE_ALIAS
257 258
# from .tensor.tensor import LoDTensor        #DEFINE_ALIAS
# from .tensor.tensor import LoDTensorArray        #DEFINE_ALIAS
259

260 261 262
from .fluid.dygraph.base import enable_dygraph as disable_static  #DEFINE_ALIAS
from .fluid.dygraph.base import disable_dygraph as enable_static  #DEFINE_ALIAS
from .fluid.framework import in_dygraph_mode as in_dynamic_mode  #DEFINE_ALIAS
263
from .fluid.dygraph.base import no_grad_ as no_grad  #DEFINE_ALIAS
264 265 266

from . import jit
from . import static
267 268 269 270

# high-level api
from .hapi import Model
from .hapi import callbacks
L
LielinJiang 已提交
271
from .hapi import summary
272 273
import paddle.text
import paddle.vision