Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
机器未来
Paddle
提交
51939c83
P
Paddle
项目概览
机器未来
/
Paddle
与 Fork 源项目一致
Fork自
PaddlePaddle / Paddle
通知
1
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
P
Paddle
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
未验证
提交
51939c83
编写于
8月 18, 2021
作者:
R
ronnywang
提交者:
GitHub
8月 18, 2021
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Fix the parameter name for atan2 API (#34812)
上级
209075a4
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
25 addition
and
25 deletion
+25
-25
python/paddle/tensor/math.py
python/paddle/tensor/math.py
+25
-25
未找到文件。
python/paddle/tensor/math.py
浏览文件 @
51939c83
...
...
@@ -2491,25 +2491,25 @@ def neg(x, name=None):
return
layers
.
scale
(
x
,
scale
=-
1.0
,
bias
=
0.0
,
bias_after_scale
=
True
,
act
=
None
,
name
=
name
)
def
atan2
(
y
,
x
,
name
=
None
):
def
atan2
(
x
,
y
,
name
=
None
):
r
"""
Element-wise arctangent of
y/x
with consideration of the quadrant.
Element-wise arctangent of
x/y
with consideration of the quadrant.
Equation:
.. math::
atan2(y,x
)=\left\{\begin{matrix}
& tan^{-1}(\frac{y}{x}) & x
> 0 \\
& tan^{-1}(\frac{y}{x}) + \pi & y>=0, x
< 0 \\
& tan^{-1}(\frac{y}{x}) - \pi & y<0, x
< 0 \\
& +\frac{\pi}{2} & y>0, x
= 0 \\
& -\frac{\pi}{2} & y<0, x
= 0 \\
&\text{undefined} & y=0, x
= 0
\end{matrix}\right.
atan2(x,y
)=\left\{\begin{matrix}
& tan^{-1}(\frac{x}{y}) & y
> 0 \\
& tan^{-1}(\frac{x}{y}) + \pi & x>=0, y
< 0 \\
& tan^{-1}(\frac{x}{y}) - \pi & x<0, y
< 0 \\
& +\frac{\pi}{2} & x>0, y
= 0 \\
& -\frac{\pi}{2} & x<0, y
= 0 \\
&\text{undefined} & x=0, y
= 0
\end{matrix}\right.
Args:
y
(Tensor): An N-D Tensor, the data type is int32, int64, float16, float32, float64.
x
(Tensor): An N-D Tensor, must have the same type as `x`.
x
(Tensor): An N-D Tensor, the data type is int32, int64, float16, float32, float64.
y
(Tensor): An N-D Tensor, must have the same type as `x`.
name (str, optional): Name for the operation (optional, default is None). For more information, please refer to :ref:`api_guide_Name`.
Returns:
...
...
@@ -2518,30 +2518,30 @@ def atan2(y, x, name=None):
Examples:
.. code-block:: python
import paddle
import paddle
y
= paddle.to_tensor([-1, +1, +1, -1]).astype('float32')
#Tensor(shape=[4], dtype=float32, place=CUDAPlace(0), stop_gradient=True,
# [-1, 1, 1, -1])
x
= paddle.to_tensor([-1, +1, +1, -1]).astype('float32')
#Tensor(shape=[4], dtype=float32, place=CUDAPlace(0), stop_gradient=True,
# [-1, 1, 1, -1])
x
= paddle.to_tensor([-1, -1, +1, +1]).astype('float32')
#Tensor(shape=[4], dtype=float32, place=CUDAPlace(0), stop_gradient=True,
# [-1, -1, 1, 1])
y
= paddle.to_tensor([-1, -1, +1, +1]).astype('float32')
#Tensor(shape=[4], dtype=float32, place=CUDAPlace(0), stop_gradient=True,
# [-1, -1, 1, 1])
out = paddle.atan2(y, x
)
#Tensor(shape=[4], dtype=float32, place=CUDAPlace(0), stop_gradient=True,
# [-2.35619450, 2.35619450, 0.78539819, -0.78539819])
out = paddle.atan2(x, y
)
#Tensor(shape=[4], dtype=float32, place=CUDAPlace(0), stop_gradient=True,
# [-2.35619450, 2.35619450, 0.78539819, -0.78539819])
"""
if
in_dygraph_mode
():
return
_C_ops
.
atan2
(
y
,
x
)
return
_C_ops
.
atan2
(
x
,
y
)
else
:
check_variable_and_dtype
(
y
,
'y'
,
[
'int32'
,
'int64'
,
'float16'
,
'float32'
,
'float64'
],
'atan2'
)
check_variable_and_dtype
(
x
,
'x'
,
[
'int32'
,
'int64'
,
'float16'
,
'float32'
,
'float64'
],
'atan2'
)
check_variable_and_dtype
(
y
,
'y'
,
[
'int32'
,
'int64'
,
'float16'
,
'float32'
,
'float64'
],
'atan2'
)
helper
=
LayerHelper
(
'atan2'
,
**
locals
())
inputs
=
{
'X1'
:
y
,
'X2'
:
x
}
inputs
=
{
'X1'
:
x
,
'X2'
:
y
}
out
=
helper
.
create_variable_for_type_inference
(
dtype
=
x
.
dtype
)
helper
.
append_op
(
type
=
'atan2'
,
inputs
=
inputs
,
outputs
=
{
'Out'
:
out
})
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录