layers_cn.rst 523.8 KB
Newer Older
C
Cheerego 已提交
1 2 3 4 5 6
###################
fluid.layers
###################


============
C
Cheerego 已提交
7
control_flow
C
Cheerego 已提交
8 9 10 11 12 13 14 15 16 17 18 19
============


.. _cn_api_fluid_layers_array_length:

array_length
-------------------------------

.. py:function:: paddle.fluid.layers.array_length(array)

**得到输入LoDTensorArray的长度**

C
Cheerego 已提交
20
此功能用于查找输入数组LOD_TENSOR_ARRAY的长度。
C
Cheerego 已提交
21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37

相关API:
    - :ref:`cn_api_fluid_layers_array_read`
    - :ref:`cn_api_fluid_layers_array_write`
    - :ref:`cn_api_fluid_layers_While`

参数:
    - **array** (LOD_TENSOR_ARRAY)-输入数组,用来计算数组长度

返回:输入数组LoDTensorArray的长度

返回类型:变量(Variable)

**代码示例**:

.. code-block:: python

R
RaindragonD 已提交
38
    import paddle.fluid as fluid
C
Cheerego 已提交
39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82
    tmp = fluid.layers.zeros(shape=[10], dtype='int32')
    i = fluid.layers.fill_constant(shape=[1], dtype='int64', value=10)
    arr = fluid.layers.array_write(tmp, i=i)
    arr_len = fluid.layers.array_length(arr)









.. _cn_api_fluid_layers_array_read:

array_read
-------------------------------

.. py:function:: paddle.fluid.layers.array_read(array,i)

此函数用于读取数据,数据以LOD_TENSOR_ARRAY数组的形式读入

::


    Given:
        array = [0.6,0.1,0.3,0.1]
    And:
        I=2
    Then:
        output = 0.3

参数:
    - **array** (Variable|list)-输入张量,存储要读的数据
    - **i** (Variable|list)-输入数组中数据的索引

返回:张量类型的变量,已有数据写入

返回类型:变量(Variable)

**代码示例**:

.. code-block:: python

R
RaindragonD 已提交
83
    import paddle.fluid as fluid
84
    array = fluid.layers.create_array(dtype='float32')
C
Cheerego 已提交
85
    i = fluid.layers.fill_constant(shape=[1],dtype='int64',value=10)
86
    item = fluid.layers.array_read(array, i)
C
Cheerego 已提交
87 88 89 90 91 92 93 94 95 96









.. _cn_api_fluid_layers_array_write:
C
Cheerego 已提交
97

C
Cheerego 已提交
98 99 100 101 102 103 104 105 106 107 108 109 110
array_write
-------------------------------

.. py:function:: paddle.fluid.layers.array_write(x, i, array=None)


该函数将给定的输入变量(即 ``x`` )写入一个作为输出的 ``LOD_TENSOR_ARRAY`` 变量的某一指定位置中,
这一位置由数组下标(即 ``i`` )指明。 如果 ``LOD_TENSOR_ARRAY`` (即 ``array`` )未指定(即为None值), 一个新的 ``LOD_TENSOR_ARRAY`` 将会被创建并作为结果返回。

参数:
    - **x** (Variable|list) – 待从中读取数据的输入张量(tensor)
    - **i** (Variable|list) – 输出结果 ``LOD_TENSOR_ARRAY`` 的下标, 该下标指向输入张量 ``x`` 写入输出数组的位置
    - **array** (Variable|list) – 会被输入张量 ``x`` 写入的输出结果 ``LOD_TENSOR_ARRAY`` 。如果该项值为None, 一个新的 ``LOD_TENSOR_ARRAY`` 将会被创建并作为结果返回
C
Cheerego 已提交
111

R
RaindragonD 已提交
112
返回: 输入张量 ``x`` 所写入的输出结果 ``LOD_TENSOR_ARRAY``
C
Cheerego 已提交
113

R
RaindragonD 已提交
114
返回类型: 变量(Variable)
C
Cheerego 已提交
115 116 117 118 119

**代码示例**

..  code-block:: python

R
RaindragonD 已提交
120
  import paddle.fluid as fluid
C
Cheerego 已提交
121 122
  tmp = fluid.layers.zeros(shape=[10], dtype='int32')
  i = fluid.layers.fill_constant(shape=[1], dtype='int64', value=10)
H
Hao Wang 已提交
123
  arr = fluid.layers.array_write(tmp, i=i)
C
Cheerego 已提交
124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144











.. _cn_api_fluid_layers_create_array:

create_array
-------------------------------

.. py:function:: paddle.fluid.layers.create_array(dtype)


创建LoDTensorArray数组。它主要用于实现RNN与array_write, array_read和While。

C
Cheerego 已提交
145
参数:
C
Cheerego 已提交
146 147 148 149 150 151 152 153 154 155
    - **dtype** (int |float) — lod_tensor_array中存储元素的数据类型。

返回: lod_tensor_array, 元素数据类型为dtype。

返回类型: Variable。


**代码示例**

..  code-block:: python
C
Cheerego 已提交
156

C
Cheerego 已提交
157
  data = fluid.layers.create_array(dtype='float32')
C
Cheerego 已提交
158 159


C
Cheerego 已提交
160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189









.. _cn_api_fluid_layers_DynamicRNN:

DynamicRNN
-------------------------------

.. py:class:: paddle.fluid.layers.DynamicRNN(name=None)


动态RNN可以处理一批序列数据,每个样本序列的长度可以不同。这个API自动批量处理它们。

必须设置输入lod,请参考 ``lod_tensor``

动态RNN将按照timesteps展开开序列。用户需要在with block中定义如何处理处理每个timestep。

memory用于缓存分段数据。memory的初始值可以是零,也可以是其他变量。

动态RNN可以将多个变量标记为其输出。使用drnn()获得输出序列。

.. note::
    目前不支持在DynamicRNN中任何层上配置 is_sparse = True

R
RaindragonD 已提交
190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211
**代码示例**

..  code-block:: python

  import paddle.fluid as fluid
  
  sentence = fluid.layers.data(name='sentence', shape=[1], dtype='int64', lod_level=1)
  embedding = fluid.layers.embedding(input=sentence, size=[65536, 32], is_sparse=True)
  
  drnn = fluid.layers.DynamicRNN()
  with drnn.block():
      word = drnn.step_input(embedding)
      prev = drnn.memory(shape=[200])
      hidden = fluid.layers.fc(input=[word, prev], size=200, act='relu')
      drnn.update_memory(prev, hidden)  # set prev to hidden
      drnn.output(hidden)
     
  # 获得上一个timestep的rnn,该值是一个编码后的结果
  rnn_output = drnn()
  last = fluid.layers.sequence_last_step(rnn_output)


Z
zy0531 已提交
212
.. py:method:: step_input(x, level=0)
H
Hao Wang 已提交
213

C
Cheerego 已提交
214 215 216
    将序列标记为动态RNN输入。

参数:
R
RaindragonD 已提交
217
      - **x** (Variable) - 含lod信息的输入序列
C
Cheerego 已提交
218 219
      - **level** (int) - 用于拆分步骤的LOD层级,默认值0

C
Cheerego 已提交
220 221 222 223
返回:当前的输入序列中的timestep。

.. py:method:: static_input(x)

R
RaindragonD 已提交
224
将变量标记为RNN输入。输入不会分散到timestep中。为可选项。
C
Cheerego 已提交
225 226

参数:
R
RaindragonD 已提交
227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254
      - **x** (Variable) - 输入序列

返回:可以访问的RNN的输入变量。

**代码示例**

..  code-block:: python

    import paddle.fluid as fluid
     
    sentence = fluid.layers.data(name='sentence', dtype='float32', shape=[32], lod_level=1)
    encoder_proj = fluid.layers.data(name='encoder_proj', dtype='float32', shape=[32], lod_level=1)
    decoder_boot = fluid.layers.data(name='boot', dtype='float32', shape=[10], lod_level=1)
     
    drnn = fluid.layers.DynamicRNN()
    with drnn.block():
        current_word = drnn.step_input(sentence)
        encoder_word = drnn.static_input(encoder_proj)
        hidden_mem = drnn.memory(init=decoder_boot, need_reorder=True)
        fc_1 = fluid.layers.fc(input=encoder_word, size=30, bias_attr=False)
        fc_2 = fluid.layers.fc(input=current_word, size=30, bias_attr=False)
        decoder_inputs = fc_1 + fc_2
        h, _, _ = fluid.layers.gru_unit(input=decoder_inputs, hidden=hidden_mem, size=30)
        drnn.update_memory(hidden_mem, h)
        out = fluid.layers.fc(input=h, size=10, bias_attr=True, act='softmax')
        drnn.output(out)
     
    rnn_output = drnn()
C
Cheerego 已提交
255 256


H
Hao Wang 已提交
257
.. py:method:: block()
C
Cheerego 已提交
258

H
Hao Wang 已提交
259
用户在RNN中定义operators的block。
C
Cheerego 已提交
260 261 262 263

.. py:method:: memory(init=None, shape=None, value=0.0, need_reorder=False, dtype='float32')

为动态rnn创建一个memory 变量。
C
Cheerego 已提交
264

R
RaindragonD 已提交
265
如果 ``init`` 不是None, ``memory`` 将由这个变量初始化。参数 ``need_reorder`` 用于将memory重新排序作为输入变量。当memory初始化依赖于输入样本时,应该将其设置为True。
C
Cheerego 已提交
266

R
RaindragonD 已提交
267
**代码示例**
C
Cheerego 已提交
268 269

..  code-block:: python
C
Cheerego 已提交
270

R
RaindragonD 已提交
271 272 273 274 275 276 277 278 279 280 281 282
  import paddle.fluid as fluid
  
  sentence = fluid.layers.data(name='sentence', shape=[32], dtype='float32', lod_level=1)
  boot_memory = fluid.layers.data(name='boot', shape=[10], dtype='float32', lod_level=1)
  
  drnn = fluid.layers.DynamicRNN()
  with drnn.block():
      word = drnn.step_input(sentence)
      memory = drnn.memory(init=boot_memory, need_reorder=True)
      hidden = fluid.layers.fc(input=[word, memory], size=10, act='tanh')
      drnn.update_memory(ex_mem=memory, new_mem=hidden)
      drnn.output(hidden)
C
Cheerego 已提交
283

R
RaindragonD 已提交
284
  rnn_output = drnn()
C
Cheerego 已提交
285 286 287 288



否则,如果已经设置 ``shape`` 、 ``value`` 、 ``dtype`` ,memory将被 ``value`` 初始化
C
Cheerego 已提交
289

R
RaindragonD 已提交
290 291
**代码示例**

C
Cheerego 已提交
292
..  code-block:: python
C
Cheerego 已提交
293

R
RaindragonD 已提交
294
  import paddle.fluid as fluid
C
Cheerego 已提交
295

R
RaindragonD 已提交
296
  sentence = fluid.layers.data(name='sentence', dtype='float32', shape=[32], lod_level=1)
C
Cheerego 已提交
297

R
RaindragonD 已提交
298 299 300 301 302 303 304 305 306
  drnn = fluid.layers.DynamicRNN()
  with drnn.block():
      word = drnn.step_input(sentence)
      memory = drnn.memory(shape=[10], dtype='float32', value=0)
      hidden = fluid.layers.fc(input=[word, memory], size=10, act='tanh')
      drnn.update_memory(ex_mem=memory, new_mem=hidden)
      drnn.output(hidden)

  rnn_output = drnn()
C
Cheerego 已提交
307 308 309 310


参数:
    - **init** (Variable|None) – 初始化的Variable
R
RaindragonD 已提交
311
    - **shape** (list|tuple) – memory shape,形状不包含batch_size
C
Cheerego 已提交
312 313 314 315 316 317 318 319 320 321 322 323
    - **value** (float) – 初始化的值
    - **need_reorder** (bool) – memory初始化依赖于输入样本时设置为True
    - **dtype** (str|numpy.dtype) – 初始化memory的数据类型

返回:memory Variable


.. py:method:: update_memory(ex_mem, new_mem)

将内存从 ``ex_mem`` 更新到 ``new_mem`` 。注意, ``ex_mem`` 和 ``new_mem`` 的 ``shape`` 和数据类型必须相同。

参数:
R
RaindragonD 已提交
324 325
  - **ex_mem** (memory Variable)-  memory 变量(Variable)
  - **new_mem** (memory Variable)- RNN块中生成的平坦变量(plain  variable)
C
Cheerego 已提交
326 327 328 329 330 331 332 333 334 335 336 337

返回:None


.. py:method:: output(*outputs)

标记RNN输出变量。

参数:
    - **\*outputs** - 输出变量。

返回:None
C
Cheerego 已提交
338

R
RaindragonD 已提交
339
      
C
Cheerego 已提交
340

R
RaindragonD 已提交
341
  
C
Cheerego 已提交
342 343 344 345 346 347 348 349 350




.. _cn_api_fluid_layers_equal:

equal
-------------------------------

H
Hao Wang 已提交
351
.. py:function:: paddle.fluid.layers.equal(x,y,cond=None)
C
Cheerego 已提交
352 353 354 355 356 357 358 359 360

**equal**
该层返回 :math:`x==y` 按逐元素运算而得的真值。

参数:
    - **x** (Variable)-equal的第一个操作数
    - **y** (Variable)-equal的第二个操作数
    - **cond** (Variable|None)-输出变量(可选),用来存储equal的结果

C
Cheerego 已提交
361
返回:张量类型的变量,存储equal的输出结果
C
Cheerego 已提交
362

C
Cheerego 已提交
363
返回类型:变量(Variable)
C
Cheerego 已提交
364

C
Cheerego 已提交
365
**代码示例**:
C
Cheerego 已提交
366 367 368

.. code-block:: python

R
RaindragonD 已提交
369 370 371
    import paddle.fluid as fluid
    label = fluid.layers.data(name="label", shape=[3,10,32,32], dtype="float32")
    limit = fluid.layers.data(name="limit", shape=[3,10,32,32], dtype="float32")
C
Cheerego 已提交
372 373 374 375 376
    less = fluid.layers.equal(x=label,y=limit)




R
RaindragonD 已提交
377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423
.. _cn_api_fluid_layers_greater_equal:

greater_equal
-------------------------------

.. py:function:: paddle.fluid.layers.greater_equal(x, y, cond=None)

该层逐元素地返回 :math:`x >= y` 的逻辑值,和重载算子 `>=` 相同。

参数:
    - **x** (Variable) - *greater_equal* 的第一个操作数
    - **y** (Variable) - *greater_equal* 的第二个操作数
    - **cond** (Variable|None) - 可选的输出变量,存储 *greater_equal* 的结果

返回:存储 *greater_equal* 的输出的张量变量。

返回类型:变量(Variable)

**代码示例**:

.. code-block:: python

     out = fluid.layers.greater_equal(x=label, y=limit)



.. _cn_api_fluid_layers_greater_than:

greater_than
-------------------------------

.. py:function:: paddle.fluid.layers.greater_than(x, y, cond=None)

该层逐元素地返回 :math:`x > y` 的逻辑值,和重载算子 `>` 相同。

参数:
    - **x** (Variable) - *greater_than* 的第一个操作数
    - **y** (Variable) - *greater_than* 的第二个操作数
    - **cond** (Variable|None) - 可选的输出变量,存储 *greater_than* 的结果

返回:存储 *greater_than* 的输出的张量变量。

返回类型:变量(Variable)

**代码示例**:

.. code-block:: python
C
Cheerego 已提交
424

R
RaindragonD 已提交
425
     out = fluid.layers.greater_than(x=label, y=limit)
C
Cheerego 已提交
426 427 428 429 430 431 432 433 434




.. _cn_api_fluid_layers_IfElse:

IfElse
-------------------------------

T
Tink_Y 已提交
435
.. py:class:: paddle.fluid.layers.IfElse(cond, name=None)
C
Cheerego 已提交
436

C
Cheerego 已提交
437
if-else控制流。
C
Cheerego 已提交
438 439 440 441 442 443 444 445 446

参数:
    - **cond** (Variable)-用于比较的条件
    - **Name** (str,默认为空(None))-该层名称

**代码示例**:

.. code-block:: python

R
RaindragonD 已提交
447 448 449 450
    import paddle.fluid as fluid
     
    image = fluid.layers.data(name="X", shape=[2, 5, 5], dtype='float32')
    label = fluid.layers.data(name='label', shape=[1], dtype='int64')
C
Cheerego 已提交
451
    limit = fluid.layers.fill_constant_batch_size_like(
R
RaindragonD 已提交
452
         input=label, dtype='int64', shape=[1], value=5.0)
C
Cheerego 已提交
453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477
    cond = fluid.layers.less_than(x=label, y=limit)
    ie = fluid.layers.IfElse(cond)
    with ie.true_block():
        true_image = ie.input(image)
        hidden = fluid.layers.fc(input=true_image, size=100, act='tanh')
        prob = fluid.layers.fc(input=hidden, size=10, act='softmax')
        ie.output(prob)

    with ie.false_block():
        false_image = ie.input(image)
        hidden = fluid.layers.fc(
            input=false_image, size=200, act='tanh')
        prob = fluid.layers.fc(input=hidden, size=10, act='softmax')
        ie.output(prob)
    prob = ie()









.. _cn_api_fluid_layers_increment:
C
Cheerego 已提交
478

C
Cheerego 已提交
479 480
increment
-------------------------------
C
Cheerego 已提交
481

C
Cheerego 已提交
482 483
.. py:function:: paddle.fluid.layers.increment(x, value=1.0, in_place=True)

C
Cheerego 已提交
484

C
Cheerego 已提交
485 486 487 488 489 490 491 492 493 494 495 496 497 498 499 500 501
该函数为输入 ``x`` 增加 ``value`` 大小, ``value`` 即函数中待传入的参数。该函数默认直接在原变量 ``x`` 上进行运算。

.. note::
    ``x`` 中元素个数必须为1

参数:
    - **x** (Variable|list) – 含有输入值的张量(tensor)
    - **value** (float) – 需要增加在 ``x`` 变量上的值
    - **in_place** (bool) – 判断是否在x变量本身执行操作,True原地执行,False时,返回增加后的副本

返回: 每个元素增加后的对象

返回类型:变量(variable)

**代码示例**

..  code-block:: python
C
Cheerego 已提交
502

R
RaindragonD 已提交
503
    import paddle.fluid as fluid
C
Cheerego 已提交
504 505 506
    data = fluid.layers.data(name='data', shape=[1], dtype='float32',
                         append_batch_size=False)
    data = fluid.layers.increment(x=data, value=3.0, in_place=True)
C
Cheerego 已提交
507 508 509



C
Cheerego 已提交
510 511 512 513 514 515 516 517 518 519 520 521 522








.. _cn_api_fluid_layers_is_empty:

is_empty
-------------------------------

H
Hao Wang 已提交
523
.. py:function:: paddle.fluid.layers.is_empty(x, cond=None)
C
Cheerego 已提交
524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540

测试变量是否为空

参数:
    - **x** (Variable)-测试的变量
    - **cond** (Variable|None)-输出参数。返回给定x的测试结果,默认为空(None)

返回:布尔类型的标量。如果变量x为空则值为真

返回类型:变量(Variable)

抛出异常:``TypeError``-如果input不是变量或cond类型不是变量

**代码示例**:

.. code-block:: python

R
RaindragonD 已提交
541 542
    import paddle.fluid as fluid
    input = fluid.layers.data(name="input", shape=[4, 32, 32], dtype="float32")
C
Cheerego 已提交
543 544
    res = fluid.layers.is_empty(x=input)
    # or:
R
RaindragonD 已提交
545 546 547 548 549 550 551 552 553 554 555 556 557 558 559 560 561 562
    # fluid.layers.is_empty(x=input, cond=res)




.. _cn_api_fluid_layers_less_equal:

less_equal
-------------------------------

.. py:function:: paddle.fluid.layers.less_equal(x, y, cond=None)

该层逐元素地返回 :math:`x <= y` 的逻辑值,和重载算子 `<=` 相同。

参数:
    - **x** (Variable) - *less_equal* 的第一个操作数
    - **y** (Variable) - *less_equal* 的第二个操作数
    - **cond** (Variable|None) - 可选的输出变量,存储 *less_equal* 的结果
C
Cheerego 已提交
563

R
RaindragonD 已提交
564
返回:存储 *less_equal* 的输出的张量变量。
C
Cheerego 已提交
565

R
RaindragonD 已提交
566
返回类型:变量(Variable)
C
Cheerego 已提交
567

R
RaindragonD 已提交
568
**代码示例**:
C
Cheerego 已提交
569

R
RaindragonD 已提交
570
.. code-block:: python
C
Cheerego 已提交
571

R
RaindragonD 已提交
572
     out = fluid.layers.less_equal(x=label, y=limit)
C
Cheerego 已提交
573 574 575 576 577 578 579 580 581




.. _cn_api_fluid_layers_less_than:

less_than
-------------------------------

H
Hao Wang 已提交
582
.. py:function:: paddle.fluid.layers.less_than(x, y, force_cpu=None, cond=None)
C
Cheerego 已提交
583 584 585 586 587 588


该函数按元素出现顺序依次在X,Y上操作,并返回 ``Out`` ,它们三个都是n维tensor(张量)。
其中,X、Y可以是任何类型的tensor,Out张量的各个元素可以通过 :math:`Out=X<Y` 计算得出。


C
Cheerego 已提交
589
参数:
C
Cheerego 已提交
590 591 592 593 594 595
    - **x** (Variable) – ``less_than`` 运算的左操作数
    - **y** (Variable) – ``less_than`` 运算的右操作数
    - **force_cpu** (BOOLEAN) – 值True则强制将输出变量写入CPU内存中。否则,将其写入目前所在的运算设备上。默认为True
    - **cond** (Variable|None) – 可选的用于存储 ``less_than`` 输出结果的变量,为None则由函数自动生成Out变量


R
RaindragonD 已提交
596 597 598 599 600 601 602 603 604 605 606 607 608 609 610 611 612
返回: n维bool型tensor,其中各个元素可以通过 *Out=X<Y* 计算得出

**代码示例**:

.. code-block:: python

    label = fluid.layers.data(name='y', shape=[1], dtype='int64')
    limit = fluid.layers.fill_constant(shape=[1], dtype='int64', value=5)
    cond = fluid.layers.less_than(x=label, y=limit)


.. _cn_api_fluid_layers_not_equal:

not_equal
-------------------------------

.. py:function:: paddle.fluid.layers.not_equal(x, y, cond=None)
C
Cheerego 已提交
613

R
RaindragonD 已提交
614
该层逐元素地返回 :math:`x != y` 的逻辑值,和重载算子 `!=` 相同。
C
Cheerego 已提交
615

R
RaindragonD 已提交
616 617 618 619
参数:
    - **x** (Variable) - *not_equal* 的第一个操作数
    - **y** (Variable) - *not_equal* 的第二个操作数
    - **cond** (Variable|None) - 可选的输出变量,存储 *not_equal* 的结果
C
Cheerego 已提交
620

R
RaindragonD 已提交
621
返回:存储 *not_equal* 的输出的张量变量。
C
Cheerego 已提交
622

R
RaindragonD 已提交
623
返回类型:变量(Variable)
C
Cheerego 已提交
624

R
RaindragonD 已提交
625
**代码示例**:
C
Cheerego 已提交
626

R
RaindragonD 已提交
627
.. code-block:: python
C
Cheerego 已提交
628

R
RaindragonD 已提交
629
     out = fluid.layers.not_equal(x=label, y=limit)
C
Cheerego 已提交
630 631 632 633 634 635 636 637 638 639 640 641 642 643 644 645 646 647 648 649 650 651 652 653 654 655 656 657 658 659






.. _cn_api_fluid_layers_Print:

Print
-------------------------------

.. py:function:: paddle.fluid.layers.Print(input, first_n=-1, message=None, summarize=-1, print_tensor_name=True, print_tensor_type=True, print_tensor_shape=True, print_tensor_lod=True, print_phase='both')

**Print操作命令**

该操作命令创建一个打印操作,打印正在访问的张量。

封装传入的张量,以便无论何时访问张量,都会打印信息message和张量的当前值。

参数:
    - **input** (Variable)-将要打印的张量
    - **summarize** (int)-打印张量中的元素数目,如果值为-1则打印所有元素
    - **message** (str)-字符串类型消息,作为前缀打印
    - **first_n** (int)-只记录first_n次数
    - **print_tensor_name** (bool)-打印张量名称
    - **print_tensor_type** (bool)-打印张量类型
    - **print_tensor_shape** (bool)-打印张量维度
    - **print_tensor_lod** (bool)-打印张量lod
    - **print_phase** (str)-打印的阶段,包括 ``forward`` , ``backward`` 和 ``both`` .若设置为 ``backward`` 或者 ``both`` ,则打印输入张量的梯度。

R
RaindragonD 已提交
660
返回:输出张量
C
Cheerego 已提交
661 662 663

返回类型:变量(Variable)

R
RaindragonD 已提交
664 665 666
.. note::
   输入和输出是两个不同的变量,在接下来的过程中,你应该使用输出变量而非输入变量,否则打印层将失去输出层前的信息。

C
Cheerego 已提交
667 668 669 670
**代码示例**:

.. code-block:: python

R
RaindragonD 已提交
671 672 673 674 675 676 677
    import paddle.fluid as fluid
     
    input = fluid.layers.data(name="input", shape=[4, 32, 32], dtype="float32")
    input = fluid.layers.Print(input, message = "The content of input layer:")
    # value = some_layer(...)
    # Print(value, summarize=10,
    #     message="The content of some_layer: ")
C
Cheerego 已提交
678 679 680 681 682 683 684 685 686 687 688 689 690 691 692 693 694









.. _cn_api_fluid_layers_reorder_lod_tensor_by_rank:

reorder_lod_tensor_by_rank
-------------------------------

.. py:function:: paddle.fluid.layers.reorder_lod_tensor_by_rank(x, rank_table)


R
RaindragonD 已提交
695 696
函数参数 ``X`` 是由多个序列(sequence)组成的的一个数据批(batch)。``rank_table`` 存储着batch中序列的重新排列规则。
该算子(operator)根据 ``rank_table`` 中提供的规则信息来实现对 ``X`` 的重新排列。
C
Cheerego 已提交
697 698 699


::
C
Cheerego 已提交
700

C
Cheerego 已提交
701
  例如:
C
Cheerego 已提交
702

C
Cheerego 已提交
703 704
  假设在 RankTable 中存储的序列索引为 [3,0,2,1], X 将会被这样被重新排列:
  X 中的第四个序列(即索引为3的序列,后面以此类推)会变成排列后的batch中的第一个,紧接着就是原来batch中的第一个元素,第三个元素,和第二个元素。
R
RaindragonD 已提交
705
  
C
Cheerego 已提交
706
  简言之,若有原batch:X = [Seq0, Seq1, Seq2, Seq3] 且 RankTable 中的索引为 [3,0,2,1],那么输出即为 Out = [Seq3, Seq0, Seq2, Seq1] ,它携带着新的LoD信息。
C
Cheerego 已提交
707 708
  如果 X 的LoD信息是空的,这表明 X 不是序列型数据。这和由多个定长为1的序列组成的batch是相同的情况。此时,该函数将对 X 中的切片(slice) 在第一轴(axis)上按 rank_table 里的规则加以排列。
  例如,现有 X = [Slice0, Slice1, Slice2, Slice3] ,并且它LoD信息为空,在 RankTable 索引为[3, 0, 2, 1]。则 Out = [Slice3, Slice0, Slice2, Slice1] ,并且不在其中追加LoD信息。
R
RaindragonD 已提交
709
  注意,该operator对 ``X`` 进行的排序所依据的 ``LoDRankTable`` 不一定是在 ``X`` 的基础上得出来的。它可以由其他不同的序列得出,并由该operator依据这个 ``LoDRankTable`` 来对  ``X`` 排序。
C
Cheerego 已提交
710

C
Cheerego 已提交
711
参数:
R
RaindragonD 已提交
712 713
    - **x(Variable)** - (LoDTensor),待根据提供的 ``RankTable`` 进行排序的LoD tensor
    - **rank_table(Variable)** - 变量
C
Cheerego 已提交
714 715


R
RaindragonD 已提交
716
返回: 重新排列后的LoDTensor
C
Cheerego 已提交
717

R
RaindragonD 已提交
718
返回类型: out(Variable)
C
Cheerego 已提交
719

R
RaindragonD 已提交
720
**代码示例**:
C
Cheerego 已提交
721

R
RaindragonD 已提交
722
.. code-block:: python
C
Cheerego 已提交
723

R
RaindragonD 已提交
724 725 726 727 728 729 730
    import paddle.fluid as fluid
    data_desc = (['input', [9], 0], ['ref', [5], 1])
    data = fluid.layers.data(name=data_desc[0][0], shape=data_desc[0][1])
    rank_data = fluid.layers.data(name=data_desc[1][0], shape=data_desc[1][1])
    table = fluid.layers.control_flow.lod_rank_table(rank_data)
    new_data = fluid.layers.reorder_lod_tensor_by_rank(
                     x=data, rank_table=table)
C
Cheerego 已提交
731 732 733 734 735 736 737 738 739 740 741 742 743 744 745 746 747










.. _cn_api_fluid_layers_StaticRNN:

StaticRNN
-------------------------------

.. py:class:: paddle.fluid.layers.StaticRNN(name=None)

R
RaindragonD 已提交
748 749 750 751 752 753 754 755 756 757 758 759 760 761 762 763 764 765 766 767 768 769 770 771 772 773 774 775 776 777 778 779 780 781 782 783 784 785
StaticRNN可以处理一批序列数据。每个样本序列的长度必须相等。StaticRNN将拥有自己的参数,如输入、输出和存储器等。请注意,输入的第一个维度表示序列长度,且输入的所有序列长度必须相同。并且输入和输出的每个轴的含义是相同的。

**代码示例**:

.. code-block:: python

        import paddle.fluid as fluid
        import paddle.fluid.layers as layers
        
        vocab_size, hidden_size=10000, 200
        x = layers.data(name="x", shape=[-1, 1, 1], dtype='int64')
        x_emb = layers.embedding(
                input=x,
                size=[vocab_size, hidden_size],
                dtype='float32',
                is_sparse=False)
        x_emb = layers.transpose(x_emb, perm=[1, 0, 2])
      
        rnn = fluid.layers.StaticRNN()
        with rnn.step():
           word = rnn.step_input(x_emb)
           prev = rnn.memory(shape=[-1, hidden_size], batch_ref = word)
           hidden = fluid.layers.fc(input=[word, prev], size=hidden_size, act='relu')
           rnn.update_memory(prev, hidden)  # set prev to hidden
           rnn.step_output(hidden)
        
        result = rnn()

StaticRNN将序列展开为时间步长。用户需要定义如何在with步骤中处理每个时间步长。

内存用作在time step之间缓存数据。内存的初始值可以是填充常量值的变量或指定变量。

StaticRNN可以将多个变量标记为其输出。使用rnn()获取输出序列。


.. py:method:: step()

  用户在该代码块中定义RNN中的operators。
C
Cheerego 已提交
786 787 788


.. py:method:: memory(init=None, shape=None, batch_ref=None, init_value=0.0, init_batch_dim_idx=0, ref_batch_dim_idx=1)
R
RaindragonD 已提交
789 790 791
 
  为静态RNN创建一个内存变量。
  如果init不为None,则此变量将初始化内存。 如果init为None,则必须设置shape和batch_ref,并且此函数将初始化init变量。
C
Cheerego 已提交
792

R
RaindragonD 已提交
793 794 795 796 797 798 799 800 801 802 803 804 805 806 807 808 809 810 811 812 813 814 815 816 817 818 819 820 821 822 823 824 825 826 827
  参数:
    - **init** (Variable|None) - 初始化过的变量,如果没有设置,则必须提供shape和batch_ref,默认值None
    - **shape** (list|tuple) - boot memory的形状,注意其不包括batch_size,默认值None
    - **batch_ref** (Variable|None) - batch引用变量,默认值None
    - **init_value** (float) - boot memory的初始化值,默认值0.0
    - **init_batch_dim_idx** (int) - init变量的batch_size轴,默认值0
    - **ref_batch_dim_idx** (int) - batch_ref变量的batch_size轴

  返回:内存变量


  **代码示例**:

  .. code-block:: python

        import paddle.fluid as fluid
        import paddle.fluid.layers as layers

        vocab_size, hidden_size=10000, 200
        x = layers.data(name="x", shape=[-1, 1, 1], dtype='int64')
        x_emb = layers.embedding(
            input=x,
            size=[vocab_size, hidden_size],
            dtype='float32',
            is_sparse=False)
        x_emb = layers.transpose(x_emb, perm=[1, 0, 2])

        rnn = fluid.layers.StaticRNN()
        with rnn.step():
            word = rnn.step_input(x_emb)
            prev = rnn.memory(shape=[-1, hidden_size], batch_ref = word)
            hidden = fluid.layers.fc(input=[word, prev], size=hidden_size, act='relu')
            rnn.update_memory(prev, hidden)

.. py:method:: step_input(x)
C
Cheerego 已提交
828

R
RaindragonD 已提交
829
  标记作为StaticRNN输入的序列。
C
Cheerego 已提交
830

R
RaindragonD 已提交
831 832 833 834 835 836 837 838 839 840 841 842 843 844 845 846 847 848 849 850 851 852 853 854 855 856 857 858 859 860 861 862 863 864 865 866
  参数:
    - **x** (Variable) – 输入序列,x的形状应为[seq_len, ...]。

  返回:输入序列中的当前时间步长。



.. py:method:: step_output(o)

  标记作为StaticRNN输出的序列。

  参数:
    -**o** (Variable) – 输出序列

  返回:None


.. py:method:: output(*outputs)

  标记StaticRNN输出变量。

  参数:
    -**outputs** – 输出变量

  返回:None


.. py:method:: update_memory(mem, var)

  将内存从ex_mem更新为new_mem。请注意,ex_mem和new_mem的形状和数据类型必须相同。

  参数:    
    - **mem** (Variable) – 内存变量
    - **var** (Variable) – RNN块中产生的普通变量

  返回:None
C
Cheerego 已提交
867

C
Cheerego 已提交
868

C
Cheerego 已提交
869 870 871 872 873 874 875 876 877 878 879 880 881








.. _cn_api_fluid_layers_Switch:

Switch
-------------------------------

T
Tink_Y 已提交
882
.. py:class:: paddle.fluid.layers.Switch (name=None)
C
Cheerego 已提交
883 884

Switch类实现的功能十分类似if-elif-else。它可以在学习率调度器(learning rate scheduler)中调整学习率。
C
Cheerego 已提交
885
::
C
Cheerego 已提交
886 887 888 889 890 891 892 893 894
  语义上,
      1. switch控制流挨个检查cases
      2. 各个case的条件是一个布尔值(boolean),它是一个标量(scalar)变量
      3. 它将执行第一个匹配的case后面的分支,如果没有匹配的case,但若存在一个default case,则会执行default case后面的语句
      4. 一旦匹配了一个case,它降会执行这个case所对应的分支,且仅此分支。

**代码示例**

..  code-block:: python
C
Cheerego 已提交
895

R
RaindragonD 已提交
896 897 898
    import paddle.fluid as fluid

    lr = fluid.layers.create_global_var(
C
Cheerego 已提交
899 900 901 902 903
        shape=[1],
        value=0.0,
        dtype='float32',
        persistable=True,
        name="learning_rate")
R
RaindragonD 已提交
904 905 906
    zero_var = fluid.layers.fill_constant(
        shape=[1], dtype='float32', value=0.0)
    one_var = fluid.layers.fill_constant(
C
Cheerego 已提交
907
        shape=[1], dtype='float32', value=1.0)
R
RaindragonD 已提交
908
    two_var = fluid.layers.fill_constant(
C
Cheerego 已提交
909 910
        shape=[1], dtype='float32', value=2.0)

R
RaindragonD 已提交
911 912 913
    global_step = fluid.layers.autoincreased_step_counter(
           counter_name='@LR_DECAY_COUNTER@', begin=0, step=1)

C
Cheerego 已提交
914 915
    with fluid.layers.control_flow.Switch() as switch:
        with switch.case(global_step == zero_var):
R
RaindragonD 已提交
916
            fluid.layers.assign(input=one_var, output=lr)
C
Cheerego 已提交
917
        with switch.default():
R
RaindragonD 已提交
918
            fluid.layers.assign(input=two_var, output=lr)
C
Cheerego 已提交
919 920


C
Cheerego 已提交
921 922 923 924 925 926 927 928 929 930 931 932 933 934 935 936











.. _cn_api_fluid_layers_While:

While
-------------------------------

T
Tink_Y 已提交
937
.. py:class:: paddle.fluid.layers.While (cond, is_test=False, name=None)
C
Cheerego 已提交
938 939 940 941 942


该类用于实现while循环控制功能。


C
Cheerego 已提交
943
参数:
R
RaindragonD 已提交
944 945 946
    - **cond** (Variable) – 用于比较的条件
    - **is_test** (bool) – 用于表明是不是在测试阶段执行
    - **name** (str) - 该层的命名
C
Cheerego 已提交
947

C
Cheerego 已提交
948 949 950 951
**代码示例**

..  code-block:: python

R
RaindragonD 已提交
952 953 954
  import paddle.fluid as fluid
  
  i = fluid.layers.fill_constant(shape=[1], dtype='int64', value=0)
H
Hao Wang 已提交
955 956 957
  d0 = fluid.layers.data("d0", shape=[10], dtype='float32')
  data_array = fluid.layers.array_write(x=d0, i=i)
  array_len = fluid.layers.fill_constant(shape=[1],dtype='int64', value=3)
C
Cheerego 已提交
958

H
Hao Wang 已提交
959 960
  cond = fluid.layers.less_than(x=i, y=array_len)
  while_op = fluid.layers.While(cond=cond)
C
Cheerego 已提交
961
  with while_op.block():
H
Hao Wang 已提交
962
      d = fluid.layers.array_read(array=data_array, i=i)
R
RaindragonD 已提交
963 964 965
      i = fluid.layers.increment(x=i, value=1, in_place=True)
      
      fluid.layers.less_than(x=i, y=array_len, cond=cond)
C
Cheerego 已提交
966 967 968 969 970 971 972 973 974 975 976 977











============
C
Cheerego 已提交
978
 io
C
Cheerego 已提交
979 980 981 982 983 984 985 986 987 988 989 990 991 992 993 994 995 996 997 998 999 1000 1001 1002 1003 1004
============


.. _cn_api_fluid_layers_batch:

batch
-------------------------------

.. py:function:: paddle.fluid.layers.batch(reader, batch_size)

该层是一个reader装饰器。接受一个reader变量并添加``batching``装饰。读取装饰的reader,输出数据自动组织成batch的形式。

参数:
    - **reader** (Variable)-装饰有“batching”的reader变量
    - **batch_size** (int)-批尺寸

返回:装饰有``batching``的reader变量

返回类型:变量(Variable)

**代码示例**:

.. code-block:: python

    raw_reader = fluid.layers.io.open_files(filenames=['./data1.recordio',
                                               './data2.recordio'],
R
RaindragonD 已提交
1005
                                        shapes=[(3,224,224), (1,)],
C
Cheerego 已提交
1006 1007 1008 1009 1010 1011 1012 1013 1014 1015 1016 1017 1018 1019 1020 1021 1022 1023 1024 1025 1026 1027 1028 1029 1030 1031 1032 1033 1034 1035 1036 1037 1038 1039
                                        lod_levels=[0, 0],
                                        dtypes=['float32', 'int64'],
                                        thread_num=2,
                                        buffer_size=2)
    batch_reader = fluid.layers.batch(reader=raw_reader, batch_size=5)

    # 如果用raw_reader读取数据:
    #     data = fluid.layers.read_file(raw_reader)
    # 只能得到数据实例。
    #
    # 但如果用batch_reader读取数据:
    #     data = fluid.layers.read_file(batch_reader)
    # 每5个相邻的实例自动连接成一个batch。因此get('data')得到的是一个batch数据而不是一个实例。









.. _cn_api_fluid_layers_create_py_reader_by_data:

create_py_reader_by_data
-------------------------------

.. py:function:: paddle.fluid.layers.create_py_reader_by_data(capacity,feed_list,name=None,use_double_buffer=True)

创建一个 Python reader用于在python中提供数据,该函数将返回一个 ``reader`` 变量。

它的工作方式与 ``py_reader`` 非常相似,除了它的输入是一个 feed_list 而不是 ``shapes``、 ``dtypes`` 和 ``lod_level``

参数:
R
RaindragonD 已提交
1040 1041 1042 1043
  - **capacity** (int) - 缓冲区容量由 :code:`py_reader` 维护
  - **feed_list** (list(Variable)) - 传输数据列表
  - **name** (basestring) - 前缀Python队列名称和 reader 名称。不定义时将自动生成名称。
  - **use_double_buffer** (bool) - 是否使用 double buffer
C
Cheerego 已提交
1044 1045 1046 1047 1048 1049

返回: Variable: 一种reader,我们可以从中获得输入数据。

**代码示例:**

 :code:`py_reader` 的基本用法如下所示:
C
Cheerego 已提交
1050

C
Cheerego 已提交
1051
.. code-block:: python
R
RaindragonD 已提交
1052 1053
    
    import paddle
C
Cheerego 已提交
1054 1055
    import paddle.fluid as fluid
    import paddle.dataset.mnist as mnist
C
Cheerego 已提交
1056

R
RaindragonD 已提交
1057 1058 1059 1060 1061 1062 1063
    def network(img, label):
        # 用户自定义网络。此处以一个简单的线性回归作为示例。
        predict = fluid.layers.fc(input=img, size=10, act='softmax')
        loss = fluid.layers.cross_entropy(input=predict, label=label)
        return fluid.layers.mean(loss)
    
    image = fluid.layers.data(name='image', shape=[1, 28, 28], dtypes='float32')
C
Cheerego 已提交
1064
    label = fluid.layers.data(name='label', shape=[1], dtypes='int64')
R
RaindragonD 已提交
1065 1066
    reader = fluid.layers.create_py_reader_by_data(capacity=64,
                                                   feed_list=[image, label])
C
Cheerego 已提交
1067
    reader.decorate_paddle_reader(
R
RaindragonD 已提交
1068
        paddle.reader.shuffle(paddle.batch(mnist.train(), batch_size=5), buf_size=500))
C
Cheerego 已提交
1069
    img, label = fluid.layers.read_file(reader)
R
RaindragonD 已提交
1070
    loss = network(img, label) # 一些网络定义
C
Cheerego 已提交
1071 1072

    fluid.Executor(fluid.CUDAPlace(0)).run(fluid.default_startup_program())
C
Cheerego 已提交
1073

C
Cheerego 已提交
1074 1075 1076 1077 1078 1079 1080 1081 1082 1083 1084 1085 1086 1087 1088 1089 1090 1091 1092 1093 1094 1095 1096 1097 1098 1099 1100 1101 1102 1103 1104 1105
    exe = fluid.ParallelExecutor(use_cuda=True, loss_name=loss.name)
    for epoch_id in range(10):
        reader.start()
        try:
            while True:
                exe.run(fetch_list=[loss.name])
        except fluid.core.EOFException:
            reader.reset()











.. _cn_api_fluid_layers_data:

data
-------------------------------

.. py:function:: paddle.fluid.layers.data(name, shape, append_batch_size=True, dtype='float32', lod_level=0, type=VarType.LOD_TENSOR, stop_gradient=True)

数据层(Data Layer)

该功能接受输入数据,判断是否需要以minibatch方式返回数据,然后使用辅助函数创建全局变量。该全局变量可由计算图中的所有operator访问。

这个函数的所有输入变量都作为本地变量传递给LayerHelper构造函数。

R
RaindragonD 已提交
1106 1107
请注意,paddle在编译期间仅使用shape来推断网络中以下变量的形状。在运行期间,paddle不会检查所需数据的形状是否与此函数中的形状设置相匹配。

C
Cheerego 已提交
1108 1109
参数:
    - **name** (str)-函数名或函数别名
H
Hao Wang 已提交
1110
    - **shape** (list)-声明维度信息的list。如果 ``append_batch_size`` 为True且内部没有维度值为-1,则应将其视为每个样本的形状。 否则,应将其视为batch数据的形状。
C
Cheerego 已提交
1111 1112
    - **append_batch_size** (bool)-

R
RaindragonD 已提交
1113 1114
        1.如果为真,则在维度shape的开头插入-1。
        例如,如果shape=[1],则输出shape为[-1,1]。这对在运行期间设置不同的batch大小很有用。
C
Cheerego 已提交
1115

R
RaindragonD 已提交
1116 1117
        2.如果维度shape包含-1,比如shape=[-1,1]。
        append_batch_size会强制变为为False(表示无效),因为PaddlePaddle不能在shape上设置一个以上的未知数。
C
Cheerego 已提交
1118

R
RaindragonD 已提交
1119
    - **dtype** (np.dtype|VarType|str)-数据类型:float32,float_16,int等
C
Cheerego 已提交
1120 1121 1122 1123 1124 1125 1126 1127 1128 1129 1130 1131 1132 1133 1134 1135 1136 1137 1138 1139 1140 1141 1142 1143 1144 1145 1146 1147 1148 1149 1150 1151 1152 1153 1154 1155 1156 1157 1158 1159 1160 1161 1162 1163 1164 1165
    - **type** (VarType)-输出类型。默认为LOD_TENSOR
    - **lod_level** (int)-LoD层。0表示输入数据不是一个序列
    - **stop_gradient** (bool)-布尔类型,提示是否应该停止计算梯度

返回:全局变量,可进行数据访问

返回类型:变量(Variable)

**代码示例**:

.. code-block:: python

    data = fluid.layers.data(name='x', shape=[784], dtype='float32')










.. _cn_api_fluid_layers_double_buffer:

double_buffer
-------------------------------

.. py:function:: paddle.fluid.layers.double_buffer(reader, place=None, name=None)


生成一个双缓冲队列reader. 数据将复制到具有双缓冲队列的位置(由place指定),如果 ``place=none`` 则将使用executor执行的位置。

参数:
  - **reader** (Variable) – 需要wrap的reader
  - **place** (Place) – 目标数据的位置. 默认是executor执行样本的位置.
  - **name** (str) – Variable 的名字. 默认为None,不关心名称时也可以设置为None


返回: 双缓冲队列的reader


**代码示例**

..  code-block:: python

R
RaindragonD 已提交
1166 1167 1168 1169 1170 1171
  import paddle.fluid as fluid
  reader = fluid.layers.open_files(filenames=['mnist.recordio'],
           shapes=[[-1, 784], [-1, 1]],
           dtypes=['float32', 'int64'])
  reader = fluid.layers.double_buffer(reader)
  img, label = fluid.layers.read_file(reader)
C
Cheerego 已提交
1172 1173 1174 1175 1176 1177 1178 1179 1180 1181 1182 1183 1184 1185 1186 1187 1188 1189 1190 1191 1192 1193 1194 1195 1196 1197 1198 1199 1200 1201 1202 1203 1204 1205 1206 1207 1208 1209 1210 1211 1212 1213 1214 1215 1216 1217 1218 1219 1220 1221 1222 1223 1224 1225 1226 1227 1228 1229 1230 1231 1232 1233 1234 1235 1236 1237 1238 1239 1240 1241 1242












.. _cn_api_fluid_layers_load:

load
-------------------------------

.. py:function:: paddle.fluid.layers.load(out, file_path, load_as_fp16=None)

Load操作命令将从磁盘文件中加载LoDTensor/SelectedRows变量。

.. code-block:: python

    import paddle.fluid as fluid
    tmp_tensor = fluid.layers.create_tensor(dtype='float32')
    fluid.layers.load(tmp_tensor, "./tmp_tensor.bin")

参数:
    - **out** (Variable)-需要加载的LoDTensor或SelectedRows
    - **file_path** (STRING)-预从“file_path”中加载的变量Variable
    - **load_as_fp16** (BOOLEAN)-如果为真,张量首先进行加载然后类型转换成float16。如果为假,张量将直接加载,不需要进行数据类型转换。默认为false。

返回:None









.. _cn_api_fluid_layers_open_files:

open_files
-------------------------------

.. py:function:: paddle.fluid.layers.open_files(filenames, shapes, lod_levels, dtypes, thread_num=None, buffer_size=None, pass_num=1, is_test=None)

打开文件(Open files)

该函数获取需要读取的文件列表,并返回Reader变量。通过Reader变量,我们可以从给定的文件中获取数据。所有文件必须有名称后缀来表示它们的格式,例如,``*.recordio``。

参数:
    - **filenames** (list)-文件名列表
    - **shape** (list)-元组类型值列表,声明数据维度
    - **lod_levels** (list)-整形值列表,声明数据的lod层级
    - **dtypes** (list)-字符串类型值列表,声明数据类型
    - **thread_num** (None)-用于读文件的线程数。默认:min(len(filenames),cpu_number)
    - **buffer_size** (None)-reader的缓冲区大小。默认:3*thread_num
    - **pass_num** (int)-用于运行的传递数量
    - **is_test** (bool|None)-open_files是否用于测试。如果用于测试,生成的数据顺序和文件顺序一致。反之,无法保证每一epoch之间的数据顺序是一致的

返回:一个Reader变量,通过该变量获取文件数据

返回类型:变量(Variable)

**代码示例**:

.. code-block:: python

R
RaindragonD 已提交
1243
    import paddle.fluid as fluid
C
Cheerego 已提交
1244 1245
    reader = fluid.layers.io.open_files(filenames=['./data1.recordio',
                                            './data2.recordio'],
R
RaindragonD 已提交
1246
                                    shapes=[(3,224,224), (1,)],
C
Cheerego 已提交
1247 1248 1249 1250 1251 1252 1253 1254 1255 1256 1257 1258 1259 1260 1261 1262 1263 1264 1265 1266 1267 1268 1269 1270 1271 1272 1273 1274 1275 1276 1277
                                    lod_levels=[0, 0],
                                    dtypes=['float32', 'int64'])

    # 通过reader, 可使用''read_file''层获取数据:
    image, label = fluid.layers.io.read_file(reader)









.. _cn_api_fluid_layers_Preprocessor:

Preprocessor
-------------------------------

.. py:class:: class paddle.fluid.layers.Preprocessor(reader, name=None)

reader变量中数据预处理块。

参数:
    - **reader** (Variable)-reader变量
    - **name** (str,默认None)-reader的名称

**代码示例**:

.. code-block:: python

R
RaindragonD 已提交
1278 1279 1280 1281 1282 1283
    reader = fluid.layers.io.open_files(
        filenames=['./data1.recordio', './data2.recordio'],
        shapes=[(3, 224, 224), (1, )],
        lod_levels=[0, 0],
        dtypes=['float32', 'int64'])

C
Cheerego 已提交
1284 1285 1286 1287 1288 1289 1290 1291 1292 1293 1294 1295 1296 1297 1298 1299 1300 1301 1302 1303 1304 1305 1306 1307 1308 1309
    preprocessor = fluid.layers.io.Preprocessor(reader=reader)
    with preprocessor.block():
        img, lbl = preprocessor.inputs()
        img_out = img / 2
        lbl_out = lbl + 1
        preprocessor.outputs(img_out, lbl_out)
    data_file = fluid.layers.io.double_buffer(preprocessor())









.. _cn_api_fluid_layers_py_reader:

py_reader
-------------------------------

.. py:function:: paddle.fluid.layers.py_reader(capacity, shapes, dtypes, lod_levels=None, name=None, use_double_buffer=True)


创建一个由在Python端提供数据的reader

R
RaindragonD 已提交
1310
该layer返回一个Reader Variable。reader提供了 ``decorate_paddle_reader()`` 和 ``decorate_tensor_provider()`` 来设置Python generator作为数据源。更多细节请参考异步数据读取:ref:`user_guide_use_py_reader`,在c++端调用 ``Executor::Run()`` 时,来自generator的数据将被自动读取。与 ``DataFeeder.feed()`` 不同,数据读取进程和  ``Executor::Run()`` 进程可以使用 ``py_reader`` 并行运行。reader的 ``start()`` 方法应该在每次数据传递开始时调用,在传递结束和抛出  ``fluid.core.EOFException`` 后执行 ``reset()`` 方法。注意, ``Program.clone()`` 方法不能克隆 ``py_reader`` 。
C
Cheerego 已提交
1311

C
Cheerego 已提交
1312
参数:
C
Cheerego 已提交
1313
  - **capacity** (int) –  ``py_reader`` 维护的缓冲区容量
R
RaindragonD 已提交
1314
  - **shapes** (list|tuple) –数据形状的元组或列表
C
Cheerego 已提交
1315 1316 1317 1318 1319 1320 1321
  - **dtypes** (list|tuple) –  ``shapes`` 对应元素的数据类型
  - **lod_levels** (list|tuple) – lod_level的整型列表或元组
  - **name** (basestring) – python 队列的前缀名称和Reader 名称。不会自动生成。
  - **use_double_buffer** (bool) – 是否使用双缓冲

返回:    reader,从reader中可以获取feed的数据

R
RaindragonD 已提交
1322
返回类型: Variable
C
Cheerego 已提交
1323

C
Cheerego 已提交
1324 1325 1326 1327


**代码示例**

R
RaindragonD 已提交
1328
1.py_reader 基本用法如下
C
Cheerego 已提交
1329 1330 1331

..  code-block:: python

R
RaindragonD 已提交
1332 1333 1334
  import paddle
  import paddle.fluid as fluid
  import paddle.dataset.mnist as mnist
C
Cheerego 已提交
1335

R
RaindragonD 已提交
1336 1337 1338 1339 1340 1341 1342 1343 1344 1345
  def network(image, label):
    # 用户自定义网络,此处以softmax回归为例
    predict = fluid.layers.fc(input=image, size=10, act='softmax')
  return fluid.layers.cross_entropy(input=predict, label=label)
         
  reader = fluid.layers.py_reader(capacity=64,
          shapes=[(-1,1, 28, 28), (-1,1)],
          dtypes=['float32', 'int64'])
  reader.decorate_paddle_reader(
      paddle.reader.shuffle(paddle.batch(mnist.train(), batch_size=5),buf_size=1000))
C
Cheerego 已提交
1346

R
RaindragonD 已提交
1347 1348
  img, label = fluid.layers.read_file(reader)
  loss = network(img, label) # 一些网络定义
C
Cheerego 已提交
1349

R
RaindragonD 已提交
1350
  fluid.Executor(fluid.CUDAPlace(0)).run(fluid.default_startup_program())
C
Cheerego 已提交
1351

R
RaindragonD 已提交
1352 1353 1354 1355 1356 1357 1358 1359
  exe = fluid.ParallelExecutor(use_cuda=True, loss_name=loss.name)
  for epoch_id in range(10):
      reader.start()
      try:
    while True:
        exe.run(fetch_list=[loss.name])
      except fluid.core.EOFException:
    reader.reset()
C
Cheerego 已提交
1360

R
RaindragonD 已提交
1361
    fluid.io.save_inference_model(dirname='./model', feeded_var_names=[img.name, label.name],target_vars=[loss], executor=fluid.Executor(fluid.CUDAPlace(0)))
C
Cheerego 已提交
1362 1363 1364 1365 1366 1367


2.训练和测试应使用不同的名称创建两个不同的py_reader,例如:

..  code-block:: python

R
RaindragonD 已提交
1368 1369 1370
  import paddle
  import paddle.fluid as fluid
  import paddle.dataset.mnist as mnist
C
Cheerego 已提交
1371

R
RaindragonD 已提交
1372 1373 1374 1375
  def network(reader):
    img, label = fluid.layers.read_file(reader)
    # 用户自定义网络,此处以softmax回归为例
    predict = fluid.layers.fc(input=img, size=10, act='softmax')
C
Cheerego 已提交
1376

R
RaindragonD 已提交
1377 1378 1379
    loss = fluid.layers.cross_entropy(input=predict, label=label)
        
    return fluid.layers.mean(loss)
C
Cheerego 已提交
1380

R
RaindragonD 已提交
1381 1382 1383 1384 1385 1386 1387 1388 1389 1390 1391 1392
  # 新建 train_main_prog 和 train_startup_prog
  train_main_prog = fluid.Program()
  train_startup_prog = fluid.Program()
  with fluid.program_guard(train_main_prog, train_startup_prog):
    # 使用 fluid.unique_name.guard() 实现与test program的参数共享
    with fluid.unique_name.guard():
      train_reader = fluid.layers.py_reader(capacity=64, shapes=[(-1, 1, 28, 28), (-1, 1)], dtypes=['float32', 'int64'], name='train_reader')
      train_reader.decorate_paddle_reader(
        paddle.reader.shuffle(paddle.batch(mnist.train(), batch_size=5), buf_size=500))
    train_loss = network(train_reader) # 一些网络定义
    adam = fluid.optimizer.Adam(learning_rate=0.01)
    adam.minimize(train_loss)
C
Cheerego 已提交
1393

R
RaindragonD 已提交
1394 1395 1396 1397 1398 1399 1400 1401 1402 1403
  # Create test_main_prog and test_startup_prog
  test_main_prog = fluid.Program()
  test_startup_prog = fluid.Program()
  with fluid.program_guard(test_main_prog, test_startup_prog):
    # 使用 fluid.unique_name.guard() 实现与train program的参数共享
    with fluid.unique_name.guard():
      test_reader = fluid.layers.py_reader(capacity=32, shapes=[(-1, 1, 28, 28), (-1, 1)], dtypes=['float32', 'int64'], name='test_reader')
                test_reader.decorate_paddle_reader(paddle.batch(mnist.test(), 512))
    
      test_loss = network(test_reader)
C
Cheerego 已提交
1404

R
RaindragonD 已提交
1405 1406
  fluid.Executor(fluid.CUDAPlace(0)).run(train_startup_prog)
  fluid.Executor(fluid.CUDAPlace(0)).run(test_startup_prog)
C
Cheerego 已提交
1407

R
RaindragonD 已提交
1408 1409 1410 1411 1412 1413 1414 1415 1416 1417 1418
  train_exe = fluid.ParallelExecutor(use_cuda=True,
      loss_name=train_loss.name, main_program=train_main_prog)
  test_exe = fluid.ParallelExecutor(use_cuda=True,
      loss_name=test_loss.name, main_program=test_main_prog)
  for epoch_id in range(10):
      train_reader.start()
      try:
    while True:
        train_exe.run(fetch_list=[train_loss.name])
      except fluid.core.EOFException:
    train_reader.reset()
C
Cheerego 已提交
1419

R
RaindragonD 已提交
1420 1421 1422 1423 1424 1425
      test_reader.start()
      try:
    while True:
        test_exe.run(fetch_list=[test_loss.name])
      except fluid.core.EOFException:
    test_reader.reset()
C
Cheerego 已提交
1426 1427 1428 1429 1430 1431 1432 1433 1434 1435 1436 1437 1438 1439 1440 1441 1442 1443 1444 1445 1446 1447 1448 1449 1450 1451 1452 1453 1454 1455 1456 1457 1458 1459 1460 1461 1462 1463 1464 1465 1466 1467 1468 1469 1470 1471 1472 1473 1474 1475 1476 1477 1478 1479 1480 1481 1482 1483 1484 1485 1486 1487 1488 1489 1490 1491 1492 1493 1494 1495












.. _cn_api_fluid_layers_random_data_generator:

random_data_generator
-------------------------------

.. py:function:: paddle.fluid.layers.random_data_generator(low, high, shapes, lod_levels, for_parallel=True)

创建一个均匀分布随机数据生成器.

该层返回一个Reader变量。该Reader变量不是用于打开文件读取数据,而是自生成float类型的均匀分布随机数。该变量可作为一个虚拟reader来测试网络,而不需要打开一个真实的文件。

参数:
    - **low** (float)--数据均匀分布的下界
    - **high** (float)-数据均匀分布的上界
    - **shapes** (list)-元组数列表,声明数据维度
    - **lod_levels** (list)-整形数列表,声明数据
    - **for_parallel** (Bool)-若要运行一系列操作命令则将其设置为True

返回:Reader变量,可从中获取随机数据

返回类型:变量(Variable)

**代码示例**:

.. code-block:: python

    reader = fluid.layers.random_data_generator(
                                 low=0.0,
                                 high=1.0,
                                 shapes=[[3,224,224], [1]],
                                 lod_levels=[0, 0])
    # 通过reader, 可以用'read_file'层获取数据:
    image, label = fluid.layers.read_file(reader)









.. _cn_api_fluid_layers_read_file:

read_file
-------------------------------

.. py:function:: paddle.fluid.layers.read_file(reader)

执行给定的reader变量并从中获取数据

reader也是变量。可以为由fluid.layers.open_files()生成的原始reader或者由fluid.layers.double_buffer()生成的装饰变量,等等。

参数:
    - **reader** (Variable)-将要执行的reader

返回:从给定的reader中读取数据

H
Hao Wang 已提交
1496 1497
返回类型: tuple(元组)

C
Cheerego 已提交
1498 1499 1500 1501
**代码示例**:

.. code-block:: python

R
RaindragonD 已提交
1502
    import paddle.fluid as fluid
C
Cheerego 已提交
1503 1504 1505 1506 1507 1508 1509 1510 1511 1512 1513 1514 1515 1516 1517 1518 1519 1520 1521 1522 1523 1524 1525 1526 1527 1528 1529 1530
    data_file = fluid.layers.open_files(
        filenames=['mnist.recordio'],
        shapes=[(-1, 748), (-1, 1)],
        lod_levels=[0, 0],
        dtypes=["float32", "int64"])
    data_file = fluid.layers.double_buffer(
        fluid.layers.batch(data_file, batch_size=64))
    input, label = fluid.layers.read_file(data_file)









.. _cn_api_fluid_layers_shuffle:

shuffle
-------------------------------

.. py:function:: paddle.fluid.layers.shuffle(reader, buffer_size)

创建一个特殊的数据读取器,它的输出数据会被重洗(shuffle)。由原始读取器创建的迭代器得到的输出将会被暂存到shuffle缓存区,其后
会对其进行重洗运算。shuffle缓存区的大小由参数 ``buffer_size`` 决定。

参数:
H
Hao Wang 已提交
1531 1532
    - **reader** (callable) – 输出会被shuffle的原始reader
    - **buffer_size** (int) – 进行shuffle的buffer的大小
C
Cheerego 已提交
1533

H
Hao Wang 已提交
1534
返回:其输出会被shuffle的一个reader(读取器)
C
Cheerego 已提交
1535 1536 1537

返回类型:Variable

R
RaindragonD 已提交
1538
**代码示例**:
C
Cheerego 已提交
1539

R
RaindragonD 已提交
1540
.. code-block:: python
C
Cheerego 已提交
1541

R
RaindragonD 已提交
1542 1543 1544 1545 1546 1547 1548 1549 1550
    raw_reader = fluid.layers.io.open_files(filenames=['./data1.recordio',
                                                   './data2.recordio'],
                                            shapes=[(3,224,224), (1,)],
                                            lod_levels=[0, 0],
                                            dtypes=['float32', 'int64'],
                                            thread_num=2,
                                            buffer_size=2)
    batch_reader = fluid.layers.batch(reader=raw_reader, batch_size=5)
    shuffle_reader = fluid.layers.shuffle(reader=batch_reader, buffer_size=5000)
C
Cheerego 已提交
1551 1552 1553 1554 1555 1556 1557 1558 1559








============
C
Cheerego 已提交
1560
 nn
C
Cheerego 已提交
1561 1562
============

H
Hao Wang 已提交
1563 1564 1565 1566 1567 1568 1569 1570 1571 1572 1573 1574 1575 1576 1577 1578 1579 1580 1581 1582 1583 1584 1585 1586 1587 1588 1589 1590 1591 1592 1593 1594 1595 1596 1597 1598 1599 1600 1601 1602 1603 1604 1605 1606 1607 1608
.. _cn_api_fluid_layers_adaptive_pool2d:

adaptive_pool2d
-------------------------------

.. py:function:: paddle.fluid.layers.adaptive_pool2d(input, pool_size, pool_type='max', require_index=False, name=None)

pooling2d操作根据输入 ``input`` , ``pool_size`` , ``pool_type`` 参数计算输出。 输入(X)和输出(Out)采用NCHW格式,其中N是批大小batch size,C是通道数,H是feature(特征)的高度,W是feature(特征)的宽度。 参数 ``pool_size`` 由两个元素构成, 这两个元素分别代表高度和宽度。 输出(Out)的H和W维与 ``pool_size`` 大小相同。


对于平均adaptive pool2d:

..  math::

       hstart &= floor(i * H_{in} / H_{out})

       hend &= ceil((i + 1) * H_{in} / H_{out})

       wstart &= floor(j * W_{in} / W_{out})

       wend &= ceil((j + 1) * W_{in} / W_{out})

       Output(i ,j) &= \frac{sum(Input[hstart:hend, wstart:wend])}{(hend - hstart) * (wend - wstart)}

参数:
  - **input** (Variable) - 池化操作的输入张量。 输入张量的格式为NCHW,其中N是batch大小,C是通道数,H是特征的高度,W是特征的宽度。
  - **pool_size** (int | list | tuple) - 池化核大小。 如果池化核大小是元组或列表,则它必须包含两个整数(pool_size_Height,pool_size_Width)。
  - **pool_type** (string)- 池化类型,可输入“max”代表max-pooling,或者“avg”代表average-pooling。
  - **require_index** (bool) - 如果为true,则输出中带有最大池化点所在的索引。 如果pool_type为avg,该项不可被设置为true。
  - **name** (str | None) - 此层的名称(可选)。 如果设置为None,则将自动命名该层。


返回: 池化结果

返回类型: Variable


抛出异常:

  - ``ValueError`` – ``pool_type`` 不是 ‘max’ 或 ‘avg’
  - ``ValueError`` – 当 ``pool_type`` 是 ‘avg’ 时,错误地设置 ‘require_index’ 为true .
  - ``ValueError`` – ``pool_size`` 应为一个长度为2的列表或元组

.. code-block:: python

    # 假设输入形为[N, C, H, W], `pool_size` 为 [m, n],
H
Hao Wang 已提交
1609
    # 输出形为 [N, C, m, n], adaptive pool 将输入的 H 和 W 维度
H
Hao Wang 已提交
1610 1611 1612 1613 1614 1615 1616 1617 1618 1619 1620 1621 1622 1623 1624 1625 1626 1627 1628 1629 1630 1631 1632 1633 1634 1635 1636 1637 1638 1639 1640 1641 1642 1643 1644 1645 1646 1647 1648 1649 1650 1651 1652 1653 1654 1655 1656 1657 1658 1659 1660 1661 1662 1663 1664 1665 1666 1667 1668 1669 1670 1671 1672 1673 1674 1675 1676 1677 1678 1679 1680 1681 1682
    # 平均分割为 m * n 个栅格(grid) ,然后为每个栅格进行池化得到输出
    # adaptive average pool 进行如下操作
    #
    #     for i in range(m):
    #         for j in range(n):
    #             hstart = floor(i * H / m)
    #             hend = ceil((i + 1) * H / m)
    #             wstart = floor(i * W / n)
    #             wend = ceil((i + 1) * W / n)
    #             output[:, :, i, j] = avg(input[:, :, hstart: hend, wstart: wend])
    #
    data = fluid.layers.data(
        name='data', shape=[3, 32, 32], dtype='float32')
    pool_out = fluid.layers.adaptive_pool2d(
                      input=data,
                      pool_size=[3, 3],
                      pool_type='avg')




.. _cn_api_fluid_layers_adaptive_pool3d:

adaptive_pool3d
-------------------------------

.. py:function:: paddle.fluid.layers.adaptive_pool3d(input, pool_size, pool_type='max', require_index=False, name=None)

pooling3d操作根据输入 ``input`` ,``pool_size`` , ``pool_type`` 参数计算输出。 输入(X)和输出(输出)采用NCDHW格式,其中N是批大小batch size,C是通道数,D是特征(feature)的深度,H是特征的高度,W是特征的宽度。 参数 ``pool_size`` 由三个元素组成。 这三个元素分别代表深度,高度和宽度。输出(Out)的D,H,W维与 ``pool_size`` 相同。


对于平均adaptive pool3d:

..  math::

      dstart &= floor(i * D_{in} / D_{out})

      dend &= ceil((i + 1) * D_{in} / D_{out})

      hstart &= floor(j * H_{in} / H_{out})

      hend &= ceil((j + 1) * H_{in} / H_{out})

      wstart &= floor(k * W_{in} / W_{out})

      wend &= ceil((k + 1) * W_{in} / W_{out})

      Output(i ,j, k) &= \frac{sum(Input[dstart:dend, hstart:hend, wstart:wend])}{(dend - dstart) * (hend - hstart) * (wend - wstart)}



参数:
  - **input** (Variable) - 池化操作的输入张量。 输入张量的格式为NCDHW,其中N是batch大小,C是通道数,D为特征的深度,H是特征的高度,W是特征的宽度。
  - **pool_size** (int | list | tuple) - 池化核大小。 如果池化核大小是元组或列表,则它必须包含三个整数(Depth, Height, Width)。
  - **pool_type** (string)- 池化类型,可输入“max”代表max-pooling,或者“avg”代表average-pooling。
  - **require_index** (bool) - 如果为true,则输出中带有最大池化点所在的索引。 如果pool_type为avg,该项不可被设置为true。
  - **name** (str | None) - 此层的名称(可选)。 如果设置为None,则将自动命名该层。


返回: 池化结果

返回类型: Variable


抛出异常:

  - ``ValueError`` – ``pool_type`` 不是 ‘max’ 或 ‘avg’
  - ``ValueError`` – 当 ``pool_type`` 是 ‘avg’ 时,错误地设置 ‘require_index’ 为true .
  - ``ValueError`` – ``pool_size`` 应为一个长度为3的列表或元组

.. code-block:: python

    # 假设输入形为[N, C, D, H, W], `pool_size` 为 [l, m, n],
H
Hao Wang 已提交
1683
    # 输出形为 [N, C, l, m, n], adaptive pool 将输入的D, H 和 W 维度
H
Hao Wang 已提交
1684 1685 1686 1687 1688 1689 1690 1691 1692 1693 1694 1695 1696 1697 1698
    # 平均分割为 l * m * n 个栅格(grid) ,然后为每个栅格进行池化得到输出
    # adaptive average pool 进行如下操作
    #
    #     for i in range(l):
    #         for j in range(m):
    #             for k in range(n):
    #                 dstart = floor(i * D / l)
    #                 dend = ceil((i + 1) * D / l)
    #                 hstart = floor(j * H / m)
    #                 hend = ceil((j + 1) * H / m)
    #                 wstart = floor(k * W / n)
    #                 wend = ceil((k + 1) * W / n)
    #                 output[:, :, i, j, k] =
    #                     avg(input[:, :, dstart:dend, hstart: hend, wstart: wend])
    #
R
RaindragonD 已提交
1699 1700 1701
    
    import paddle.fluid as fluid

H
Hao Wang 已提交
1702
    data = fluid.layers.data(
R
RaindragonD 已提交
1703
    name='data', shape=[3, 32, 32, 32], dtype='float32')
H
Hao Wang 已提交
1704 1705 1706 1707 1708 1709 1710
    pool_out, mask = fluid.layers.adaptive_pool3d(
                      input=data,
                      pool_size=[3, 3, 3],
                      pool_type='avg')



C
Cheerego 已提交
1711 1712 1713 1714 1715 1716 1717 1718 1719 1720 1721 1722

.. _cn_api_fluid_layers_add_position_encoding:

add_position_encoding
-------------------------------

.. py:function:: paddle.fluid.layers.add_position_encoding(input, alpha, beta, name=None)

**添加位置编码层**

接受形状为[N×M×P]的三维输入张量,并返回一个形为[N×M×P]的输出张量,且输出张量具有位置编码值。

C
Cheerego 已提交
1723
可参考论文: `Attention Is All You Need <http://arxiv.org/pdf/1706.03762.pdf>`_
C
Cheerego 已提交
1724 1725 1726 1727 1728 1729

.. math::

  PE(pos, 2i) &= \sin{(pos / 10000^{2i / P})}\\
  PE(pos, 2i + 1) &= \cos{(pos / 10000^{2i / P})}\\
  Out(:, pos, i) &= \alpha * input(:, pos, i) + \beta * PE(pos, i)
C
Cheerego 已提交
1730

C
Cheerego 已提交
1731 1732 1733 1734
其中:
    - PE(pos, 2i): 偶数位置上数字的增量
    - PE(pos, 2i + 1): 奇数位置上数字的增量

H
Hao Wang 已提交
1735 1736 1737 1738 1739 1740 1741 1742 1743 1744
参数:
    - **input**  (Variable) – 形状为[N x M x P]的三维输入张量
    - **alpha**  (float) – 输入张量的倍数
    - **beta**  (float) – 位置编码张量Positional Encoding Tensor的倍数
    - **name**  (string) – 位置编码层的名称


返回:  具有位置编码的三维形状张量[N×M×P]

返回类型: Variable
C
Cheerego 已提交
1745 1746 1747 1748 1749

**代码示例:**

.. code-block:: python

R
RaindragonD 已提交
1750 1751 1752 1753 1754 1755 1756 1757 1758
  import paddle.fluid as fluid
     
  tensor = fluid.layers.data(
        name='tensor',
        shape=[32, 64, 512],
        dtype='float32',
        append_batch_size=False)
  position_tensor = fluid.layers.add_position_encoding(
        input=tensor, alpha=1.0, beta=1.0)
C
Cheerego 已提交
1759 1760 1761 1762 1763 1764 1765 1766 1767 1768 1769 1770 1771 1772 1773 1774











.. _cn_api_fluid_layers_affine_channel:

affine_channel
-------------------------------

Z
zy0531 已提交
1775
.. py:function:: paddle.fluid.layers.affine_channel(x, scale=None, bias=None, data_layout='NCHW', name=None,act=None)
C
Cheerego 已提交
1776 1777 1778 1779 1780 1781

对输入的每个 channel 应用单独的仿射变换。用于将空间批处理范数替换为其等价的固定变换。

输入也可以是二维张量,并在二维应用仿射变换。

参数:
R
RaindragonD 已提交
1782 1783 1784 1785 1786 1787
  - **x** (Variable):特征图输入可以是一个具有NCHW阶或NHWC阶的4D张量。它也可以是二维张量和应用于第二维度的仿射变换。
  - **scale** (Variable): 形状为(C)的一维输入,第C个元素为输入的第C通道仿射变换的尺度因子。
  - **bias** (Variable):形状为(C)的一维输入,第C个元素是输入的第C个通道的仿射变换的偏置。
  - **data_layout** (string, default NCHW): NCHW 或 NHWC,如果输入是一个2D张量,可以忽略该参数
  - **name** (str, default None): 此层的名称
  - **act** (str, default None): 应用于该层输出的激活函数
C
Cheerego 已提交
1788 1789 1790

返回: out (Variable): 与x具有相同形状和数据布局的张量。

R
RaindragonD 已提交
1791
**代码示例:**
C
Cheerego 已提交
1792

R
RaindragonD 已提交
1793
.. code-block:: python
C
Cheerego 已提交
1794

R
RaindragonD 已提交
1795 1796 1797 1798 1799 1800 1801 1802 1803
    import paddle.fluid as fluid
    data = fluid.layers.data(name='data', shape=[3, 32, 32],
                             dtype='float32')
    input_scale = fluid.layers.create_parameter(shape=[3],
                             dtype="float32")
    input_bias = fluid.layers.create_parameter(shape=[3],
                             dtype="float32")
    out = fluid.layers.affine_channel(data,scale=input_scale,
                             bias=input_bias)
C
Cheerego 已提交
1804 1805 1806 1807 1808 1809 1810 1811 1812 1813 1814 1815 1816 1817 1818 1819 1820





.. _cn_api_fluid_layers_affine_grid:

affine_grid
-------------------------------

.. py:function:: paddle.fluid.layers.affine_grid(theta, out_shape, name=None)

它使用仿射变换的参数生成(x,y)坐标的网格,这些参数对应于一组点,在这些点上,输入特征映射应该被采样以生成转换后的输出特征映射。



.. code-block:: text
C
Cheerego 已提交
1821

C
Cheerego 已提交
1822 1823 1824 1825 1826 1827 1828
        * 例 1:
          给定:
              theta = [[[x_11, x_12, x_13]
                        [x_14, x_15, x_16]]
                       [[x_21, x_22, x_23]
                        [x_24, x_25, x_26]]]
              out_shape = [2, 3, 5, 5]
C
Cheerego 已提交
1829

C
Cheerego 已提交
1830
          Step 1:
C
Cheerego 已提交
1831

C
Cheerego 已提交
1832 1833 1834
              根据out_shape生成标准化坐标

              归一化坐标的值在-1和1之间
C
Cheerego 已提交
1835

C
Cheerego 已提交
1836
              归一化坐标的形状为[2,H, W],如下所示:
C
Cheerego 已提交
1837

C
Cheerego 已提交
1838 1839 1840 1841 1842 1843 1844 1845 1846 1847
              C = [[[-1.  -1.  -1.  -1.  -1. ]
                    [-0.5 -0.5 -0.5 -0.5 -0.5]
                    [ 0.   0.   0.   0.   0. ]
                    [ 0.5  0.5  0.5  0.5  0.5]
                    [ 1.   1.   1.   1.   1. ]]
                   [[-1.  -0.5  0.   0.5  1. ]
                    [-1.  -0.5  0.   0.5  1. ]
                    [-1.  -0.5  0.   0.5  1. ]
                    [-1.  -0.5  0.   0.5  1. ]
                    [-1.  -0.5  0.   0.5  1. ]]]
C
Cheerego 已提交
1848

C
Cheerego 已提交
1849 1850 1851
              C[0]是高轴坐标,C[1]是宽轴坐标。

          Step2:
C
Cheerego 已提交
1852

C
Cheerego 已提交
1853 1854 1855 1856 1857 1858 1859 1860 1861 1862 1863 1864 1865 1866 1867 1868 1869 1870 1871 1872 1873 1874 1875 1876 1877 1878 1879 1880 1881 1882
              将C转换并重组成形为[H * W, 2]的张量,并追加到最后一个维度

              我们得到:

              C_ = [[-1.  -1.   1. ]
                    [-0.5 -1.   1. ]
                    [ 0.  -1.   1. ]
                    [ 0.5 -1.   1. ]
                    [ 1.  -1.   1. ]
                    [-1.  -0.5  1. ]
                    [-0.5 -0.5  1. ]
                    [ 0.  -0.5  1. ]
                    [ 0.5 -0.5  1. ]
                    [ 1.  -0.5  1. ]
                    [-1.   0.   1. ]
                    [-0.5  0.   1. ]
                    [ 0.   0.   1. ]
                    [ 0.5  0.   1. ]
                    [ 1.   0.   1. ]
                    [-1.   0.5  1. ]
                    [-0.5  0.5  1. ]
                    [ 0.   0.5  1. ]
                    [ 0.5  0.5  1. ]
                    [ 1.   0.5  1. ]
                    [-1.   1.   1. ]
                    [-0.5  1.   1. ]
                    [ 0.   1.   1. ]
                    [ 0.5  1.   1. ]
                    [ 1.   1.   1. ]]
          Step3:
C
Cheerego 已提交
1883
              按下列公式计算输出
C
Cheerego 已提交
1884
.. math::
C
Cheerego 已提交
1885

C
Cheerego 已提交
1886 1887 1888
  Output[i] = C\_ * Theta[i]^T

参数:
R
RaindragonD 已提交
1889 1890 1891
  - **theta** (Variable): 一类具有形状为[N, 2, 3]的仿射变换参数
  - **out_shape** (Variable | list | tuple):具有格式[N, C, H, W]的目标输出的shape,out_shape可以是变量、列表或元组。
  - **name** (str|None): 此层的名称(可选)。如果没有设置,将自动命名。
C
Cheerego 已提交
1892 1893 1894 1895 1896 1897 1898 1899 1900

返回: Variable: 形为[N, H, W, 2]的输出。

抛出异常: ValueError: 如果输入了不支持的参数类型

**代码示例:**

.. code-block:: python

R
RaindragonD 已提交
1901
    import paddle.fluid as fluid
C
Cheerego 已提交
1902 1903 1904 1905 1906 1907 1908 1909 1910 1911 1912 1913 1914 1915 1916 1917 1918 1919 1920 1921 1922 1923 1924 1925 1926 1927 1928 1929 1930 1931 1932 1933 1934 1935 1936 1937 1938
    theta = fluid.layers.data(name="x", shape=[2, 3], dtype="float32")
    out_shape = fluid.layers.data(name="y", shape=[-1], dtype="float32")
    data = fluid.layers.affine_grid(theta, out_shape)
    # or
    data = fluid.layers.affine_grid(theta, [5, 3, 28, 28])









.. _cn_api_fluid_layers_autoincreased_step_counter:

autoincreased_step_counter
-------------------------------

.. py:function:: paddle.fluid.layers.autoincreased_step_counter(counter_name=None, begin=1, step=1)

创建一个自增变量,每个mini-batch返回主函数运行次数,变量自动加1,默认初始值为1.

参数:
    - **counter_name** (str)-计数名称,默认为 ``@STEP_COUNTER@``
    - **begin** (int)-开始计数
    - **step** (int)-执行之间增加的步数

返回:全局运行步数

返回类型:变量(Variable)

**代码示例**:

.. code-block:: python

    global_step = fluid.layers.autoincreased_step_counter(
R
RaindragonD 已提交
1939
        counter_name='@LR_DECAY_COUNTER@', begin=0, step=1)
C
Cheerego 已提交
1940 1941 1942 1943 1944 1945 1946 1947 1948 1949 1950 1951 1952 1953









.. _cn_api_fluid_layers_batch_norm:

batch_norm
-------------------------------

H
Hao Wang 已提交
1954
.. py:function:: paddle.fluid.layers.batch_norm(input, act=None, is_test=False, momentum=0.9, epsilon=1e-05, param_attr=None, bias_attr=None, data_layout='NCHW', in_place=False, name=None, moving_mean_name=None, moving_variance_name=None, do_model_average_for_mean_and_var=False, fuse_with_relu=False, use_global_stats=False)
C
Cheerego 已提交
1955 1956 1957 1958 1959 1960 1961 1962 1963 1964 1965 1966 1967 1968 1969 1970 1971 1972

批正则化层(Batch Normalization Layer)

可用作conv2d和全链接操作的正则化函数。该层需要的数据格式如下:

1.NHWC[batch,in_height,in_width,in_channels]
2.NCHW[batch,in_channels,in_height,in_width]

更多详情请参考 : `Batch Normalization: Accelerating Deep Network Training by Reducing Internal Covariate Shift <https://arxiv.org/pdf/1502.03167.pdf>`_

``input`` 是mini-batch的输入特征。

.. math::
    \mu_{\beta}        &\gets \frac{1}{m} \sum_{i=1}^{m} x_i                                 \quad &// mini-batch-mean \\
    \sigma_{\beta}^{2} &\gets \frac{1}{m} \sum_{i=1}^{m}(x_i - \mu_{\beta})^2               \quad &// mini-batch-variance \\
    \hat{x_i}          &\gets \frac{x_i - \mu_\beta} {\sqrt{\sigma_{\beta}^{2} + \epsilon}}  \quad &// normalize \\
    y_i &\gets \gamma \hat{x_i} + \beta                                                      \quad &// scale-and-shift

H
Hao Wang 已提交
1973 1974 1975 1976 1977 1978 1979 1980 1981 1982
当use_global_stats = True时, :math:`\mu_{\beta}` 和 :math:`\sigma_{\beta}^{2}` 不是一个minibatch的统计数据。 它们是全局(或运行)统计数据。 (它通常来自预先训练好的模型。)训练和测试(或预测)具有相同的行为:

.. math::

    \hat{x_i} &\gets \frac{x_i - \mu_\beta} {\sqrt{\
    \sigma_{\beta}^{2} + \epsilon}}  \\
    y_i &\gets \gamma \hat{x_i} + \beta



C
Cheerego 已提交
1983
参数:
Z
zy0531 已提交
1984
    - **input** (Variable) - 输入变量的排序,可以为 2, 3, 4, 5
C
Cheerego 已提交
1985
    - **act** (string,默认None)- 激活函数类型,linear|relu|prelu|...
Z
zy0531 已提交
1986 1987 1988
    - **is_test** (bool,默认False) - 指示它是否在测试阶段。
    - **momentum** (float,默认0.9)- 此值用于计算 moving_mean and moving_var. 更新公式为:  :math:`\(moving\_mean = moving\_mean * momentum + new\_mean * (1. - momentum)\)` :math:`\(moving\_var = moving\_var * momentum + new\_var * (1. - momentum)\)` , 默认值0.9.
    - **epsilon** (float,默认1e-05)- 加在分母上为了数值稳定的值。默认值为1e-5。
C
Cheerego 已提交
1989 1990 1991 1992 1993
    - **param_attr** (ParamAttr|None) - batch_norm参数范围的属性,如果设为None或者是ParamAttr的一个属性,batch_norm创建ParamAttr为param_attr。如果没有设置param_attr的初始化函数,参数初始化为Xavier。默认:None
    - **bias_attr** (ParamAttr|None) - batch_norm bias参数的属性,如果设为None或者是ParamAttr的一个属性,batch_norm创建ParamAttr为bias_attr。如果没有设置bias_attr的初始化函数,参数初始化为0。默认:None
    - **data_layout** (string,默认NCHW) - NCHW|NHWC
    - **in_place** (bool,默认False)- 得出batch norm可复用记忆的输入和输出
    - **name** (string,默认None)- 该层名称(可选)。若设为None,则自动为该层命名
R
RaindragonD 已提交
1994 1995
    - **moving_mean_name** (string,默认None)- moving_mean的名称,存储全局Mean。如果将其设置为None, ``batch_norm``将随机命名全局平均值;否则, `batch_norm`将命名全局平均值为``moving_mean_name``
    - **moving_variance_name** (string,默认None)- moving_variance的名称,存储全局变量。如果将其设置为None,``batch_norm``将随机命名全局方差;否则, `batch_norm`将命名全局方差为``moving_mean_name``
C
Cheerego 已提交
1996
    - **do_model_average_for_mean_and_var** (bool,默认False)- 是否为mean和variance做模型均值
H
Hao Wang 已提交
1997
    - **fuse_with_relu** (bool)- 如果为True,batch norm后该操作符执行relu
C
Cheerego 已提交
1998
    - **use_global_stats** (bool, Default False) – 是否使用全局均值和方差。 在预测或测试模式下,将use_global_stats设置为true或将is_test设置为true,并且行为是等效的。 在训练模式中,当设置use_global_stats为True时,在训练期间也使用全局均值和方差。
C
Cheerego 已提交
1999 2000 2001 2002 2003 2004 2005 2006

返回: 张量,在输入中运用批正则后的结果

返回类型:变量(Variable)

**代码示例**:

.. code-block:: python
R
RaindragonD 已提交
2007 2008
    
    x = fluid.layers.data(name='x', shape=[3, 7, 3, 7], dtype='float32', append_batch_size=False)
C
Cheerego 已提交
2009 2010 2011 2012 2013 2014 2015 2016 2017 2018 2019 2020 2021 2022 2023 2024 2025 2026
    hidden1 = fluid.layers.fc(input=x, size=200, param_attr='fc1.w')
    hidden2 = fluid.layers.batch_norm(input=hidden1)











.. _cn_api_fluid_layers_beam_search:

beam_search
-------------------------------

H
Hao Wang 已提交
2027
.. py:function:: paddle.fluid.layers.beam_search(pre_ids, pre_scores, ids, scores, beam_size, end_id, level=0, is_accumulated=True, name=None, return_parent_idx=False)
C
Cheerego 已提交
2028 2029 2030 2031 2032

在机器翻译任务中,束搜索(Beam search)是选择候选词的一种经典算法

更多细节参考 `Beam Search <https://en.wikipedia.org/wiki/Beam_search>`_

H
Hao Wang 已提交
2033
该层在一时间步中按束进行搜索。具体而言,根据候选词使用于源句子所得的 ``scores`` , 从候选词 ``ids`` 中选择当前步骤的 top-K (最佳K)候选词的id,其中 ``K`` 是 ``beam_size`` , ``ids`` , ``scores`` 是计算单元的预测结果。如果没有提供 ``ids`` ,则将会根据 ``scores`` 计算得出。 另外, ``pre_id`` 和 ``pre_scores`` 是上一步中 ``beam_search`` 的输出,用于特殊处理翻译的结束边界。
C
Cheerego 已提交
2034

H
Hao Wang 已提交
2035
注意,如果 ``is_accumulated`` 为 True,传入的 ``scores`` 应该是累积分数。反之,``scores`` 会被认为为直接得分(straightforward scores), 并且会被转化为log值并且在此运算中会被累积到 ``pre_scores`` 中。在计算累积分数之前应该使用额外的 operators 进行长度惩罚。
C
Cheerego 已提交
2036

H
Hao Wang 已提交
2037
有关束搜索用法演示,请参阅以下示例:
C
Cheerego 已提交
2038

C
Cheerego 已提交
2039
     fluid/tests/book/test_machine_translation.py
C
Cheerego 已提交
2040

C
Cheerego 已提交
2041 2042 2043


参数:
C
Cheerego 已提交
2044
  - **pre_ids** (Variable) -  LodTensor变量,它是上一步 ``beam_search`` 的输出。在第一步中。它应该是LodTensor,shape为 :math:`(batch\_size,1)` , :math:`lod [[0,1,...,batch\_size],[0,1,...,batch\_size]]`
C
Cheerego 已提交
2045
  - **pre_scores** (Variable) -  LodTensor变量,它是上一步中beam_search的输出
C
Cheerego 已提交
2046
  - **ids** (Variable) - 包含候选ID的LodTensor变量。shape为 :math:`(batch\_size×beam\_ize,K)` ,其中 ``K`` 应该是 ``beam_size``
C
Cheerego 已提交
2047 2048 2049 2050
  - **scores** (Variable) - 与 ``ids`` 及其shape对应的累积分数的LodTensor变量, 与 ``ids`` 的shape相同。
  - **beam_size** (int) - 束搜索中的束宽度。
  - **end_id** (int) - 结束标记的id。
  - **level** (int,default 0) - **可忽略,当前不能更改** 。它表示lod的源级别,解释如下。 ``ids`` 的 lod 级别应为2.第一级是源级别, 描述每个源句子(beam)的前缀(分支)的数量,第二级是描述这些候选者属于前缀的句子级别的方式。链接前缀和所选候选者的路径信息保存在lod中。
H
Hao Wang 已提交
2051
  - **is_accumulated** (bool,默认为True) - 输入分数是否为累计分数。
C
Cheerego 已提交
2052
  - **name** (str | None) - 该层的名称(可选)。如果设置为None,则自动命名该层。
H
Hao Wang 已提交
2053 2054
  - **return_parent_idx** (bool) - 是否返回一个额外的Tensor变量,在输出的pre_ids中保留selected_ids的双亲indice,可用于在下一个时间步收集单元状态。

C
Cheerego 已提交
2055

H
Hao Wang 已提交
2056
返回:LodTensor元组。包含所选的id和与其相应的分数。 如果return_parent_idx为True,则包含一个保留selected_ids的双亲indice的额外Tensor变量。
C
Cheerego 已提交
2057 2058 2059 2060 2061 2062

返回类型:Variable

**代码示例**

..  code-block:: python
C
Cheerego 已提交
2063

R
RaindragonD 已提交
2064 2065
    import paddle.fluid as fluid

C
Cheerego 已提交
2066 2067
    # 假设 `probs` 包含计算神经元所得的预测结果
    # `pre_ids` 和 `pre_scores` 为beam_search之前时间步的输出
R
RaindragonD 已提交
2068 2069 2070 2071 2072 2073 2074 2075
    beam_size = 4
    end_id = 1
    pre_ids = fluid.layers.data(
        name='pre_id', shape=[1], lod_level=2, dtype='int64')
    pre_scores = fluid.layers.data(
        name='pre_scores', shape=[1], lod_level=2, dtype='float32')
    probs = fluid.layers.data(
        name='probs', shape=[10000], dtype='float32')
H
Hao Wang 已提交
2076 2077
    topk_scores, topk_indices = fluid.layers.topk(probs, k=beam_size)
    accu_scores = fluid.layers.elementwise_add(
R
RaindragonD 已提交
2078 2079
                                          x=fluid.layers.log(x=topk_scores)),
                                          y=fluid.layers.reshape(
C
Cheerego 已提交
2080 2081
                                              pre_scores, shape=[-1]),
                                          axis=0)
H
Hao Wang 已提交
2082
    selected_ids, selected_scores = fluid.layers.beam_search(
C
Cheerego 已提交
2083 2084 2085 2086 2087 2088 2089 2090 2091 2092 2093 2094 2095 2096 2097 2098 2099 2100 2101 2102 2103 2104 2105 2106 2107 2108 2109 2110 2111 2112 2113 2114 2115 2116 2117 2118
                                          pre_ids=pre_ids,
                                          pre_scores=pre_scores,
                                          ids=topk_indices,
                                          scores=accu_scores,
                                          beam_size=beam_size,
                                          end_id=end_id)











.. _cn_api_fluid_layers_beam_search_decode:

beam_search_decode
-------------------------------

.. py:function:: paddle.fluid.layers.beam_search_decode(ids, scores, beam_size, end_id, name=None)

束搜索层(Beam Search Decode Layer)通过回溯LoDTensorArray ids,为每个源语句构建完整假设,LoDTensorArray ``ids`` 的lod可用于恢复束搜索树中的路径。请参阅下面的demo中的束搜索使用示例:

    ::

        fluid/tests/book/test_machine_translation.py

参数:
        - **id** (Variable) - LodTensorArray,包含所有回溯步骤重中所需的ids。
        - **score** (Variable) - LodTensorArra,包含所有回溯步骤对应的score。
        - **beam_size** (int) - 束搜索中波束的宽度。
        - **end_id** (int) - 结束token的id。
        - **name** (str|None) - 该层的名称(可选)。如果设置为None,该层将被自动命名。
C
Cheerego 已提交
2119

R
RaindragonD 已提交
2120
返回: LodTensor 对(pair), 由生成的id序列和相应的score序列组成。两个LodTensor的shape和lod是相同的。lod的level=2,这两个level分别表示每个源句有多少个假设,每个假设有多少个id。
C
Cheerego 已提交
2121

R
RaindragonD 已提交
2122
返回类型: 变量(variable)
C
Cheerego 已提交
2123 2124 2125 2126 2127


**代码示例**

.. code-block:: python
C
Cheerego 已提交
2128

R
RaindragonD 已提交
2129 2130 2131 2132 2133 2134 2135
       import paddle.fluid as fluid

       # 假设 `ids` 和 `scores` 为 LodTensorArray变量,它们保留了
       # 选择出的所有时间步的id和score
       ids = fluid.layers.create_array(dtype='int64')
       scores = fluid.layers.create_array(dtype='float32')
       finished_ids, finished_scores = fluid.layers.beam_search_decode(
C
Cheerego 已提交
2136 2137 2138 2139 2140 2141 2142 2143 2144 2145 2146 2147 2148 2149 2150 2151 2152 2153 2154 2155 2156 2157
                ids, scores, beam_size=5, end_id=0)









.. _cn_api_fluid_layers_bilinear_tensor_product:

bilinear_tensor_product
-------------------------------

.. py:function:: paddle.fluid.layers.bilinear_tensor_product(x, y, size, act=None, name=None, param_attr=None, bias_attr=None)

该层对两个输入执行双线性张量积。

例如:

.. math::
T
Tink_Y 已提交
2158
       out_{i} = x * W_{i} * {y^\mathrm{T}}, i=0,1,...,size-1
C
Cheerego 已提交
2159 2160

在这个公式中:
R
RaindragonD 已提交
2161 2162 2163 2164 2165
  - :math:`x`: 第一个输入,包含M个元素,形状为[batch_size, M]
  - :math:`y`: 第二个输入,包含N个元素,形状为[batch_size, N]
  - :math:`W_{i}`: 第i个被学习的权重,形状是[M, N]
  - :math:`out_{i}`: out的第i个元素,形状是[batch_size, size]
  - :math:`y^\mathrm{T}`: :math:`y_{2}` 的转置
C
Cheerego 已提交
2166 2167 2168 2169 2170 2171 2172 2173 2174 2175 2176 2177 2178 2179 2180 2181

参数:
    - **x** (Variable): 2-D 输入张量,形状为 [batch_size, M]
    - **y** (Variable): 2-D 输入张量,形状为 [batch_size, N]
    - **size** (int): 此层的维度,
    - **act** (str, default None): 应用到该层输出的激活函数
    - **name** (str, default None): 该层的名称
    - **param_attr** (ParamAttr, default None): 可学习参数/权重(w) 的参数属性
    - **bias_attr** (ParamAttr, default None): 偏差的参数属性,如果设置为False,则不会向输出单元添加偏差。如果设置为零,偏差初始化为零。默认值:None

返回: Variable: 一个形为[batch_size, size]的2-D张量

**代码示例:**

.. code-block:: python

R
RaindragonD 已提交
2182 2183 2184
  layer1 = fluid.layers.data("t1", shape=[-1, 5], dtype="float32")
  layer2 = fluid.layers.data("t2", shape=[-1, 4], dtype="float32")
  tensor = fluid.layers.bilinear_tensor_product(x=layer1, y=layer2, size=1000)
C
Cheerego 已提交
2185 2186 2187 2188




H
Hao Wang 已提交
2189 2190 2191 2192 2193 2194 2195 2196
.. _cn_api_fluid_layers_bpr_loss:

bpr_loss
-------------------------------

.. py:function:: paddle.fluid.layers.bpr_loss(input, label, name=None)


R
RaindragonD 已提交
2197
贝叶斯个性化排序损失计算(Bayesian Personalized Ranking Loss Operator )
H
Hao Wang 已提交
2198 2199 2200 2201

该算子属于pairwise的排序类型,其标签是期望物品。在某次会话中某一给定点的损失值由下式计算而得:

.. math::
C
Cheerego 已提交
2202

R
RaindragonD 已提交
2203
  \[Y[i] = 1/(N[i] - 1) * \sum_j{\log(\sigma(X[i, Label[i]]-X[i, j]))}\]
H
Hao Wang 已提交
2204

R
RaindragonD 已提交
2205
更多细节请参考 `Session Based Recommendations with Recurrent Neural Networks`_
H
Hao Wang 已提交
2206

C
Cheerego 已提交
2207
参数:
R
RaindragonD 已提交
2208 2209 2210
  - **input** (Variable|list) - 一个形为[N x D]的2-D tensor , 其中 N 为批大小batch size ,D 为种类的数量。该输入为logits而非概率。
  - **label** (Variable|list) - 2-D tensor<int64> 类型的真实值, 形为[N x 1]
  - **name** (str|None) - (可选)该层的命名。 如果为None, 则自动为该层命名。 默认为None.
H
Hao Wang 已提交
2211 2212 2213 2214 2215 2216

返回: 形为[N x 1]的2D张量,即bpr损失

**代码示例:**

.. code-block:: python
C
Cheerego 已提交
2217

R
RaindragonD 已提交
2218 2219 2220 2221 2222 2223 2224
    import paddle.fluid as fluid
     
    neg_size = 10
    label = fluid.layers.data(
              name="label", shape=[1], dtype="int64")
    predict = fluid.layers.data(
              name="predict", shape=[neg_size + 1], dtype="float32")
H
Hao Wang 已提交
2225
    cost = fluid.layers.bpr_loss(input=predict, label=label)
C
Cheerego 已提交
2226 2227 2228 2229 2230 2231 2232 2233 2234 2235 2236 2237 2238 2239 2240 2241 2242





.. _cn_api_fluid_layers_brelu:

brelu
-------------------------------

.. py:function:: paddle.fluid.layers.brelu(x, t_min=0.0, t_max=24.0, name=None)


BRelu 激活函数

.. math::   out=max(min(x,tmin),tmax)

C
Cheerego 已提交
2243
参数:
C
Cheerego 已提交
2244 2245 2246 2247 2248 2249 2250 2251 2252 2253 2254 2255 2256 2257 2258 2259 2260 2261 2262 2263 2264 2265 2266 2267 2268 2269 2270 2271 2272 2273 2274 2275 2276 2277 2278 2279 2280 2281 2282 2283 2284 2285 2286 2287 2288 2289 2290 2291 2292 2293 2294 2295 2296 2297 2298 2299 2300 2301 2302 2303 2304 2305 2306 2307 2308 2309 2310 2311 2312 2313 2314 2315 2316 2317 2318 2319 2320 2321 2322 2323 2324 2325 2326 2327 2328 2329 2330 2331 2332 2333 2334 2335 2336 2337 2338 2339
    - **x** (Variable) - BReluoperator的输入
    - **t_min** (FLOAT|0.0) - BRelu的最小值
    - **t_max** (FLOAT|24.0) - BRelu的最大值
    - **name** (str|None) - 该层的名称(可选)。如果设置为None,该层将被自动命名


**代码示例:**

.. code-block:: python

    x = fluid.layers.data(name="x", shape=[2,3,16,16], dtype=”float32”)
    y = fluid.layers.brelu(x, t_min=1.0, t_max=20.0)






.. _cn_api_fluid_layers_chunk_eval:

chunk_eval
-------------------------------

.. py:function:: paddle.fluid.layers.chunk_eval(input, label, chunk_scheme, num_chunk_types, excluded_chunk_types=None)

块估计(Chunk Evaluator)

该功能计算并输出块检测(chunk detection)的准确率、召回率和F1值。

chunking的一些基础请参考 `Chunking with Support Vector Machines <https://aclanthology.info/pdf/N/N01/N01-1025.pdf>`_

ChunkEvalOp计算块检测(chunk detection)的准确率、召回率和F1值,并支持IOB,IOE,IOBES和IO标注方案。以下是这些标注方案的命名实体(NER)标注例子:

::


    ====== ====== ======  =====  ==  ============   =====  ===== =====  ==  =========
           Li     Ming    works  at  Agricultural   Bank   of    China  in  Beijing.
    ====== ====== ======  =====  ==  ============   =====  ===== =====  ==  =========
    IO     I-PER  I-PER   O      O   I-ORG          I-ORG  I-ORG I-ORG  O   I-LOC
    IOB    B-PER  I-PER   O      O   B-ORG          I-ORG  I-ORG I-ORG  O   B-LOC
    IOE    I-PER  E-PER   O      O   I-ORG          I-ORG  I-ORG E-ORG  O   E-LOC
    IOBES  B-PER  E-PER   O      O   I-ORG          I-ORG  I-ORG E-ORG  O   S-LOC
    ====== ====== ======  =====  ==  ============   =====  ===== =====  ==  =========

有三种块类别(命名实体类型),包括PER(人名),ORG(机构名)和LOC(地名),标签形式为标注类型(tag type)-块类型(chunk type)。

由于计算实际上用的是标签id而不是标签,需要额外注意将标签映射到相应的id,这样CheckEvalOp才可运行。关键在于id必须在列出的等式中有效。

::


    tag_type = label % num_tag_type
    chunk_type = label / num_tag_type

num_tag_type是标注规则中的标签类型数,num_chunk_type是块类型数,tag_type从下面的表格中获取值。

::


    Scheme Begin Inside End   Single
    plain   0     -      -     -
    IOB     0     1      -     -
    IOE     -     0      1     -
    IOBES   0     1      2     3

仍以NER为例,假设标注规则是IOB块类型为ORG,PER和LOC。为了满足以上等式,标签图如下:

::


    B-ORG  0
    I-ORG  1
    B-PER  2
    I-PER  3
    B-LOC  4
    I-LOC  5
    O      6

不难证明等式的块类型数为3,IOB规则中的标签类型数为2.例如I-LOC的标签id为5,I-LOC的标签类型id为1,I-LOC的块类型id为2,与等式的结果一致。

参数:
    - **input** (Variable) - 网络的输出预测
    - **label** (Variable) - 测试数据集的标签
    - **chunk_scheme** (str) - 标注规则,表示如何解码块。必须数IOB,IOE,IOBES或者plain。详情见描述
    - **num_chunk_types** (int) - 块类型数。详情见描述
    - **excluded_chunk_types** (list) - 列表包含块类型id,表示不在计数内的块类型。详情见描述

返回:元组(tuple),包含precision, recall, f1_score, num_infer_chunks, num_label_chunks, num_correct_chunks

返回类型:tuple(元组)

**代码示例**:

.. code-block:: python:

R
RaindragonD 已提交
2340 2341 2342 2343 2344 2345 2346 2347 2348 2349 2350
    import paddle.fluid as fluid
     
    dict_size = 10000
    label_dict_len = 7
    sequence = fluid.layers.data(
        name='id', shape=[1], lod_level=1, dtype='int64')
    embedding = fluid.layers.embedding(
        input=sequence, size=[dict_size, 512])
    hidden = fluid.layers.fc(input=embedding, size=512)
    label = fluid.layers.data(
        name='label', shape=[1], lod_level=1, dtype='int32')
C
Cheerego 已提交
2351
    crf = fluid.layers.linear_chain_crf(
R
RaindragonD 已提交
2352
        input=hidden, label=label, param_attr=fluid.ParamAttr(name="crfw"))
C
Cheerego 已提交
2353
    crf_decode = fluid.layers.crf_decoding(
R
RaindragonD 已提交
2354
        input=hidden, param_attr=fluid.ParamAttr(name="crfw"))
C
Cheerego 已提交
2355 2356 2357 2358 2359 2360 2361 2362 2363 2364 2365 2366 2367 2368 2369 2370 2371 2372 2373 2374
    fluid.layers.chunk_eval(
        input=crf_decode,
        label=label,
        chunk_scheme="IOB",
        num_chunk_types=(label_dict_len - 1) / 2)









.. _cn_api_fluid_layers_clip:

clip
-------------------------------

.. py:function:: paddle.fluid.layers.clip(x, min, max, name=None)
C
Cheerego 已提交
2375

C
Cheerego 已提交
2376 2377
clip算子

2378
clip算子限制给定输入的值在一个区间内。间隔使用参数"min"和"max"来指定:公式为
C
Cheerego 已提交
2379

C
Cheerego 已提交
2380
.. math::
C
Cheerego 已提交
2381 2382 2383 2384 2385 2386 2387 2388 2389 2390
        Out=min(max(X,min),max)

参数:
        - **x** (Variable)- (Tensor)clip运算的输入,维数必须在[1,9]之间。
        - **min** (FLOAT)- (float)最小值,小于该值的元素由min代替。
        - **max** (FLOAT)- (float)最大值,大于该值的元素由max替换。
        - **name** (basestring | None)- 输出的名称。

返回:        (Tensor)clip操作后的输出和输入(X)具有形状(shape)

C
Cheerego 已提交
2391
返回类型:        输出(Variable)。
C
Cheerego 已提交
2392 2393 2394 2395

**代码示例:**

.. code-block:: python
R
RaindragonD 已提交
2396 2397
    
    import paddle.fluid as fluid
C
Cheerego 已提交
2398 2399 2400 2401 2402 2403 2404 2405 2406 2407 2408 2409 2410 2411 2412
    input = fluid.layers.data(
        name='data', shape=[1], dtype='float32')
    reward = fluid.layers.clip(x=input, min=-1.0, max=1.0)






.. _cn_api_fluid_layers_clip_by_norm:

clip_by_norm
-------------------------------

.. py:function:: paddle.fluid.layers.clip_by_norm(x, max_norm, name=None)
C
Cheerego 已提交
2413

C
Cheerego 已提交
2414 2415
ClipByNorm算子

2416
此算子将输入 ``X`` 的L2范数限制在 ``max_norm`` 内。如果 ``X`` 的L2范数小于或等于 ``max_norm``  ,则输出(Out)将与 ``X`` 相同。如果X的L2范数大于 ``max_norm`` ,则 ``X`` 将被线性缩放,使得输出(Out)的L2范数等于 ``max_norm`` ,如下面的公式所示:
C
Cheerego 已提交
2417

C
Cheerego 已提交
2418 2419
.. math::
         Out = \frac{max\_norm * X}{norm(X)}
C
Cheerego 已提交
2420 2421 2422 2423 2424 2425 2426 2427 2428 2429 2430

其中, :math:`norm(X)` 代表 ``x`` 的L2范数。


参数:
        - **x** (Variable)- (Tensor) clip_by_norm运算的输入,维数必须在[1,9]之间。
        - **max_norm** (float)- 最大范数值。
        - **name** (basestring | None)- 输出的名称。

返回:        (Tensor)clip_by_norm操作后的输出和输入(X)具有形状(shape).

C
Cheerego 已提交
2431
返回类型:       Variable
C
Cheerego 已提交
2432 2433 2434 2435 2436 2437 2438 2439 2440 2441 2442 2443 2444 2445 2446

**代码示例:**

.. code-block:: python

    input = fluid.layers.data(
        name='data', shape=[1], dtype='float32')
    reward = fluid.layers.clip_by_norm(x=input, max_norm=1.0)







R
RaindragonD 已提交
2447 2448 2449 2450 2451 2452 2453 2454 2455 2456 2457 2458 2459 2460 2461 2462 2463 2464 2465 2466 2467 2468 2469 2470 2471 2472 2473 2474 2475 2476 2477 2478 2479 2480 2481 2482 2483 2484 2485 2486 2487 2488
.. _cn_api_fluid_layers_continuous_value_model:

continuous_value_model
-------------------------------

.. py:function:: paddle.fluid.layers.continuous_value_model(input, cvm, use_cvm=True)

**continuous_value_model层**

现在,continuous value model(cvm)仅考虑CTR项目中的展示和点击值。我们假设输入是一个含cvm_feature的词向量,其形状为[N * D](D为2 + 嵌入维度)。如果use_cvm=True,它会计算log(cvm_feature),且输出的形状为[N * D]。如果use_cvm=False,它会从输入中移除cvm_feature,且输出的形状为[N * (D - 2)]。
    
该层接受一个名为input的张量,嵌入后成为ID层(lod level为1), cvm为一个show_click info。

参数:
    - **input** (Variable)-一个N x D的二维LodTensor, N为batch size, D为2 + 嵌入维度, lod level = 1。
    - **cvm** (Variable)-一个N x 2的二维Tensor, N为batch size,2为展示和点击值。
    - **use_cvm** (bool)-分使用/不使用cvm两种情况。如果使用cvm,输出维度和输入相等;如果不使用cvm,输出维度为输入-2(移除展示和点击值)。(cvm op是一个自定义的op,其输入是一个含embed_with_cvm默认值的序列,因此我们需要一个名为cvm的op来决定是否使用cvm。)

返回:变量,一个N x D的二维LodTensor,如果使用cvm,D等于输入的维度,否则D等于输入的维度-2。

返回类型:变量(Variable)

**代码示例**:

.. code-block:: python

    input = fluid.layers.data(name="input", shape=[-1, 1], lod_level=1, append_batch_size=False, dtype="int64")#, stop_gradient=False)
    label = fluid.layers.data(name="label", shape=[-1, 1], append_batch_size=False, dtype="int64")
    embed = fluid.layers.embedding(
                            input=input,
                            size=[100, 11],
                            dtype='float32')
    ones = fluid.layers.fill_constant_batch_size_like(input=label, shape=[-1, 1], dtype="int64", value=1)
    show_clk = fluid.layers.cast(fluid.layers.concat([ones, label], axis=1), dtype='float32')
    show_clk.stop_gradient = True
    input_with_cvm = fluid.layers.continuous_value_model(embed, show_clk, True)






C
Cheerego 已提交
2489 2490 2491 2492 2493 2494 2495 2496 2497 2498 2499 2500 2501 2502 2503 2504 2505 2506 2507 2508

.. _cn_api_fluid_layers_conv2d:

conv2d
-------------------------------

.. py:function:: paddle.fluid.layers.conv2d(input, num_filters, filter_size, stride=1, padding=0, dilation=1, groups=None, param_attr=None, bias_attr=None, use_cudnn=True, act=None, name=None)

卷积二维层(convolution2D layer)根据输入、滤波器(filter)、步长(stride)、填充(padding)、dilations、一组参数计算输出。输入和输出是NCHW格式,N是批尺寸,C是通道数,H是特征高度,W是特征宽度。滤波器是MCHW格式,M是输出图像通道数,C是输入图像通道数,H是滤波器高度,W是滤波器宽度。如果组数大于1,C等于输入图像通道数除以组数的结果。详情请参考UFLDL's : `卷积 <http://ufldl.stanford.edu/tutorial/supervised/FeatureExtractionUsingConvolution/>`_ 。如果提供了bias属性和激活函数类型,bias会添加到卷积(convolution)的结果中相应的激活函数会作用在最终结果上。

对每个输入X,有等式:

.. math::

    Out = \sigma \left ( W * X + b \right )

其中:
    - :math:`X` :输入值,NCHW格式的张量(Tensor)
    - :math:`W` :滤波器值,MCHW格式的张量(Tensor)
    - :math:`*` : 卷积操作
H
Hao Wang 已提交
2509
    - :math:`b` :Bias值,二维张量(Tensor),shape为 ``[M,1]``
C
Cheerego 已提交
2510
    - :math:`\sigma` :激活函数
H
Hao Wang 已提交
2511
    - :math:`Out` :输出值,``Out`` 和 ``X`` 的shape可能不同
C
Cheerego 已提交
2512 2513 2514 2515 2516 2517 2518 2519 2520 2521 2522 2523 2524 2525 2526 2527 2528 2529 2530

**示例**

- 输入:

  输入shape::math:`( N,C_{in},H_{in},W_{in} )`

  滤波器shape: :math:`( C_{out},C_{in},H_{f},W_{f} )`

- 输出:

  输出shape: :math:`( N,C_{out},H_{out},W_{out} )`

其中

.. math::

    H_{out} = \frac{\left ( H_{in}+2*paddings[0]-\left ( dilations[0]*\left ( H_{f}-1 \right )+1 \right ) \right )}{strides[0]}+1

H
Hao Wang 已提交
2531
    W_{out} = \frac{\left ( W_{in}+2*paddings[1]-\left ( dilations[1]*\left ( W_{f}-1 \right )+1 \right ) \right )}{strides[1]}+1
C
Cheerego 已提交
2532 2533 2534 2535 2536 2537 2538 2539 2540 2541 2542 2543 2544 2545 2546 2547 2548 2549 2550 2551 2552 2553 2554 2555 2556 2557 2558 2559 2560 2561 2562 2563 2564 2565 2566 2567 2568 2569 2570 2571 2572 2573 2574 2575 2576 2577 2578 2579 2580 2581 2582 2583 2584 2585

参数:
    - **input** (Variable) - 格式为[N,C,H,W]格式的输入图像
    - **num_fliters** (int) - 滤波器数。和输出图像通道相同
    - **filter_size** (int|tuple|None) - 滤波器大小。如果filter_size是一个元组,则必须包含两个整型数,(filter_size,filter_size_W)。否则,滤波器为square
    - **stride** (int|tuple) - 步长(stride)大小。如果步长(stride)为元组,则必须包含两个整型数,(stride_H,stride_W)。否则,stride_H = stride_W = stride。默认:stride = 1
    - **padding** (int|tuple) - 填充(padding)大小。如果填充(padding)为元组,则必须包含两个整型数,(padding_H,padding_W)。否则,padding_H = padding_W = padding。默认:padding = 0
    - **dilation** (int|tuple) - 膨胀(dilation)大小。如果膨胀(dialation)为元组,则必须包含两个整型数,(dilation_H,dilation_W)。否则,dilation_H = dilation_W = dilation。默认:dilation = 1
    - **groups** (int) - 卷积二维层(Conv2D Layer)的组数。根据Alex Krizhevsky的深度卷积神经网络(CNN)论文中的成组卷积:当group=2,滤波器的前一半仅和输入通道的前一半连接。滤波器的后一半仅和输入通道的后一半连接。默认:groups = 1
    - **param_attr** (ParamAttr|None) - conv2d的可学习参数/权重的参数属性。如果设为None或者ParamAttr的一个属性,conv2d创建ParamAttr为param_attr。如果param_attr的初始化函数未设置,参数则初始化为 :math:`Normal(0.0,std)` ,并且std为 :math:`\frac{2.0}{filter\_elem\_num}^{0.5}` 。默认为None
    - **bias_attr** (ParamAttr|bool|None) - conv2d bias的参数属性。如果设为False,则没有bias加到输出。如果设为None或者ParamAttr的一个属性,conv2d创建ParamAttr为bias_attr。如果bias_attr的初始化函数未设置,bias初始化为0.默认为None
    - **use_cudnn** (bool) - 是否用cudnn核,仅当下载cudnn库才有效。默认:True
    - **act** (str) - 激活函数类型,如果设为None,则未添加激活函数。默认:None
    - **name** (str|None) - 该层名称(可选)。若设为None,则自动为该层命名。

返回:张量,存储卷积和非线性激活结果

返回类型:变量(Variable)

抛出异常:
  - ``ValueError`` - 如果输入shape和filter_size,stride,padding和group不匹配。

**代码示例**:

.. code-block:: python

    data = fluid.layers.data(name='data', shape=[3, 32, 32], dtype='float32')
    conv2d = fluid.layers.conv2d(input=data, num_filters=2, filter_size=3, act="relu")











.. _cn_api_fluid_layers_conv2d_transpose:

conv2d_transpose
-------------------------------

.. py:function:: paddle.fluid.layers.conv2d_transpose(input, num_filters, output_size=None, filter_size=None, padding=0, stride=1, dilation=1, groups=None, param_attr=None, bias_attr=None, use_cudnn=True, act=None, name=None)

2-D卷积转置层(Convlution2D transpose layer)

该层根据 输入(input)、滤波器(filter)和卷积核膨胀(dilations)、步长(stride)、填充(padding)来计算输出。输入(Input)和输出(Output)为NCHW格式,其中 ``N`` 为batch大小, ``C`` 为通道数(channel),``H`` 为特征高度, ``W`` 为特征宽度。参数(膨胀、步长、填充)分别都包含两个元素。这两个元素分别表示高度和宽度。欲了解卷积转置层细节,请参考下面的说明和 参考文献_ 。如果参数 ``bias_attr`` 和 ``act`` 不为 ``None``,则在卷积的输出中加入偏置,并对最终结果应用相应的激活函数。

.. _参考文献: http://www.matthewzeiler.com/wp-content/uploads/2017/07/cvpr2010.pdf

输入 :math:`X` 和输出 :math:`Out` 函数关系如下:

C
Cheerego 已提交
2586
.. math::
C
Cheerego 已提交
2587 2588 2589 2590 2591 2592 2593 2594 2595
                        Out=\sigma (W*X+b)\\

其中:
    -  :math:`X` : 输入张量,具有 ``NCHW`` 格式

    -  :math:`W` : 滤波器张量,具有 ``NCHW`` 格式

    -  :math:`*` : 卷积操作

H
Hao Wang 已提交
2596
    -  :math:`b` : 偏置(bias),二维张量,shape为 ``[M,1]``
C
Cheerego 已提交
2597 2598

    -  :math:`σ` : 激活函数
C
Cheerego 已提交
2599

C
Cheerego 已提交
2600 2601 2602 2603 2604 2605
    -  :math:`Out` : 输出值,Out和 ``X`` 的 ``shape`` 可能不一样

**样例**:

输入:

C
Cheerego 已提交
2606
.. math::
C
Cheerego 已提交
2607 2608 2609

    输入张量的shape :  (N,C_{in}, H_{in}, W_{in})

C
Cheerego 已提交
2610
    滤波器(filter)shape : (C_{in}, C_{out}, H_f, W_f)
C
Cheerego 已提交
2611 2612

输出:
C
Cheerego 已提交
2613 2614

.. math::
C
Cheerego 已提交
2615 2616 2617 2618
    输出张量的 shape : (N,C_{out}, H_{out}, W_{out})

其中

C
Cheerego 已提交
2619
.. math::
C
Cheerego 已提交
2620 2621 2622 2623 2624 2625

        & H'_{out} = (H_{in}-1)*strides[0]-2*paddings[0]+dilations[0]*(H_f-1)+1\\
        & W'_{out} = (W_{in}-1)*strides[1]-2*paddings[1]+dilations[1]*(W_f-1)+1 \\
        & H_{out}\in[H'_{out},H'_{out} + strides[0])\\
        & W_{out}\in[W'_{out},W'_{out} + strides[1])\\

C
Cheerego 已提交
2626

C
Cheerego 已提交
2627 2628

参数:
R
RaindragonD 已提交
2629 2630 2631 2632 2633 2634 2635 2636 2637 2638 2639 2640 2641
  - **input** (Variable)- 输入张量,格式为[N, C, H, W]
  - **num_filters** (int) - 滤波器(卷积核)的个数,与输出的图片的通道数( channel )相同
  - **output_size** (int|tuple|None) - 输出图片的大小。如果output_size是一个元组(tuple),则该元形式为(image_H,image_W),这两个值必须为整型。如果output_size=None,则内部会使用filter_size、padding和stride来计算output_size。如果output_size和filter_size是同时指定的,那么它们应满足上面的公式。
  - **filter_size** (int|tuple|None) - 滤波器大小。如果filter_size是一个tuple,则形式为(filter_size_H, filter_size_W)。否则,滤波器将是一个方阵。如果filter_size=None,则内部会计算输出大小。
  - **padding** (int|tuple) - 填充大小。如果padding是一个元组,它必须包含两个整数(padding_H、padding_W)。否则,padding_H = padding_W = padding。默认:padding = 0。
  - **stride** (int|tuple) - 步长大小。如果stride是一个元组,那么元组的形式为(stride_H、stride_W)。否则,stride_H = stride_W = stride。默认:stride = 1。
  - **dilation** (int|元组) - 膨胀(dilation)大小。如果dilation是一个元组,那么元组的形式为(dilation_H, dilation_W)。否则,dilation_H = dilation_W = dilation_W。默认:dilation= 1。
  - **groups** (int) - Conv2d转置层的groups个数。从Alex Krizhevsky的CNN Deep论文中的群卷积中受到启发,当group=2时,前半部分滤波器只连接到输入通道的前半部分,而后半部分滤波器只连接到输入通道的后半部分。默认值:group = 1。
  - **param_attr** (ParamAttr|None) - conv2d_transfer中可学习参数/权重的属性。如果param_attr值为None或ParamAttr的一个属性,conv2d_transfer使用ParamAttrs作为param_attr的值。如果没有设置的param_attr初始化器,那么使用Xavier初始化。默认值:None。
  - **bias_attr** (ParamAttr|bool|None) - conv2d_tran_bias中的bias属性。如果设置为False,则不会向输出单元添加偏置。如果param_attr值为None或ParamAttr的一个属性,将conv2d_transfer使用ParamAttrs作为,bias_attr。如果没有设置bias_attr的初始化器,bias将初始化为零。默认值:None。
  - **use_cudnn** (bool) - 是否使用cudnn内核,只有已安装cudnn库时才有效。默认值:True。
  - **act** (str) -  激活函数类型,如果设置为None,则不使用激活函数。默认值:None。
  - **name** (str|None) -  该layer的名称(可选)。如果设置为None, 将自动命名该layer。默认值:True。
C
Cheerego 已提交
2642 2643


R
RaindragonD 已提交
2644
返回: 存储卷积转置结果的张量。
C
Cheerego 已提交
2645

R
RaindragonD 已提交
2646
返回类型: 变量(variable)
C
Cheerego 已提交
2647 2648 2649 2650 2651 2652 2653

抛出异常:
    -  ``ValueError`` : 如果输入的shape、filter_size、stride、padding和groups不匹配,抛出ValueError

**代码示例**

..  code-block:: python
C
Cheerego 已提交
2654

C
Cheerego 已提交
2655 2656
    data = fluid.layers.data(name='data', shape=[3, 32, 32], dtype='float32')
    conv2d_transpose = fluid.layers.conv2d_transpose(input=data, num_filters=2, filter_size=3)
C
Cheerego 已提交
2657 2658


C
Cheerego 已提交
2659 2660 2661 2662 2663 2664 2665 2666 2667 2668 2669 2670 2671 2672 2673 2674









.. _cn_api_fluid_layers_conv3d:

conv3d
-------------------------------

.. py:function:: paddle.fluid.layers.conv3d(input, num_filters, filter_size, stride=1, padding=0, dilation=1, groups=None, param_attr=None, bias_attr=None, use_cudnn=True, act=None, name=None)

H
Hao Wang 已提交
2675
3D卷积层(convolution3D layer)根据输入、滤波器(filter)、步长(stride)、填充(padding)、膨胀(dilations)、组数参数计算得到输出。输入和输出是NCHW格式,N是批尺寸,C是通道数,H是特征高度,W是特征宽度。卷积三维(Convlution3D)和卷积二维(Convlution2D)相似,但多了一维深度(depth)。如果提供了bias属性和激活函数类型,bias会添加到卷积(convolution)的结果中相应的激活函数会作用在最终结果上。
C
Cheerego 已提交
2676 2677 2678 2679 2680 2681 2682 2683 2684

对每个输入X,有等式:

.. math::


    Out = \sigma \left ( W * X + b \right )

其中:
H
Hao Wang 已提交
2685 2686
    - :math:`X` :输入值,NCDHW格式的张量(Tensor)
    - :math:`W` :滤波器值,MCDHW格式的张量(Tensor)
C
Cheerego 已提交
2687
    - :math:`*` : 卷积操作
H
Hao Wang 已提交
2688
    - :math:`b` :Bias值,二维张量(Tensor),形为 ``[M,1]``
C
Cheerego 已提交
2689
    - :math:`\sigma` :激活函数
H
Hao Wang 已提交
2690
    - :math:`Out` :输出值, 和 ``X`` 的形状可能不同
C
Cheerego 已提交
2691 2692 2693 2694

**示例**

- 输入:
C
Cheerego 已提交
2695
    输入shape: :math:`(N, C_{in}, D_{in}, H_{in}, W_{in})`
C
Cheerego 已提交
2696

C
Cheerego 已提交
2697
    滤波器shape: :math:`(C_{out}, C_{in}, D_f, H_f, W_f)`
C
Cheerego 已提交
2698
- 输出:
C
Cheerego 已提交
2699
    输出shape: :math:`(N, C_{out}, D_{out}, H_{out}, W_{out})`
C
Cheerego 已提交
2700 2701 2702 2703 2704 2705

其中

.. math::


H
Hao Wang 已提交
2706 2707 2708
    D_{out}&= \frac{(D_{in} + 2 * paddings[0] - (dilations[0] * (D_f - 1) + 1))}{strides[0]} + 1 \\
    H_{out}&= \frac{(H_{in} + 2 * paddings[1] - (dilations[1] * (H_f - 1) + 1))}{strides[1]} + 1 \\
    W_{out}&= \frac{(W_{in} + 2 * paddings[2] - (dilations[2] * (W_f - 1) + 1))}{strides[2]} + 1
C
Cheerego 已提交
2709 2710

参数:
H
Hao Wang 已提交
2711
    - **input** (Variable) - 格式为[N,C,D,H,W]格式的输入图像
C
Cheerego 已提交
2712
    - **num_fliters** (int) - 滤波器数。和输出图像通道相同
H
Hao Wang 已提交
2713 2714 2715 2716
    - **filter_size** (int|tuple|None) - 滤波器大小。如果filter_size是一个元组,则必须包含三个整型数,(filter_size_D, filter_size_H, filter_size_W)。否则,滤波器为棱长为int的立方体形。
    - **stride** (int|tuple) - 步长(stride)大小。如果步长(stride)为元组,则必须包含三个整型数, (stride_D, stride_H, stride_W)。否则,stride_D = stride_H = stride_W = stride。默认:stride = 1
    - **padding** (int|tuple) - 填充(padding)大小。如果填充(padding)为元组,则必须包含三个整型数,(padding_D, padding_H, padding_W)。否则, padding_D = padding_H = padding_W = padding。默认:padding = 0
    - **dilation** (int|tuple) - 膨胀(dilation)大小。如果膨胀(dialation)为元组,则必须包含两个整型数, (dilation_D, dilation_H, dilation_W)。否则,dilation_D = dilation_H = dilation_W = dilation。默认:dilation = 1
C
Cheerego 已提交
2717 2718 2719 2720 2721 2722 2723 2724 2725 2726 2727 2728 2729 2730 2731 2732 2733 2734 2735 2736 2737 2738 2739 2740 2741 2742 2743 2744 2745 2746 2747 2748 2749 2750 2751 2752 2753 2754 2755 2756 2757 2758 2759 2760 2761 2762 2763 2764 2765 2766 2767 2768 2769 2770
    - **groups** (int) - 卷积二维层(Conv2D Layer)的组数。根据Alex Krizhevsky的深度卷积神经网络(CNN)论文中的成组卷积:当group=2,滤波器的前一半仅和输入通道的前一半连接。滤波器的后一半仅和输入通道的后一半连接。默认:groups = 1
    - **param_attr** (ParamAttr|None) - conv2d的可学习参数/权重的参数属性。如果设为None或者ParamAttr的一个属性,conv2d创建ParamAttr为param_attr。如果param_attr的初始化函数未设置,参数则初始化为 :math:`Normal(0.0,std)`,并且std为 :math:`\left ( \frac{2.0}{filter\_elem\_num} \right )^{0.5}` 。默认为None
    - **bias_attr** (ParamAttr|bool|None) - conv2d bias的参数属性。如果设为False,则没有bias加到输出。如果设为None或者ParamAttr的一个属性,conv2d创建ParamAttr为bias_attr。如果bias_attr的初始化函数未设置,bias初始化为0.默认为None
    - **use_cudnn** (bool) - 是否用cudnn核,仅当下载cudnn库才有效。默认:True
    - **act** (str) - 激活函数类型,如果设为None,则未添加激活函数。默认:None
    - **name** (str|None) - 该层名称(可选)。若设为None,则自动为该层命名。

返回:张量,存储卷积和非线性激活结果

返回类型:变量(Variable)

抛出异常:
  - ``ValueError`` - 如果 ``input`` 的形和 ``filter_size`` , ``stride`` , ``padding`` 和 ``group`` 不匹配。

**代码示例**:

.. code-block:: python

    data = fluid.layers.data(name='data', shape=[3, 12, 32, 32], dtype='float32')
    conv3d = fluid.layers.conv3d(input=data, num_filters=2, filter_size=3, act="relu")









.. _cn_api_fluid_layers_conv3d_transpose:

conv3d_transpose
-------------------------------

.. py:function:: paddle.fluid.layers.conv3d_transpose(input, num_filters, output_size=None, filter_size=None, padding=0, stride=1, dilation=1, groups=None, param_attr=None, bias_attr=None, use_cudnn=True, act=None, name=None)

3-D卷积转置层(Convlution3D transpose layer)

该层根据 输入(input)、滤波器(filter)和卷积核膨胀(dilations)、步长(stride)、填充来计算输出。输入(Input)和输出(Output)为NCDHW格式。其中 ``N`` 为batch大小, ``C`` 为通道数(channel), ``D``  为特征深度, ``H`` 为特征高度, ``W`` 为特征宽度。参数(膨胀、步长、填充)分别包含两个元素。这两个元素分别表示高度和宽度。欲了解卷积转置层细节,请参考下面的说明和 参考文献_ 。如果参数 ``bias_attr`` 和 ``act`` 不为None,则在卷积的输出中加入偏置,并对最终结果应用相应的激活函数

.. _参考文献: http://www.matthewzeiler.com/wp-content/uploads/2017/07/cvpr2010.pdf

输入X和输出Out函数关系X,有等式如下:

.. math::
                        \\Out=\sigma (W*X+b)\\

其中:
    -  :math:`X` : 输入张量,具有 ``NCDHW`` 格式

    -  :math:`W` : 滤波器张量,,具有 ``NCDHW`` 格式

    -  :math:`*` : 卷积操作

H
Hao Wang 已提交
2771
    -  :math:`b` : 偏置(bias),二维张量,shape为 ``[M,1]``
C
Cheerego 已提交
2772 2773

    -  :math:`σ` : 激活函数
C
Cheerego 已提交
2774

C
Cheerego 已提交
2775 2776 2777 2778 2779 2780 2781
    -  :math:`Out` : 输出值, ``Out`` 和 ``X`` 的 shape可能不一样


**样例**

输入:

C
Cheerego 已提交
2782 2783
.. math::

R
RaindragonD 已提交
2784
    Input shape: (N,C_{in},D_{in},H_{in},W_{in})
C
Cheerego 已提交
2785

R
RaindragonD 已提交
2786
    Filter shape: (C_{in},C_{out},D_f,H_f,W_f)
C
Cheerego 已提交
2787

C
Cheerego 已提交
2788

C
Cheerego 已提交
2789 2790 2791

输出:

C
Cheerego 已提交
2792 2793
.. math::

R
RaindragonD 已提交
2794
    Output shape: (N,C_{out},D_{out},H_{out},W_{out})
C
Cheerego 已提交
2795

C
Cheerego 已提交
2796

C
Cheerego 已提交
2797 2798
其中:

C
Cheerego 已提交
2799 2800
.. math::

C
Cheerego 已提交
2801 2802


R
RaindragonD 已提交
2803
    D_{out}=(D_{in}-1)*strides[0]-2*paddings[0]+dilations[0]*(D_f-1)+1
C
Cheerego 已提交
2804

R
RaindragonD 已提交
2805
    H_{out}=(H_{in}-1)*strides[1]-2*paddings[1]+dilations[1]*(H_f-1)+1
C
Cheerego 已提交
2806

R
RaindragonD 已提交
2807
    W_{out}=(W_{in}-1)*strides[2]-2*paddings[2]+dilations[2]*(W_f-1)+1
C
Cheerego 已提交
2808

C
Cheerego 已提交
2809 2810 2811


参数:
R
RaindragonD 已提交
2812 2813 2814 2815 2816 2817 2818 2819 2820 2821 2822 2823 2824
  - **input** (Variable)- 输入张量,格式为[N, C, D, H, W]
  - **num_filters** (int) - 滤波器(卷积核)的个数,与输出的图片的通道数(channel)相同
  - **output_size** (int|tuple|None) - 输出图片的大小。如果 ``output_size`` 是一个元组(tuple),则该元形式为(image_H,image_W),这两个值必须为整型。如果 ``output_size=None`` ,则内部会使用filter_size、padding和stride来计算output_size。如果 ``output_size`` 和 ``filter_size`` 是同时指定的,那么它们应满足上面的公式。
  - **filter_size** (int|tuple|None) - 滤波器大小。如果 ``filter_size`` 是一个tuple,则形式为(filter_size_H, filter_size_W)。否则,滤波器将是一个方阵。如果 ``filter_size=None`` ,则内部会计算输出大小。
  - **padding** (int|tuple) - 填充大小。如果 ``padding`` 是一个元组,它必须包含两个整数(padding_H、padding_W)。否则,padding_H = padding_W = padding。默认:padding = 0。
  - **stride** (int|tuple) - 步长大小。如果 ``stride`` 是一个元组,那么元组的形式为(stride_H、stride_W)。否则,stride_H = stride_W = stride。默认:stride = 1。
  - **dilation** (int|元组) - 膨胀大小。如果 ``dilation`` 是一个元组,那么元组的形式为(dilation_H, dilation_W)。否则,dilation_H = dilation_W = dilation_W。默认:dilation= 1。
  - **groups** (int) - Conv2d转置层的groups个数。从Alex Krizhevsky的CNN Deep论文中的群卷积中受到启发,当group=2时,前半部分滤波器只连接到输入通道的前半部分,而后半部分滤波器只连接到输入通道的后半部分。默认值:group = 1。
  - **param_attr** (ParamAttr|None) - conv2d_transfer中可学习参数/权重的属性。如果param_attr值为None或ParamAttr的一个属性,conv2d_transfer使用ParamAttrs作为param_attr的值。如果没有设置的param_attr初始化器,那么使用Xavier初始化。默认值:None。
  - **bias_attr** (ParamAttr|bool|None) - conv2d_tran_bias中的bias属性。如果设置为False,则不会向输出单元添加偏置。如果param_attr值为None或ParamAttr的一个属性,将conv2d_transfer使用ParamAttrs作为,bias_attr。如果没有设置bias_attr的初始化器,bias将初始化为零。默认值:None。
  - **use_cudnn** (bool) - 是否使用cudnn内核,只有已安装cudnn库时才有效。默认值:True。
  - **act** (str) -  激活函数类型,如果设置为None,则不使用激活函数。默认值:None。
  - **name** (str|None) - 该layer的名称(可选)。如果设置为None, 将自动命名该layer。默认值:True。
C
Cheerego 已提交
2825 2826


R
RaindragonD 已提交
2827
返回: 存储卷积转置结果的张量。
C
Cheerego 已提交
2828

R
RaindragonD 已提交
2829
返回类型: 变量(variable)
C
Cheerego 已提交
2830 2831 2832 2833 2834 2835 2836 2837

抛出异常:
    -  ``ValueError``  : 如果输入的shape、filter_size、stride、padding和groups不匹配,抛出ValueError


**代码示例**

..  code-block:: python
C
Cheerego 已提交
2838

C
Cheerego 已提交
2839 2840 2841 2842 2843 2844 2845 2846 2847 2848 2849 2850 2851 2852
    data = fluid.layers.data(name='data', shape=[3, 12, 32, 32], dtype='float32')
    conv3d_transpose = fluid.layers.conv3d_transpose(input=data, num_filters=2, filter_size=3)










.. _cn_api_fluid_layers_cos_sim:

C
Cheerego 已提交
2853
cos_sim
C
Cheerego 已提交
2854 2855 2856 2857
-------------------------------

.. py:function:: paddle.fluid.layers.cos_sim(X, Y)

2858
余弦相似度算子(Cosine Similarity Operator)
C
Cheerego 已提交
2859 2860 2861 2862 2863 2864 2865 2866 2867 2868 2869 2870 2871

.. math::

        Out = \frac{X^{T}*Y}{\sqrt{X^{T}*X}*\sqrt{Y^{T}*Y}}

输入X和Y必须具有相同的shape,除非输入Y的第一维为1(不同于输入X),在计算它们的余弦相似度之前,Y的第一维会被broadcasted,以匹配输入X的shape。

输入X和Y都携带或者都不携带LoD(Level of Detail)信息。但输出仅采用输入X的LoD信息。

参数:
    - **X** (Variable) - cos_sim操作函数的一个输入
    - **Y** (Variable) - cos_sim操作函数的第二个输入

2872
返回:cosine(X,Y)的输出
C
Cheerego 已提交
2873 2874 2875

返回类型:变量(Variable)

R
RaindragonD 已提交
2876
**代码示例**
C
Cheerego 已提交
2877

R
RaindragonD 已提交
2878
..  code-block:: python
C
Cheerego 已提交
2879

R
RaindragonD 已提交
2880 2881 2882
     x = fluid.layers.data(name='x', shape=[3, 7], dtype='float32', append_batch_size=False)
     y = fluid.layers.data(name='y', shape=[1, 7], dtype='float32', append_batch_size=False)
     out = fluid.layers.cos_sim(x, y)
C
Cheerego 已提交
2883 2884 2885 2886 2887 2888 2889 2890 2891 2892 2893 2894 2895 2896 2897 2898





.. _cn_api_fluid_layers_crf_decoding:

crf_decoding
-------------------------------

.. py:function::  paddle.fluid.layers.crf_decoding(input, param_attr, label=None)

该函数读取由 ``linear_chain_crf`` 学习的emission feature weights(发射状态特征的权重)和 transition feature weights(转移特征的权重)。
本函数实现了Viterbi算法,可以动态地寻找隐藏状态最可能的序列,该序列也被称为Viterbi路径(Viterbi path),从而得出的标注(tags)序列。

这个运算的结果会随着 ``Label`` 参数的有无而改变:
C
Cheerego 已提交
2899

C
Cheerego 已提交
2900
      1. ``Label`` 非None的情况,在实际训练中时常发生。此时本函数会协同 ``chunk_eval`` 工作。本函数会返回一行形为[N X 1]的向量,其中值为0的部分代表该label不适合作为对应结点的标注,值为1的部分则反之。此类型的输出可以直接作为 ``chunk_eval`` 算子的输入
C
Cheerego 已提交
2901

C
Cheerego 已提交
2902 2903 2904
      2. 当没有 ``Label`` 时,该函数会执行标准decoding过程

(没有 ``Label`` 时)该运算返回一个形为 [N X 1]的向量,其中元素取值范围为 0 ~ 最大标注个数-1,分别为预测出的标注(tag)所在的索引。
C
Cheerego 已提交
2905 2906

参数:
C
Cheerego 已提交
2907 2908 2909 2910 2911 2912 2913 2914 2915 2916 2917 2918 2919
    - **input** (Variable)(LoDTensor,默认类型为 LoDTensor<float>) — 一个形为 [N x D] 的LoDTensor,其中 N 是mini-batch的大小,D是标注(tag) 的总数。 该输入是 ``linear_chain_crf`` 的 unscaled emission weight matrix (未标准化的发射权重矩阵)
    - **param_attr** (ParamAttr) — 参与训练的参数的属性
    - **label** (Variable)(LoDTensor,默认类型为 LoDTensor<int64_t>) —  形为[N x 1]的正确标注(ground truth)。 该项可选择传入。 有关该参数的更多信息,请详见上述描述

返回:(LoDTensor, LoDTensor<int64_t>)decoding结果。具体内容根据 ``Label`` 参数是否提供而定。请参照函数介绍来详细了解。

返回类型: Variable


**代码示例**

..  code-block:: python

R
RaindragonD 已提交
2920 2921 2922 2923 2924 2925 2926
    images = fluid.layers.data(name='pixel', shape=[784], dtype='float32')
    label = fluid.layers.data(name='label', shape=[1], dtype='int32')
    hidden = fluid.layers.fc(input=images, size=2)
    crf = fluid.layers.linear_chain_crf(input=hidden, label=label,
            param_attr=fluid.ParamAttr(name="crfw"))
    crf_decode = fluid.layers.crf_decoding(input=hidden,
            param_attr=fluid.ParamAttr(name="crfw"))
C
Cheerego 已提交
2927 2928 2929 2930 2931 2932 2933 2934 2935 2936 2937 2938 2939 2940 2941 2942 2943 2944 2945 2946 2947 2948 2949 2950 2951 2952 2953 2954 2955 2956 2957 2958 2959 2960 2961 2962 2963 2964 2965 2966 2967 2968 2969 2970 2971 2972 2973 2974 2975 2976 2977












.. _cn_api_fluid_layers_crop:

crop
-------------------------------

.. py:function:: paddle.fluid.layers.crop(x, shape=None, offsets=None, name=None)

根据偏移量(offsets)和形状(shape),裁剪输入张量。

**样例**:

::

    * Case 1:
        Given
            X = [[0, 1, 2, 0, 0]
                 [0, 3, 4, 0, 0]
                 [0, 0, 0, 0, 0]],
        and
            shape = [2, 2],
            offsets = [0, 1],
        output is:
            Out = [[1, 2],
                   [3, 4]].
    * Case 2:
        Given
            X = [[0, 1, 2, 5, 0]
                 [0, 3, 4, 6, 0]
                 [0, 0, 0, 0, 0]],
        and shape is tensor
            shape = [[0, 0, 0]
                     [0, 0, 0]]
        and
            offsets = [0, 1],

        output is:
            Out = [[1, 2, 5],
                   [3, 4, 6]].

C
Cheerego 已提交
2978

C
Cheerego 已提交
2979 2980 2981 2982 2983 2984 2985 2986 2987 2988 2989 2990 2991 2992 2993 2994
参数:
  - **x** (Variable): 输入张量。
  - **shape** (Variable|list/tuple of integer) - 输出张量的形状由参数shape指定,它可以是一个变量/整数的列表/整数元组。如果是张量变量,它的秩必须与x相同。该方式适可用于每次迭代时候需要改变输出形状的情况。如果是整数列表/tupe,则其长度必须与x的秩相同
  - **offsets** (Variable|list/tuple of integer|None) - 指定每个维度上的裁剪的偏移量。它可以是一个Variable,或者一个整数list/tupe。如果是一个tensor variable,它的rank必须与x相同,这种方法适用于每次迭代的偏移量(offset)都可能改变的情况。如果是一个整数list/tupe,则长度必须与x的rank的相同,如果shape=None,则每个维度的偏移量为0。
  - **name** (str|None) - 该层的名称(可选)。如果设置为None,该层将被自动命名。

返回: 裁剪张量。

返回类型: 变量(Variable)

抛出异常: 如果形状不是列表、元组或变量,抛出ValueError


**代码示例**:

..  code-block:: python
R
RaindragonD 已提交
2995 2996
    
    import paddle.fluid as fluid
C
Cheerego 已提交
2997 2998 2999 3000 3001 3002 3003 3004 3005 3006 3007 3008 3009 3010 3011 3012 3013 3014 3015 3016 3017 3018 3019 3020 3021 3022 3023 3024 3025
    x = fluid.layers.data(name="x", shape=[3, 5], dtype="float32")
    y = fluid.layers.data(name="y", shape=[2, 3], dtype="float32")
    crop = fluid.layers.crop(x, shape=y)


    ## or
    z = fluid.layers.data(name="z", shape=[3, 5], dtype="float32")
    crop = fluid.layers.crop(z, shape=[2, 3])










.. _cn_api_fluid_layers_cross_entropy:

cross_entropy
-------------------------------

.. py:function:: paddle.fluid.layers.cross_entropy(input, label, soft_label=False, ignore_index=-100)

该函数定义了输入和标签之间的cross entropy(交叉熵)层。该函数支持standard cross-entropy computation(标准交叉熵损失计算)
以及soft-label cross-entropy computation(软标签交叉熵损失计算)

  1. One-hot cross-entropy算法
C
Cheerego 已提交
3026 3027

     soft_label = False, Label[i, 0] 指明样本i的类别所具的索引:
C
Cheerego 已提交
3028 3029
                            .. math::
                                     \\Y[i]=-log(X[i,Label[i]])\\
C
Cheerego 已提交
3030

C
Cheerego 已提交
3031
  2. Soft-label cross-entropy算法
C
Cheerego 已提交
3032 3033

     soft_label = True, Label[i, j] 表明样本i对应类别j的soft label(软标签):
C
Cheerego 已提交
3034 3035
                            .. math::
                                     \\Y[i]= \sum_{j}-Label[i,j]*log(X[i,j])\\
C
Cheerego 已提交
3036

C
Cheerego 已提交
3037
     **请确保采用此算法时识别为各软标签的概率总和为1**
C
Cheerego 已提交
3038

C
Cheerego 已提交
3039
  3. One-hot cross-entropy with vecterized label(使用向量化标签的One-hot)算法
C
Cheerego 已提交
3040

C
Cheerego 已提交
3041 3042 3043 3044
     作为 *2* 的特殊情况,当软类标签内部只有一个非零概率元素,且它的值为1,那么 *2* 算法降级为一种仅有one-hot标签的one-hot交叉熵



C
Cheerego 已提交
3045 3046 3047


参数:
C
Cheerego 已提交
3048 3049 3050
    - **input** (Variable|list) – 一个形为[N x D]的二维tensor,其中N是batch大小,D是类别(class)数目。 这是由之前的operator计算出的概率,绝大多数情况下是由softmax operator得出的结果
    - **label** (Variable|list) – 一个二维tensor组成的正确标记的数据集(ground truth)。 当 ``soft_label`` 为False时,label为形为[N x 1]的tensor<int64>。 ``soft_label`` 为True时, label是形为 [N x D]的 tensor<float/double>
    - **soft_label** (bool) – 标志位,指明是否需要把给定的标签列表认定为软标签。默认为False。
H
Hao Wang 已提交
3051
    - **ignore_index** (int) – 指定一个被无视的目标值,并且这个值不影响输入梯度。仅在 ``soft_label`` 为False时生效。 默认值: kIgnoreIndex
C
Cheerego 已提交
3052 3053 3054

返回: 一个形为[N x 1]的二维tensor,承载了交叉熵损失

C
Cheerego 已提交
3055
弹出异常: ``ValueError``
C
Cheerego 已提交
3056 3057 3058 3059

                        1. 当 ``input`` 的第一维和 ``label`` 的第一维不相等时,弹出异常
                        2. 当 ``soft_label`` 值为True, 且 ``input`` 的第二维和 ``label`` 的第二维不相等时,弹出异常
                        3. 当 ``soft_label`` 值为False,且 ``label`` 的第二维不是1时,弹出异常
C
Cheerego 已提交
3060

C
Cheerego 已提交
3061 3062 3063 3064 3065 3066


**代码示例**

..  code-block:: python

R
RaindragonD 已提交
3067 3068 3069 3070
        classdim = 7
        x = fluid.layers.data(name='x', shape=[3, 7], dtype='float32', append_batch_size=False)
        label = fluid.layers.data(name='label', shape=[3, 1], dtype='float32', append_batch_size=False)
        predict = fluid.layers.fc(input=x, size=classdim, act='softmax')
C
Cheerego 已提交
3071 3072 3073 3074 3075 3076 3077 3078 3079 3080 3081 3082 3083 3084 3085 3086 3087 3088 3089 3090 3091 3092 3093 3094 3095 3096 3097 3098 3099 3100 3101 3102 3103 3104 3105 3106 3107 3108 3109 3110 3111 3112 3113 3114 3115 3116 3117 3118 3119 3120 3121 3122 3123 3124 3125 3126 3127 3128 3129 3130 3131 3132 3133 3134
        cost = fluid.layers.cross_entropy(input=predict, label=label)













.. _cn_api_fluid_layers_ctc_greedy_decoder:

ctc_greedy_decoder
-------------------------------

.. py:function:: paddle.fluid.layers.ctc_greedy_decoder(input, blank, name=None)

此op用于贪婪策略解码序列,步骤如下:
    1. 获取输入中的每一行的最大值索引,也就是numpy.argmax(input, axis=0)。
    2. 对于step1结果中的每个序列,在两个空格之间合并重复部分(即合并重复的上一步中的到的索引值)并删除所有空格。


简单举一个例子,

::

        已知:

        input.data = [[0.6, 0.1, 0.3, 0.1],
                      [0.3, 0.2, 0.4, 0.1],
                      [0.1, 0.5, 0.1, 0.3],
                      [0.5, 0.1, 0.3, 0.1],

                      [0.5, 0.1, 0.3, 0.1],
                      [0.2, 0.2, 0.2, 0.4],
                      [0.2, 0.2, 0.1, 0.5],
                      [0.5, 0.1, 0.3, 0.1]]

        input.lod = [[4, 4]]

        计算过程:

        1. 将argmax的运算结果应用于输入的第一个序列,即 input.data[0:4] 。
           则得出的结果为[[0], [2], [1], [0]]
        2. 合并重复的索引值部分,删除空格,即为0的值。
           则第一个输入序列对应的输出为:[[2], [1]]

        最后

        output.data = [[2],
                       [1],
                       [3]]

        output.lod = [[2, 1]]


参数:
        - **input** (Variable) — (LoDTensor<float>),变长序列的概率,它是一个具有LoD信息的二维张量。它的形状是[Lp, num_classes + 1],其中Lp是所有输入序列长度的和,num_classes是真正的类别。(不包括空白标签)。
        - **blank** (int) — Connectionist Temporal Classification (CTC) loss空白标签索引,  属于半开区间[0,num_classes + 1)。
        - **name** (str) — 此层的名称。可选。
C
Cheerego 已提交
3135

C
Cheerego 已提交
3136 3137 3138
返回: CTC贪婪解码结果是一个形为(Lp,1)的二维张量,其中Lp是所有输出序列的长度之和。如果结果中的所有序列都为空,则输出LoDTensor 为[-1],其中LoD[[]] 形为[1,1]。

返回类型: 变量(Variable)
C
Cheerego 已提交
3139

C
Cheerego 已提交
3140 3141 3142 3143

**代码示例**

..  code-block:: python
C
Cheerego 已提交
3144

R
RaindragonD 已提交
3145
    import paddle.fluid as fluid
C
Cheerego 已提交
3146 3147 3148 3149 3150 3151 3152 3153
    x = fluid.layers.data(name='x', shape=[8], dtype='float32')

    cost = fluid.layers.ctc_greedy_decoder(input=x, blank=0)





H
Hao Wang 已提交
3154 3155 3156 3157 3158
.. _cn_api_fluid_layers_data_norm:

data_norm
-------------------------------

Z
zy0531 已提交
3159
.. py:function:: paddle.fluid.layers.data_norm(input, act=None, epsilon=1e-05, param_attr=None, data_layout='NCHW', in_place=False, name=None, moving_mean_name=None, moving_variance_name=None, do_model_average_for_mean_and_var=False)
H
Hao Wang 已提交
3160 3161

**数据正则化层**
C
Cheerego 已提交
3162

H
Hao Wang 已提交
3163 3164 3165 3166 3167 3168 3169
可用作conv2d和fully_connected操作的正则化函数。 此层所需的数据格式为以下之一:

1. NHWC [batch, in_height, in_width, in_channels]
2. NCHW [batch, in_channels, in_height, in_width]

:math:`input` 为一个mini-batch上的特征:

C
Cheerego 已提交
3170
.. math::
H
Hao Wang 已提交
3171 3172 3173 3174 3175 3176
        \mu_{\beta} &\gets \frac{1}{m} \sum_{i=1}^{m} x_i \qquad &//\
        \ mini-batch\ mean \\
        \sigma_{\beta}^{2} &\gets \frac{1}{m} \sum_{i=1}^{m}(x_i - \
        \mu_{\beta})^2 \qquad &//\ mini-batch\ variance \\
        \hat{x_i} &\gets \frac{x_i - \mu_\beta} {\sqrt{\
        \sigma_{\beta}^{2} + \epsilon}} \qquad &//\ normalize \\
C
Cheerego 已提交
3177
        y_i &\gets \gamma \hat{x_i} + \beta \qquad &//\ scale\ and\ shift
H
Hao Wang 已提交
3178 3179 3180 3181

参数:
  - **input** (variable) - 输入变量,它是一个LoDTensor。
  - **act** (string,默认None) - 激活函数类型,线性| relu | prelu | ...
C
Cheerego 已提交
3182
  - **epsilon** (float,默认1e-05) -
H
Hao Wang 已提交
3183 3184 3185 3186 3187 3188 3189
  - **param_attr** (ParamAttr) - 参数比例的参数属性。
  - **data_layout** (string,默认NCHW) -  NCHW | NHWC
  - **in_place** (bool,默认值False) - 使data_norm的输入和输出复用同一块内存。
  - **name** (string,默认None) - 此层的名称(可选)。 如果设置为None,则将自动命名该层。
  - **moving_mean_name** (string,Default None) - 存储全局Mean的moving_mean的名称。
  - **moving_variance_name** (string,默认None) - 存储全局Variance的moving_variance的名称。
  - **do_model_average_for_mean_and_var** (bool,默认值为false) - 是否为mean和variance进行模型平均。
C
Cheerego 已提交
3190

H
Hao Wang 已提交
3191 3192 3193 3194 3195 3196 3197
返回: 张量变量,是对输入数据进行正则化后的结果。

返回类型: Variable

**代码示例**

..  code-block:: python
C
Cheerego 已提交
3198

R
RaindragonD 已提交
3199 3200 3201 3202 3203 3204 3205 3206 3207 3208 3209 3210 3211 3212 3213 3214 3215 3216 3217 3218 3219 3220 3221 3222 3223 3224 3225 3226 3227 3228 3229 3230 3231 3232 3233 3234 3235 3236 3237 3238 3239 3240 3241 3242 3243 3244 3245 3246 3247 3248 3249 3250 3251 3252 3253 3254 3255 3256 3257 3258 3259 3260 3261 3262 3263 3264 3265 3266 3267 3268 3269 3270 3271
    import paddle.fluid as fluid

    hidden1 = fluid.layers.data(name="hidden1", shape=[200])
    hidden2 = fluid.layers.data_norm(name="hidden2", input=hidden1)







.. _cn_api_fluid_layers_deformable_conv:

deformable_conv
-------------------------------

.. py:function:: paddle.fluid.layers.deformable_conv(input, offset, mask, num_filters, filter_size, stride=1, padding=0, dilation=1, groups=None, deformable_groups=None, im2col_step=None, param_attr=None, bias_attr=None, name=None)

可变形卷积层

在4-D输入上计算2-D可变形卷积。给定输入图像x,输出特征图y,可变形卷积操作如下所示:
\[y(p) = \sum_{k=1}^{K}{w_k * x(p + p_k + \Delta p_k) * \Delta m_k}\]
其中\(\Delta p_k\) 和 \(\Delta m_k\) 分别为第k个位置的可学习偏移和调制标量。
参考可变形卷积网络v2:可变形程度越高,结果越好。

**示例**
     
输入:
    输入形状: \((N, C_{in}, H_{in}, W_{in})\)
    卷积核形状: \((C_{out}, C_{in}, H_f, W_f)\)
    偏移形状: \((N, 2 * deformable\_groups * H_f * H_w, H_{in}, W_{in})\)
    掩膜形状: \((N, deformable\_groups * H_f * H_w, H_{in}, W_{in})\)
     
输出:
    输出形状: \((N, C_{out}, H_{out}, W_{out})\)

其中
    \[\begin{split}H_{out}&= \frac{(H_{in} + 2 * paddings[0] - (dilations[0] * (H_f - 1) + 1))}{strides[0]} + 1 \\
    W_{out}&= \frac{(W_{in} + 2 * paddings[1] - (dilations[1] * (W_f - 1) + 1))}{strides[1]} + 1\end{split}\]
     

参数:
    - **input** (Variable) - 形式为[N, C, H, W]的输入图像。
    - **offset** (Variable) – 可变形卷积层的输入坐标偏移。
    - **Mask** (Variable) – 可变形卷积层的输入掩膜。
    - **num_filters** (int) – 卷积核数。和输出图像通道数相同。
    - **filter_size** (int|tuple|None) – 卷积核大小。如果filter_size为元组,则必须包含两个整数(filter_size_H, filter_size_W)。否则卷积核将为方形。
    - **stride** (int|tuple) – 步长大小。如果stride为元组,则必须包含两个整数(stride_H, stride_W)。否则stride_H = stride_W = stride。默认stride = 1。
    - **padding** (int|tuple) – padding大小。如果padding为元组,则必须包含两个整数(padding_H, padding_W)。否则padding_H = padding_W = padding。默认padding = 0。
    - **dilation** (int|tuple) – dilation大小。如果dilation为元组,则必须包含两个整数(dilation_H, dilation_W)。否则dilation_H = dilation_W = dilation。默认dilation = 1。
    - **groups** (int) – 可变形卷积层的群组数。依据Alex Krizhevsky的Deep CNN论文中的分组卷积,有:当group=2时,前一半卷积核只和前一半输入通道有关,而后一半卷积核只和后一半输入通道有关。默认groups=1。
    - **deformable_groups** (int) – 可变形群组分区数。默认deformable_groups = 1。
    - **im2col_step** (int) – 每个im2col计算的最大图像数。总batch大小应该可以被该值整除或小于该值。如果您面临内存问题,可以尝试在此处使用一个更小的值。默认im2col_step = 64。
    - **param_attr** (ParamAttr|None) – 可变形卷积的可学习参数/权重的参数属性。如果将其设置为None或ParamAttr的一个属性,可变形卷积将创建ParamAttr作为param_attr。如果没有设置此param_attr的Initializer,该参数将被\(Normal(0.0, std)\)初始化,且其中的\(std\) 为 \((\frac{2.0 }{filter\_elem\_num})^{0.5}\)。默认值None。
    - **bias_attr** (ParamAttr|bool|None) – 可变形卷积层的偏置的参数属性。如果设为False,则输出单元不会加偏置。如果设为None或者ParamAttr的一个属性,conv2d会创建ParamAttr作为bias_attr。如果不设置bias_attr的Initializer,偏置会被初始化为0。默认值None。
    - **name** (str|None) – 该层的名字(可选项)。如果设为None,该层将会被自动命名。默认值None。
 
返回:储存可变形卷积结果的张量变量。
     
返回类型:变量(Variable)
     
抛出:ValueError – 如果input, filter_size, stride, padding和groups的大小不匹配。

**代码示例**

..  code-block:: python

    data = fluid.layers.data(name='data', shape=[3, 32, 32], dtype='float32')
    offset = fluid.layers.data(name='offset', shape=[18, 32, 32], dtype='float32')
    mask = fluid.layers.data(name='mask', shape=[9, 32, 32], dtype='float32')
    out = fluid.layers.deformable_conv(input=data, offset=offset, mask=mask, num_filters=2, filter_size=3, padding=1)


H
Hao Wang 已提交
3272 3273 3274



C
Cheerego 已提交
3275

R
RaindragonD 已提交
3276 3277 3278 3279 3280 3281 3282 3283
.. _cn_api_fluid_layers_deformable_roi_pooling:

deformable_roi_pooling
-------------------------------

.. py:function:: paddle.fluid.layers.deformable_roi_pooling(input, rois, trans, no_trans=False, spatial_scale=1.0, group_size=[1, 1], pooled_height=1, pooled_width=1, part_size=None, sample_per_part=1, trans_std=0.1, position_sensitive=False, name=None)

可变形PSROI池层
C
Cheerego 已提交
3284

R
RaindragonD 已提交
3285 3286 3287 3288 3289 3290 3291 3292 3293 3294 3295 3296 3297 3298 3299 3300 3301 3302
参数:
    - **input** (Variable) - 可变形PSROI池层的输入。输入张量的形状为[N,C,H,W]。其中N是批量大小,C是输入通道的数量,H是特征的高度,W是特征的宽度。
    - **rois** (Variable)- 将池化的ROIs(感兴趣区域)。应为一个形状为(num_rois, 4)的2-D LoDTensor,且lod level为1。给出[[x1, y1, x2, y2], ...],(x1, y1)为左上角坐标,(x2, y2)为右下角坐标。
    - **trans** (Variable)- 池化时ROIs上的特征偏移。格式为NCHW,其中N是ROIs的数量,C是通道的数量,指示x和y方向上的偏移距离,H是池化的高度,W是池化的宽度。
    - **no_trans** (bool)- roi池化阶段是否加入偏移以获取新值。取True或False。默认为False。
    - **spatial_scale** (float) - 输入特征图的高度(或宽度)与原始图像高度(或宽度)的比率。等于卷积图层中总步长的倒数,默认为1.0。
    - **group_size** (list|tuple)- 输入通道划分成的组数(例如,输入通道的数量是k1 * k2 *(C + 1),其中k1和k2是组宽度和高度,C + 1是输出通道的数量。如( 4,6)中4是组的高度,6是组的宽度)。默认为[1,1]。
    - **pooled_height** (integer)- 池化后输出的高度。
    - **pooled_width** (integer)- 池化后输出的宽度。
    - **part_size** (list|tuple)- 偏移高度和宽度,如(4, 6)代表高度为4、宽度为6,默认为None,此时默认值[pooled_height, pooled_width]。
    - **sample_per_part** (integer)- 每个bin中的样本数量,默认为1。
    - **trans_std** (float)- 偏移系数,默认为0.1。
    - **position_sensitive** (bool)- 是否选择可变形psroi池化模式,默认为False。
    - **name** (str)- 层名,默认为None。

返回: 存储可变形psroi池层的张量变量

返回类型:  变量(Variable)
C
Cheerego 已提交
3303

R
RaindragonD 已提交
3304
**代码示例**
C
Cheerego 已提交
3305

R
RaindragonD 已提交
3306
..  code-block:: python
C
Cheerego 已提交
3307

R
RaindragonD 已提交
3308 3309 3310 3311 3312 3313 3314 3315 3316 3317 3318 3319 3320 3321 3322 3323 3324 3325 3326 3327 3328 3329 3330 3331
    input = fluid.layers.data(name="input",
                              shape=[2, 192, 64, 64],
                              dtype='float32',
                              append_batch_size=False)
    rois = fluid.layers.data(name="rois",
                             shape=[4],
                             dtype='float32',
                             lod_level=1)
    trans = fluid.layers.data(name="trans",
                              shape=[2, 384, 64, 64],
                              dtype='float32',
                              append_batch_size=False)
    x = fluid.layers.nn.deformable_roi_pooling(input=input,
                                                 rois=rois,
                                                 trans=trans,
                                                 no_trans=False,
                                                 spatial_scale=1.0,
                                                 group_size=(1, 1),
                                                 pooled_height=8,
                                                 pooled_width=8,
                                                 part_size=(8, 8),
                                                 sample_per_part=4,
                                                 trans_std=0.1,
                                                 position_sensitive=False)
C
Cheerego 已提交
3332 3333 3334 3335 3336 3337 3338 3339 3340

.. _cn_api_fluid_layers_dice_loss:

dice_loss
-------------------------------

.. py:function:: paddle.fluid.layers.dice_loss(input, label, epsilon=1e-05)

dice_loss是比较两批数据相似度,通常用于二值图像分割,即标签为二值。
C
Cheerego 已提交
3341

C
Cheerego 已提交
3342 3343
dice_loss定义为:

C
Cheerego 已提交
3344
.. math::
C
Cheerego 已提交
3345 3346
        dice\_loss &= 1- \frac{2 * intersection\_area}{total\_rea}\\
                   &= \frac{(total\_area−intersection\_area)−intersection\_area}{total\_area}\\
C
Cheerego 已提交
3347
                   &= \frac{union\_area−intersection\_area}{total\_area}
C
Cheerego 已提交
3348 3349 3350 3351 3352

参数:
    - **input** (Variable) - rank>=2的预测。第一个维度是batch大小,最后一个维度是类编号。
    - **label** (Variable)- 与输入tensor rank相同的正确的标注数据(groud truth)。第一个维度是batch大小,最后一个维度是1。
    - **epsilon** (float) - 将会加到分子和分母上。如果输入和标签都为空,则确保dice为1。默认值:0.00001
C
Cheerego 已提交
3353

C
Cheerego 已提交
3354 3355 3356 3357 3358 3359 3360
返回: dice_loss shape为[1]。

返回类型:  dice_loss(Variable)

**代码示例**

..  code-block:: python
C
Cheerego 已提交
3361

R
RaindragonD 已提交
3362 3363 3364 3365 3366
    import paddle.fluid as fluid
    x = fluid.layers.data(name='data', shape = [3, 224, 224, 2], dtype='float32')
    label = fluid.layers.data(name='label', shape=[3, 224, 224, 1], dtype='float32')
    predictions = fluid.layers.softmax(x)
    loss = fluid.layers.dice_loss(input=predictions, label=label)
C
Cheerego 已提交
3367 3368 3369 3370 3371 3372 3373 3374 3375 3376 3377 3378 3379 3380 3381 3382











.. _cn_api_fluid_layers_dropout:

dropout
-------------------------------

3383
.. py:function:: paddle.fluid.layers.dropout(x,dropout_prob,is_test=False,seed=None,name=None,dropout_implementation='downgrade_in_infer')
C
Cheerego 已提交
3384 3385 3386 3387 3388

dropout操作

丢弃或者保持x的每个元素独立。Dropout是一种正则化技术,通过在训练过程中阻止神经元节点间的联合适应性来减少过拟合。根据给定的丢弃概率dropout操作符随机将一些神经元输出设置为0,其他的仍保持不变。

H
Hao Wang 已提交
3389 3390
dropout op可以从Program中删除,提高执行效率。

C
Cheerego 已提交
3391 3392 3393 3394 3395 3396
参数:
    - **x** (Variable)-输入张量
    - **dropout_prob** (float)-设置为0的单元的概率
    - **is_test** (bool)-显示是否进行测试用语的标记
    - **seed** (int)-Python整型,用于创建随机种子。如果该参数设为None,则使用随机种子。注:如果给定一个整型种子,始终丢弃相同的输出单元。训练过程中勿用固定不变的种子。
    - **name** (str|None)-该层名称(可选)。如果设置为None,则自动为该层命名
C
Cheerego 已提交
3397
    - **dropout_implementation** (string) -
C
Cheerego 已提交
3398

H
Hao Wang 已提交
3399
      [‘downgrade_in_infer’(default)|’upscale_in_train’] 其中:
C
Cheerego 已提交
3400

C
Cheerego 已提交
3401
      1. downgrade_in_infer(default), 在预测时减小输出结果
H
Hao Wang 已提交
3402

C
Cheerego 已提交
3403
         - train: out = input * mask
C
Cheerego 已提交
3404 3405

         - inference: out = input * (1.0 - dropout_prob)
H
Hao Wang 已提交
3406 3407

         (mask是一个张量,维度和输入维度相同,值为0或1,值为0的比例即为 ``dropout_prob`` )
C
Cheerego 已提交
3408

H
Hao Wang 已提交
3409
      2. upscale_in_train, 增加训练时的结果
C
Cheerego 已提交
3410

H
Hao Wang 已提交
3411
         - train: out = input * mask / ( 1.0 - dropout_prob )
C
Cheerego 已提交
3412

C
Cheerego 已提交
3413
         - inference: out = input
C
Cheerego 已提交
3414

H
Hao Wang 已提交
3415
         (mask是一个张量,维度和输入维度相同,值为0或1,值为0的比例即为 ``dropout_prob`` )
C
Cheerego 已提交
3416 3417 3418

dropout操作符可以从程序中移除,程序变得高效。

T
Tink_Y 已提交
3419
返回:与输入X,shape相同的张量
C
Cheerego 已提交
3420 3421 3422 3423 3424 3425 3426 3427 3428 3429 3430 3431 3432 3433 3434 3435 3436 3437 3438 3439 3440 3441 3442

返回类型:变量

**代码示例**:

.. code-block:: python

    x = fluid.layers.data(name="data", shape=[32, 32], dtype="float32")
    droped = fluid.layers.dropout(x, dropout_prob=0.5)









.. _cn_api_fluid_layers_dynamic_gru:

dynamic_gru
-------------------------------

H
Hao Wang 已提交
3443
.. py:function::  paddle.fluid.layers.dynamic_gru(input, size, param_attr=None, bias_attr=None, is_reverse=False, gate_activation='sigmoid', candidate_activation='tanh', h_0=None, origin_mode=False)
C
Cheerego 已提交
3444 3445 3446 3447 3448



**实现了Gated Recurrent Unit层。**

H
Hao Wang 已提交
3449
如果origin_mode为False,那么gru运算公式来自论文 `Empirical Evaluation of Gated Recurrent Neural Networks on Sequence Modeling <https://arxiv.org/abs/1412.3555>`_ 。
C
Cheerego 已提交
3450 3451 3452 3453


公式如下:

C
Cheerego 已提交
3454
.. math::
C
Cheerego 已提交
3455 3456 3457 3458 3459 3460 3461 3462
  u_{t}=act_g(W_{ux}x_{t}+W_{uh}h_{t-1}+b_{u})
.. math::
  r_{t}=act_g(W_{rx}x_{t}+W_{rh}h_{t-1}+b_{r})
.. math::
  \widetilde{h_{t}}=act_{c}(W_{cx}x_{t}+W_{ch}(r_{t}\odot h_{t-1})+b_c)
.. math::
  h_t=(1-u_t)\odot h_{t-1}+u_t\odot \widetilde{h_t}

H
Hao Wang 已提交
3463 3464 3465 3466 3467 3468 3469 3470 3471 3472 3473 3474 3475 3476 3477 3478 3479 3480



如果origin_mode为True,那么运算公式来自于 `Learning Phrase Representations using RNN Encoder Decoder for Statistical Machine Translation <https://arxiv.org/pdf/1406.1078.pdf>`_



公式如下:

.. math::
    u_t & = act_g(W_{ux}x_{t} + W_{uh}h_{t-1} + b_u)\\
    r_t & = act_g(W_{rx}x_{t} + W_{rh}h_{t-1} + b_r)\\
    \tilde{h_t} & = act_c(W_{cx}x_{t} + W_{ch}(r_t \odot h_{t-1}) + b_c)\\
    h_t & = u_t \odot h_{t-1} + (1-u_t) \odot \tilde{h_t}




C
Cheerego 已提交
3481 3482 3483 3484 3485 3486 3487 3488 3489
其中, :math:`\odot` 为按元素将向量相乘。 :math:`act_g` 是更新门(update gate)和重置门(reset gate)的激励函数(activation), 常为 :math:`sigmoid` 函数。 :math:`act_c` 是candidate hidden state(候选隐藏状态)的激励函数,常为 :math:`tanh` 。

注意 :math:`W_{ux}x_{t},W_{rx}x_{t},W_{cx}x_{t}` 这些在 input  :math:`x_t` 上的操作不包括在该运算中。用户可以选择性地在GRU层之前使用FC层来进行这一操作。



参数:
  - **input** (Variable) – dynamic_gru层的输入, 支持variable time length input sequence(可变时长输入序列)。 本变量底层的tensor是一个(T×3D)矩阵, 其中T是该mini-batch中总时间步数, D是隐藏状态的规模(hidden size)。
  - **size** (int) – GRU cell的维度
C
Cheerego 已提交
3490
  - **param_attr** (ParamAttr|None)  –  可学习的隐藏层权重矩阵的参数属性。
C
Cheerego 已提交
3491 3492 3493 3494 3495 3496 3497 3498 3499
    注意:
                                    - 该矩阵为一个(T X 3D)矩阵。其中D为隐藏状态的规模(hidden size)
                                    - 该矩阵的所有元素由两部分组成。一是update gate和reset gate的权重,形为(D X 2D),二是候选隐藏状态(candidate hidden state)的权重,形为 (D X D)
    如果该函数参数被设为None或者 ``ParamAttr`` 类的属性之一,则会生成一个 ``ParamAttr`` 类的对象作为param_attr。如果param_attr未被初始化(即其构造函数未被设置),Xavier会负责初始化它。 默认值为None。
  - **bias_attr** (ParamAttr|bool|None) - GRU层bias的参数属性。该(1 X 3D)形的bias变量将会连结(concatenate)在update gate(更新门)、reset gate(重置门)、candidate calculations(候选隐藏状态计算)后。如果值为False,将没有bias会应用到上述三个过程中。如果该函数参数被设为None或者 ``ParamAttr`` 类的属性之一, ``dynamic_gru`` 会生成一个 ``ParamAttr`` 类的对象作为param_attr。如果bias_attr未被初始化(即其构造函数未被设置),则它会被初始化为0。默认值为None。
  - **is_reverse** (bool) –是否计算反GRU(reversed GRU),默认为False
  - **gate_activation** (str) – update gate 和 reset gate的激励函数(activation)。 可选择[“sigmoid”, “tanh”, “relu”, “identity”]其一, 默认为 “sigmoid”
  - **candidate_activation** (str) – candidate hidden state(候选隐藏状态)计算所需的激励函数(activation)。 可从[“sigmoid”, “tanh”, “relu”, “identity”]中选择, 默认为 “tanh”
  - **h_0** (Variable) – 该函数参数为初始隐藏状态。若未赋值,则默认为0。它是一个 (N x D) tensor, 其中 N 为输入mini-batch的总时间步数, D 为 隐藏状态规模(hidden size)
C
Cheerego 已提交
3500 3501


R
RaindragonD 已提交
3502
返回: GRU的隐藏状态(hidden state)。形为(T X D),序列长度和输入相同。
C
Cheerego 已提交
3503

R
RaindragonD 已提交
3504
返回类型: 变量(variable)
C
Cheerego 已提交
3505 3506 3507 3508 3509 3510


**代码示例**

..  code-block:: python

R
RaindragonD 已提交
3511 3512
    import paddle.fluid as fluid

C
Cheerego 已提交
3513 3514 3515 3516 3517 3518 3519 3520 3521 3522 3523 3524 3525 3526 3527 3528 3529 3530 3531 3532 3533 3534 3535 3536 3537 3538 3539 3540 3541 3542 3543 3544 3545 3546 3547 3548 3549 3550 3551 3552 3553 3554 3555 3556 3557 3558 3559 3560 3561 3562 3563 3564 3565 3566 3567 3568 3569 3570 3571 3572 3573 3574 3575 3576 3577 3578 3579 3580 3581 3582 3583 3584 3585 3586 3587 3588 3589 3590 3591 3592 3593 3594 3595 3596 3597 3598
    dict_dim, emb_dim = 128, 64
    data = fluid.layers.data(name='sequence', shape=[1],
                             dtype='int32', lod_level=1)
    emb = fluid.layers.embedding(input=data, size=[dict_dim, emb_dim])
    hidden_dim = 512
    x = fluid.layers.fc(input=emb, size=hidden_dim * 3)
    hidden = fluid.layers.dynamic_gru(input=x, size=hidden_dim)
















.. _cn_api_fluid_layers_dynamic_lstm:

dynamic_lstm
-------------------------------

.. py:function::  paddle.fluid.layers.dynamic_lstm(input, size, h_0=None, c_0=None, param_attr=None, bias_attr=None, use_peepholes=True, is_reverse=False, gate_activation='sigmoid', cell_activation='tanh', candidate_activation='tanh', dtype='float32', name=None)

LSTM,即Long-Short Term Memory(长短期记忆)运算。

默认实现方式为diagonal/peephole连接(https://arxiv.org/pdf/1402.1128.pdf),公式如下:


.. math::
      i_t=\sigma (W_{ix}x_{t}+W_{ih}h_{t-1}+W_{ic}c_{t-1}+b_i)
.. math::
      f_t=\sigma (W_{fx}x_{t}+W_{fh}h_{t-1}+W_{fc}c_{t-1}+b_f)
.. math::
      \widetilde{c_t}=act_g(W_{ct}x_{t}+W_{ch}h_{t-1}+b_{c})
.. math::
      o_t=\sigma (W_{ox}x_{t}+W_{oh}h_{t-1}+W_{oc}c_{t}+b_o)
.. math::
      c_t=f_t\odot c_{t-1}+i_t\odot \widetilde{c_t}
.. math::
      h_t=o_t\odot act_h(c_t)

W 代表了权重矩阵(weight matrix),例如 :math:`W_{xi}` 是从输入门(input gate)到输入的权重矩阵, :math:`W_{ic}` ,:math:`W_{fc}` ,  :math:`W_{oc}` 是对角权重矩阵(diagonal weight matrix),用于peephole连接。在此实现方式中,我们使用向量来代表这些对角权重矩阵。

其中:
      - :math:`b` 表示bias向量( :math:`b_i` 是输入门的bias向量)
      - :math:`σ` 是非线性激励函数(non-linear activations),比如逻辑sigmoid函数
      - :math:`i` ,:math:`f` ,:math:`o` 和 :math:`c` 分别为输入门(input gate),遗忘门(forget gate),输出门(output gate),以及神经元激励向量(cell activation vector)这些向量和神经元输出激励向量(cell output activation vector) :math:`h` 有相同的大小。
      - :math:`⊙` 意为按元素将两向量相乘
      - :math:`act_g` , :math:`act_h` 分别为神经元(cell)输入、输出的激励函数(activation)。常常使用tanh函数。
      - :math:`\widetilde{c_t}` 也被称为候选隐藏状态(candidate hidden state)。可根据当前输入和之前的隐藏状态计算而得

将 ``use_peepholes`` 设为False来禁用 peephole 连接方法。 公式等详细信息请参考 http://www.bioinf.jku.at/publications/older/2604.pdf 。

注意, :math:`W_{xi}x_t, W_{xf}x_t, W_{xc}x_t,W_{xo}x_t` 这些在输入 :math:`x_t` 上的操作不包括在此运算中。用户可以在LSTM operator之前选择使用全连接运算。




参数:
  - **input** (Variable) (LoDTensor) - LodTensor类型,支持variable time length input sequence(时长可变的输入序列)。 该LoDTensor中底层的tensor是一个形为(T X 4D)的矩阵,其中T为此mini-batch上的总共时间步数。D为隐藏层的大小、规模(hidden size)
  - **size** (int) – 4 * 隐藏层大小
  - **h_0** (Variable) – 最初的隐藏状态(hidden state),可选项。默认值为0。它是一个(N x D)张量,其中N是batch大小,D是隐藏层大小。
  - **c_0** (Variable) – 最初的神经元状态(cell state), 可选项。 默认值0。它是一个(N x D)张量, 其中N是batch大小。h_0和c_0仅可以同时为None,不能只其中一个为None。
  - **param_attr** (ParamAttr|None) – 可学习的隐藏层权重的参数属性。
    注意:
                      - Weights = :math:`\{W_{ch}, W_{ih},  W_{fh},  W_{oh} \}`
                      - 形为(D x 4D), 其中D是hidden size(隐藏层规模)

    如果它被设为None或者 ``ParamAttr`` 属性之一, dynamic_lstm会创建 ``ParamAttr`` 对象作为param_attr。如果没有对param_attr初始化(即构造函数没有被设置), Xavier会负责初始化参数。默认为None。
  - **bias_attr** (ParamAttr|None) – 可学习的bias权重的属性, 包含两部分,input-hidden bias weights(输入隐藏层的bias权重)和 peephole connections weights(peephole连接权重)。如果 ``use_peepholes`` 值为 ``True`` , 则意为使用peephole连接的权重。
    另外:
      - use_peepholes = False - Biases = :math:`\{ b_c,b_i,b_f,b_o \}` - 形为(1 x 4D)。
      - use_peepholes = True - Biases = :math:`\{ b_c,b_i,b_f,b_o,W_{ic},W_{fc},W_{oc} \}` - 形为 (1 x 7D)。

    如果它被设为None或 ``ParamAttr`` 的属性之一, ``dynamic_lstm`` 会创建一个 ``ParamAttr`` 对象作为bias_attr。 如果没有对bias_attr初始化(即构造函数没有被设置),bias会被初始化为0。默认值为None。
  - **use_peepholes** (bool) – (默认: True) 是否使用diagonal/peephole连接方式
  - **is_reverse** (bool) – (默认: False) 是否计算反LSTM(reversed LSTM)
  - **gate_activation** (str) – (默认: "sigmoid")应用于input gate(输入门),forget gate(遗忘门)和 output gate(输出门)的激励函数(activation),默认为sigmoid
  - **cell_activation** (str) – (默认: tanh)用于神经元输出的激励函数(activation), 默认为tanh
C
Cheerego 已提交
3599
  - **candidate_activation** (str) – (默认: tanh)candidate hidden state(候选隐藏状态)的激励函数(activation), 默认为tanh
C
Cheerego 已提交
3600 3601 3602 3603 3604 3605 3606 3607 3608 3609 3610 3611
  - **dtype** (str) – 即 Data type(数据类型)。 可以选择 [“float32”, “float64”],默认为“float32”
  - **name** (str|None) – 该层的命名,可选项。如果值为None, 将会自动对该层命名

返回:隐藏状态(hidden state),LSTM的神经元状态。两者都是(T x D)形,且LoD保持与输入一致

返回类型: 元组(tuple)


**代码示例**

..  code-block:: python

R
RaindragonD 已提交
3612 3613
  emb_dim = 256
  vocab_size = 10000
C
Cheerego 已提交
3614
  hidden_dim = 512
R
RaindragonD 已提交
3615 3616 3617 3618 3619 3620

  data = fluid.layers.data(name='x', shape=[1],
                 dtype='int32', lod_level=1)
  emb = fluid.layers.embedding(input=data, size=[vocab_size, emb_dim], is_sparse=True)
     
  forward_proj = fluid.layers.fc(input=emb, size=hidden_dim * 4,
C
Cheerego 已提交
3621 3622 3623 3624 3625 3626 3627 3628 3629 3630 3631 3632 3633 3634 3635 3636 3637 3638 3639 3640
                                 bias_attr=False)
  forward, _ = fluid.layers.dynamic_lstm(
      input=forward_proj, size=hidden_dim * 4, use_peepholes=False)













.. _cn_api_fluid_layers_dynamic_lstmp:

dynamic_lstmp
-------------------------------
Z
zy0531 已提交
3641
.. py:function:: paddle.fluid.layers.dynamic_lstmp(input, size, proj_size, param_attr=None, bias_attr=None, use_peepholes=True, is_reverse=False, gate_activation='sigmoid', cell_activation='tanh', candidate_activation='tanh', proj_activation='tanh', dtype='float32', name=None, h_0=None, c_0=None, cell_clip=None, proj_clip=None)
C
Cheerego 已提交
3642 3643 3644 3645 3646 3647 3648 3649 3650 3651 3652 3653 3654 3655 3656 3657 3658 3659 3660 3661 3662 3663 3664 3665 3666 3667 3668 3669 3670

动态LSTMP层(Dynamic LSTMP Layer)

LSTMP层(具有循环映射的LSTM)在LSTM层后有一个分离的映射层,从原始隐藏状态映射到较低维的状态,用来减少参数总数,减少LSTM计算复杂度,特别是输出单元相对较大的情况下。 `Long Short-Term Memory Recurrent Neural Network Architectures for Large Scale Acoustic Modeling <https://research.google.com/pubs/archive/43905.pdf>`_

公式如下:

.. math::

        i_t & = \sigma(W_{ix}x_{t} + W_{ir}r_{t-1} + W_{ic}c_{t-1} + b_i)\\
        f_t & = \sigma(W_{fx}x_{t} + W_{fr}r_{t-1} + W_{fc}c_{t-1} + b_f)\\
        \tilde{c_t} & = act_g(W_{cx}x_t + W_{cr}r_{t-1} + b_c)\\
        o_t & = \sigma(W_{ox}x_{t} + W_{or}r_{t-1} + W_{oc}c_t + b_o)\\
        c_t & = f_t \odot c_{t-1} + i_t \odot \tilde{c_t}\\
        h_t & = o_t \odot act_h(c_t)\\
        r_t & = \overline{act_h}(W_{rh}h_t)\\


在以上公式中:
    - :math:`W` : 代表权重矩阵(例如 :math:`W_{xi}` 是输入门道输入的权重矩阵)
    - :math:`W_{ic}` , :math:`W_{fc}` , :math:`W_{oc}`  : peephole connections的对角权重矩阵。在我们的实现中,外面用向量代表这些对角权重矩阵
    - :math:`b` : 代表偏差向量(例如 :math:`b_{i}` 是输入偏差向量)
    - :math:`\delta` : 激活函数,比如逻辑回归函数
    - :math:`i,f,o` 和 :math:`c` :分别代表输入门,遗忘门,输出门和cell激活函数向量,四者的大小和cell输出激活函数向量 :math:`h` 的四者大小相等
    - :math:`h` : 隐藏状态
    - :math:`r` : 隐藏状态的循环映射
    - :math:`\tilde{c_t}` : 候选隐藏状态
    - :math:`\odot` : 向量的元素状态生成
    - :math:`act_g` 和 :math:`act_h` : cell输入和cell输出激活函数,通常使用 :math:`tanh`
C
Cheerego 已提交
3671
    - :math:`\overline{act_h}` : 映射输出的激活函数,通常用 :math:`identity` 或等同的 :math:`act_h`
C
Cheerego 已提交
3672 3673 3674 3675 3676 3677 3678 3679 3680 3681 3682 3683 3684 3685 3686 3687 3688 3689 3690 3691 3692 3693 3694 3695 3696 3697 3698

将 ``use_peepholes`` 设置为False,断开窥视孔连接(peephole connection)。在此省略公式,详情请参照论文 `LONG SHORT-TERM MEMORY <http://www.bioinf.jku.at/publications/older/2604.pdf>`_ 。

注意输入 :math:`x_{t}` 中的 :math:`W_{xi}x_{t},W_{xf}x_{t},W_{xc}x_{t},W_{xo}x_{t}` 不在此操作符中。用户选择在LSTMP层之前使用全链接层。

参数:
    - **input** (Variable) - dynamic_lstmp层的输入,支持输入序列长度为变量的倍数。该变量的张量为一个矩阵,维度为(T X 4D),T为mini-batch的总时间步长,D是隐藏大小。
    - **size** (int) - 4*隐藏状态大小(hidden size)
    - **proj_size** (int) - 投影输出的大小
    - **param_attr** (ParamAttr|None) -   可学习hidden-hidden权重和投影权重的参数属性。
      说明:
        - Hidden-hidden (隐藏状态到隐藏状态)权重 = :math:`\{ W_{ch},W_{ih},W_{fh},W_{oh} \}`
        - hidden-hidden权重的权重矩阵为(P*4D),P是投影大小,D是隐藏大小。
        - 投影(Projection)权重 = :math:`\{ W_{rh} \}`
        - 投影权重的shape为(D\*P)

      如果设为None或者ParamAttr的一个属性,dynamic_lstm将创建ParamAttr为param_attr。如果param_attr的初始函数未设置,参数则初始化为Xavier。默认:None。
    - **bias_attr** (ParamAttr|None) - 可学习bias权重的bias属性,包含输入隐藏的bias权重和窥视孔连接权重(peephole connection),前提是use_peepholes设为True。

      说明:
        1.use_peepholes = False
            - Biases = { :math:`b_{c},b_{i},b_{f},b_{o}`}.
            - 维度为(1*4D)

        2.use_peepholes = True
            - Biases = { :math:`b_{c},b_{i},b_{f},b_{o},W_{ic},W_{fc},W_{oc}`}
            - 维度为(1*7D)
C
Cheerego 已提交
3699

C
Cheerego 已提交
3700
        如果设置为None或者ParamAttr的一个属性,dynamic_lstm将创建ParamAttr为bias_attr。bias_attr的初始函数未设置,bias则初始化为0.默认:None。
C
Cheerego 已提交
3701

C
Cheerego 已提交
3702 3703 3704 3705 3706 3707 3708
    - **use_peepholes** (bool) - 是否开启诊断/窥视孔链接,默认为True。
    - **is_reverse** (bool) - 是否计算反向LSTM,默认为False。
    - **gate_activation** (bool) - 输入门(input gate)、遗忘门(forget gate)和输出门(output gate)的激活函数。Choices = [“sigmoid”,“tanh”,“relu”,“identity”],默认“sigmoid”。
    - **cell_activation** (str) - cell输出的激活函数。Choices = [“sigmoid”,“tanh”,“relu”,“identity”],默认“tanh”。
    - **candidate_activation** (str) - 候选隐藏状态(candidate hidden state)的激活状态。Choices = [“sigmoid”,“tanh”,“relu”,“identity”],默认“tanh”。
    - **proj_activation** (str) - 投影输出的激活函数。Choices = [“sigmoid”,“tanh”,“relu”,“identity”],默认“tanh”。
    - **dtype** (str) - 数据类型。Choices = [“float32”,“float64”],默认“float32”。
Z
zy0531 已提交
3709
    - **name** (str|None) - 该层名称(可选)。若设为None,则自动为该层命名。
C
Cheerego 已提交
3710
    - **h_0** (Variable) - 初始隐藏状态是可选输入,默认为0。这是一个具有形状的张量(N x D),其中N是批大小,D是投影大小。
Z
zy0531 已提交
3711
    - **c_0** (Variable) - 初始cell状态是可选输入,默认为0。这是一个具有形状(N x D)的张量,其中N是批大小。h_0和c_0可以为空,但只能同时为空。
C
Cheerego 已提交
3712
    - **cell_clip** (float) - 如果提供该参数,则在单元输出激活之前,单元状态将被此值剪裁。
Z
zy0531 已提交
3713 3714
    - **proj_clip** (float) - 如果 num_proj > 0 并且 proj_clip 被提供,那么将投影值沿元素方向剪切到[-proj_clip,proj_clip]内

C
Cheerego 已提交
3715 3716 3717 3718 3719 3720 3721 3722 3723 3724 3725 3726 3727 3728 3729 3730 3731 3732 3733 3734 3735 3736 3737 3738 3739 3740 3741 3742 3743 3744 3745 3746 3747 3748 3749 3750 3751 3752 3753
返回:含有两个输出变量的元组,隐藏状态(hidden state)的投影和LSTMP的cell状态。投影的shape为(T*P),cell state的shape为(T*D),两者的LoD和输入相同。

返回类型:元组(tuple)

**代码示例**:

.. code-block:: python

    dict_dim, emb_dim = 128, 64
    data = fluid.layers.data(name='sequence', shape=[1],
                         dtype='int32', lod_level=1)
    emb = fluid.layers.embedding(input=data, size=[dict_dim, emb_dim])
    hidden_dim, proj_dim = 512, 256
    fc_out = fluid.layers.fc(input=emb, size=hidden_dim * 4,
                         act=None, bias_attr=None)
    proj_out, _ = fluid.layers.dynamic_lstmp(input=fc_out,
                                         size=hidden_dim * 4,
                                         proj_size=proj_dim,
                                         use_peepholes=False,
                                         is_reverse=True,
                                         cell_activation="tanh",
                                         proj_activation="tanh")











.. _cn_api_fluid_layers_edit_distance:


edit_distance
-------------------------------

3754
.. py:function:: paddle.fluid.layers.edit_distance(input,label,normalized=True,ignored_tokens=None)
C
Cheerego 已提交
3755

3756
编辑距离算子
C
Cheerego 已提交
3757 3758 3759 3760 3761 3762 3763 3764 3765 3766 3767 3768 3769 3770 3771 3772 3773 3774 3775 3776 3777 3778 3779 3780 3781 3782

计算一批给定字符串及其参照字符串间的编辑距离。编辑距离也称Levenshtein距离,通过计算从一个字符串变成另一个字符串所需的最少操作步骤来衡量两个字符串的相异度。这里的操作包括插入、删除和替换。

比如给定假设字符串A=“kitten”和参照字符串B=“sitting”,从A变换成B编辑距离为3,至少需要两次替换和一次插入:

“kitten”->“sitten”->“sittn”->“sitting”

输入为LoDTensor,包含假设字符串(带有表示批尺寸的总数)和分离信息(具体为LoD信息)。并且批尺寸大小的参照字符串和输入LoDTensor的顺序保持一致。

输出包含批尺寸大小的结果,代表一对字符串中每个字符串的编辑距离。如果Attr(normalized)为真,编辑距离则处以参照字符串的长度。

参数:
    - **input** (Variable)-假设字符串的索引
    - **label** (Variable)-参照字符串的索引
    - **normalized** (bool,默认为True)-表示是否用参照字符串的长度进行归一化
    - **ignored_tokens** (list<int>,默认为None)-计算编辑距离前需要移除的token
    - **name** (str)-该层名称,可选

返回:[batch_size,1]中序列到序列到编辑距离

返回类型:变量

**代码示例**:

.. code-block:: python

R
RaindragonD 已提交
3783 3784 3785 3786 3787 3788 3789 3790 3791 3792 3793 3794 3795 3796 3797 3798 3799 3800 3801 3802 3803 3804
    import paddle.fluid as fluid
    x = fluid.layers.data(name='x', shape=[1], dtype='int64')
    y = fluid.layers.data(name='y', shape=[1], dtype='int64')
    cost, _ = fluid.layers.edit_distance(input=x,label=y)

    cpu = fluid.core.CPUPlace()
    exe = fluid.Executor(cpu)
    exe.run(fluid.default_startup_program())

    import numpy
    x_ = numpy.random.randint(5, size=(2, 1)).astype('int64')
    y_ = numpy.random.randint(5, size=(2, 1)).astype('int64')
    
    print(x_)
    print(y_)
    
    x = fluid.create_lod_tensor(x_, [[2]], cpu)
    y = fluid.create_lod_tensor(y_, [[2]], cpu)
    
    outs = exe.run(feed={'x':x, 'y':y}, fetch_list=[cost.name])
    
    print(outs)
C
Cheerego 已提交
3805 3806 3807 3808 3809 3810 3811 3812 3813 3814 3815 3816 3817 3818 3819 3820 3821 3822 3823 3824 3825 3826 3827 3828 3829 3830 3831 3832









.. _cn_api_fluid_layers_elementwise_add:

elementwise_add
-------------------------------

.. py:function:: paddle.fluid.layers.elementwise_add(x, y, axis=-1, act=None, name=None)

逐元素相加算子

等式为:

.. math::
        Out = X + Y

- :math:`X` :任意维度的张量(Tensor).
- :math:`Y` :一个维度必须小于等于X维度的张量(Tensor)。
对于这个运算算子有2种情况:
        1. :math:`Y` 的形状(shape)与 :math:`X` 相同。
        2. :math:`Y` 的形状(shape)是 :math:`X` 的连续子序列。
C
Cheerego 已提交
3833

C
Cheerego 已提交
3834 3835 3836
对于情况2:
        1. 用 :math:`Y` 匹配 :math:`X` 的形状(shape),则 ``axis`` 为 :math:`Y` 传到 :math:`X` 上的起始维度索引。
        2. 如果 ``axis`` 为-1(默认值),则 :math:`axis= rank(X)-rank(Y)` 。
R
RaindragonD 已提交
3837
        3. 考虑到子序列, :math:`Y` 的大小为1的尾部维度将被忽略,例如shape(Y)=(2,1)=>(2)。
C
Cheerego 已提交
3838

C
Cheerego 已提交
3839 3840
例如:

R
RaindragonD 已提交
3841
..  code-block:: text
C
Cheerego 已提交
3842 3843 3844 3845 3846 3847 3848 3849 3850 3851 3852

        shape(X) = (2, 3, 4, 5), shape(Y) = (,)
        shape(X) = (2, 3, 4, 5), shape(Y) = (5,)
        shape(X) = (2, 3, 4, 5), shape(Y) = (4, 5), with axis=-1(default) or axis=2
        shape(X) = (2, 3, 4, 5), shape(Y) = (3, 4), with axis=1
        shape(X) = (2, 3, 4, 5), shape(Y) = (2), with axis=0
        shape(X) = (2, 3, 4, 5), shape(Y) = (2, 1), with axis=0

输入 :math:`X` 和 :math:`Y` 可以携带不同的LoD信息。但输出仅与输入 :math:`X` 共享LoD信息。

参数:
R
RaindragonD 已提交
3853 3854
        - **x** (Tensor)- 第一个输入张量(Tensor)。
        - **y** (Tensor)- 第二个输入张量(Tensor)。
C
Cheerego 已提交
3855
        - **axis** (INT)- (int,默认-1)。将Y传到X上的起始维度索引。
R
RaindragonD 已提交
3856
        - **act** (basestring | None)- 激活函数名称,应用于输出。
C
Cheerego 已提交
3857 3858 3859 3860
        - **name** (basestring | None)- 输出的名称。

返回:        元素运算的输出。

R
RaindragonD 已提交
3861
**代码示例**
C
Cheerego 已提交
3862

R
RaindragonD 已提交
3863
..  code-block:: python
C
Cheerego 已提交
3864

R
RaindragonD 已提交
3865 3866 3867 3868 3869 3870 3871 3872 3873 3874 3875 3876 3877 3878 3879 3880 3881 3882 3883 3884 3885 3886 3887 3888 3889 3890 3891 3892 3893 3894
    import paddle.fluid as fluid
    # 例1: shape(x) = (2, 3, 4, 5), shape(y) = (2, 3, 4, 5)
    x0 = fluid.layers.data(name="x0", shape=[2, 3, 4, 5], dtype='float32')
    y0 = fluid.layers.data(name="y0", shape=[2, 3, 4, 5], dtype='float32')
    z0 = fluid.layers.elementwise_add(x0, y0)
     
    # 例2: shape(X) = (2, 3, 4, 5), shape(Y) = (5)
    x1 = fluid.layers.data(name="x1", shape=[2, 3, 4, 5], dtype='float32')
    y1 = fluid.layers.data(name="y1", shape=[5], dtype='float32')
    z1 = fluid.layers.elementwise_add(x1, y1)
     
    # 例3: shape(X) = (2, 3, 4, 5), shape(Y) = (4, 5), with axis=-1(default) or axis=2
    x2 = fluid.layers.data(name="x2", shape=[2, 3, 4, 5], dtype='float32')
    y2 = fluid.layers.data(name="y2", shape=[4, 5], dtype='float32')
    z2 = fluid.layers.elementwise_add(x2, y2, axis=2)
     
    # 例4: shape(X) = (2, 3, 4, 5), shape(Y) = (3, 4), with axis=1
    x3 = fluid.layers.data(name="x3", shape=[2, 3, 4, 5], dtype='float32')
    y3 = fluid.layers.data(name="y3", shape=[3, 4], dtype='float32')
    z3 = fluid.layers.elementwise_add(x3, y3, axis=1)
     
    # 例5: shape(X) = (2, 3, 4, 5), shape(Y) = (2), with axis=0
    x4 = fluid.layers.data(name="x4", shape=[2, 3, 4, 5], dtype='float32')
    y4 = fluid.layers.data(name="y4", shape=[2], dtype='float32')
    z4 = fluid.layers.elementwise_add(x4, y4, axis=0)
     
    # 例6: shape(X) = (2, 3, 4, 5), shape(Y) = (2, 1), with axis=0
    x5 = fluid.layers.data(name="x5", shape=[2, 3, 4, 5], dtype='float32')
    y5 = fluid.layers.data(name="y5", shape=[2], dtype='float32')
    z5 = fluid.layers.elementwise_add(x5, y5, axis=0)
C
Cheerego 已提交
3895 3896 3897 3898 3899 3900 3901 3902 3903 3904 3905 3906 3907 3908 3909 3910 3911 3912 3913





.. _cn_api_fluid_layers_elementwise_div:

elementwise_div
-------------------------------

.. py:function:: paddle.fluid.layers.elementwise_div(x, y, axis=-1, act=None, name=None)

逐元素相除算子

等式是:

.. math::
        Out = X / Y

R
RaindragonD 已提交
3914 3915
- :math:`X` :任何维度的张量(Tensor)。
- :math:`Y` :维度必须小于或等于X维度的张量(Tensor)。
C
Cheerego 已提交
3916 3917 3918 3919 3920 3921 3922 3923

此运算算子有两种情况:
        1. :math:`Y` 的形状(shape)与 :math:`X` 相同。
        2. :math:`Y` 的形状(shape)是 :math:`X` 的连续子序列。

对于情况2:
        1. 用 :math:`Y` 匹配 :math:`X` 的形状(shape),其中 ``axis`` 将是 :math:`Y` 传到 :math:`X` 上的起始维度索引。
        2. 如果 ``axis`` 为-1(默认值),则 :math:`axis = rank(X)-rank(Y)` 。
R
RaindragonD 已提交
3924
        3. 考虑到子序列, :math:`Y` 的大小为1的尾部维度将被忽略,例如shape(Y)=(2,1)=>(2)。
C
Cheerego 已提交
3925 3926 3927

例如:

R
RaindragonD 已提交
3928 3929 3930 3931 3932 3933 3934 3935 3936 3937 3938 3939 3940 3941 3942 3943 3944 3945 3946 3947 3948 3949
..  code-block:: text

        shape(X) = (2, 3, 4, 5), shape(Y) = (,)
        shape(X) = (2, 3, 4, 5), shape(Y) = (5,)
        shape(X) = (2, 3, 4, 5), shape(Y) = (4, 5), with axis=-1(default) or axis=2
        shape(X) = (2, 3, 4, 5), shape(Y) = (3, 4), with axis=1
        shape(X) = (2, 3, 4, 5), shape(Y) = (2), with axis=0
        shape(X) = (2, 3, 4, 5), shape(Y) = (2, 1), with axis=0

输入 :math:`X` 和 :math:`Y` 可以携带不同的LoD信息。但输出仅与输入 :math:`X` 共享LoD信息。

参数:
        - **x** (Tensor)- 第一个输入张量(Tensor)。
        - **y** (Tensor)- 第二个输入张量(Tensor)。
        - **axis** (INT)- (int,默认-1)。将Y传到X上的起始维度索引。
        - **act** (basestring | None)- 激活函数名称,应用于输出。
        - **name** (basestring | None)- 输出的名称。

返回:        元素运算的输出。

**代码示例**

C
Cheerego 已提交
3950 3951
..  code-block:: python

R
RaindragonD 已提交
3952 3953 3954 3955 3956 3957 3958 3959 3960 3961 3962 3963 3964 3965 3966 3967 3968 3969 3970 3971 3972 3973 3974 3975 3976 3977 3978 3979 3980 3981 3982 3983 3984 3985 3986 3987 3988 3989 3990 3991 3992 3993 3994 3995 3996 3997 3998 3999 4000 4001 4002 4003 4004 4005 4006 4007 4008 4009 4010 4011 4012 4013 4014 4015 4016 4017 4018 4019 4020 4021 4022 4023 4024 4025
    import paddle.fluid as fluid
    # 例1: shape(x) = (2, 3, 4, 5), shape(y) = (2, 3, 4, 5)
    x0 = fluid.layers.data(name="x0", shape=[2, 3, 4, 5], dtype='float32')
    y0 = fluid.layers.data(name="y0", shape=[2, 3, 4, 5], dtype='float32')
    z0 = fluid.layers.elementwise_div(x0, y0)
     
    # 例2: shape(X) = (2, 3, 4, 5), shape(Y) = (5)
    x1 = fluid.layers.data(name="x1", shape=[2, 3, 4, 5], dtype='float32')
    y1 = fluid.layers.data(name="y1", shape=[5], dtype='float32')
    z1 = fluid.layers.elementwise_div(x1, y1)
     
    # 例3: shape(X) = (2, 3, 4, 5), shape(Y) = (4, 5), with axis=-1(default) or axis=2
    x2 = fluid.layers.data(name="x2", shape=[2, 3, 4, 5], dtype='float32')
    y2 = fluid.layers.data(name="y2", shape=[4, 5], dtype='float32')
    z2 = fluid.layers.elementwise_div(x2, y2, axis=2)
     
    # 例4: shape(X) = (2, 3, 4, 5), shape(Y) = (3, 4), with axis=1
    x3 = fluid.layers.data(name="x3", shape=[2, 3, 4, 5], dtype='float32')
    y3 = fluid.layers.data(name="y3", shape=[3, 4], dtype='float32')
    z3 = fluid.layers.elementwise_div(x3, y3, axis=1)
     
    # 例5: shape(X) = (2, 3, 4, 5), shape(Y) = (2), with axis=0
    x4 = fluid.layers.data(name="x4", shape=[2, 3, 4, 5], dtype='float32')
    y4 = fluid.layers.data(name="y4", shape=[2], dtype='float32')
    z4 = fluid.layers.elementwise_div(x4, y4, axis=0)
     
    # 例6: shape(X) = (2, 3, 4, 5), shape(Y) = (2, 1), with axis=0
    x5 = fluid.layers.data(name="x5", shape=[2, 3, 4, 5], dtype='float32')
    y5 = fluid.layers.data(name="y5", shape=[2], dtype='float32')
    z5 = fluid.layers.elementwise_div(x5, y5, axis=0)














.. _cn_api_fluid_layers_elementwise_floordiv:
    
elementwise_floordiv
-------------------------------

.. py:function:: paddle.fluid.layers.elementwise_floordiv(x, y, axis=-1, act=None, name=None)

FloorDiv运算。

等式是:

.. math::
        Out = X // Y

- :math:`X` :任何维度的张量(Tensor)。
- :math:`Y` :维度必须小于或等于X维度的张量(Tensor)。

此运算分两种情况:
        1. :math:`Y` 的形状(shape)与 :math:`X` 相同。
        2. :math:`Y` 的形状(shape)是 :math:`X` 的连续子序列。

对于情况2:
        1. 用 :math:`Y` 匹配 :math:`X` 的形状(shape),其中 ``axis`` 将是 :math:`Y` 传到 :math:`X` 上的起始维度索引。
        2. 如果 ``axis`` 为-1(默认值),则 :math:`axis = rank(X)-rank(Y)` 。
        3. 考虑到子序列, :math:`Y` 的大小为1的尾部维度将被忽略,例如shape(Y)=(2,1)=>(2)。

例如:

..  code-block:: text

C
Cheerego 已提交
4026 4027 4028 4029 4030 4031
        shape(X) = (2, 3, 4, 5), shape(Y) = (,)
        shape(X) = (2, 3, 4, 5), shape(Y) = (5,)
        shape(X) = (2, 3, 4, 5), shape(Y) = (4, 5), with axis=-1(default) or axis=2
        shape(X) = (2, 3, 4, 5), shape(Y) = (3, 4), with axis=1
        shape(X) = (2, 3, 4, 5), shape(Y) = (2), with axis=0
        shape(X) = (2, 3, 4, 5), shape(Y) = (2, 1), with axis=0
C
Cheerego 已提交
4032

C
Cheerego 已提交
4033 4034 4035
输入 :math:`X` 和 :math:`Y` 可以携带不同的LoD信息。但输出仅与输入 :math:`X` 共享LoD信息。

参数:
R
RaindragonD 已提交
4036 4037
        - **x** (Tensor)- 第一个输入张量(Tensor)。
        - **y** (Tensor)- 第二个输入张量(Tensor)。
C
Cheerego 已提交
4038
        - **axis** (INT)- (int,默认-1)。将Y传到X上的起始维度索引。
R
RaindragonD 已提交
4039
        - **act** (basestring | None)- 激活函数名称,应用于输出。
C
Cheerego 已提交
4040 4041 4042
        - **name** (basestring | None)- 输出的名称。

返回:        元素运算的输出。
C
Cheerego 已提交
4043 4044


R
RaindragonD 已提交
4045 4046 4047 4048 4049 4050 4051 4052 4053 4054 4055 4056 4057 4058 4059 4060 4061 4062 4063 4064 4065 4066 4067 4068
**代码示例**

..  code-block:: python

    import paddle.fluid as fluid
    # example 1: shape(x) = (2, 3, 4, 5), shape(y) = (2, 3, 4, 5)
    x0 = fluid.layers.data(name="x0", shape=[2, 3, 4, 5], dtype='float32')
    y0 = fluid.layers.data(name="y0", shape=[2, 3, 4, 5], dtype='float32')
    z0 = fluid.layers.elementwise_floordiv(x0, y0)

    # example 2: shape(X) = (2, 3, 4, 5), shape(Y) = (5)
    x1 = fluid.layers.data(name="x1", shape=[2, 3, 4, 5], dtype='float32')
    y1 = fluid.layers.data(name="y1", shape=[5], dtype='float32')
    z1 = fluid.layers.elementwise_floordiv(x1, y1)

    # example 3: shape(X) = (2, 3, 4, 5), shape(Y) = (4, 5), with axis=-1(default) or axis=2
    x2 = fluid.layers.data(name="x2", shape=[2, 3, 4, 5], dtype='float32')
    y2 = fluid.layers.data(name="y2", shape=[4, 5], dtype='float32')
    z2 = fluid.layers.elementwise_floordiv(x2, y2, axis=2)

    # example 4: shape(X) = (2, 3, 4, 5), shape(Y) = (3, 4), with axis=1
    x3 = fluid.layers.data(name="x3", shape=[2, 3, 4, 5], dtype='float32')
    y3 = fluid.layers.data(name="y3", shape=[3, 4], dtype='float32')
    z3 = fluid.layers.elementwise_floordiv(x3, y3, axis=1)
C
Cheerego 已提交
4069

R
RaindragonD 已提交
4070 4071 4072 4073
    # example 5: shape(X) = (2, 3, 4, 5), shape(Y) = (2), with axis=0
    x4 = fluid.layers.data(name="x4", shape=[2, 3, 4, 5], dtype='float32')
    y4 = fluid.layers.data(name="y4", shape=[2], dtype='float32')
    z4 = fluid.layers.elementwise_floordiv(x4, y4, axis=0)
C
Cheerego 已提交
4074

R
RaindragonD 已提交
4075 4076 4077 4078
    # example 6: shape(X) = (2, 3, 4, 5), shape(Y) = (2, 1), with axis=0
    x5 = fluid.layers.data(name="x5", shape=[2, 3, 4, 5], dtype='float32')
    y5 = fluid.layers.data(name="y5", shape=[2], dtype='float32')
    z5 = fluid.layers.elementwise_floordiv(x5, y5, axis=0)
C
Cheerego 已提交
4079 4080 4081 4082 4083 4084 4085 4086 4087 4088 4089 4090 4091 4092 4093 4094 4095 4096






.. _cn_api_fluid_layers_elementwise_max:

elementwise_max
-------------------------------

.. py:function:: paddle.fluid.layers.elementwise_max(x, y, axis=-1, act=None, name=None)
最大元素算子

等式是:

.. math::
        Out = max(X, Y)
C
Cheerego 已提交
4097

R
RaindragonD 已提交
4098 4099
- :math:`X` :任何维度的张量(Tensor)。
- :math:`Y` :维度必须小于或等于X维度的张量(Tensor)。
C
Cheerego 已提交
4100 4101 4102 4103 4104 4105 4106 4107

此运算算子有两种情况:
        1. :math:`Y` 的形状(shape)与 :math:`X` 相同。
        2. :math:`Y` 的形状(shape)是 :math:`X` 的连续子序列。

对于情况2:
        1. 用 :math:`Y` 匹配 :math:`X` 的形状(shape),其中 ``axis`` 将是 :math:`Y` 传到 :math:`X` 上的起始维度索引。
        2. 如果 ``axis`` 为-1(默认值),则 :math:`axis = rank(X)-rank(Y)` 。
R
RaindragonD 已提交
4108
        3. 考虑到子序列, :math:`Y` 的大小为1的尾部维度将被忽略,例如shape(Y)=(2,1)=>(2)。
C
Cheerego 已提交
4109 4110 4111

例如:

R
RaindragonD 已提交
4112
..  code-block:: text
C
Cheerego 已提交
4113 4114 4115 4116 4117 4118 4119

        shape(X) = (2, 3, 4, 5), shape(Y) = (,)
        shape(X) = (2, 3, 4, 5), shape(Y) = (5,)
        shape(X) = (2, 3, 4, 5), shape(Y) = (4, 5), with axis=-1(default) or axis=2
        shape(X) = (2, 3, 4, 5), shape(Y) = (3, 4), with axis=1
        shape(X) = (2, 3, 4, 5), shape(Y) = (2), with axis=0
        shape(X) = (2, 3, 4, 5), shape(Y) = (2, 1), with axis=0
C
Cheerego 已提交
4120

C
Cheerego 已提交
4121 4122 4123
输入X和Y可以携带不同的LoD信息。但输出仅与输入X共享LoD信息。

参数:
R
RaindragonD 已提交
4124 4125
        - **x** (Tensor)- 第一个输入张量(Tensor)。
        - **y** (Tensor)- 第二个输入张量(Tensor)。
C
Cheerego 已提交
4126
        - **axis** (INT)- (int,默认-1)。将Y传到X上的起始维度索引。
R
RaindragonD 已提交
4127
        - **act** (basestring | None)- 激活函数名称,应用于输出。
C
Cheerego 已提交
4128 4129
        - **name** (basestring | None)- 输出的名称。

C
Cheerego 已提交
4130 4131
返回:        元素运算的输出。

R
RaindragonD 已提交
4132 4133 4134
**代码示例**

..  code-block:: python
C
Cheerego 已提交
4135

R
RaindragonD 已提交
4136 4137 4138 4139 4140 4141 4142 4143 4144 4145 4146 4147 4148 4149 4150 4151 4152 4153 4154 4155 4156 4157 4158 4159 4160 4161 4162 4163 4164 4165
    import paddle.fluid as fluid
    # 例1: shape(x) = (2, 3, 4, 5), shape(y) = (2, 3, 4, 5)
    x0 = fluid.layers.data(name="x0", shape=[2, 3, 4, 5], dtype='float32')
    y0 = fluid.layers.data(name="y0", shape=[2, 3, 4, 5], dtype='float32')
    z0 = fluid.layers.elementwise_max(x0, y0)
     
    # 例2: shape(X) = (2, 3, 4, 5), shape(Y) = (5)
    x1 = fluid.layers.data(name="x1", shape=[2, 3, 4, 5], dtype='float32')
    y1 = fluid.layers.data(name="y1", shape=[5], dtype='float32')
    z1 = fluid.layers.elementwise_max(x1, y1)
     
    # 例3: shape(X) = (2, 3, 4, 5), shape(Y) = (4, 5), with axis=-1(default) or axis=2
    x2 = fluid.layers.data(name="x2", shape=[2, 3, 4, 5], dtype='float32')
    y2 = fluid.layers.data(name="y2", shape=[4, 5], dtype='float32')
    z2 = fluid.layers.elementwise_max(x2, y2, axis=2)
     
    # 例4: shape(X) = (2, 3, 4, 5), shape(Y) = (3, 4), with axis=1
    x3 = fluid.layers.data(name="x3", shape=[2, 3, 4, 5], dtype='float32')
    y3 = fluid.layers.data(name="y3", shape=[3, 4], dtype='float32')
    z3 = fluid.layers.elementwise_max(x3, y3, axis=1)
     
    # 例5: shape(X) = (2, 3, 4, 5), shape(Y) = (2), with axis=0
    x4 = fluid.layers.data(name="x4", shape=[2, 3, 4, 5], dtype='float32')
    y4 = fluid.layers.data(name="y4", shape=[2], dtype='float32')
    z4 = fluid.layers.elementwise_max(x4, y4, axis=0)
     
    # 例6: shape(X) = (2, 3, 4, 5), shape(Y) = (2, 1), with axis=0
    x5 = fluid.layers.data(name="x5", shape=[2, 3, 4, 5], dtype='float32')
    y5 = fluid.layers.data(name="y5", shape=[2], dtype='float32')
    z5 = fluid.layers.elementwise_max(x5, y5, axis=0)
C
Cheerego 已提交
4166 4167 4168 4169 4170 4171 4172 4173 4174 4175 4176 4177 4178 4179 4180 4181 4182 4183 4184 4185 4186








.. _cn_api_fluid_layers_elementwise_min:

elementwise_min
-------------------------------

.. py:function:: paddle.fluid.layers.elementwise_min(x, y, axis=-1, act=None, name=None)

最小元素算子

等式是:

.. math::
        Out = min(X, Y)
C
Cheerego 已提交
4187

R
RaindragonD 已提交
4188 4189
- :math:`X` :任何维度的张量(Tensor)。
- :math:`Y` :维度必须小于或等于X维度的张量(Tensor)。
C
Cheerego 已提交
4190 4191 4192 4193 4194 4195 4196 4197

此运算算子有两种情况:
        1. :math:`Y` 的形状(shape)与 :math:`X` 相同。
        2. :math:`Y` 的形状(shape)是 :math:`X` 的连续子序列。

对于情况2:
        1. 用 :math:`Y` 匹配 :math:`X` 的形状(shape),其中 ``axis`` 将是 :math:`Y` 传到 :math:`X` 上的起始维度索引。
        2. 如果 ``axis`` 为-1(默认值),则 :math:`axis = rank(X)-rank(Y)` 。
R
RaindragonD 已提交
4198
        3. 考虑到子序列, :math:`Y` 的大小为1的尾部维度将被忽略,例如shape(Y)=(2,1)=>(2)。
C
Cheerego 已提交
4199 4200 4201

例如:

R
RaindragonD 已提交
4202
..  code-block:: text
C
Cheerego 已提交
4203 4204 4205 4206 4207 4208 4209

        shape(X) = (2, 3, 4, 5), shape(Y) = (,)
        shape(X) = (2, 3, 4, 5), shape(Y) = (5,)
        shape(X) = (2, 3, 4, 5), shape(Y) = (4, 5), with axis=-1(default) or axis=2
        shape(X) = (2, 3, 4, 5), shape(Y) = (3, 4), with axis=1
        shape(X) = (2, 3, 4, 5), shape(Y) = (2), with axis=0
        shape(X) = (2, 3, 4, 5), shape(Y) = (2, 1), with axis=0
C
Cheerego 已提交
4210

C
Cheerego 已提交
4211 4212 4213
输入X和Y可以携带不同的LoD信息。但输出仅与输入X共享LoD信息。

参数:
R
RaindragonD 已提交
4214 4215
        - **x** (Tensor)- 第一个输入张量(Tensor)。
        - **y** (Tensor)- 第二个输入张量(Tensor)。
C
Cheerego 已提交
4216
        - **axis** (INT)- (int,默认-1)。将Y传到X上的起始维度索引。
R
RaindragonD 已提交
4217
        - **act** (basestring | None)- 激活函数名称,应用于输出。
C
Cheerego 已提交
4218 4219
        - **name** (basestring | None)- 输出的名称。

C
Cheerego 已提交
4220 4221
返回:        元素运算的输出。

R
RaindragonD 已提交
4222 4223 4224 4225 4226 4227 4228 4229 4230 4231 4232 4233 4234 4235 4236 4237 4238 4239 4240 4241 4242 4243 4244 4245 4246 4247 4248 4249 4250 4251 4252 4253 4254 4255 4256 4257 4258 4259 4260 4261 4262 4263 4264 4265 4266 4267 4268 4269 4270 4271 4272 4273 4274 4275 4276 4277 4278 4279 4280 4281 4282 4283 4284 4285 4286 4287 4288 4289 4290 4291 4292 4293 4294 4295 4296 4297 4298 4299 4300 4301 4302 4303 4304 4305 4306 4307 4308 4309 4310 4311
**代码示例**

..  code-block:: python

    import paddle.fluid as fluid
    # 例1: shape(x) = (2, 3, 4, 5), shape(y) = (2, 3, 4, 5)
    x0 = fluid.layers.data(name="x0", shape=[2, 3, 4, 5], dtype='float32')
    y0 = fluid.layers.data(name="y0", shape=[2, 3, 4, 5], dtype='float32')
    z0 = fluid.layers.elementwise_min(x0, y0)
     
    # 例2: shape(X) = (2, 3, 4, 5), shape(Y) = (5)
    x1 = fluid.layers.data(name="x1", shape=[2, 3, 4, 5], dtype='float32')
    y1 = fluid.layers.data(name="y1", shape=[5], dtype='float32')
    z1 = fluid.layers.elementwise_min(x1, y1)
     
    # 例3: shape(X) = (2, 3, 4, 5), shape(Y) = (4, 5), with axis=-1(default) or axis=2
    x2 = fluid.layers.data(name="x2", shape=[2, 3, 4, 5], dtype='float32')
    y2 = fluid.layers.data(name="y2", shape=[4, 5], dtype='float32')
    z2 = fluid.layers.elementwise_min(x2, y2, axis=2)
     
    # 例4: shape(X) = (2, 3, 4, 5), shape(Y) = (3, 4), with axis=1
    x3 = fluid.layers.data(name="x3", shape=[2, 3, 4, 5], dtype='float32')
    y3 = fluid.layers.data(name="y3", shape=[3, 4], dtype='float32')
    z3 = fluid.layers.elementwise_min(x3, y3, axis=1)
     
    # 例5: shape(X) = (2, 3, 4, 5), shape(Y) = (2), with axis=0
    x4 = fluid.layers.data(name="x4", shape=[2, 3, 4, 5], dtype='float32')
    y4 = fluid.layers.data(name="y4", shape=[2], dtype='float32')
    z4 = fluid.layers.elementwise_min(x4, y4, axis=0)
     
    # 例6: shape(X) = (2, 3, 4, 5), shape(Y) = (2, 1), with axis=0
    x5 = fluid.layers.data(name="x5", shape=[2, 3, 4, 5], dtype='float32')
    y5 = fluid.layers.data(name="y5", shape=[2], dtype='float32')
    z5 = fluid.layers.elementwise_min(x5, y5, axis=0)
     





.. _cn_api_fluid_layers_elementwise_mod:
    
elementwise_mod
-------------------------------

.. py:function:: paddle.fluid.layers.elementwise_mod(x, y, axis=-1, act=None, name=None)

按元素的取模运算。

等式是:

.. math::
        Out = X\%Y

- :math:`X` :任何维度的张量(Tensor)。
- :math:`Y` :维度必须小于或等于X维度的张量(Tensor)。

此运算算子有两种情况:
        1. :math:`Y` 的形状(shape)与 :math:`X` 相同。
        2. :math:`Y` 的形状(shape)是 :math:`X` 的连续子序列。

对于情况2:
        1. 用 :math:`Y` 匹配 :math:`X` 的形状(shape),其中 ``axis`` 将是 :math:`Y` 传到 :math:`X` 上的起始维度索引。
        2. 如果 ``axis`` 为-1(默认值),则 :math:`axis = rank(X)-rank(Y)` 。
        3. 考虑到子序列, :math:`Y` 的大小为1的尾随维度将被忽略,例如shape(Y)=(2,1)=>(2)。

例如:

..  code-block:: text

        shape(X) = (2, 3, 4, 5), shape(Y) = (,)
        shape(X) = (2, 3, 4, 5), shape(Y) = (5,)
        shape(X) = (2, 3, 4, 5), shape(Y) = (4, 5), with axis=-1(default) or axis=2
        shape(X) = (2, 3, 4, 5), shape(Y) = (3, 4), with axis=1
        shape(X) = (2, 3, 4, 5), shape(Y) = (2), with axis=0
        shape(X) = (2, 3, 4, 5), shape(Y) = (2, 1), with axis=0

输入X和Y可以携带不同的LoD信息。但输出仅与输入X共享LoD信息。

参数:
        - **x** (Tensor)- 第一个输入张量(Tensor)。
        - **y** (Tensor)- 第二个输入张量(Tensor)。
        - **axis** (INT)- (int,默认-1)。将Y传到X上的起始维度索引。
        - **act** (basestring | None)- 激活函数名称,应用于输出。
        - **name** (basestring | None)- 输出的名称。

返回:        元素运算的输出。
    
    
**代码示例**
C
Cheerego 已提交
4312

R
RaindragonD 已提交
4313 4314 4315 4316 4317 4318 4319
..  code-block:: python
  
    import paddle.fluid as fluid
    # example 1: shape(x) = (2, 3, 4, 5), shape(y) = (2, 3, 4, 5)
    x0 = fluid.layers.data(name="x0", shape=[2, 3, 4, 5], dtype='float32')
    y0 = fluid.layers.data(name="y0", shape=[2, 3, 4, 5], dtype='float32')
    z0 = fluid.layers.elementwise_mod(x0, y0)
C
Cheerego 已提交
4320

R
RaindragonD 已提交
4321 4322 4323 4324
    # example 2: shape(X) = (2, 3, 4, 5), shape(Y) = (5)
    x1 = fluid.layers.data(name="x1", shape=[2, 3, 4, 5], dtype='float32')
    y1 = fluid.layers.data(name="y1", shape=[5], dtype='float32')
    z1 = fluid.layers.elementwise_mod(x1, y1)
C
Cheerego 已提交
4325

R
RaindragonD 已提交
4326 4327 4328 4329
    # example 3: shape(X) = (2, 3, 4, 5), shape(Y) = (4, 5), with axis=-1(default) or axis=2
    x2 = fluid.layers.data(name="x2", shape=[2, 3, 4, 5], dtype='float32')
    y2 = fluid.layers.data(name="y2", shape=[4, 5], dtype='float32')
    z2 = fluid.layers.elementwise_mod(x2, y2, axis=2)
C
Cheerego 已提交
4330

R
RaindragonD 已提交
4331 4332 4333 4334
    # example 4: shape(X) = (2, 3, 4, 5), shape(Y) = (3, 4), with axis=1
    x3 = fluid.layers.data(name="x3", shape=[2, 3, 4, 5], dtype='float32')
    y3 = fluid.layers.data(name="y3", shape=[3, 4], dtype='float32')
    z3 = fluid.layers.elementwise_mod(x3, y3, axis=1)
C
Cheerego 已提交
4335

R
RaindragonD 已提交
4336 4337 4338 4339
    # example 5: shape(X) = (2, 3, 4, 5), shape(Y) = (2), with axis=0
    x4 = fluid.layers.data(name="x4", shape=[2, 3, 4, 5], dtype='float32')
    y4 = fluid.layers.data(name="y4", shape=[2], dtype='float32')
    z4 = fluid.layers.elementwise_mod(x4, y4, axis=0)
C
Cheerego 已提交
4340

R
RaindragonD 已提交
4341 4342 4343 4344
    # example 6: shape(X) = (2, 3, 4, 5), shape(Y) = (2, 1), with axis=0
    x5 = fluid.layers.data(name="x5", shape=[2, 3, 4, 5], dtype='float32')
    y5 = fluid.layers.data(name="y5", shape=[2], dtype='float32')
    z5 = fluid.layers.elementwise_mod(x5, y5, axis=0)
C
Cheerego 已提交
4345 4346 4347 4348 4349 4350 4351 4352 4353 4354 4355 4356 4357 4358 4359 4360



.. _cn_api_fluid_layers_elementwise_mul:

elementwise_mul
-------------------------------

.. py:function:: paddle.fluid.layers.elementwise_mul(x, y, axis=-1, act=None, name=None)

逐元素相乘算子

等式是:

.. math::
        Out = X \odot Y
C
Cheerego 已提交
4361

R
RaindragonD 已提交
4362 4363
- :math:`X` :任何维度的张量(Tensor)。
- :math:`Y` :维度必须小于或等于X维度的张量(Tensor)。
C
Cheerego 已提交
4364 4365 4366 4367 4368 4369 4370 4371

此运算算子有两种情况:
        1. :math:`Y` 的形状(shape)与 :math:`X` 相同。
        2. :math:`Y` 的形状(shape)是 :math:`X` 的连续子序列。

对于情况2:
        1. 用 :math:`Y` 匹配 :math:`X` 的形状(shape),其中 ``axis`` 将是 :math:`Y` 传到 :math:`X` 上的起始维度索引。
        2. 如果 ``axis`` 为-1(默认值),则 :math:`axis = rank(X)-rank(Y)` 。
R
RaindragonD 已提交
4372
        3. 考虑到子序列, :math:`Y` 的大小为1的尾随维度将被忽略,例如shape(Y)=(2,1)=>(2)。
C
Cheerego 已提交
4373

C
Cheerego 已提交
4374 4375
例如:

R
RaindragonD 已提交
4376
..  code-block:: text
C
Cheerego 已提交
4377 4378 4379 4380 4381 4382 4383

        shape(X) = (2, 3, 4, 5), shape(Y) = (,)
        shape(X) = (2, 3, 4, 5), shape(Y) = (5,)
        shape(X) = (2, 3, 4, 5), shape(Y) = (4, 5), with axis=-1(default) or axis=2
        shape(X) = (2, 3, 4, 5), shape(Y) = (3, 4), with axis=1
        shape(X) = (2, 3, 4, 5), shape(Y) = (2), with axis=0
        shape(X) = (2, 3, 4, 5), shape(Y) = (2, 1), with axis=0
C
Cheerego 已提交
4384

C
Cheerego 已提交
4385 4386 4387
输入X和Y可以携带不同的LoD信息。但输出仅与输入X共享LoD信息。

参数:
R
RaindragonD 已提交
4388 4389
        - **x** (Tensor)- 第一个输入张量(Tensor)。
        - **y** (Tensor)- 第二个输入张量(Tensor)。
C
Cheerego 已提交
4390
        - **axis** (INT)- (int,默认-1)。将Y传到X上的起始维度索引。
R
RaindragonD 已提交
4391
        - **act** (basestring | None)- 激活函数名称,应用于输出。
C
Cheerego 已提交
4392 4393
        - **name** (basestring | None)- 输出的名称。

C
Cheerego 已提交
4394 4395
返回:        元素运算的输出。

R
RaindragonD 已提交
4396 4397 4398
**代码示例**

..  code-block:: python
C
Cheerego 已提交
4399

R
RaindragonD 已提交
4400 4401 4402 4403 4404 4405 4406 4407 4408 4409 4410 4411 4412 4413 4414 4415 4416 4417 4418 4419 4420 4421 4422 4423 4424 4425 4426 4427 4428 4429
    import paddle.fluid as fluid
    # 例1: shape(x) = (2, 3, 4, 5), shape(y) = (2, 3, 4, 5)
    x0 = fluid.layers.data(name="x0", shape=[2, 3, 4, 5], dtype='float32')
    y0 = fluid.layers.data(name="y0", shape=[2, 3, 4, 5], dtype='float32')
    z0 = fluid.layers.elementwise_mul(x0, y0)
     
    # 例2: shape(X) = (2, 3, 4, 5), shape(Y) = (5)
    x1 = fluid.layers.data(name="x1", shape=[2, 3, 4, 5], dtype='float32')
    y1 = fluid.layers.data(name="y1", shape=[5], dtype='float32')
    z1 = fluid.layers.elementwise_mul(x1, y1)
     
    # 例3: shape(X) = (2, 3, 4, 5), shape(Y) = (4, 5), with axis=-1(default) or axis=2
    x2 = fluid.layers.data(name="x2", shape=[2, 3, 4, 5], dtype='float32')
    y2 = fluid.layers.data(name="y2", shape=[4, 5], dtype='float32')
    z2 = fluid.layers.elementwise_mul(x2, y2, axis=2)
     
    # 例4: shape(X) = (2, 3, 4, 5), shape(Y) = (3, 4), with axis=1
    x3 = fluid.layers.data(name="x3", shape=[2, 3, 4, 5], dtype='float32')
    y3 = fluid.layers.data(name="y3", shape=[3, 4], dtype='float32')
    z3 = fluid.layers.elementwise_mul(x3, y3, axis=1)
     
    # 例5: shape(X) = (2, 3, 4, 5), shape(Y) = (2), with axis=0
    x4 = fluid.layers.data(name="x4", shape=[2, 3, 4, 5], dtype='float32')
    y4 = fluid.layers.data(name="y4", shape=[2], dtype='float32')
    z4 = fluid.layers.elementwise_mul(x4, y4, axis=0)
     
    # 例6: shape(X) = (2, 3, 4, 5), shape(Y) = (2, 1), with axis=0
    x5 = fluid.layers.data(name="x5", shape=[2, 3, 4, 5], dtype='float32')
    y5 = fluid.layers.data(name="y5", shape=[2], dtype='float32')
    z5 = fluid.layers.elementwise_mul(x5, y5, axis=0)
C
Cheerego 已提交
4430 4431 4432 4433 4434 4435 4436 4437 4438 4439 4440 4441 4442 4443 4444 4445 4446 4447 4448 4449







.. _cn_api_fluid_layers_elementwise_pow:

elementwise_pow
-------------------------------

.. py:function:: paddle.fluid.layers.elementwise_pow(x, y, axis=-1, act=None, name=None)

逐元素幂运算算子

等式是:

.. math::
        Out = X ^ Y
C
Cheerego 已提交
4450

R
RaindragonD 已提交
4451 4452
- :math:`X` :任何维度的张量(Tensor)。
- :math:`Y` :维度必须小于或等于X维度的张量(Tensor)。
C
Cheerego 已提交
4453 4454 4455 4456 4457 4458 4459 4460

此运算算子有两种情况:
        1. :math:`Y` 的形状(shape)与 :math:`X` 相同。
        2. :math:`Y` 的形状(shape)是 :math:`X` 的连续子序列。

对于情况2:
        1. 用 :math:`Y` 匹配 :math:`X` 的形状(shape),其中 ``axis`` 将是 :math:`Y` 传到 :math:`X` 上的起始维度索引。
        2. 如果 ``axis`` 为-1(默认值),则 :math:`axis = rank(X)-rank(Y)` 。
R
RaindragonD 已提交
4461
        3. 考虑到子序列, :math:`Y` 的大小为1的尾随维度将被忽略,例如shape(Y)=(2,1)=>(2)。
C
Cheerego 已提交
4462

R
RaindragonD 已提交
4463
**代码示例**
C
Cheerego 已提交
4464

R
RaindragonD 已提交
4465
..  code-block:: text
C
Cheerego 已提交
4466 4467 4468 4469 4470 4471 4472

        shape(X) = (2, 3, 4, 5), shape(Y) = (,)
        shape(X) = (2, 3, 4, 5), shape(Y) = (5,)
        shape(X) = (2, 3, 4, 5), shape(Y) = (4, 5), with axis=-1(default) or axis=2
        shape(X) = (2, 3, 4, 5), shape(Y) = (3, 4), with axis=1
        shape(X) = (2, 3, 4, 5), shape(Y) = (2), with axis=0
        shape(X) = (2, 3, 4, 5), shape(Y) = (2, 1), with axis=0
C
Cheerego 已提交
4473

C
Cheerego 已提交
4474 4475 4476
输入X和Y可以携带不同的LoD信息。但输出仅与输入X共享LoD信息。

参数:
R
RaindragonD 已提交
4477 4478
        - **x** (Tensor)- 第一个输入张量(Tensor)。
        - **y** (Tensor)- 第二个输入张量(Tensor)。
C
Cheerego 已提交
4479
        - **axis** (INT)- (int,默认-1)。将Y传到X上的起始维度索引。
R
RaindragonD 已提交
4480
        - **act** (basestring | None)- 激活函数名称,应用于输出。
C
Cheerego 已提交
4481 4482
        - **name** (basestring | None)- 输出的名称。

C
Cheerego 已提交
4483 4484
返回:        元素运算的输出。

R
RaindragonD 已提交
4485 4486 4487
**代码示例**

..  code-block:: python
C
Cheerego 已提交
4488

R
RaindragonD 已提交
4489 4490 4491 4492 4493 4494 4495 4496 4497 4498 4499 4500 4501 4502 4503 4504 4505 4506 4507 4508 4509 4510 4511 4512 4513 4514 4515 4516 4517
    # 例1: shape(x) = (2, 3, 4, 5), shape(y) = (2, 3, 4, 5)
    x0 = fluid.layers.data(name="x0", shape=[2, 3, 4, 5], dtype='float32')
    y0 = fluid.layers.data(name="y0", shape=[2, 3, 4, 5], dtype='float32')
    z0 = fluid.layers.elementwise_pow(x0, y0)
     
    # 例2: shape(X) = (2, 3, 4, 5), shape(Y) = (5)
    x1 = fluid.layers.data(name="x1", shape=[2, 3, 4, 5], dtype='float32')
    y1 = fluid.layers.data(name="y1", shape=[5], dtype='float32')
    z1 = fluid.layers.elementwise_pow(x1, y1)
     
    # 例3: shape(X) = (2, 3, 4, 5), shape(Y) = (4, 5), with axis=-1(default) or axis=2
    x2 = fluid.layers.data(name="x2", shape=[2, 3, 4, 5], dtype='float32')
    y2 = fluid.layers.data(name="y2", shape=[4, 5], dtype='float32')
    z2 = fluid.layers.elementwise_pow(x2, y2, axis=2)
     
    # 例4: shape(X) = (2, 3, 4, 5), shape(Y) = (3, 4), with axis=1
    x3 = fluid.layers.data(name="x3", shape=[2, 3, 4, 5], dtype='float32')
    y3 = fluid.layers.data(name="y3", shape=[3, 4], dtype='float32')
    z3 = fluid.layers.elementwise_pow(x3, y3, axis=1)
     
    # 例5: shape(X) = (2, 3, 4, 5), shape(Y) = (2), with axis=0
    x4 = fluid.layers.data(name="x4", shape=[2, 3, 4, 5], dtype='float32')
    y4 = fluid.layers.data(name="y4", shape=[2], dtype='float32')
    z4 = fluid.layers.elementwise_pow(x4, y4, axis=0)
     
    # 例6: shape(X) = (2, 3, 4, 5), shape(Y) = (2, 1), with axis=0
    x5 = fluid.layers.data(name="x5", shape=[2, 3, 4, 5], dtype='float32')
    y5 = fluid.layers.data(name="y5", shape=[2], dtype='float32')
    z5 = fluid.layers.elementwise_pow(x5, y5, axis=0)
C
Cheerego 已提交
4518 4519 4520 4521 4522 4523 4524 4525 4526 4527 4528 4529 4530 4531 4532 4533 4534 4535 4536 4537 4538








.. _cn_api_fluid_layers_elementwise_sub:

elementwise_sub
-------------------------------

.. py:function:: paddle.fluid.layers.elementwise_sub(x, y, axis=-1, act=None, name=None)

逐元素相减算子

等式是:

.. math::
       Out = X - Y
C
Cheerego 已提交
4539

R
RaindragonD 已提交
4540 4541
- **X** :任何维度的张量(Tensor)。
- **Y** :维度必须小于或等于**X**维度的张量(Tensor)。
C
Cheerego 已提交
4542 4543 4544 4545 4546 4547 4548 4549

此运算算子有两种情况:
        1. :math:`Y` 的形状(shape)与 :math:`X` 相同。
        2. :math:`Y` 的形状(shape)是 :math:`X` 的连续子序列。

对于情况2:
        1. 用 :math:`Y` 匹配 :math:`X` 的形状(shape),其中 ``axis`` 将是 :math:`Y` 传到 :math:`X` 上的起始维度索引。
        2. 如果 ``axis`` 为-1(默认值),则 :math:`axis = rank(X)-rank(Y)` 。
R
RaindragonD 已提交
4550
        3. 考虑到子序列, :math:`Y` 的大小为1的尾随维度将被忽略,例如shape(Y)=(2,1)=>(2)。
C
Cheerego 已提交
4551

C
Cheerego 已提交
4552 4553
例如:

R
RaindragonD 已提交
4554
..  code-block:: text
C
Cheerego 已提交
4555 4556 4557 4558 4559 4560 4561

        shape(X) = (2, 3, 4, 5), shape(Y) = (,)
        shape(X) = (2, 3, 4, 5), shape(Y) = (5,)
        shape(X) = (2, 3, 4, 5), shape(Y) = (4, 5), with axis=-1(default) or axis=2
        shape(X) = (2, 3, 4, 5), shape(Y) = (3, 4), with axis=1
        shape(X) = (2, 3, 4, 5), shape(Y) = (2), with axis=0
        shape(X) = (2, 3, 4, 5), shape(Y) = (2, 1), with axis=0
C
Cheerego 已提交
4562

C
Cheerego 已提交
4563 4564 4565
输入X和Y可以携带不同的LoD信息。但输出仅与输入X共享LoD信息。

参数:
R
RaindragonD 已提交
4566 4567
        - **x** (Tensor)- 第一个输入张量(Tensor)。
        - **y** (Tensor)- 第二个输入张量(Tensor)。
C
Cheerego 已提交
4568
        - **axis** (INT)- (int,默认-1)。将Y传到X上的起始维度索引。
R
RaindragonD 已提交
4569
        - **act** (basestring | None)- 激活函数名称,应用于输出。
C
Cheerego 已提交
4570 4571 4572
        - **name** (basestring | None)- 输出的名称。

返回:        元素运算的输出。
C
Cheerego 已提交
4573

R
RaindragonD 已提交
4574
**代码示例**
C
Cheerego 已提交
4575

R
RaindragonD 已提交
4576
..  code-block:: python
C
Cheerego 已提交
4577

R
RaindragonD 已提交
4578 4579 4580 4581 4582 4583 4584 4585 4586 4587 4588 4589 4590 4591 4592 4593 4594 4595 4596 4597 4598 4599 4600 4601 4602 4603 4604 4605 4606 4607
    import paddle.fluid as fluid
    # 例1: shape(x) = (2, 3, 4, 5), shape(y) = (2, 3, 4, 5)
    x0 = fluid.layers.data(name="x0", shape=[2, 3, 4, 5], dtype='float32')
    y0 = fluid.layers.data(name="y0", shape=[2, 3, 4, 5], dtype='float32')
    z0 = fluid.layers.elementwise_sub(x0, y0)
     
    # 例2: shape(X) = (2, 3, 4, 5), shape(Y) = (5)
    x1 = fluid.layers.data(name="x1", shape=[2, 3, 4, 5], dtype='float32')
    y1 = fluid.layers.data(name="y1", shape=[5], dtype='float32')
    z1 = fluid.layers.elementwise_sub(x1, y1)
     
    # 例3: shape(X) = (2, 3, 4, 5), shape(Y) = (4, 5), with axis=-1(default) or axis=2
    x2 = fluid.layers.data(name="x2", shape=[2, 3, 4, 5], dtype='float32')
    y2 = fluid.layers.data(name="y2", shape=[4, 5], dtype='float32')
    z2 = fluid.layers.elementwise_sub(x2, y2, axis=2)
     
    # 例4: shape(X) = (2, 3, 4, 5), shape(Y) = (3, 4), with axis=1
    x3 = fluid.layers.data(name="x3", shape=[2, 3, 4, 5], dtype='float32')
    y3 = fluid.layers.data(name="y3", shape=[3, 4], dtype='float32')
    z3 = fluid.layers.elementwise_sub(x3, y3, axis=1)
     
    # 例5: shape(X) = (2, 3, 4, 5), shape(Y) = (2), with axis=0
    x4 = fluid.layers.data(name="x4", shape=[2, 3, 4, 5], dtype='float32')
    y4 = fluid.layers.data(name="y4", shape=[2], dtype='float32')
    z4 = fluid.layers.elementwise_sub(x4, y4, axis=0)
     
    # 例6: shape(X) = (2, 3, 4, 5), shape(Y) = (2, 1), with axis=0
    x5 = fluid.layers.data(name="x5", shape=[2, 3, 4, 5], dtype='float32')
    y5 = fluid.layers.data(name="y5", shape=[2], dtype='float32')
    z5 = fluid.layers.elementwise_sub(x5, y5, axis=0)
C
Cheerego 已提交
4608 4609 4610 4611 4612 4613 4614 4615 4616 4617 4618 4619 4620 4621 4622





.. _cn_api_fluid_layers_elu:

elu
-------------------------------

.. py:function:: paddle.fluid.layers.elu(x, alpha=1.0, name=None)

ELU激活层(ELU Activation Operator)

根据 https://arxiv.org/abs/1511.07289 对输入张量中每个元素应用以下计算。
C
Cheerego 已提交
4623 4624

.. math::
C
Cheerego 已提交
4625 4626 4627 4628 4629 4630 4631 4632 4633 4634 4635
        \\out=max(0,x)+min(0,α∗(ex−1))\\

参数:
    - x(Variable)- ELU operator的输入
    - alpha(FAOAT|1.0)- ELU的alpha值
    - name (str|None) -这个层的名称(可选)。如果设置为None,该层将被自动命名。

返回: ELU操作符的输出

返回类型: 输出(Variable)

R
RaindragonD 已提交
4636
**代码示例**
C
Cheerego 已提交
4637 4638 4639 4640 4641 4642 4643 4644 4645 4646 4647 4648 4649 4650 4651 4652 4653 4654 4655 4656 4657 4658 4659 4660 4661 4662 4663 4664 4665 4666 4667 4668 4669 4670 4671 4672 4673 4674 4675 4676 4677

.. code-block:: python

    x = fluid.layers.data(name="x", shape=[3,10,32,32], dtype="float32")
    y = fluid.layers.elu(x, alpha=0.2)







.. _cn_api_fluid_layers_embedding:

embedding
-------------------------------

.. py:function:: paddle.fluid.layers.embedding(input, size, is_sparse=False, is_distributed=False, padding_idx=None, param_attr=None, dtype='float32')

嵌入层(Embedding Layer)

该层用于查找由输入提供的id在查找表中的嵌入矩阵。查找的结果是input里每个ID对应的嵌入矩阵。
所有的输入变量都作为局部变量传入LayerHelper构造器

参数:
    - **input** (Variable)-包含IDs的张量
    - **size** (tuple|list)-查找表参数的维度。应当有两个参数,一个代表嵌入矩阵字典的大小,一个代表每个嵌入向量的大小。
    - **is_sparse** (bool)-代表是否用稀疏更新的标志
    - **is_distributed** (bool)-是否从远程参数服务端运行查找表
    - **padding_idx** (int|long|None)-如果为 ``None`` ,对查找结果无影响。如果padding_idx不为空,表示一旦查找表中找到input中对应的 ``padding_idz``,则用0填充输出结果。如果 :math:`padding_{i}dx<0` ,在查找表中使用的 ``padding_idx`` 值为 :math:`size[0]+dim` 。
    - **param_attr** (ParamAttr)-该层参数
    - **dtype** (np.dtype|core.VarDesc.VarType|str)-数据类型:float32,float_16,int等。

返回:张量,存储已有输入的嵌入矩阵。

返回类型:变量(Variable)

**代码示例**:

.. code-block:: python

R
RaindragonD 已提交
4678 4679 4680
    import paddle.fluid as fluid
    data = fluid.layers.data(name='sequence', shape=[1], dtype='int64', lod_level=1)
    emb = fluid.layers.embedding(input=data, size=[128, 64])
C
Cheerego 已提交
4681 4682 4683 4684 4685 4686 4687 4688 4689 4690 4691 4692 4693 4694 4695 4696 4697 4698 4699 4700 4701 4702 4703 4704 4705 4706 4707 4708 4709 4710 4711 4712 4713 4714 4715









.. _cn_api_fluid_layers_expand:

expand
-------------------------------

.. py:function:: paddle.fluid.layers.expand(x, expand_times, name=None)

expand运算会按给定的次数对输入各维度进行复制(tile)运算。 您应该通过提供属性 ``expand_times`` 来为每个维度设置次数。 X的秩应该在[1,6]中。请注意, ``expand_times`` 的大小必须与X的秩相同。以下是一个用例:

::

        输入(X) 是一个形状为[2, 3, 1]的三维张量(Tensor):

                [
                   [[1], [2], [3]],
                   [[4], [5], [6]]
                ]

        属性(expand_times):  [1, 2, 2]

        输出(Out) 是一个形状为[2, 6, 2]的三维张量(Tensor):

                [
                    [[1, 1], [2, 2], [3, 3], [1, 1], [2, 2], [3, 3]],
                    [[4, 4], [5, 5], [6, 6], [4, 4], [5, 5], [6, 6]]
                ]
C
Cheerego 已提交
4716

C
Cheerego 已提交
4717 4718 4719
参数:
        - **x** (Variable)- 一个秩在[1, 6]范围中的张量(Tensor).
        - **expand_times** (list|tuple) - 每一个维度要扩展的次数.
C
Cheerego 已提交
4720

C
Cheerego 已提交
4721 4722 4723 4724 4725 4726 4727 4728 4729 4730
返回:     expand变量是LoDTensor。expand运算后,输出(Out)的每个维度的大小等于输入(X)的相应维度的大小乘以 ``expand_times`` 给出的相应值。

返回类型:   变量(Variable)

**代码示例**

..  code-block:: python

        x = fluid.layers.data(name='x', shape=[10], dtype='float32')
        out = fluid.layers.expand(x=x, expand_times=[1, 2, 2])
C
Cheerego 已提交
4731 4732


C
Cheerego 已提交
4733 4734 4735 4736 4737 4738 4739 4740 4741 4742 4743 4744 4745 4746 4747 4748 4749 4750








.. _cn_api_fluid_layers_fc:

fc
-------------------------------

.. py:function::  paddle.fluid.layers.fc(input, size, num_flatten_dims=1, param_attr=None, bias_attr=None, act=None, is_test=False, name=None)


**全连接层**

Z
zy0531 已提交
4751
该函数在神经网络中建立一个全连接层。 它可以将一个或多个tensor( ``input`` 可以是一个list或者Variable,详见参数说明)作为自己的输入,并为每个输入的tensor创立一个变量,称为“权”(weights),等价于一个从每个输入单元到每个输出单元的全连接权矩阵。FC层用每个tensor和它对应的权相乘得到形状为[M, size]输出tensor,M是批大小。如果有多个输入tensor,那么形状为[M, size]的多个输出张量的结果将会被加起来。如果 ``bias_attr`` 非空,则会新创建一个偏向变量(bias variable),并把它加入到输出结果的运算中。最后,如果 ``act`` 非空,它也会加入最终输出的计算中。
C
Cheerego 已提交
4752

Z
zy0531 已提交
4753 4754 4755 4756 4757 4758 4759 4760 4761
当输入为单个张量:

.. math::

        \\Out = Act({XW + b})\\



当输入为多个张量:
C
Cheerego 已提交
4762 4763 4764 4765 4766 4767 4768

.. math::

        \\Out=Act(\sum^{N-1}_{i=0}X_iW_i+b) \\


上述等式中:
Z
zy0531 已提交
4769
  - :math:`N` :输入的数目,如果输入是变量列表,N等于len(input)
R
RaindragonD 已提交
4770
  - :math:`X_i` :第i个输入的tensor
Z
zy0531 已提交
4771
  - :math:`W_i` :对应第i个输入张量的第i个权重矩阵
C
Cheerego 已提交
4772
  - :math:`b` :该层创立的bias参数
R
RaindragonD 已提交
4773 4774
  - :math:`Act` :activation function(激励函数)
  - :math:`Out` :输出tensor
C
Cheerego 已提交
4775

Z
zy0531 已提交
4776 4777 4778 4779 4780 4781
::

            Given:
                data_1.data = [[[0.1, 0.2],
                               [0.3, 0.4]]]
                data_1.shape = (1, 2, 2) # 1 is batch_size
C
Cheerego 已提交
4782

Z
zy0531 已提交
4783 4784
                data_2 = [[[0.1, 0.2, 0.3]]]
                data_2.shape = (1, 1, 3)
C
Cheerego 已提交
4785

Z
zy0531 已提交
4786
                out = fluid.layers.fc(input=[data_1, data_2], size=2)
C
Cheerego 已提交
4787

Z
zy0531 已提交
4788 4789 4790 4791
            Then:
                out.data = [[0.18669507, 0.1893476]]
                out.shape = (1, 2)

C
Cheerego 已提交
4792 4793 4794 4795 4796 4797 4798 4799 4800 4801 4802 4803 4804 4805 4806 4807 4808 4809 4810 4811 4812 4813

参数:
  - **input** (Variable|list of Variable) – 该层的输入tensor(s)(张量),其维度至少是2
  - **size** (int) – 该层输出单元的数目
  - **num_flatten_dims** (int, default 1) – fc层可以接受一个维度大于2的tensor。此时, 它首先会被扁平化(flattened)为一个二维矩阵。 参数``num_flatten_dims`` 决定了输入tensor的flattened方式: 前 ``num_flatten_dims`` (包含边界,从1开始数) 个维度会被扁平化为最终矩阵的第一维 (维度即为矩阵的高), 剩下的 rank(X) - num_flatten_dims 维被扁平化为最终矩阵的第二维 (即矩阵的宽)。 例如, 假设X是一个五维tensor,其形可描述为(2, 3, 4, 5, 6), 且num_flatten_dims = 3。那么扁平化的矩阵形状将会如此: (2 x 3 x 4, 5 x 6) = (24, 30)
  - **param_attr** (ParamAttr|list of ParamAttr, default None) – 该层可学习的参数/权的参数属性
  - **bias_attr** (ParamAttr|list of ParamAttr, default None) – 该层bias变量的参数属性。如果值为False, 则bias变量不参与输出单元运算。 如果值为None,bias变量被初始化为0。默认为 None。
  - **act** (str, default None) – 应用于输出的Activation(激励函数)
  - **is_test** (bool) – 表明当前执行是否处于测试阶段的标志
  - **name** (str, default None) – 该层的命名


返回:转换结果

返回类型: Variable

弹出异常:``ValueError`` - 如果输入tensor的维度小于2

**代码示例**

..  code-block:: python

Z
zy0531 已提交
4814 4815
         # 当输入为单个张量时

C
Cheerego 已提交
4816 4817 4818
        data = fluid.layers.data(name="data", shape=[32, 32], dtype="float32")
        fc = fluid.layers.fc(input=data, size=1000, act="tanh")

Z
zy0531 已提交
4819 4820 4821 4822
        # 当输入为多个张量时
        data_1 = fluid.layers.data(name="data_1", shape=[32, 32], dtype="float32")
        data_2 = fluid.layers.data(name="data_2", shape=[24, 36], dtype="float32")
        fc = fluid.layers.fc(input=[data_1, data_2], size=1000, act="tanh")
C
Cheerego 已提交
4823 4824 4825 4826 4827 4828 4829 4830 4831 4832 4833 4834 4835 4836 4837 4838 4839 4840













.. _cn_api_fluid_layers_flatten:

flatten
-------------------------------

T
Tink_Y 已提交
4841 4842
.. py:function::  paddle.fluid.layers.flatten(x, axis=1, name=None)

C
Cheerego 已提交
4843 4844 4845 4846 4847 4848 4849
将输入张量压扁成二维矩阵

例如:

.. code-block:: text

    Case 1:
C
Cheerego 已提交
4850

C
Cheerego 已提交
4851 4852 4853 4854 4855 4856
      给定
        X.shape = (3, 100, 100, 4)

        axis = 2
      得到:
        Out.shape = (3 * 100, 4 * 100)
C
Cheerego 已提交
4857

C
Cheerego 已提交
4858
    Case 2:
C
Cheerego 已提交
4859

C
Cheerego 已提交
4860 4861 4862 4863 4864 4865 4866 4867
      给定
        X.shape = (3, 100, 100, 4)

        axis = 0
      得到:
        Out.shape = (1, 3 * 100 * 100 * 4)

参数:
R
RaindragonD 已提交
4868 4869 4870
  - **x** (Variable) - 一个秩>=axis 的张量
  - **axis** (int) - flatten的划分轴,[0, axis) 轴数据被flatten到输出矩阵的0轴,[axis, R)被flatten到输出矩阵的1轴,其中R是输入张量的秩。axis的值必须在[0,R]范围内。当 axis= 0 时,输出张量的形状为 (1,d_0 \* d_1 \*… d_n) ,其输入张量的形状为(d_0, d_1,… d_n)。
  - **name** (str|None) - 此层的名称(可选)。如果没有设置,层将自动命名。
H
Hao Wang 已提交
4871 4872

返回: 一个二维张量,它包含输入张量的内容,但维数发生变化。输入的[0, axis)维将沿给定轴flatten到输出的前一个维度,剩余的输入维数flatten到输出的后一个维度。
C
Cheerego 已提交
4873

H
Hao Wang 已提交
4874
返回类型: Variable
C
Cheerego 已提交
4875 4876

抛出异常:
R
RaindragonD 已提交
4877 4878
  - ValueError: 如果 x 不是一个变量
  - ValueError: 如果axis的范围不在 [0, rank(x)]
C
Cheerego 已提交
4879 4880 4881 4882 4883 4884 4885 4886 4887 4888

**代码示例**

.. code-block:: python

    x = fluid.layers.data(name="x", shape=[4, 4, 3], dtype="float32")
    out = fluid.layers.flatten(x=x, axis=2)



Z
zy0531 已提交
4889
.. _cn_api_fluid_layers_fsp_matrix:
C
Cheerego 已提交
4890

Z
zy0531 已提交
4891 4892 4893 4894 4895 4896 4897 4898 4899 4900 4901 4902 4903 4904 4905 4906 4907 4908 4909 4910 4911 4912 4913 4914 4915 4916
fsp_matrix
-------------------------------

.. py:function:: paddle.fluid.layers.fsp_matrix(x, y)

**FSP matrix op**

此运算用于计算两个特征映射的求解过程(FSP)矩阵。给定形状为[x_channel,h,w]的特征映射x和形状为[y_channel,h,w]的特征映射y,我们可以分两步得到x和y的fsp矩阵:

1.用形状[X_channel,H*W]将X重塑为矩阵,并用形状[H*W,y_channel]将Y重塑和转置为矩阵。

2.乘以x和y得到形状为[x_channel,y_channel]的fsp矩阵。

输出是一批fsp矩阵。

参数:
    - **x** (Variable): 一个形状为[batch_size, x_channel, height, width]的特征映射
    - **y** (Variable):具有形状[batch_size, y_channel, height, width]的特征映射。Y轴通道可以与输入(X)的X轴通道不同,而其他尺寸必须与输入(X)相同。

返回:形状为[batch_size, x_channel, y_channel]的fsp op的输出。x_channel 是x的通道,y_channel是y的通道。

返回类型:fsp matrix (Variable)

**代码示例**

..  code-block:: python
C
Cheerego 已提交
4917

R
RaindragonD 已提交
4918 4919 4920 4921 4922 4923
    import paddle.fluid as fluid
    data = fluid.layers.data(name='data', shape=[3, 32, 32])
    feature_map_0 = fluid.layers.conv2d(data, num_filters=2,
                                        filter_size=3)
    feature_map_1 = fluid.layers.conv2d(feature_map_0, num_filters=2,
                                        filter_size=1)
Z
zy0531 已提交
4924
    loss = fluid.layers.fsp_matrix(feature_map_0, feature_map_1)
C
Cheerego 已提交
4925 4926 4927 4928 4929 4930 4931 4932 4933 4934 4935






.. _cn_api_fluid_layers_gather:

gather
-------------------------------

R
RaindragonD 已提交
4936
.. py:function:: paddle.fluid.layers.gather(input, index, overwrite=True)
C
Cheerego 已提交
4937 4938 4939 4940 4941 4942 4943 4944 4945 4946 4947 4948 4949 4950 4951 4952 4953 4954 4955 4956 4957 4958 4959

收集层(gather layer)

根据索引index获取X的最外层维度的条目,并将它们串连在一起。

.. math::
                        Out=X[Index]

::

        X = [[1, 2],
             [3, 4],
             [5, 6]]

        Index = [1, 2]

        Then:

        Out = [[3, 4],
               [5, 6]]


参数:
R
RaindragonD 已提交
4960 4961 4962 4963 4964
         - **input** (Variable) - input的秩rank >= 1。
        - **index** (Variable) - index的秩rank = 1。
        - **overwrite** (bool) - 具有相同索引时更新grad的模式。如果为True,则使用覆盖模式更新相同索引的grad,如果为False,则使用accumulate模式更新相同索引的grad。Default值为True。

返回:和输入的秩相同的输出张量。
C
Cheerego 已提交
4965

R
RaindragonD 已提交
4966
返回类型:output (Variable)
C
Cheerego 已提交
4967 4968 4969 4970

**代码示例**

..  code-block:: python
R
RaindragonD 已提交
4971 4972 4973 4974
  
  x = fluid.layers.data(name='x', shape=[-1, 5], dtype='float32')
  index = fluid.layers.data(name='index', shape=[-1, 1], dtype='int32')
  output = fluid.layers.gather(x, index)
C
Cheerego 已提交
4975 4976 4977 4978 4979 4980 4981 4982 4983 4984 4985 4986 4987 4988 4989 4990 4991 4992 4993 4994 4995 4996 4997 4998









.. _cn_api_fluid_layers_gaussian_random:

gaussian_random
-------------------------------

.. py:function:: paddle.fluid.layers.gaussian_random(shape, mean=0.0, std=1.0, seed=0, dtype='float32')

gaussian_random算子。

用于使用高斯随机生成器初始化张量(Tensor)。

参数:
        - **shape** (tuple | list)- (vector <int>)随机张量的维数
        - **mean** (Float)- (默认值0.0)随机张量的均值
        - **std** (Float)- (默认值为1.0)随机张量的std
4999
        - **seed** (Int)- (默认值为 0)生成器随机生成种子。0表示使用系统范围的种子。注意如果seed不为0,则此算子每次将始终生成相同的随机数
C
Cheerego 已提交
5000 5001 5002 5003 5004 5005
        - **dtype** (np.dtype | core.VarDesc.VarType | str)- 输出的数据类型。

返回:        输出高斯随机运算矩阵

返回类型:        输出(Variable)

T
Tink_Y 已提交
5006 5007 5008 5009
**代码示例:**

.. code-block:: python

R
RaindragonD 已提交
5010
    import paddle.fluid.layers as layers
C
Cheerego 已提交
5011
    out = fluid.layers.gaussian_random(shape=[20, 30])
C
Cheerego 已提交
5012 5013 5014 5015 5016 5017 5018 5019 5020 5021 5022 5023 5024 5025 5026 5027 5028 5029 5030 5031 5032 5033 5034 5035








.. _cn_api_fluid_layers_gaussian_random_batch_size_like:

gaussian_random_batch_size_like
-------------------------------

.. py:function:: paddle.fluid.layers.gaussian_random_batch_size_like(input, shape, input_dim_idx=0, output_dim_idx=0, mean=0.0, std=1.0, seed=0, dtype='float32')

用于使用高斯随机发生器初始化张量。分布的defalut均值为0.并且分布的defalut标准差(std)为1.用户可以通过输入参数设置mean和std。

参数:
        - **input** (Variable)- 其input_dim_idx'th维度指定batch_size的张量(Tensor)。
        - **shape** (元组|列表)- 输出的形状。
        - **input_dim_idx** (Int)- 默认值0.输入批量大小维度的索引。
        - **output_dim_idx** (Int)- 默认值0.输出批量大小维度的索引。
        - **mean** (Float)- (默认值0.0)高斯分布的平均值(或中心值)。
        - **std** (Float)- (默认值 1.0)高斯分布的标准差(std或spread)。
5036
        - **seed** (Int)- (默认为0)用于随机数引擎的随机种子。0表示使用系统生成的种子。请注意,如果seed不为0,则此算子将始终每次生成相同的随机数。
C
Cheerego 已提交
5037 5038 5039 5040 5041 5042 5043 5044
        - **dtype** (np.dtype | core.VarDesc.VarType | str)- 输出数据的类型为float32,float_16,int等。

返回:        指定形状的张量将使用指定值填充。

返回类型:        输出(Variable)。



T
Tink_Y 已提交
5045
**代码示例:**
C
Cheerego 已提交
5046

T
Tink_Y 已提交
5047 5048
.. code-block:: python

H
Hao Wang 已提交
5049
    input = fluid.layers.data(name="input", shape=[13, 11], dtype='float32')
T
Tink_Y 已提交
5050

H
Hao Wang 已提交
5051
    out = fluid.layers.gaussian_random_batch_size_like(
T
Tink_Y 已提交
5052
        input, shape=[-1, 11], mean=1.0, std=2.0)
C
Cheerego 已提交
5053 5054 5055 5056 5057 5058 5059 5060 5061 5062 5063 5064 5065 5066 5067 5068






.. _cn_api_fluid_layers_get_tensor_from_selected_rows:

get_tensor_from_selected_rows
-------------------------------

.. py:function::  paddle.fluid.layers.get_tensor_from_selected_rows(x, name=None)

:code:`Get Tensor From Selected Rows` 用于从选中行(Selected Rows)中获取张量

参数:
R
RaindragonD 已提交
5069 5070
  - **x** (Variable) - 输入,类型是SelectedRows
  - **name** (basestring|None) - 输出的名称
C
Cheerego 已提交
5071 5072 5073 5074 5075

返回: 输出类型为LoDTensor

返回类型: out(Variable)

R
RaindragonD 已提交
5076 5077 5078
**代码示例:**

.. code-block:: python
C
Cheerego 已提交
5079

R
RaindragonD 已提交
5080 5081 5082 5083
    import paddle.fluid as fluid
    b = fluid.default_main_program().global_block()
    input = b.create_var(name="X", dtype="float32", persistable=True, type=fluid.core.VarDesc.VarType.SELECTED_ROWS)
    out = fluid.layers.get_tensor_from_selected_rows(input)
C
Cheerego 已提交
5084 5085 5086 5087 5088 5089 5090 5091 5092 5093 5094 5095 5096 5097 5098 5099 5100 5101 5102 5103 5104 5105 5106 5107









.. _cn_api_fluid_layers_grid_sampler:

grid_sampler
-------------------------------

.. py:function::  paddle.fluid.layers.grid_sampler(x, grid, name=None)

该操作使用基于flow field网格的双线性插值对输入X进行采样,通常由affine_grid生成。

形状为(N、H、W、2)的网格是由两个形状均为(N、H、W)的坐标(grid_x grid_y)连接而成的。

其中,grid_x是输入数据x的第四个维度(宽度维度)的索引,grid_y是第三维度(高维)的索引,最终得到4个最接近的角点的双线性插值值。

step 1:

R
RaindragonD 已提交
5108
  得到(x, y)网格坐标,缩放到[0,h -1/W-1]
C
Cheerego 已提交
5109

R
RaindragonD 已提交
5110
  grid_x = 0.5 * (grid[:, :, :, 0] + 1) * (W - 1) grid_y = 0.5 * (grid[:, :, :, 1] + 1) * (H - 1)
C
Cheerego 已提交
5111 5112 5113

step 2:

R
RaindragonD 已提交
5114
  在每个[H, W]区域用网格(X, y)作为输入数据X的索引,并将双线性插值点值由4个最近的点表示。
C
Cheerego 已提交
5115 5116 5117 5118 5119 5120 5121 5122 5123 5124 5125 5126

.. code-block:: text

      wn ------- y_n ------- en
      |           |           |
      |          d_n          |
      |           |           |
     x_w --d_w-- grid--d_e-- x_e
      |           |           |
      |          d_s          |
      |           |           |
      ws ------- y_s ------- wn
C
Cheerego 已提交
5127

C
Cheerego 已提交
5128 5129 5130 5131 5132 5133 5134 5135 5136 5137 5138 5139
    x_w = floor(x)              // west side x coord
    x_e = x_w + 1               // east side x coord
    y_n = floor(y)              // north side y coord
    y_s = y_s + 1               // south side y coord
    d_w = grid_x - x_w          // distance to west side
    d_e = x_e - grid_x          // distance to east side
    d_n = grid_y - y_n          // distance to north side
    d_s = y_s - grid_y          // distance to south side
    wn = X[:, :, y_n, x_w]      // north-west point value
    en = X[:, :, y_n, x_e]      // north-east point value
    ws = X[:, :, y_s, x_w]      // south-east point value
    es = X[:, :, y_s, x_w]      // north-east point value
C
Cheerego 已提交
5140

C
Cheerego 已提交
5141 5142 5143 5144 5145

    output = wn * d_e * d_s + en * d_w * d_s
           + ws * d_e * d_n + es * d_w * d_n

参数:
R
RaindragonD 已提交
5146 5147 5148
  - **x** (Variable): 输入数据,形状为[N, C, H, W]
  - **grid** (Variable): 输入网格张量,形状为[N, H, W, 2]
  - **name** (str, default None): 该层的名称
C
Cheerego 已提交
5149 5150 5151 5152 5153 5154 5155

返回: **out** (Variable): 输入X基于输入网格的bilnear插值计算结果,形状为[N, C, H, W]

**代码示例:**

.. code-block:: python

R
RaindragonD 已提交
5156 5157
    import paddle.fluid as fluid

C
Cheerego 已提交
5158 5159
    x = fluid.layers.data(name='x', shape=[3, 10, 32, 32], dtype='float32')
    theta = fluid.layers.data(name='theta', shape=[3, 2, 3], dtype='float32')
R
RaindragonD 已提交
5160
    grid = fluid.layers.affine_grid(theta=theta, out_shape=[3, 10, 32, 32]})
C
Cheerego 已提交
5161 5162 5163 5164 5165 5166 5167 5168 5169 5170 5171 5172 5173 5174 5175 5176 5177 5178 5179 5180 5181
    out = fluid.layers.grid_sampler(x=x, grid=grid)










.. _cn_api_fluid_layers_group_norm:

group_norm
-------------------------------

.. py:function::  paddle.fluid.layers.group_norm(input, groups, epsilon=1e-05, param_attr=None, bias_attr=None, act=None, data_layout='NCHW', name=None)

参考论文: `Group Normalization <https://arxiv.org/abs/1803.08494>`_

参数:
R
RaindragonD 已提交
5182 5183 5184 5185 5186 5187 5188 5189
  - **input** (Variable):输入张量变量
  - **groups** (int):从 channel 中分离出来的 group 的数目
  - **epsilon** (float):为防止方差除零,增加一个很小的值
  - **param_attr** (ParamAttr|None):可学习标度的参数属性 :math:`g`,如果设置为False,则不会向输出单元添加标度。如果设置为0,偏差初始化为1。默认值:None
  - **bias_attr** (ParamAttr|None):可学习偏置的参数属性 :math:`b ` , 如果设置为False,则不会向输出单元添加偏置量。如果设置为零,偏置初始化为零。默认值:None。
  - **act** (str):将激活应用于输出的 group normalizaiton
  - **data_layout** (string|NCHW): 只支持NCHW。
  - **name** (str):这一层的名称(可选)
C
Cheerego 已提交
5190 5191 5192 5193 5194 5195 5196 5197 5198 5199 5200 5201 5202 5203 5204 5205 5206 5207 5208 5209 5210 5211 5212 5213 5214

返回: Variable: 一个张量变量,它是对输入进行 group normalization 后的结果。

**代码示例:**

.. code-block:: python

    data = fluid.layers.data(name='data', shape=[8, 32, 32],
                             dtype='float32')
    x = fluid.layers.group_norm(input=data, groups=4)










.. _cn_api_fluid_layers_gru_unit:

gru_unit
-------------------------------

H
Hao Wang 已提交
5215
.. py:function:: paddle.fluid.layers.gru_unit(input, hidden, size, param_attr=None, bias_attr=None, activation='tanh', gate_activation='sigmoid', origin_mode=False)
C
Cheerego 已提交
5216 5217 5218

GRU单元层。GRU执行步骤基于如下等式:

H
Hao Wang 已提交
5219 5220 5221 5222 5223 5224

如果origin_mode为True,则该运算公式来自论文
`Empirical Evaluation of Gated Recurrent Neural Networks on Sequence Modeling  <https://arxiv.org/pdf/1412.3555.pdf>`_ 。

公式如下:

C
Cheerego 已提交
5225 5226 5227 5228 5229 5230 5231 5232
.. math::
    u_t=actGate(xu_t+W_{u}h_{t-1}+b_u)
.. math::
    r_t=actGate(xr_t+W_{r}h_{t-1}+b_r)
.. math::
    m_t=actNode(xm_t+W_{c}dot(r_t,h_{t-1})+b_m)
.. math::
    h_t=dot((1-u_t),m_t)+dot(u_t,h_{t-1})
H
Hao Wang 已提交
5233 5234 5235 5236 5237 5238 5239 5240 5241 5242 5243 5244


如果origin_mode为False,则该运算公式来自论文
`Learning Phrase Representations using RNN Encoder Decoder for Statistical Machine Translation <https://arxiv.org/pdf/1406.1078.pdf>`_ 。

.. math::
    u_t & = act_g(W_{ux}x_{t} + W_{uh}h_{t-1} + b_u)\\
    r_t & = act_g(W_{rx}x_{t} + W_{rh}h_{t-1} + b_r)\\
    \tilde{h_t} & = act_c(W_{cx}x_{t} + W_{ch}(r_t \odot h_{t-1}) + b_c)\\
    h_t & = u_t \odot h_{t-1} + (1-u_t) \odot \tilde{h_t}


C
Cheerego 已提交
5245 5246 5247 5248 5249
GRU单元的输入包括 :math:`z_t` , :math:`h_{t-1}` 。在上述等式中, :math:`z_t` 会被分割成三部分: :math:`xu_t` 、 :math:`xr_t` 和 :math:`xm_t`  。
这意味着要为一批输入实现一个全GRU层,我们需要采用一个全连接层,才能得到 :math:`z_t=W_{fc}x_t` 。
:math:`u_t` 和 :math:`r_t` 分别代表了GRU神经元的update gates(更新门)和reset gates(重置门)。
和LSTM不同,GRU少了一个门(它没有LSTM的forget gate)。但是它有一个叫做中间候选隐藏状态(intermediate candidate hidden output)的输出,
记为 :math:`m_t` 。 该层有三个输出: :math:`h_t, dot(r_t,h_{t-1})` 以及 :math:`u_t,r_t,m_t` 的连结(concatenation)。
C
Cheerego 已提交
5250 5251


C
Cheerego 已提交
5252 5253 5254 5255 5256 5257 5258 5259 5260 5261 5262 5263 5264 5265


参数:
  - **input** (Variable) – 经FC层变换后的当前步骤的输入值
  - **hidden** (Variable) –  从上一步而来的gru unit 隐藏状态值(hidden value)
  - **size** (integer) – 输入数据的维度
  - **param_attr** (ParamAttr|None) – 可学习的隐藏层权重矩阵的参数属性。
    注意:
      - 该权重矩阵形为 :math:`(T×3D)` , :math:`D` 是隐藏状态的规模(hidden size)
      - 该权重矩阵的所有元素由两部分组成, 一是update gate和reset gate的权重,形为 :math:`(D×2D)` ;二是候选隐藏状态(candidate hidden state)的权重矩阵,形为 :math:`(D×D)`
    如果该函数参数值为None或者 ``ParamAttr`` 类中的属性之一,gru_unit则会创建一个 ``ParamAttr`` 类的对象作为 param_attr。如果param_attr没有被初始化,那么会由Xavier来初始化它。默认值为None
  - **bias_attr** (ParamAttr|bool|None) - GRU的bias变量的参数属性。形为 :math:`(1x3D)` 的bias连结(concatenate)在update gates(更新门),reset gates(重置门)以及candidate calculations(候选隐藏状态计算)中的bias。如果值为False,那么上述三者将没有bias参与运算。若值为None或者 ``ParamAttr`` 类中的属性之一,gru_unit则会创建一个 ``ParamAttr`` 类的对象作为 bias_attr。如果bias_attr没有被初始化,那它会被默认初始化为0。默认值为None。
  - **activation** (string) –  神经元 “actNode” 的激励函数(activation)类型。默认类型为‘tanh’
  - **gate_activation** (string) – 门 “actGate” 的激励函数(activation)类型。 默认类型为 ‘sigmoid’
C
Cheerego 已提交
5266

C
Cheerego 已提交
5267

R
RaindragonD 已提交
5268
返回:  hidden value(隐藏状态的值),reset-hidden value(重置隐藏状态值),gate values(门值)
C
Cheerego 已提交
5269

R
RaindragonD 已提交
5270
返回类型:  元组(tuple)
C
Cheerego 已提交
5271 5272 5273 5274 5275 5276


**代码示例**

..  code-block:: python

R
RaindragonD 已提交
5277 5278 5279 5280 5281 5282 5283 5284 5285 5286 5287
    import paddle.fluid as fluid

    dict_dim, emb_dim = 128, 64
    data = fluid.layers.data(name='step_data', shape=[1], dtype='int32')
    emb = fluid.layers.embedding(input=data, size=[dict_dim, emb_dim])
    hidden_dim = 512
    x = fluid.layers.fc(input=emb, size=hidden_dim * 3)
    pre_hidden = fluid.layers.data(
        name='pre_hidden', shape=[hidden_dim], dtype='float32')
    hidden = fluid.layers.gru_unit(
        input=x, hidden=pre_hidden, size=hidden_dim * 3)
C
Cheerego 已提交
5288 5289 5290 5291 5292 5293 5294 5295 5296 5297 5298 5299 5300 5301 5302 5303 5304 5305 5306 5307 5308 5309 5310 5311 5312














.. _cn_api_fluid_layers_hard_sigmoid:

hard_sigmoid
-------------------------------

.. py:function:: paddle.fluid.layers.hard_sigmoid(x, slope=0.2, offset=0.5, name=None)

HardSigmoid激活算子。

sigmoid的分段线性逼近(https://arxiv.org/abs/1603.00391),比sigmoid快得多。

C
Cheerego 已提交
5313
.. math::
C
Cheerego 已提交
5314 5315

      \\out=\max(0,\min(1,slope∗x+shift))\\
C
Cheerego 已提交
5316

C
Cheerego 已提交
5317 5318 5319 5320 5321 5322 5323 5324 5325 5326 5327 5328 5329 5330
斜率是正数。偏移量可正可负的。斜率和位移的默认值是根据上面的参考设置的。建议使用默认值。

参数:
    - **x** (Variable) - HardSigmoid operator的输入
    - **slope** (FLOAT|0.2) -斜率
    - **offset** (FLOAT|0.5)  - 偏移量
    - **name** (str|None) - 这个层的名称(可选)。如果设置为None,该层将被自动命名。


**代码示例:**


.. code-block:: python

R
RaindragonD 已提交
5331
    import paddle.fluid as fluid
C
Cheerego 已提交
5332 5333 5334 5335 5336 5337 5338 5339 5340 5341 5342 5343 5344 5345 5346 5347 5348 5349 5350 5351 5352 5353 5354
    x = fluid.layers.data(name="x", shape=[3,10,32,32], dtype="float32")
    y = fluid.layers.hard_sigmoid(x, slope=0.3, offset=0.8)






.. _cn_api_fluid_layers_hash:

hash
-------------------------------

.. py:function::  paddle.fluid.layers.hash(input, hash_size, num_hash=1, name=None)

将输入 hash 到一个整数,该数的值小于给定的 hash size

我们使用的哈希算法是 xxHash - `Extremely fast hash algorithm <https://github.com/Cyan4973/xxHash/tree/v0.6.5>`_

提供一简单的例子:

.. code-block:: text

R
RaindragonD 已提交
5355
  给出:
C
Cheerego 已提交
5356

R
RaindragonD 已提交
5357 5358 5359 5360 5361
    # shape [2, 2]
    input.data = [
        [[1, 2],
        [3, 4]],
    ]
C
Cheerego 已提交
5362

R
RaindragonD 已提交
5363
    input.lod = [[0, 2]]
C
Cheerego 已提交
5364

R
RaindragonD 已提交
5365
    hash_size = 10000
C
Cheerego 已提交
5366

R
RaindragonD 已提交
5367
    num_hash = 4
C
Cheerego 已提交
5368

R
RaindragonD 已提交
5369
  然后:
C
Cheerego 已提交
5370

R
RaindragonD 已提交
5371
    哈希操作将这个二维input的所有数字作为哈希算法每次的输入。
C
Cheerego 已提交
5372

R
RaindragonD 已提交
5373
    每个输入都将被哈希4次,最终得到一个长度为4的数组。
C
Cheerego 已提交
5374

R
RaindragonD 已提交
5375
    数组中的每个值的范围从0到9999。
C
Cheerego 已提交
5376 5377 5378



R
RaindragonD 已提交
5379 5380 5381 5382 5383
    # shape [2, 4]
    output.data = [
        [[9662, 9217, 1129, 8487],
        [8310, 1327, 1654, 4567]],
    ]
C
Cheerego 已提交
5384

R
RaindragonD 已提交
5385
    output.lod = [[0, 2]]
C
Cheerego 已提交
5386 5387

参数:
R
RaindragonD 已提交
5388 5389 5390 5391
  - **input** (Variable) - 输入变量是一个 one-hot 词。输入变量的维数必须是2。
  - **hash_size** (int) - 哈希算法的空间大小。输出值将保持在 :math:`[0, hash\_size - 1]` 范围内。
  - **num_hash** (int) - 哈希次数,默认为1。
  - **name** (str, default None) - 该层的名称
C
Cheerego 已提交
5392 5393 5394 5395 5396 5397 5398 5399 5400

返回:哈希的结果变量,是一个lodtensor。

返回类型: Variable

**代码示例:**

.. code-block:: python

R
RaindragonD 已提交
5401 5402 5403 5404 5405 5406 5407 5408 5409 5410 5411 5412 5413 5414 5415 5416 5417 5418
    import paddle.fluid as fluid
    import paddle.fluid.layers as layers
    import numpy as np

    titles = fluid.layers.data(name='titles', shape=[1], dtype='int32', lod_level=1)
    hash_r = fluid.layers.hash(name='hash_x', input=titles, num_hash=1, hash_size=1000)

    place = fluid.core.CPUPlace()
    exece = fluid.Executor(place)
    exece.run(fluid.default_startup_program())

    # 初始化Tensor
    tensor = fluid.core.LoDTensor()
    tensor.set(np.random.randint(0, 10, (3, 1)).astype("int32"), place)
    # 设置LoD
    tensor.set_recursive_sequence_lengths([[1, 1, 1]])

    out = exece.run(feed={'titles': tensor}, fetch_list=[hash_r], return_numpy=False)
C
Cheerego 已提交
5419 5420 5421 5422 5423 5424 5425 5426 5427 5428 5429 5430 5431 5432









.. _cn_api_fluid_layers_hsigmoid:

hsigmoid
-------------------------------

5433
.. py:function:: paddle.fluid.layers.hsigmoid(input, label, num_classes, param_attr=None, bias_attr=None, name=None, path_table=None, path_code=None, is_custom=False, is_sparse=False)
C
Cheerego 已提交
5434

C
Cheerego 已提交
5435
层次sigmod( hierarchical sigmoid )加速语言模型的训练过程。这个operator将类别组织成一个完全二叉树,也可以使用 ``is_custom`` 参数来传入自定义的树结构来实现层次化。
C
Cheerego 已提交
5436 5437 5438 5439 5440 5441 5442

树中每个叶节点表示一个类(一个单词),每个内部节点进行一个二分类。对于每个单词,都有一个从根到它的叶子节点的唯一路径,hsigmoid计算路径上每个内部节点的损失(cost),并将它们相加得到总损失(cost)。

hsigmoid可以把时间复杂度 :math:`O(N)` 优化到 :math:`O(logN)` ,其中 :math:`N` 表示单词字典的大小。

使用默认树结构,请参考 `Hierarchical Probabilistic Neural Network Language Model <http://www.iro.umontreal.ca/~lisa/pointeurs/hierarchical-nnlm-aistats05.pdf>`_ 。

H
Hao Wang 已提交
5443
若要使用自定义树结构,请设置 ``is_custom`` 值为True。但在此之前,请完成以下几步:
C
Cheerego 已提交
5444 5445 5446

1.使用自定义词典来建立二叉树,每个叶结点都应该是词典中的单词

H
Hao Wang 已提交
5447
2.建立一个dict类型数据结构,来存储 **单词id -> 该单词叶结点至根结点路径** 的映射,称之为路径表 ``path_table`` 参数
C
Cheerego 已提交
5448

H
Hao Wang 已提交
5449
3.建立一个dict类型数据结构,来存储 **单词id -> 该单词叶结点至根结点路径的编码(code)** 的映射。 编码code是指每次二分类的标签,1为真,0为假
C
Cheerego 已提交
5450 5451 5452 5453 5454

4.现在我们的每个单词都已经有自己的路径和路径编码,当对于同一批输入进行操作时,你可以同时传入一批路径和路径编码进行运算。

参数:
    - **input** (Variable) - 输入张量,shape为 ``[N×D]`` ,其中 ``N`` 是minibatch的大小,D是特征大小。
C
Cheerego 已提交
5455
    - **label** (Variable) - 训练数据的标签。该tensor的shape为 ``[N×1]``
C
Cheerego 已提交
5456 5457 5458 5459 5460 5461
    - **num_classes** (int) - 类别的数量不能少于2。若使用默认树结构,该参数必须用户设置。当 ``is_custom=False`` 时,该项绝不能为None。反之,如果 ``is_custom=True`` ,它取值应为非叶节点的个数,来指明二分类实用的类别数目。
    - **param_attr** (ParamAttr|None) - 可学习参数/ hsigmoid权重的参数属性。如果将其设置为ParamAttr的一个属性或None,则将ParamAttr设置为param_attr。如果没有设置param_attr的初始化器,那么使用用Xavier初始化。默认值:没None。
    - **bias_attr** (ParamAttr|bool|None) - hsigmoid偏置的参数属性。如果设置为False,则不会向输出添加偏置。如果将其设置ParamAttr的一个属性或None,则将ParamAttr设置为bias_attr。如果没有设置bias_attr的初始化器,偏置将初始化为零。默认值:None。
    - **name** (str|None) - 该layer的名称(可选)。如果设置为None,该层将被自动命名。默认值:None。
    - **path_table** (Variable|None) – 存储每一批样本从词到根节点的路径。路径应为从叶至根方向。 ``path_table`` 和 ``path_code`` 应具有相同的形, 对于每个样本 i ,path_table[i]为一个类似np.array的结构,该数组内的每个元素都是其双亲结点权重矩阵的索引
    - **path_code** (Variable|None) – 存储每批样本的路径编码,仍然是按从叶至根方向。各样本路径编码批都由其各祖先结点的路径编码组成
C
Cheerego 已提交
5462
    - **is_custom** (bool|False) – 使用用户自定义二叉树取代默认二叉树结构,如果该项为真, 请务必设置 ``path_table`` , ``path_code`` , ``num_classes`` , 否则就需要设置 num_classes
C
Cheerego 已提交
5463 5464 5465
    - **is_sparse** (bool|False) – 使用稀疏更新方式,而非密集更新。如果为真, W的梯度和输入梯度将会变得稀疏

返回:  (LoDTensor) 层次sigmod( hierarchical sigmoid) 。shape[N, 1]
C
Cheerego 已提交
5466

C
Cheerego 已提交
5467 5468 5469 5470 5471 5472
返回类型:  Out


**代码示例**

..  code-block:: python
C
Cheerego 已提交
5473

R
RaindragonD 已提交
5474 5475 5476 5477
      import paddle.fluid as fluid
      x = fluid.layers.data(name='x', shape=[2], dtype='float32')
      y = fluid.layers.data(name='y', shape=[1], dtype='int64')
      out = fluid.layers.hsigmoid(input=x, label=y, num_classes=6)
C
Cheerego 已提交
5478 5479 5480 5481




H
Hao Wang 已提交
5482 5483 5484 5485 5486 5487 5488 5489 5490 5491 5492
.. _cn_api_fluid_layers_huber_loss:

huber_loss
-------------------------------

.. py:function:: paddle.fluid.layers.huber_loss(input, label, delta)

Huber损失是更具鲁棒性的损失函数。 huber损失可以评估输入对标签的合适度。 与MSE损失不同,Huber损失可更为稳健地处理异常值。

当输入和标签之间的距离大于delta时:

C
Cheerego 已提交
5493
.. math::
H
Hao Wang 已提交
5494 5495 5496 5497
        huber\_loss = delta * (label - input) - 0.5 * delta * delta

当输入和标签之间的距离小于delta时:

C
Cheerego 已提交
5498
.. math::
H
Hao Wang 已提交
5499 5500 5501 5502 5503 5504 5505 5506 5507 5508 5509 5510 5511 5512 5513 5514 5515
        huber\_loss = 0.5 * (label - input) * (label - input)


参数:
  - **input** (Variable) - 此输入是前一个算子计算得到的概率。 第一个维度是批大小batch_size,最后一个维度是1。
  - **label** (Variable) - 第一个维度为批量大小batch_size且最后一个维度为1的真实值
  - **delta** (float) -  huber loss的参数,用于控制异常值的范围

返回: 形为[batch_size, 1]的huber loss.

返回类型:   huber_loss (Variable)



**代码示例**

..  code-block:: python
C
Cheerego 已提交
5516

R
RaindragonD 已提交
5517 5518 5519 5520 5521 5522 5523 5524
    import paddle.fluid as fluid

    x = fluid.layers.data(name='x', shape=[13], dtype='float32')
    predict = fluid.layers.fc(input=x, size=1)
    label = fluid.layers.data(
        name='label', shape=[1], dtype='float32')
    loss = fluid.layers.huber_loss(
        input=predict, label=label, delta=1.0)
C
Cheerego 已提交
5525 5526 5527 5528 5529 5530 5531 5532 5533 5534 5535 5536 5537 5538 5539





.. _cn_api_fluid_layers_im2sequence:

im2sequence
-------------------------------

.. py:function:: paddle.fluid.layers.im2sequence(input, filter_size=1, stride=1, padding=0, input_image_size=None, out_stride=1, name=None)

从输入张量中提取图像张量,与im2col相似,shape={input.batch_size * output_height * output_width, filter_size_H * filter_size_W * input.通道}。这个op使用filter / kernel扫描图像并将这些图像转换成序列。一个图片展开后的timestep的个数为output_height * output_width,其中output_height和output_width由下式计算:


C
Cheerego 已提交
5540
.. math::
B
Bai Yifan 已提交
5541
                        output\_size=1+\frac{(2∗padding+img\_size−block\_size+stride-1)}{stride}
C
Cheerego 已提交
5542 5543 5544 5545

每个timestep的维度为 :math:`block\_y * block\_x * input.channels` 。

参数:
R
RaindragonD 已提交
5546 5547 5548 5549 5550 5551 5552
  - **input** (Variable)- 输入张量,格式为[N, C, H, W]
  - **filter_size** (int|tuple|None) - 滤波器大小。如果filter_size是一个tuple,它必须包含两个整数(filter_size_H, filter_size_W)。否则,过滤器将是一个方阵。
  - **stride** (int|tuple) - 步长大小。如果stride是一个元组,它必须包含两个整数(stride_H、stride_W)。否则,stride_H = stride_W = stride。默认:stride = 1。
  - **padding** (int|tuple) - 填充大小。如果padding是一个元组,它可以包含两个整数(padding_H, padding_W),这意味着padding_up = padding_down = padding_H和padding_left = padding_right = padding_W。或者它可以使用(padding_up, padding_left, padding_down, padding_right)来指示四个方向的填充。否则,标量填充意味着padding_up = padding_down = padding_left = padding_right = padding Default: padding = 0。
  - **input_image_size** (Variable) - 输入包含图像的实际大小。它的维度为[batchsize,2]。该参数可有可无,是用于batch上的预测。
  - **out_stride** (int|tuple) - 通过CNN缩放图像。它可有可无,只有当input_image_size不为空时才有效。如果out_stride是tuple,它必须包含(out_stride_H, out_stride_W),否则,out_stride_H = out_stride_W = out_stride。
  - **name** (int) - 该layer的名称,可以忽略。
C
Cheerego 已提交
5553

R
RaindragonD 已提交
5554
返回: LoDTensor shape为{batch_size * output_height * output_width, filter_size_H * filter_size_W * input.channels}。如果将输出看作一个矩阵,这个矩阵的每一行都是一个序列的step。
C
Cheerego 已提交
5555

R
RaindragonD 已提交
5556
返回类型: output
C
Cheerego 已提交
5557 5558 5559

::

R
RaindragonD 已提交
5560
  Given:
C
Cheerego 已提交
5561 5562

    x = [[[[ 6.  2.  1.]
R
RaindragonD 已提交
5563 5564
      [ 8.  3.  5.]
      [ 0.  2.  6.]]
C
Cheerego 已提交
5565 5566 5567 5568 5569 5570 5571 5572 5573 5574 5575 5576 5577 5578 5579 5580 5581 5582 5583 5584 5585 5586 5587 5588 5589 5590 5591 5592 5593 5594 5595 5596 5597 5598 5599 5600 5601 5602 5603 5604

        [[ 2.  4.  4.]
         [ 6.  3.  0.]
         [ 6.  4.  7.]]]

       [[[ 6.  7.  1.]
         [ 5.  7.  9.]
         [ 2.  4.  8.]]

        [[ 1.  2.  1.]
         [ 1.  3.  5.]
         [ 9.  0.  8.]]]]

    x.dims = {2, 2, 3, 3}

    And:

    filter = [2, 2]
    stride = [1, 1]
    padding = [0, 0]

    Then:

    output.data = [[ 6.  2.  8.  3.  2.  4.  6.  3.]
                   [ 2.  1.  3.  5.  4.  4.  3.  0.]
                   [ 8.  3.  0.  2.  6.  3.  6.  4.]
                   [ 3.  5.  2.  6.  3.  0.  4.  7.]
                   [ 6.  7.  5.  7.  1.  2.  1.  3.]
                   [ 7.  1.  7.  9.  2.  1.  3.  5.]
                   [ 5.  7.  2.  4.  1.  3.  9.  0.]
                   [ 7.  9.  4.  8.  3.  5.  0.  8.]]

    output.dims = {8, 8}

    output.lod = [[4, 4]]


**代码示例**

..  code-block:: python
C
Cheerego 已提交
5605

R
RaindragonD 已提交
5606 5607 5608
    import paddle.fluid as fluid
    data = fluid.layers.data(name='data', shape=[3, 32, 32],
                             dtype='float32')
C
Cheerego 已提交
5609
    output = fluid.layers.im2sequence(
R
RaindragonD 已提交
5610
        input=data, stride=[1, 1], filter_size=[2, 2])
C
Cheerego 已提交
5611 5612 5613 5614 5615 5616 5617 5618 5619 5620 5621 5622 5623 5624 5625










.. _cn_api_fluid_layers_image_resize:

image_resize
-------------------------------

H
Hao Wang 已提交
5626
.. py:function:: paddle.fluid.layers.image_resize(input, out_shape=None, scale=None, name=None, resample='BILINEAR', actual_shape=None, align_corners=True, align_mode=1)
C
Cheerego 已提交
5627

H
Hao Wang 已提交
5628
调整一个batch中图片的大小。
C
Cheerego 已提交
5629

C
Cheerego 已提交
5630
输入张量的shape为(num_batch, channels, in_h, in_w),并且调整大小只适用于最后两个维度(高度和宽度)。
C
Cheerego 已提交
5631 5632

支持重新取样方法:
C
Cheerego 已提交
5633 5634

    BILINEAR:双线性插值
T
Tink_Y 已提交
5635

C
Cheerego 已提交
5636 5637
    NEAREST:最近邻插值

H
Hao Wang 已提交
5638 5639 5640 5641 5642 5643 5644 5645 5646 5647 5648 5649

最近邻插值是在输入张量的第3维(高度)和第4维(宽度)上进行最近邻插值。

双线性插值是线性插值的扩展,用于在直线2D网格上插值两个变量(例如,该操作中的H方向和W方向)的函数。 关键思想是首先在一个方向上执行线性插值,然后在另一个方向上再次执行线性插值。

Align_corners和align_mode是可选参数,插值的计算方法可以由它们选择。

示例:

::

      For scale:
C
Cheerego 已提交
5650

H
Hao Wang 已提交
5651 5652 5653
        if align_corners = True && out_size > 1 :

          scale_factor = (in_size-1.0)/(out_size-1.0)
C
Cheerego 已提交
5654

H
Hao Wang 已提交
5655
        else:
C
Cheerego 已提交
5656

H
Hao Wang 已提交
5657
          scale_factor = float(in_size/out_size)
C
Cheerego 已提交
5658 5659


H
Hao Wang 已提交
5660
      Nearest neighbor interpolation:
C
Cheerego 已提交
5661

H
Hao Wang 已提交
5662 5663 5664 5665 5666 5667 5668 5669 5670 5671 5672 5673 5674 5675 5676 5677 5678 5679 5680 5681 5682 5683
      if:
          align_corners = False

          input : (N,C,H_in,W_in)
          output: (N,C,H_out,W_out) where:

          H_out = \left \lfloor {H_{in} * scale_{}factor}} \right \rfloor
          W_out = \left \lfloor {W_{in} * scale_{}factor}} \right \rfloor

      else:
          align_corners = True

          input : (N,C,H_in,W_in)
          output: (N,C,H_out,W_out) where:

          H_out = round(H_{in} * scale_{factor})
          W_out = round(W_{in} * scale_{factor})

      Bilinear interpolation:

      if:
          align_corners = False , align_mode = 0
C
Cheerego 已提交
5684

H
Hao Wang 已提交
5685 5686
          input : (N,C,H_in,W_in)
          output: (N,C,H_out,W_out) where:
C
Cheerego 已提交
5687

H
Hao Wang 已提交
5688 5689 5690 5691 5692
          H_out = (H_{in}+0.5) * scale_{factor} - 0.5
          W_out = (W_{in}+0.5) * scale_{factor} - 0.5


      else:
C
Cheerego 已提交
5693

H
Hao Wang 已提交
5694 5695 5696 5697 5698 5699 5700 5701 5702 5703 5704 5705 5706
          input : (N,C,H_in,W_in)
          output: (N,C,H_out,W_out) where:

          H_out = H_{in} * scale_{factor}
          W_out = W_{in} * scale_{factor}


有关最近邻插值的详细信息,请参阅维基百科:
https://en.wikipedia.org/wiki/Nearest-neighbor_interpolation。

有关双线性插值的详细信息,请参阅维基百科:
https://en.wikipedia.org/wiki/Bilinear_interpolation。

C
Cheerego 已提交
5707 5708 5709 5710 5711 5712 5713
参数:
    - **input** (Variable) - 图片调整层的输入张量,这是一个shape=4的张量(num_batch, channels, in_h, in_w)
    - **out_shape** (list|tuple|Variable|None) - 图片调整层的输出,shape为(out_h, out_w)。默认值:None
    - **scale** (float|None)-输入的高度或宽度的乘数因子 。 out_shape和scale至少要设置一个。out_shape的优先级高于scale。默认值:None
    - **name** (str|None) - 该层的名称(可选)。如果设置为None,该层将被自动命名
    - **resample** (str) - 重采样方法。目前只支持“双线性”。默认值:双线性插值
    - **actual_shape** (Variable) - 可选输入,用于动态指定输出形状。如果指定actual_shape,图像将根据给定的形状调整大小,而不是根据指定形状的 :code:`out_shape` 和 :code:`scale` 进行调整。也就是说, :code:`actual_shape` 具有最高的优先级。如果希望动态指定输出形状,建议使用 :code:`actual_shape` 而不是 :code:`out_shape` 。在使用actual_shape指定输出形状时,还需要设置out_shape和scale之一,否则在图形构建阶段会出现错误。默认值:None
H
Hao Wang 已提交
5714 5715
    - **align_corners** (bool)- 一个可选的bool型参数,如果为True,则将输入和输出张量的4个角落像素的中心对齐,并保留角点像素的值。 默认值:True
    - **align_mode** (int)- 双线性插值的可选项。 可以是 '0' 代表src_idx = scale *(dst_indx + 0.5)-0.5;可以为'1' ,代表src_idx = scale * dst_index。
C
Cheerego 已提交
5716 5717 5718

返回: 4维tensor,shape为 (num_batches, channls, out_h, out_w).

R
RaindragonD 已提交
5719
返回类型: 变量(variable)
C
Cheerego 已提交
5720 5721

抛出异常:
H
Hao Wang 已提交
5722
    - :code:`TypeError` - out_shape应该是一个列表、元组或变量。
R
RaindragonD 已提交
5723
    - :code:`TypeError` - actual_shape应该是变量或None。
H
Hao Wang 已提交
5724
    - :code:`ValueError` - image_resize的"resample"只能是"BILINEAR"或"NEAREST"。
R
RaindragonD 已提交
5725 5726 5727 5728 5729
    - :code:`ValueError` - out_shape 和 scale 不可同时为 None。
    - :code:`ValueError` - out_shape 的长度必须为 2。
    - :code:`ValueError` - scale应大于0。
    - :code:`TypeError`  - align_corners 应为bool型。
    - :code:`ValueError` - align_mode 只能取 ‘0’ 或 ‘1’。
H
Hao Wang 已提交
5730

C
Cheerego 已提交
5731 5732 5733 5734

**代码示例**

..  code-block:: python
C
Cheerego 已提交
5735

R
RaindragonD 已提交
5736 5737
  input = fluid.layers.data(name="input", shape=[3,6,9], dtype="float32")
  out = fluid.layers.image_resize(input, out_shape=[12, 12], resample="NEAREST")
C
Cheerego 已提交
5738

C
Cheerego 已提交
5739 5740 5741 5742 5743 5744 5745 5746 5747 5748 5749 5750 5751 5752 5753 5754 5755 5756 5757 5758 5759 5760 5761 5762











.. _cn_api_fluid_layers_image_resize_short:

image_resize_short
-------------------------------

.. py:function:: paddle.fluid.layers.image_resize_short(input, out_short_len, resample='BILINEAR')

调整一批图片的大小。输入图像的短边将被调整为给定的out_short_len 。输入图像的长边按比例调整大小,最终图像的长宽比保持不变。

参数:
        - **input** (Variable) -  图像调整图层的输入张量,这是一个4维的形状张量(num_batch, channels, in_h, in_w)。
        - **out_short_len** (int) -  输出图像的短边长度。
        - **resample** (str) - resample方法,默认为双线性插值。
C
Cheerego 已提交
5763

R
RaindragonD 已提交
5764
返回: 4维张量,shape为(num_batch, channls, out_h, out_w)
C
Cheerego 已提交
5765

R
RaindragonD 已提交
5766
返回类型: 变量(variable)
C
Cheerego 已提交
5767

R
RaindragonD 已提交
5768 5769 5770
**代码示例**

..  code-block:: python
C
Cheerego 已提交
5771

R
RaindragonD 已提交
5772 5773
    input = fluid.layers.data(name="input", shape=[3,6,9], dtype="float32")
    out = fluid.layers.image_resize_short(input, out_short_len=3)
C
Cheerego 已提交
5774

Z
zy0531 已提交
5775 5776 5777 5778 5779 5780 5781 5782 5783 5784 5785 5786
.. _cn_api_fluid_layers_kldiv_loss:

kldiv_loss
-------------------------------

.. py:function:: paddle.fluid.layers.kldiv_loss(x, target, reduction='mean', name=None)

此运算符计算输入(x)和输入(Target)之间的Kullback-Leibler发散损失。

kL发散损失计算如下:

..  math::
C
Cheerego 已提交
5787

Z
zy0531 已提交
5788 5789 5790 5791 5792 5793 5794 5795 5796 5797 5798 5799 5800 5801 5802 5803 5804 5805 5806 5807 5808 5809 5810 5811 5812 5813 5814 5815 5816
    l(x, y) = y * (log(y) - x)

:math:`x` 为输入(x),:math:`y` 输入(Target)。

当 ``reduction``  为 ``none`` 时,输出损失与输入(x)形状相同,各点的损失单独计算,不应用reduction 。

当 ``reduction``  为 ``mean`` 时,输出损失为[1]的形状,损失值为所有损失的平均值。

当 ``reduction``  为 ``sum`` 时,输出损失为[1]的形状,损失值为所有损失的总和。

当 ``reduction``  为 ``batchmean`` 时,输出损失为[1]的形状,损失值为所有损失的总和除以批量大小。

参数:
    - **x** (Variable) - KL发散损失算子的输入张量。这是一个形状为[N, \*]的张量,其中N是批大小,\*表示任何数量的附加维度
    - **target** (Variable) - KL发散损失算子的张量。这是一个具有输入(x)形状的张量
    - **reduction** (Variable)-要应用于输出的reduction类型,可用类型为‘none’ | ‘batchmean’ | ‘mean’ | ‘sum’,‘none’表示无reduction,‘batchmean’ 表示输出的总和除以批大小,‘mean’ 表示所有输出的平均值,‘sum’表示输出的总和。
    - **name** (str, default None) - 该层的名称

返回:KL发散损失

返回类型:kldiv_loss (Variable)

**代码示例**:

.. code-block:: python

    x = fluid.layers.data(name='x', shape=[4,2,2], dtype='float32')
    target = fluid.layers.data(name='target', shape=[4,2,2], dtype='float32')
    loss = fluid.layers.kldiv_loss(x=x, target=target, reduction='batchmean')
C
Cheerego 已提交
5817 5818 5819 5820 5821 5822 5823 5824 5825 5826 5827 5828 5829 5830 5831 5832 5833 5834 5835 5836 5837 5838 5839 5840 5841 5842 5843







.. _cn_api_fluid_layers_l2_normalize:

l2_normalize
-------------------------------

.. py:function:: paddle.fluid.layers.l2_normalize(x,axis,epsilon=1e-12,name=None)

L2正则(L2 normalize Layer)

该层用欧几里得距离之和对维轴的x归一化。对于1-D张量(系数矩阵的维度固定为0),该层计算公式如下:

.. math::

    y=\frac{x}{\sqrt{\sum x^{2}+epsion}}

对于x多维的情况,该函数分别对维度轴上的每个1-D切片单独归一化

参数:
    - **x** (Variable|list)- l2正则层(l2_normalize layer)的输入
    - **axis** (int)-运用归一化的轴。如果轴小于0,归一化的维是rank(X)+axis。-1是最后维
R
RaindragonD 已提交
5844
    - **epsilon** (float)-epsilon用于避免分母为0,默认值为1e-12
C
Cheerego 已提交
5845
    - **name** (str|None)-该层名称(可选)。如果设为空,则自动为该层命名
C
Cheerego 已提交
5846

C
Cheerego 已提交
5847
    返回:输出张量,同x的维度一致
C
Cheerego 已提交
5848

C
Cheerego 已提交
5849
    返回类型:变量
C
Cheerego 已提交
5850

C
Cheerego 已提交
5851 5852 5853 5854 5855 5856 5857 5858 5859 5860 5861 5862 5863 5864 5865 5866 5867 5868 5869 5870 5871 5872 5873 5874 5875 5876 5877 5878 5879 5880 5881 5882 5883 5884 5885 5886 5887 5888 5889 5890 5891 5892 5893 5894 5895 5896 5897 5898 5899 5900 5901 5902 5903
**代码示例**:

.. code-block:: python

    data = fluid.layers.data(name="data",
                         shape=(3, 17, 13),
                         dtype="float32")
    normed = fluid.layers.l2_normalize(x=data, axis=1)









.. _cn_api_fluid_layers_label_smooth:

label_smooth
-------------------------------

.. py:function:: paddle.fluid.layers.label_smooth(label, prior_dist=None, epsilon=0.1, dtype='float32', name=None)

标签平滑是一种对分类器层进行正则化的机制,称为标签平滑正则化(LSR)。


由于直接优化正确标签的对数似然可能会导致过拟合,降低模型的适应能力,因此提出了标签平滑的方法来降低模型置信度。
标签平滑使用标签 :math:`y` 自身和一些固定模式随机分布变量 :math:`\mu` 。对 :math:`k` 标签,我们有:

.. math::
            \tilde{y_k} = (1 - \epsilon) * y_k + \epsilon * \mu_k,

其中 :math:`1-\epsilon` 和 :math:`\epsilon` 分别是权重, :math:`\tilde{y_k}` 是平滑后的标签。 通常μ 使用均匀分布


查看更多关于标签平滑的细节 https://arxiv.org/abs/1512.00567

参数:
  - **label** (Variable) - 包含标签数据的输入变量。 标签数据应使用 one-hot 表示。
  - **prior_dist** (Variable) - 用于平滑标签的先验分布。 如果未提供,则使用均匀分布。 prior_dist的shape应为 :math:`(1,class\_num)` 。
  - **epsilon** (float) - 用于混合原始真实分布和固定分布的权重。
  - **dtype** (np.dtype | core.VarDesc.VarType | str) - 数据类型:float32,float_64,int等。
  - **name** (str | None) - 此层的名称(可选)。 如果设置为None,则将自动命名图层。

返回:张量变量, 包含平滑后的标签

返回类型: Variable

**代码示例**

..  code-block:: python

R
RaindragonD 已提交
5904 5905
    import paddle.fluid.layers as layers

H
Hao Wang 已提交
5906 5907 5908
    label = fluid.layers.data(name="label", shape=[1], dtype="float32")
    one_hot_label = fluid.layers.one_hot(input=label, depth=10)
    smooth_label = fluid.layers.label_smooth(
C
Cheerego 已提交
5909 5910 5911 5912 5913 5914 5915 5916 5917 5918 5919 5920 5921 5922 5923 5924 5925 5926 5927
    label=one_hot_label, epsilon=0.1, dtype="float32")









.. _cn_api_fluid_layers_layer_norm:

layer_norm
-------------------------------

.. py:function:: paddle.fluid.layers.layer_norm(input, scale=True, shift=True, begin_norm_axis=1, epsilon=1e-05, param_attr=None, bias_attr=None, act=None, name=None)

假设特征向量存在于维度 ``begin_norm_axis ... rank (input)`` 上,计算大小为 ``H`` 的特征向量a在该维度上的矩统计量,然后使用相应的统计量对每个特征向量进行归一化。 之后,如果设置了 ``scale`` 和 ``shift`` ,则在标准化的张量上应用可学习的增益和偏差以进行缩放和移位。

C
Cheerego 已提交
5928 5929
请参考 `Layer Normalization <https://arxiv.org/pdf/1607.06450v1.pdf>`_

C
Cheerego 已提交
5930 5931 5932 5933 5934 5935 5936 5937
公式如下

.. math::
            \\\mu=\frac{1}{H}\sum_{i=1}^{H}a_i\\
.. math::
            \\\sigma=\sqrt{\frac{1}{H}\sum_i^H{(a_i-\mu)^2}}\\
.. math::
             \\h=f(\frac{g}{\sigma}(a-\mu) + b)\\
C
Cheerego 已提交
5938

C
Cheerego 已提交
5939 5940 5941 5942 5943 5944 5945 5946 5947 5948 5949 5950 5951 5952 5953 5954 5955
- :math:`\alpha` : 该层神经元输入总和的向量表示
- :math:`H` : 层中隐藏的神经元个数
- :math:`g` : 可训练的缩放因子参数
- :math:`b` : 可训练的bias参数


参数:
  - **input** (Variable) - 输入张量变量。
  - **scale** (bool) - 是否在归一化后学习自适应增益g。默认为True。
  - **shift** (bool) - 是否在归一化后学习自适应偏差b。默认为True。
  - **begin_norm_axis** (int) - ``begin_norm_axis`` 到 ``rank(input)`` 的维度执行规范化。默认1。
  - **epsilon** (float) - 添加到方差的很小的值,以防止除零。默认1e-05。
  - **param_attr** (ParamAttr | None) - 可学习增益g的参数属性。如果  ``scale`` 为False,则省略 ``param_attr`` 。如果 ``scale`` 为True且 ``param_attr`` 为None,则默认 ``ParamAttr`` 将作为比例。如果添加了 ``param_attr``, 则将其初始化为1。默认None。
  - **bias_attr** (ParamAttr | None) - 可学习偏差的参数属性b。如果 ``shift`` 为False,则省略 ``bias_attr`` 。如果 ``shift`` 为True且 ``param_attr`` 为None,则默认 ``ParamAttr`` 将作为偏差。如果添加了 ``bias_attr`` ,则将其初始化为0。默认None。
  - **act** (str) - 激活函数。默认 None
  - **name** (str) - 该层的名称, 可选的。默认为None,将自动生成唯一名称。

C
Cheerego 已提交
5956
返回: 标准化后的结果
C
Cheerego 已提交
5957 5958 5959 5960

**代码示例**

..  code-block:: python
C
Cheerego 已提交
5961

C
Cheerego 已提交
5962 5963 5964 5965 5966 5967 5968 5969 5970 5971 5972 5973 5974 5975 5976 5977 5978 5979 5980 5981 5982 5983 5984 5985 5986 5987 5988 5989 5990 5991 5992 5993 5994 5995 5996 5997 5998 5999 6000 6001 6002 6003 6004 6005 6006 6007 6008 6009 6010 6011 6012 6013 6014 6015 6016 6017 6018
   data = fluid.layers.data(name='data', shape=[3, 32, 32],
                                           dtype='float32')
   x = fluid.layers.layer_norm(input=data, begin_norm_axis=1)









.. _cn_api_fluid_layers_leaky_relu:

leaky_relu
-------------------------------

.. py:function:: paddle.fluid.layers.leaky_relu(x, alpha=0.02, name=None)

LeakyRelu 激活函数

.. math::   out=max(x,α∗x)

参数:
    - **x** (Variable) - LeakyRelu Operator的输入
    - **alpha** (FLOAT|0.02) - 负斜率,值很小。
    - **name** (str|None) - 此层的名称(可选)。如果设置为None,该层将被自动命名。

**代码示例:**

.. code-block:: python

    x = fluid.layers.data(name="x", shape=[2,3,16,16], dtype="float32")
    y = fluid.layers.leaky_relu(x, alpha=0.01)







.. _cn_api_fluid_layers_linear_chain_crf:

linear_chain_crf
-------------------------------

.. py:function:: paddle.fluid.layers.linear_chain_crf(input, label, param_attr=None)

线性链条件随机场(Linear Chain CRF)

条件随机场定义间接概率图,节点代表随机变量,边代表两个变量之间的依赖。CRF学习条件概率 :math:`P\left ( Y|X \right )` , :math:`X = \left ( x_{1},x_{2},...,x_{n} \right )` 是结构性输入,:math:`Y = \left ( y_{1},y_{2},...,y_{n} \right )` 为输入标签。

线性链条件随机场(Linear Chain CRF)是特殊的条件随机场(CRF),有利于序列标注任务。序列标注任务不为输入设定许多条件依赖。唯一的限制是输入和输出必须是线性序列。因此类似CRF的图是一个简单的链或者线,也就是线性链随机场(linear chain CRF)。

该操作符实现了线性链条件随机场(linear chain CRF)的前向——反向算法。详情请参照 http://www.cs.columbia.edu/~mcollins/fb.pdf 和 http://cseweb.ucsd.edu/~elkan/250Bwinter2012/loglinearCRFs.pdf。


T
Tink_Y 已提交
6019 6020 6021 6022 6023
长度为L的序列s的概率定义如下:

.. math::

    P(s) = (1/Z) exp(a_{s_1} + b_{s_L} + sum_{l=1}^L x_{s_l} + sum_{l=2}^L w_{s_{l-1},s_l})
C
Cheerego 已提交
6024 6025


T
Tink_Y 已提交
6026
其中Z是正则化值,所有可能序列的P(s)之和为1,x是线性链条件随机场(linear chain CRF)的发射(emission)特征权重。
C
Cheerego 已提交
6027

T
Tink_Y 已提交
6028
线性链条件随机场最终输出mini-batch每个训练样本的条件概率的对数
C
Cheerego 已提交
6029 6030


R
RaindragonD 已提交
6031
  1.这里 :math:`x` 代表Emission
C
Cheerego 已提交
6032

R
RaindragonD 已提交
6033
  2.Transition的第一维度值,代表起始权重,这里用 :math:`a` 表示
C
Cheerego 已提交
6034

R
RaindragonD 已提交
6035
  3.Transition的下一维值,代表末尾权重,这里用 :math:`b` 表示
C
Cheerego 已提交
6036

R
RaindragonD 已提交
6037
  4.Transition剩下的值,代表转移权重,这里用 :math:`w` 表示
T
Tink_Y 已提交
6038

R
RaindragonD 已提交
6039
  5.Label用 :math:`s` 表示
T
Tink_Y 已提交
6040

C
Cheerego 已提交
6041

C
Cheerego 已提交
6042 6043 6044 6045 6046 6047 6048 6049 6050 6051 6052 6053 6054 6055 6056 6057 6058 6059 6060


**注意:**

    1.条件随机场(CRF)的特征函数由发射特征(emission feature)和转移特征(transition feature)组成。发射特征(emission feature)权重在调用函数前计算,而不在函数里计算。

    2.由于该函数对所有可能序列的进行全局正则化,发射特征(emission feature)权重应是未缩放的。因此如果该函数带有发射特征(emission feature),并且发射特征是任意非线性激活函数的输出,则请勿调用该函数。

    3.Emission的第二维度必须和标记数字(tag number)相同

参数:
    - **input** (Variable,LoDTensor,默认float类型LoDTensor) - 一个二维LoDTensor,shape为[N*D],N是mini-batch的大小,D是总标记数。线性链条件随机场的未缩放发射权重矩阵
    - **input** (Tensor,默认float类型LoDTensor) - 一个二维张量,shape为[(D+2)*D]。linear_chain_crf操作符的可学习参数。更多详情见operator注释
    - **label** (Variable,LoDTensor,默认int64类型LoDTensor) - shape为[N*10的LoDTensor,N是mini-batch的总元素数
    - **param_attr** (ParamAttr) - 可学习参数的属性

返回:
    output(Variable,Tensor,默认float类型Tensor):shape为[N*D]的二维张量。Emission的指数。这是前向计算中的中间计算结果,在后向计算中还会复用

C
Cheerego 已提交
6061
    output(Variable,Tensor,默认float类型Tensor):shape为[(D+2)*D]的二维张量。Transition的指数。这是前向计算中的中间计算结果,在后向计算中还会复用
C
Cheerego 已提交
6062 6063 6064 6065 6066

    output(Variable,Tensor,默认float类型Tensor):mini-batch每个训练样本的条件概率的对数。这是一个shape为[S*1]的二维张量,S是mini-batch的序列数。注:S等同于mini-batch的序列数。输出不再是LoDTensor

返回类型:output(Variable)

R
RaindragonD 已提交
6067 6068 6069 6070 6071 6072 6073 6074 6075 6076 6077 6078 6079
**代码示例:**

.. code-block:: python

    import paddle.fluid as fluid
    emission = fluid.layers.data(name='emission', shape=[1000], dtype='float32')
    target = fluid.layers.data(name='target', shape=[1], dtype='int32')
    crf_cost = fluid.layers.linear_chain_crf(
        input=emission,
        label=target,
        param_attr=fluid.ParamAttr(
            name='crfw',
            learning_rate=0.2))
C
Cheerego 已提交
6080 6081 6082 6083 6084 6085 6086 6087 6088 6089 6090 6091 6092 6093 6094 6095 6096 6097 6098 6099 6100 6101 6102 6103 6104 6105 6106 6107 6108 6109 6110 6111 6112 6113 6114 6115 6116 6117 6118 6119 6120 6121 6122 6123 6124 6125 6126 6127 6128 6129 6130 6131 6132 6133 6134 6135 6136 6137 6138 6139 6140 6141 6142 6143 6144 6145 6146 6147 6148 6149 6150 6151 6152 6153 6154 6155 6156 6157 6158 6159











.. _cn_api_fluid_layers_lod_reset:

lod_reset
-------------------------------

.. py:function:: paddle.fluid.layers.lod_reset(x, y=None, target_lod=None)


设定x的LoD为y或者target_lod。如果提供y,首先将y.lod指定为目标LoD,否则y.data将指定为目标LoD。如果未提供y,目标LoD则指定为target_lod。如果目标LoD指定为Y.data或target_lod,只提供一层LoD。

::


    * 例1:

    给定一级LoDTensor x:
        x.lod =  [[ 2,           3,                   1 ]]
        x.data = [[1.0], [2.0], [3.0], [4.0], [5.0], [6.0]]
        x.dims = [6, 1]

    target_lod: [4, 2]

    得到一级LoDTensor:
        out.lod =  [[4,                          2]]
        out.data = [[1.0], [2.0], [3.0], [4.0], [5.0], [6.0]]
        out.dims = [6, 1]

    * 例2:

    给定一级LoDTensor x:
        x.lod =  [[2,            3,                   1]]
        x.data = [[1.0], [2.0], [3.0], [4.0], [5.0], [6.0]]
        x.dims = [6, 1]

    y是张量(Tensor):
        y.data = [[2, 4]]
        y.dims = [1, 3]

    得到一级LoDTensor:
        out.lod =  [[2,            4]]
        out.data = [[1.0], [2.0], [3.0], [4.0], [5.0], [6.0]]
        out.dims = [6, 1]

    * 例3:

    给定一级LoDTensor x:
        x.lod =  [[2,            3,                   1]]
        x.data = [[1.0], [2.0], [3.0], [4.0], [5.0], [6.0]]
        x.dims = [6, 1]

    y是二级LoDTensor:
        y.lod =  [[2, 2], [2, 2, 1, 1]]
        y.data = [[1.1], [2.1], [3.1], [4.1], [5.1], [6.1]]
        y.dims = [6, 1]

    得到一个二级LoDTensor:
        out.lod =  [[2, 2], [2, 2, 1, 1]]
        out.data = [[1.0], [2.0], [3.0], [4.0], [5.0], [6.0]]
        out.dims = [6, 1]

参数:
    - **x** (Variable)-输入变量,可以为Tensor或者LodTensor
    - **y** (Variable|None)-若提供,输出的LoD则衍生自y
    - **target_lod** (list|tuple|None)-一层LoD,y未提供时作为目标LoD

返回:输出变量,该层指定为LoD

返回类型:变量

T
Tink_Y 已提交
6160
抛出异常:``TypeError`` - 如果y和target_lod都为空
C
Cheerego 已提交
6161 6162 6163 6164 6165

**代码示例**:

.. code-block:: python

H
Hao Wang 已提交
6166 6167 6168
    x = fluid.layers.data(name='x', shape=[10])
    y = fluid.layers.data(name='y', shape=[10, 20], lod_level=2)
    out = fluid.layers.lod_reset(x=x, y=y)
C
Cheerego 已提交
6169 6170 6171 6172 6173 6174 6175 6176 6177 6178 6179 6180 6181 6182 6183 6184 6185 6186 6187 6188 6189









.. _cn_api_fluid_layers_log:

log
-------------------------------

.. py:function:: paddle.fluid.layers.log(x, name=None)


给定输入张量,计算其每个元素的自然对数

.. math::
                  \\Out=ln(x)\\
C
Cheerego 已提交
6190

C
Cheerego 已提交
6191 6192 6193 6194 6195 6196 6197

参数:
  - **x** (Variable) – 输入张量
  - **name** (str|None, default None) – 该layer的名称,如果为None,自动命名

返回:给定输入张量计算自然对数

R
RaindragonD 已提交
6198
返回类型: 变量(variable)
C
Cheerego 已提交
6199 6200 6201 6202 6203 6204


**代码示例**

..  code-block:: python

R
RaindragonD 已提交
6205
  x = fluid.layers.data(name="x", shape=[3, 4], dtype="float32")
C
Cheerego 已提交
6206 6207 6208 6209 6210 6211 6212 6213 6214 6215 6216 6217 6218 6219 6220 6221 6222 6223 6224 6225 6226 6227 6228 6229 6230 6231 6232 6233 6234 6235 6236 6237 6238 6239
  output = fluid.layers.log(x)











.. _cn_api_fluid_layers_log_loss:

log_loss
-------------------------------

.. py:function:: paddle.fluid.layers.log_loss(input, label, epsilon=0.0001, name=None)

**负log loss层**

该层对输入的预测结果和目的标签进行计算,返回负log loss损失值。

.. math::

    Out = -label * \log{(input + \epsilon)} - (1 - label) * \log{(1 - input + \epsilon)}


参数:
  - **input** (Variable|list) – 形为[N x 1]的二维张量, 其中N为batch大小。 该输入是由先前运算得来的概率集。
  - **label** (Variable|list) – 形为[N x 1]的二维张量,承载着正确标记的数据, 其中N为batch大小。
  - **epsilon** (float) – epsilon
  - **name** (string) – log_loss层的名称

R
RaindragonD 已提交
6240
返回: 形为[N x 1]的二维张量,承载着负log_loss值
C
Cheerego 已提交
6241

R
RaindragonD 已提交
6242
返回类型: 变量(Variable)
C
Cheerego 已提交
6243 6244 6245 6246 6247 6248


**代码示例**

..  code-block:: python

R
RaindragonD 已提交
6249 6250 6251
    label = fluid.layers.data(name='label', shape=[1], dtype='int64')
    prob = fluid.layers.data(name='prob', shape=[10], dtype='float32')
    cost = fluid.layers.log_loss(input=prob, label=label)
C
Cheerego 已提交
6252 6253 6254 6255 6256 6257 6258 6259 6260 6261 6262 6263 6264 6265 6266 6267 6268 6269 6270 6271 6272 6273 6274 6275 6276 6277











.. _cn_api_fluid_layers_logical_and:

logical_and
-------------------------------

.. py:function:: paddle.fluid.layers.logical_and(x, y, out=None, name=None)

logical_and算子

它在X和Y上以元素方式操作,并返回Out。X、Y和Out是N维布尔张量(Tensor)。Out的每个元素的计算公式为:

.. math::
       Out = X \&\& Y

参数:
6278 6279
        - **x** (Variable)- (LoDTensor)logical_and算子的左操作数
        - **y** (Variable)- (LoDTensor)logical_and算子的右操作数
C
Cheerego 已提交
6280 6281 6282
        - **out** (Tensor)- 输出逻辑运算的张量。
        - **name** (basestring | None)- 输出的名称。

C
Cheerego 已提交
6283 6284 6285 6286 6287
返回:        (LoDTensor)n-dim bool张量。每个元素的计算公式: :math:`Out = X \&\& Y`

返回类型:        输出(Variable)。


C
Cheerego 已提交
6288 6289 6290 6291 6292 6293 6294 6295 6296 6297 6298 6299 6300 6301 6302 6303 6304 6305 6306 6307 6308 6309 6310 6311 6312 6313 6314 6315 6316
**代码示例:**

.. code-block:: python

    left = fluid.layers.data(
        name='left', shape=[1], dtype='int32')
    right = fluid.layers.data(
        name='right', shape=[1], dtype='int32')
    result = fluid.layers.logical_and(x=left, y=right)









.. _cn_api_fluid_layers_logical_not:

logical_not
-------------------------------

.. py:function:: paddle.fluid.layers.logical_not(x, out=None, name=None)

logical_not算子

它在X上以元素方式操作,并返回Out。X和Out是N维布尔张量(Tensor)。Out的每个元素的计算公式为:

C
Cheerego 已提交
6317
.. math::
C
Cheerego 已提交
6318 6319 6320
        Out = !X

参数:
6321
        - **x** (Variable)- (LoDTensor)logical_not算子的操作数
C
Cheerego 已提交
6322 6323 6324 6325 6326
        - **out** (Tensor)- 输出逻辑运算的张量。
        - **name** (basestring | None)- 输出的名称。

返回:        (LoDTensor)n维布尔张量。

C
Cheerego 已提交
6327
返回类型:        输出(Variable)。
C
Cheerego 已提交
6328 6329 6330 6331 6332


**代码示例:**

.. code-block:: python
C
Cheerego 已提交
6333

C
Cheerego 已提交
6334 6335 6336 6337 6338 6339 6340 6341 6342 6343 6344 6345 6346 6347 6348 6349 6350 6351 6352 6353 6354
    left = fluid.layers.data(
        name='left', shape=[1], dtype='int32')
    result = fluid.layers.logical_not(x=left)







.. _cn_api_fluid_layers_logical_or:

logical_or
-------------------------------

.. py:function:: paddle.fluid.layers.logical_or(x, y, out=None, name=None)

logical_or算子

它在X和Y上以元素方式操作,并返回Out。X、Y和Out是N维布尔张量(Tensor)。Out的每个元素的计算公式为:

C
Cheerego 已提交
6355
.. math::
C
Cheerego 已提交
6356 6357 6358
        Out = X || Y

参数:
6359 6360
        - **x** (Variable)- (LoDTensor)logical_or算子的左操作数
        - **y** (Variable)- (LoDTensor)logical_or算子的右操作数
C
Cheerego 已提交
6361 6362 6363
        - **out** (Tensor)- 输出逻辑运算的张量。
        - **name** (basestring | None)- 输出的名称。

C
Cheerego 已提交
6364 6365 6366
返回:        (LoDTensor)n维布尔张量。每个元素的计算公式: :math:`Out = X || Y`

返回类型:        输出(Variable)。
C
Cheerego 已提交
6367 6368 6369 6370 6371 6372 6373 6374 6375 6376 6377 6378 6379 6380 6381 6382 6383 6384 6385 6386 6387 6388 6389 6390 6391 6392 6393 6394 6395 6396



**代码示例:**

.. code-block:: python


    left = fluid.layers.data(
        name='left', shape=[1], dtype='int32')
    right = fluid.layers.data(
        name='right', shape=[1], dtype='int32')
    result = fluid.layers.logical_or(x=left, y=right)






.. _cn_api_fluid_layers_logical_xor:

logical_xor
-------------------------------

.. py:function:: paddle.fluid.layers.logical_xor(x, y, out=None, name=None)

logical_xor算子

它在X和Y上以元素方式操作,并返回Out。X、Y和Out是N维布尔张量(Tensor)。Out的每个元素的计算公式为:

C
Cheerego 已提交
6397
.. math::
C
Cheerego 已提交
6398 6399 6400
        Out = (X || Y) \&\& !(X \&\& Y)

参数:
6401 6402
        - **x** (Variable)- (LoDTensor)logical_xor算子的左操作数
        - **y** (Variable)- (LoDTensor)logical_xor算子的右操作数
C
Cheerego 已提交
6403 6404 6405 6406
        - **out** (Tensor)- 输出逻辑运算的张量。
        - **name** (basestring | None)- 输出的名称。

返回:        (LoDTensor)n维布尔张量。
C
Cheerego 已提交
6407 6408

返回类型:        输出(Variable)。
C
Cheerego 已提交
6409 6410 6411 6412 6413 6414 6415 6416 6417 6418 6419 6420 6421 6422 6423 6424 6425 6426 6427 6428 6429 6430 6431 6432 6433 6434 6435 6436 6437 6438 6439 6440 6441



**代码示例:**

.. code-block:: python

    left = fluid.layers.data(
        name='left', shape=[1], dtype='int32')
    right = fluid.layers.data(
        name='right', shape=[1], dtype='int32')
    result = fluid.layers.logical_xor(x=left, y=right)






.. _cn_api_fluid_layers_lrn:

lrn
-------------------------------

.. py:function:: paddle.fluid.layers.lrn(input, n=5, k=1.0, alpha=0.0001, beta=0.75, name=None)

局部响应正则层(Local Response Normalization Layer)

该层对局部输入区域正则化,执行一种侧向抑制(lateral inhibition)。

公式如下:

.. math::

X
xiaoting 已提交
6442
    Output(i,x,y) = Input(i,x,y)/\left ( k+\alpha \sum_{j=max(0,i-n/2)}^{min(C-1,i+n/2)}(Input(j,x,y))^2 \right )^\beta
C
Cheerego 已提交
6443 6444 6445 6446 6447 6448 6449 6450 6451 6452 6453

在以上公式中:
  - :math:`n` :累加的通道数
  - :math:`k` :位移(避免除数为0)
  - :math:`\alpha` : 缩放参数
  - :math:`\beta` : 指数参数

参考 : `ImageNet Classification with Deep Convolutional Neural Networks <https://papers.nips.cc/paper/4824-imagenet-classification-with-deep-convolutional-neural-networks.pdf>`_

参数:
    - **input** (Variable)- 该层输入张量,输入张量维度必须为4
6454
    - **n** (int,默认5) - 累加的通道数
C
Cheerego 已提交
6455 6456 6457 6458 6459 6460 6461 6462 6463 6464 6465 6466 6467 6468 6469 6470 6471 6472 6473 6474 6475 6476 6477 6478 6479 6480 6481 6482 6483 6484 6485 6486 6487 6488 6489 6490 6491 6492 6493 6494 6495
    - **k** (float,默认1.0)- 位移(通常为正数,避免除数为0)
    - **alpha** (float,默认1e-4)- 缩放参数
    - **beta** (float,默认0.75)- 指数
    - **name** (str,默认None)- 操作符名

抛出异常:
  - ``ValueError`` - 如果输入张量的阶不为4

返回:张量,存储转置结果

**代码示例**:

.. code-block:: python

    data = fluid.layers.data(
        name="data", shape=[3, 112, 112], dtype="float32")
    lrn = fluid.layers.lrn(input=data)











.. _cn_api_fluid_layers_lstm:

lstm
-------------------------------

.. py:function::  paddle.fluid.layers.lstm(input, init_h, init_c, max_len, hidden_size, num_layers, dropout_prob=0.0, is_bidirec=False, is_test=False, name=None, default_initializer=None, seed=-1)

如果您的设备是GPU,本op将使用cudnn LSTM实现

一个没有 peephole 连接的四门长短期记忆网络。在前向传播中,给定迭代的输出ht和单元输出ct可由递归输入ht-1、单元输入ct-1和上一层输入xt计算,给定矩阵W、R和bias bW, bR由下式计算:

.. math::

R
RaindragonD 已提交
6496 6497 6498 6499 6500 6501
  i_t &= \sigma(W_{ix}x_{t} + W_{ih}h_{t-1} + bx_i + bh_i)\\
  f_t &= \sigma(W_{fx}x_{t} + W_{fh}h_{t-1} + bx_f + bh_f)\\
  o_t &= \sigma(W_{ox}x_{t} + W_{oh}h_{t-1} + bx_o + bh_o)\\
  \tilde{c_t} &= tanh(W_{cx}x_t + W_{ch}h_{t-1} + bx_c + bh_c)\\
  c_t &= f_t \odot c_{t-1} + i_t \odot \tilde{c_t}\\
  h_t &= o_t \odot tanh(c_t)
C
Cheerego 已提交
6502 6503

公式中:
R
RaindragonD 已提交
6504 6505 6506 6507 6508 6509 6510
  - W 项表示权重矩阵(e.g. :math:`W_{ix}` 是从输入门到输入的权重矩阵)
  - b 项表示偏差向量( :math:`b_{xi}` 和 :math:`b_{hi}` 是输入门的偏差向量)
  - sigmoid 是 logistic sigmoid 函数
  - i、f、o、c 分别为输入门、遗忘门、输出门和激活向量,它们的大小与 cell 输出激活向量h相同。
  - :math:`\odot` 是向量的元素乘积
  - tanh是激活函数
  - :math:`\tilde{c_t}` 也称为候选隐藏状态,它是根据当前输入和之前的隐藏状态来计算的
H
Hao Wang 已提交
6511 6512 6513

sigmoid的计算公式为: :math:`sigmoid(x) = 1 / (1 + e^{-x})` 。

C
Cheerego 已提交
6514 6515

参数:
R
RaindragonD 已提交
6516 6517 6518 6519 6520 6521 6522 6523 6524 6525 6526 6527
  - **input** (Variable) - LSTM 输入张量,形状必须为(seq_len x,batch_size,x,input_size)
  - **init_h** (Variable) – LSTM的初始隐藏状态,是一个有形状的张量(num_layers,x,batch_size,x,hidden_size)如果is_bidirec = True,形状应该是(num_layers*2,x, batch_size, x, hidden_size)
  - **init_c** (Variable) - LSTM的初始状态。这是一个有形状的张量(num_layers, x, batch_size, x, hidden_size)如果is_bidirec = True,形状应该是(num_layers*2, x, batch_size, x, hidden_size)
  - **max_len** (int) – LSTM的最大长度。输入张量的第一个 dim 不能大于max_len
  - **hidden_size** (int) - LSTM的隐藏大小
  - **num_layers** (int) –  LSTM的总层数
  - **dropout_prob** (float|0.0) – dropout prob,dropout 只在 rnn 层之间工作,而不是在时间步骤之间。dropout 不作用于最后的 rnn 层的 rnn 输出中
  - **is_bidirec** (bool) – 是否是双向的
  - **is_test** (bool) – 是否在测试阶段
  - **name** (str|None) - 此层的名称(可选)。如果没有设置,该层将被自动命名。
  - **default_initializer** (Initialize|None) – 在哪里使用初始化器初始化权重,如果没有设置,将进行默认初始化。
  - **seed** (int) – LSTM中dropout的Seed,如果是-1,dropout将使用随机Seed
C
Cheerego 已提交
6528

H
Hao Wang 已提交
6529 6530 6531 6532 6533 6534 6535
返回:   三个张量, rnn_out, last_h, last_c:

- rnn_out为LSTM hidden的输出结果。形为(seq_len x batch_size x hidden_size)如果is_bidirec设置为True,则形为(seq_len x batch_sze hidden_size * 2)
- last_h(Tensor):  LSTM最后一步的隐藏状态,形状为(num_layers x batch_size x hidden_size);如果is_bidirec设置为True,形状为(num_layers*2 x batch_size x hidden_size)
- last_c(Tensor): LSTM最后一步的cell状态,形状为(num_layers x batch_size x hidden_size);如果is_bidirec设置为True,形状为(num_layers*2 x batch_size x hidden_size)

返回类型:   rnn_out(Tensor),last_h(Tensor),last_c(Tensor)
C
Cheerego 已提交
6536 6537 6538 6539 6540

**代码示例:**

.. code-block:: python

R
RaindragonD 已提交
6541 6542 6543 6544 6545 6546 6547 6548 6549 6550 6551 6552 6553
  emb_dim = 256
  vocab_size = 10000
  data = fluid.layers.data(name='x', shape=[-1, 100, 1],
                 dtype='int32')
  emb = fluid.layers.embedding(input=data, size=[vocab_size, emb_dim], is_sparse=True)
  batch_size = 20
  max_len = 100
  dropout_prob = 0.2
  input_size = 100
  hidden_size = 150
  num_layers = 1
  init_h = layers.fill_constant( [num_layers, batch_size, hidden_size], 'float32', 0.0 )
  init_c = layers.fill_constant( [num_layers, batch_size, hidden_size], 'float32', 0.0 )
C
Cheerego 已提交
6554

R
RaindragonD 已提交
6555
  rnn_out, last_h, last_c = fluid.layers.lstm(emb, init_h, init_c, max_len, hidden_size, num_layers, dropout_prob=dropout_prob)
C
Cheerego 已提交
6556 6557 6558 6559 6560 6561 6562 6563 6564 6565 6566 6567 6568 6569 6570 6571 6572 6573 6574 6575 6576 6577 6578 6579 6580 6581 6582 6583 6584 6585 6586 6587 6588 6589 6590 6591 6592 6593 6594 6595 6596 6597 6598












.. _cn_api_fluid_layers_lstm_unit:

lstm_unit
-------------------------------

.. py:function:: paddle.fluid.layers.lstm_unit(x_t, hidden_t_prev, cell_t_prev, forget_bias=0.0, param_attr=None, bias_attr=None, name=None)

Lstm unit layer

lstm步的等式:

.. math::

    i_{t} &= \sigma \left ( W_{x_{i}}x_{t}+W_{h_{i}}h_{t-1}+b_{i} \right ) \\
    f_{t} &= \sigma \left ( W_{x_{f}}x_{t}+W_{h_{f}}h_{t-1}+b_{f} \right ) \\
    c_{t} &= f_{t}c_{t-1}+i_{t}tanh\left ( W_{x_{c}}x_{t} +W_{h_{c}}h_{t-1}+b_{c}\right ) \\
    o_{t} &= \sigma \left ( W_{x_{o}}x_{t}+W_{h_{o}}h_{t-1}+b_{o} \right ) \\
    h_{t} &= o_{t}tanh \left ( c_{t} \right )

lstm单元的输入包括 :math:`x_{t}` , :math:`h_{t-1}` 和 :math:`c_{t-1}` 。:math:`h_{t-1}` 和 :math:`c_{t-1}` 的第二维应当相同。在此实现过程中,线性转换和非线性转换分离。以 :math:`i_{t}` 为例。线性转换运用到fc层,等式为:

.. math::

    L_{i_{t}} = W_{x_{i}}x_{t} + W_{h_{i}}h_{t-1} + b_{i}

非线性转换运用到lstm_unit运算,方程如下:

.. math::

    i_{t} = \sigma \left ( L_{i_{t}} \right )

R
RaindragonD 已提交
6599
该层有 :math:`h_{t}` 和 :math:`c_{t}` 两个输出。
C
Cheerego 已提交
6600 6601 6602 6603 6604 6605 6606 6607 6608 6609 6610 6611 6612 6613 6614 6615 6616 6617 6618 6619 6620

参数:
    - **x_t** (Variable) - 当前步的输入值,二维张量,shape为 M x N ,M是批尺寸,N是输入尺寸
    - **hidden_t_prev** (Variable) - lstm单元的隐藏状态值,二维张量,shape为 M x S,M是批尺寸,N是lstm单元的大小
    - **cell_t_prev** (Variable) - lstm单元的cell值,二维张量,shape为 M x S ,M是批尺寸,N是lstm单元的大小
    - **forget_bias** (Variable) - lstm单元的遗忘bias
    - **param_attr** (ParamAttr|None) - 可学习hidden-hidden权重的擦参数属性。如果设为None或者ParamAttr的一个属性,lstm_unit创建ParamAttr为param_attr。如果param_attr的初始化函数未设置,参数初始化为Xavier。默认:None
    - **bias_attr** (ParamAttr|None) - 可学习bias权重的bias属性。如果设为False,输出单元中则不添加bias。如果设为None或者ParamAttr的一个属性,lstm_unit创建ParamAttr为bias_attr。如果bias_attr的初始化函数未设置,bias初始化为0.默认:None
    - **name** (str|None) - 该层名称(可选)。若设为None,则自动为该层命名

返回:lstm单元的hidden(隐藏状态)值和cell值

返回类型:tuple(元组)

抛出异常:
  - ``ValueError`` - ``x_t``,``hidden_t_prev`` 和 ``cell_t_prev`` 的阶不为2,或者 ``x_t`` ,``hidden_t_prev`` 和 ``cell_t_prev`` 的第一维不一致,或者 ``hidden_t_prev`` 和 ``cell_t_prev`` 的第二维不一致

**代码示例**:

.. code-block:: python

R
RaindragonD 已提交
6621 6622 6623 6624 6625 6626 6627 6628 6629 6630 6631
    import paddle.fluid as fluid
     
    dict_dim, emb_dim, hidden_dim = 128, 64, 512
    data = fluid.layers.data(name='step_data', shape=[1], dtype='int32')
    x = fluid.layers.embedding(input=data, size=[dict_dim, emb_dim])
    pre_hidden = fluid.layers.data(name='pre_hidden', shape=[hidden_dim], dtype='float32')
    pre_cell = fluid.layers.data(name='pre_cell', shape=[hidden_dim], dtype='float32')
    hidden = fluid.layers.lstm_unit(
        x_t=x,
        hidden_t_prev=prev_hidden,
        cell_t_prev=prev_cell)
C
Cheerego 已提交
6632 6633 6634 6635 6636 6637 6638 6639 6640 6641 6642 6643 6644 6645 6646 6647 6648 6649 6650 6651 6652 6653 6654 6655 6656 6657 6658 6659 6660 6661 6662 6663 6664 6665 6666











.. _cn_api_fluid_layers_margin_rank_loss:

margin_rank_loss
-------------------------------

.. py:function:: paddle.fluid.layers.margin_rank_loss(label, left, right, margin=0.1, name=None)

margin rank loss(差距排序损失)层。在排序问题中,它可以比较传进来的 ``left`` 得分和 ``right`` 得分。

可用如下等式定义:

.. math::
    rank\_loss = max(0, -label * (left - right) + margin)


参数:
  - **label** (Variable) – 表明是否左元素排名要高于右元素
  - **left** (Variable) – 左元素排序得分
  - **right** (Variable) – 右元素排序得分
  - **margin** (float) – 指定固定的得分差
  - **name** (str|None) – 可选项,该层的命名。如果为None, 该层将会被自动命名

返回: 排序损失

R
RaindragonD 已提交
6667
返回类型: 变量(Variable)
C
Cheerego 已提交
6668

C
Cheerego 已提交
6669
抛出异常:
C
Cheerego 已提交
6670
  - ``ValueError`` - ``label`` , ``left`` , ``right`` 有一者不为Variable类型时,抛出此异常
C
Cheerego 已提交
6671

C
Cheerego 已提交
6672 6673 6674 6675
**代码示例**

..  code-block:: python

R
RaindragonD 已提交
6676 6677 6678 6679
    label = fluid.layers.data(name="label", shape=[-1, 1], dtype="float32")
    left = fluid.layers.data(name="left", shape=[-1, 1], dtype="float32")
    right = fluid.layers.data(name="right", shape=[-1, 1], dtype="float32")
    out = fluid.layers.margin_rank_loss(label, left, right)
C
Cheerego 已提交
6680 6681 6682 6683 6684 6685 6686 6687 6688 6689 6690 6691 6692 6693 6694 6695 6696 6697 6698 6699 6700 6701 6702 6703 6704











.. _cn_api_fluid_layers_matmul:



matmul
-------------------------------

.. py:function:: paddle.fluid.layers.matmul(x, y, transpose_x=False, transpose_y=False, alpha=1.0, name=None)

对两个张量进行矩阵相乘

当前输入的张量可以为任意阶,但当任意一个输入的阶数大于3时,两个输入的阶必须相等。
实际的操作取决于x,y的维度和 ``transpose_x`` , ``transpose_y`` 的标记值。具体如下:

T
Tink_Y 已提交
6705
- 如果transpose值为真,则对应 ``tensor`` 的最后两维将被转置。如:x是一个shape=[D]的一阶张量,那么x在非转置形式中为[1,D],在转置形式中为[D,1],而y则相反,在非转置形式中作为[D,1],在转置形式中作为[1,D]。
C
Cheerego 已提交
6706 6707

- 转置后,这两个`tensors`将为 2-D 或 n-D ,并依据下列规则进行矩阵相乘:
R
RaindragonD 已提交
6708 6709
  - 如果两个都是2-D,则同普通矩阵一样进行矩阵相乘
  - 如果任意一个是n-D,则将其视为驻留在最后两个维度的矩阵堆栈,并在两个张量上应用支持广播的批处理矩阵乘法。
C
Cheerego 已提交
6710 6711 6712 6713 6714 6715 6716 6717

**注意,如果原始张量x或y的秩为1且没有转置,则在矩阵乘法之后,前置或附加维度1将被移除。**


参数:
    - **x** (Variable)-输入变量,类型为Tensor或LoDTensor
    - **y** (Variable)-输入变量,类型为Tensor或LoDTensor
    - **transpose_x** (bool)-相乘前是否转置x
T
Tink_Y 已提交
6718
    - **transpose_y** (bool)-相乘前是否转置y
C
Cheerego 已提交
6719 6720 6721 6722 6723 6724 6725 6726 6727 6728 6729 6730 6731
    - **alpha** (float)-输出比例。默认为1.0
    - **name** (str|None)-该层名称(可选)。如果设置为空,则自动为该层命名

返回:张量乘积变量

返回类型:变量(Variable)

**代码示例**:

.. code-block:: python

    # 以下是解释输入和输出维度的示例
    # x: [B, ..., M, K], y: [B, ..., K, N]
R
RaindragonD 已提交
6732
    # fluid.layers.matmul(x, y)  # out: [B, ..., M, N]
C
Cheerego 已提交
6733 6734

    # x: [B, M, K], y: [B, K, N]
R
RaindragonD 已提交
6735
    # fluid.layers.matmul(x, y)  # out: [B, M, N]
C
Cheerego 已提交
6736 6737

    # x: [B, M, K], y: [K, N]
R
RaindragonD 已提交
6738
    # fluid.layers.matmul(x, y)  # out: [B, M, N]
C
Cheerego 已提交
6739 6740

    # x: [M, K], y: [K, N]
R
RaindragonD 已提交
6741
    # fluid.layers.matmul(x, y)  # out: [M, N]
C
Cheerego 已提交
6742 6743

    # x: [B, M, K], y: [K]
R
RaindragonD 已提交
6744
    # fluid.layers.matmul(x, y)  # out: [B, M]
C
Cheerego 已提交
6745 6746

    # x: [K], y: [K]
R
RaindragonD 已提交
6747
    # fluid.layers.matmul(x, y)  # out: [1]
C
Cheerego 已提交
6748 6749

    # x: [M], y: [N]
R
RaindragonD 已提交
6750
    # fluid.layers.matmul(x, y, True, True)  # out: [M, N]
C
Cheerego 已提交
6751

R
RaindragonD 已提交
6752 6753 6754
    x = fluid.layers.data(name='x', shape=[2, 3], dtype='float32')
    y = fluid.layers.data(name='y', shape=[3, 2], dtype='float32')
    out = fluid.layers.matmul(x, y, True, True)
C
Cheerego 已提交
6755 6756 6757 6758 6759 6760 6761 6762 6763 6764 6765 6766 6767 6768 6769 6770







.. _cn_api_fluid_layers_maxout:

maxout
-------------------------------

.. py:function:: paddle.fluid.layers.maxout(x, groups, name=None)

假设输入形状为(N, Ci, H, W),输出形状为(N, Co, H, W),则 :math:`Co=Ci/groups` 运算公式如下:

C
Cheerego 已提交
6771
.. math::
C
Cheerego 已提交
6772

R
RaindragonD 已提交
6773 6774 6775 6776 6777 6778
  y_{si+j} &= \max_k x_{gsi + sk + j} \\
  g &= groups \\
  s &= \frac{input.size}{num\_channels} \\
  0 \le &i < \frac{num\_channels}{groups} \\
  0 \le &j < s \\
  0 \le &k < groups
C
Cheerego 已提交
6779 6780 6781


请参阅论文:
R
RaindragonD 已提交
6782 6783
  - Maxout Networks:  http://www.jmlr.org/proceedings/papers/v28/goodfellow13.pdf
  - Multi-digit Number Recognition from Street View Imagery using Deep Convolutional Neural Networks: https://arxiv.org/pdf/1312.6082v4.pdf
C
Cheerego 已提交
6784 6785

参数:
R
RaindragonD 已提交
6786 6787 6788
    - **x** (Variable) - (tensor) maxout算子的输入张量。输入张量的格式为NCHW。其中N为 batch size ,C为通道数,H和W为feature的高和宽
    - **groups** (INT)- 指定将输入张量的channel通道维度进行分组的数目。输出的通道数量为通道数除以组数。
    - **name** (basestring|None) - 输出的名称
C
Cheerego 已提交
6789 6790 6791

返回:Tensor,maxout算子的输出张量。输出张量的格式也是NCHW。其中N为 batch size,C为通道数,H和W为特征的高和宽。

R
RaindragonD 已提交
6792 6793 6794 6795 6796 6797 6798 6799 6800 6801 6802
返回类型:out(Variable)

**代码示例**:
    
.. code-block:: python

    input = fluid.layers.data(
        name='data',
        shape=[256, 32, 32],
        dtype='float32')
    out = fluid.layers.maxout(input, groups=2)
C
Cheerego 已提交
6803 6804 6805 6806 6807 6808 6809 6810 6811 6812 6813 6814 6815 6816 6817 6818










.. _cn_api_fluid_layers_mean:

mean
-------------------------------

.. py:function:: paddle.fluid.layers.mean(x, name=None)
C
Cheerego 已提交
6819

C
Cheerego 已提交
6820
mean算子计算X中所有元素的平均值
C
Cheerego 已提交
6821

C
Cheerego 已提交
6822 6823 6824 6825 6826
参数:
        - **x** (Variable)- (Tensor) 均值运算的输入。
        - **name** (basestring | None)- 输出的名称。

返回:       均值运算输出张量(Tensor)
C
Cheerego 已提交
6827

C
Cheerego 已提交
6828
返回类型:        Variable
C
Cheerego 已提交
6829

R
RaindragonD 已提交
6830 6831 6832 6833 6834 6835 6836
**代码示例**:

.. code-block:: python

    input = fluid.layers.data(
        name='data', shape=[2, 3], dtype='float32')
    mean = fluid.layers.mean(input)
C
Cheerego 已提交
6837

C
Cheerego 已提交
6838 6839 6840 6841 6842 6843 6844 6845 6846 6847 6848 6849 6850








.. _cn_api_fluid_layers_mean_iou:

mean_iou
-------------------------------

6851
.. py:function:: paddle.fluid.layers.mean_iou(input, label, num_classes)
C
Cheerego 已提交
6852 6853

均值IOU(Mean  Intersection-Over-Union)是语义图像分割中的常用的评价指标之一,它首先计算每个语义类的IOU,然后计算类之间的平均值。定义如下:
C
Cheerego 已提交
6854 6855

.. math::
H
Hao Wang 已提交
6856 6857

    IOU = \frac{true\_positive}{true\_positive+false\_positive+false\_negative}
C
Cheerego 已提交
6858

H
Hao Wang 已提交
6859
在一个confusion矩阵中累积得到预测值,然后从中计算均值-IOU。
C
Cheerego 已提交
6860 6861 6862 6863 6864

参数:
    - **input** (Variable) - 类型为int32或int64的语义标签的预测结果张量。
    - **label** (Variable) - int32或int64类型的真实label张量。它的shape应该与输入相同。
    - **num_classes** (int) - 标签可能的类别数目。
C
Cheerego 已提交
6865

H
Hao Wang 已提交
6866
返回: 返回三个变量:
C
Cheerego 已提交
6867

H
Hao Wang 已提交
6868 6869 6870
- mean_iou: 张量,形为[1], 代表均值IOU。
- out_wrong: 张量,形为[num_classes]。每个类别中错误的个数。
- out_correct:张量,形为[num_classes]。每个类别中的正确的个数。
C
Cheerego 已提交
6871

H
Hao Wang 已提交
6872 6873 6874
返回类型:   mean_iou (Variable),out_wrong(Variable),out_correct(Variable)

**代码示例**
C
Cheerego 已提交
6875 6876 6877

..  code-block:: python

R
RaindragonD 已提交
6878 6879 6880
   import paddle.fluid as fluid
   predict = fluid.layers.data(name='predict', shape=[3, 32, 32])
   label = fluid.layers.data(name='label', shape=[1])
C
Cheerego 已提交
6881 6882 6883 6884 6885 6886 6887 6888 6889 6890 6891 6892 6893 6894 6895 6896 6897 6898 6899 6900 6901 6902
   iou, wrongs, corrects = fluid.layers.mean_iou(predict, label, num_classes)









.. _cn_api_fluid_layers_merge_selected_rows:

merge_selected_rows
-------------------------------

.. py:function:: paddle.fluid.layers.merge_selected_rows(x, name=None)

**实现合并选中行(row)操作**

该运算用于合并(值相加)输入张量中重复的行。输出行没有重复的行,并且按值从小到大顺序重新对行排序。

::
C
Cheerego 已提交
6903

C
Cheerego 已提交
6904
    例如:
C
Cheerego 已提交
6905 6906

          输入:
C
Cheerego 已提交
6907 6908 6909
               X.rows = [0, 5, 5, 4, 19]
               X.height = 20
               X.value = [[1, 1] [2, 2] [3, 3] [4, 4] [6, 6]]
C
Cheerego 已提交
6910 6911


C
Cheerego 已提交
6912
          输出:
C
Cheerego 已提交
6913 6914
               Out.row is [0, 4, 5, 19]
               Out.height is 20
C
Cheerego 已提交
6915 6916 6917 6918 6919 6920 6921 6922
               Out.value is: [[1, 1] [4, 4] [5, 5] [6, 6]]



参数:
  - x (Variable) – 输入类型为SelectedRows, 选中行有可能重复
  - name (basestring|None) – 输出变量的命名

C
Cheerego 已提交
6923
返回: 输出类型为SelectedRows,并且选中行不会重复
C
Cheerego 已提交
6924

R
RaindragonD 已提交
6925 6926 6927
返回类型: 变量(Variable)

**代码示例**
C
Cheerego 已提交
6928

R
RaindragonD 已提交
6929
..  code-block:: python
C
Cheerego 已提交
6930

R
RaindragonD 已提交
6931 6932 6933 6934 6935
  b = fluid.default_main_program().global_block()
  var = b.create_var(
        name="X", dtype="float32", persistable=True,
        type=fluid.core.VarDesc.VarType.SELECTED_ROWS)
  y = fluid.layers.merge_selected_rows(var)
C
Cheerego 已提交
6936 6937 6938 6939 6940 6941 6942 6943 6944 6945 6946 6947 6948 6949 6950









.. _cn_api_fluid_layers_mul:

mul
-------------------------------

.. py:function:: paddle.fluid.layers.mul(x, y, x_num_col_dims=1, y_num_col_dims=1, name=None)
C
Cheerego 已提交
6951

C
Cheerego 已提交
6952 6953 6954 6955
mul算子
此运算是用于对输入X和Y执行矩阵乘法。
等式是:

C
Cheerego 已提交
6956
.. math::
C
Cheerego 已提交
6957 6958 6959 6960 6961 6962 6963 6964 6965 6966 6967 6968
        Out = X * Y

输入X和Y都可以携带LoD(详细程度)信息。但输出仅与输入X共享LoD信息。

参数:
        - **x** (Variable)- (Tensor) 乘法运算的第一个输入张量。
        - **y** (Variable)- (Tensor) 乘法运算的第二个输入张量。
        - **x_num_col_dims** (int)- 默认值1, 可以将具有两个以上维度的张量作为输入。如果输入X是具有多于两个维度的张量,则输入X将先展平为二维矩阵。展平规则是:前 ``num_col_dims`` 将被展平成最终矩阵的第一个维度(矩阵的高度),其余的 rank(X) - num_col_dims 维度被展平成最终矩阵的第二个维度(矩阵的宽度)。结果是展平矩阵的高度等于X的前 ``x_num_col_dims`` 维数的乘积,展平矩阵的宽度等于X的最后一个秩(x)- ``num_col_dims`` 个剩余维度的维数的乘积。例如,假设X是一个五维张量,形状为(2,3,4,5,6)。 则扁平化后的张量具有的形即为 (2x3x4,5x6)=(24,30)。
        - **y_num_col_dims** (int)- 默认值1, 可以将具有两个以上维度的张量作为输入。如果输入Y是具有多于两个维度的张量,则Y将首先展平为二维矩阵。 ``y_num_col_dims`` 属性确定Y的展平方式。有关更多详细信息,请参阅 ``x_num_col_dims`` 的注释。
        - **name** (basestring | None)- 输出的名称。

返回:       乘法运算输出张量(Tensor).
C
Cheerego 已提交
6969 6970 6971

返回类型:    输出(Variable)。

R
RaindragonD 已提交
6972
**代码示例**
C
Cheerego 已提交
6973

R
RaindragonD 已提交
6974
..  code-block:: python
C
Cheerego 已提交
6975

R
RaindragonD 已提交
6976 6977 6978 6979 6980 6981
    import paddle.fluid as fluid
    dataX = fluid.layers.data(name="dataX", append_batch_size = False, shape=[2, 5], dtype="float32")
    dataY = fluid.layers.data(name="dataY", append_batch_size = False, shape=[5, 3], dtype="float32")
    output = fluid.layers.mul(dataX, dataY,
                              x_num_col_dims = 1,
                              y_num_col_dims = 1)
C
Cheerego 已提交
6982 6983 6984 6985 6986 6987 6988 6989 6990 6991 6992 6993 6994






.. _cn_api_fluid_layers_multiplex:

multiplex
-------------------------------

.. py:function:: paddle.fluid.layers.multiplex(inputs, index)

C
Cheerego 已提交
6995
引用给定的索引变量,该层从输入变量中选择行构造Multiplex变量。
C
Cheerego 已提交
6996

C
Cheerego 已提交
6997
假设有 :math:`m` 个输入变量,:math:`I_{i}` 代表第i个输入变量,而且 :math:`i` is in :math:`[0,m)` 。
C
Cheerego 已提交
6998

C
Cheerego 已提交
6999
所有输入变量都是具有相同形状的张量 :math:`[d_0,d_1, ... ,d_R]` 。
C
Cheerego 已提交
7000

C
Cheerego 已提交
7001
请注意,输入张量的秩应至少为2。每个输入变量将被视为形状为 :math:`[M,N]` 的二维矩阵,其中 :math:`M` 表示 :math:`d0` ,N表示 :math:`d_1 * d_2 * ... * d_R` 。
C
Cheerego 已提交
7002

C
Cheerego 已提交
7003 7004 7005
设 :math:`I_{i}[j]` 为第i个输入变量的第j行。 给定的索引变量是具有形状[M,1]的2-D张量。 设 :math:`ID[i]` 为索引变量的第i个索引值。 然后输出变量将是一个形状为 :math:`[d_0,d_1, ... ,d_R]` 的张量。

如果将输出张量视为具有形状[M,N]的2-D矩阵,并且令O[i]为矩阵的第i行,则O[i]等于 :math:`I_{ID}[i][i]`
C
Cheerego 已提交
7006 7007 7008 7009 7010 7011 7012 7013 7014 7015 7016 7017

- Ids: 索引张量
- X[0 : N - 1]: 输出的候选张量度(N >= 2).
- 对于从 0 到 batchSize-1 的每个索引i,输出是第(Ids [i])  张量的第i行

对于第i行的输出张量:

.. math::
            \\y[i]=x_k[i]\\

其中 :math:`y` 为输出张量, :math:`x_k` 为第k个输入张量,并且 :math:`k=Ids[i]` 。

7018 7019 7020 7021 7022 7023 7024 7025 7026 7027 7028 7029 7030 7031 7032 7033 7034 7035 7036 7037 7038 7039 7040 7041 7042 7043 7044 7045 7046 7047 7048 7049 7050 7051 7052 7053 7054 7055
示例:

.. code-block:: text

        例1:

        假设:

        X = [[[0,0,3,4], [0,1,3,4], [0,2,4,4], [0,3,3,4]],
             [[1,0,3,4], [1,1,7,8], [1,2,4,2], [1,3,3,4]],
             [[2,0,3,4], [2,1,7,8], [2,2,4,2], [2,3,3,4]],
             [[3,0,3,4], [3,1,7,8], [3,2,4,2], [3,3,3,4]]]

        index = [3,0,1,2]

        out:[[3 0 3 4]    // X[3,0] (3 = index[i], 0 = i); i=0
             [0 1 3 4]    // X[0,1] (0 = index[i], 1 = i); i=1
             [1 2 4 2]    // X[1,2] (0 = index[i], 2 = i); i=2
             [2 3 3 4]]   // X[2,3] (0 = index[i], 3 = i); i=3

        例2:

        假设:

        X = [[[0,0,3,4], [0,1,3,4], [0,2,4,4], [0,3,3,4]],
             [[1,0,3,4], [1,1,7,8], [1,2,4,2], [1,3,3,4]]]

        index = [1,0]

        out:[[1 0 3 4]    // X[1,0] (3 = index[0], 0 = i); i=1
             [0 1 3 4]    // X[0,1] (0 = index[1], 1 = i); i=2
             [0 2 4 4]    // X[0,2] (0 = 0, 2 = i); i=3
             [0 3 3 4]]   // X[0,3] (0 = 0, 3 = i); i=4





C
Cheerego 已提交
7056 7057 7058 7059 7060 7061 7062 7063 7064 7065 7066
参数:
  - **inputs** (list) - 要从中收集的变量列表。所有变量的形状相同,秩至少为2
  - **index** (Variable) -  Tensor <int32>,索引变量为二维张量,形状[M, 1],其中M为批大小。

返回:multiplex 张量

**代码示例**

..  code-block:: python

   import paddle.fluid as fluid
C
Cheerego 已提交
7067

C
Cheerego 已提交
7068 7069 7070 7071 7072 7073 7074 7075 7076 7077 7078 7079 7080 7081 7082 7083 7084 7085
   x1 = fluid.layers.data(name='x1', shape=[4], dtype='float32')
   x2 = fluid.layers.data(name='x2', shape=[4], dtype='float32')
   index = fluid.layers.data(name='index', shape=[1], dtype='int32')
   out = fluid.layers.multiplex(inputs=[x1, x2], index=index)









.. _cn_api_fluid_layers_nce:

nce
-------------------------------

7086
.. py:function:: paddle.fluid.layers.nce(input, label, num_total_classes, sample_weight=None, param_attr=None, bias_attr=None, num_neg_samples=None, name=None, sampler='uniform', custom_dist=None, seed=0, is_sparse=False)
C
Cheerego 已提交
7087 7088

计算并返回噪音对比估计( noise-contrastive estimation training loss)。
C
Cheerego 已提交
7089 7090
`请参考 See Noise-contrastive estimation: A new estimation principle for unnormalized statistical models
<http://www.jmlr.org/proceedings/papers/v9/gutmann10a/gutmann10a.pdf>`_
C
Cheerego 已提交
7091 7092 7093 7094 7095 7096 7097 7098 7099 7100 7101 7102 7103 7104 7105 7106
该operator默认使用均匀分布进行抽样。

参数:
    - **input** (Variable) -  输入变量
    - **label** (Variable) -  标签
    - **num_total_classes** (int) - 所有样本中的类别的总数
    - **sample_weight** (Variable|None) - 存储每个样本权重,shape为[batch_size, 1]存储每个样本的权重。每个样本的默认权重为1.0
    - **param_attr** (ParamAttr|None) - :math:`可学习参数/nce权重` 的参数属性。如果它没有被设置为ParamAttr的一个属性,nce将创建ParamAttr为param_attr。如没有设置param_attr的初始化器,那么参数将用Xavier初始化。默认值:None
    - **bias_attr** (ParamAttr|bool|None) -  nce偏置的参数属性。如果设置为False,则不会向输出添加偏置(bias)。如果值为None或ParamAttr的一个属性,则bias_attr=ParamAtt。如果没有设置bias_attr的初始化器,偏置将被初始化为零。默认值:None
    - **num_neg_samples** (int) - 负样例的数量。默认值是10
    - **name** (str|None) - 该layer的名称(可选)。如果设置为None,该层将被自动命名
    - **sampler** (str) – 取样器,用于从负类别中进行取样。可以是 ‘uniform’, ‘log_uniform’ 或 ‘custom_dist’。 默认 ‘uniform’
    - **custom_dist** (float[]) – 一个 float[] 并且它的长度为 ``num_total_classes`` 。  如果取样器类别为‘custom_dist’,则使用此参数。 custom_dist[i] 是第i个类别被取样的概率。默认为 None
    - **seed** (int) – 取样器使用的seed。默认为0
    - **is_sparse** (bool) – 标志位,指明是否使用稀疏更新,  :math:`weight@GRAD` 和 :math:`bias@GRAD` 会变为 SelectedRows

R
RaindragonD 已提交
7107
返回: nce loss
C
Cheerego 已提交
7108

R
RaindragonD 已提交
7109
返回类型: 变量(Variable)
C
Cheerego 已提交
7110 7111 7112 7113 7114 7115


**代码示例**

..  code-block:: python

R
RaindragonD 已提交
7116 7117 7118 7119 7120 7121 7122
    import numpy as np

    window_size = 5
    words = []
    for i in xrange(window_size):
        words.append(fluid.layers.data(
            name='word_{0}'.format(i), shape=[1], dtype='int64'))
C
Cheerego 已提交
7123

R
RaindragonD 已提交
7124 7125
    dict_size = 10000
    label_word = int(window_size / 2) + 1
C
Cheerego 已提交
7126

R
RaindragonD 已提交
7127 7128 7129 7130
    embs = []
    for i in xrange(window_size):
        if i == label_word:
            continue
C
Cheerego 已提交
7131

R
RaindragonD 已提交
7132 7133 7134
        emb = fluid.layers.embedding(input=words[i], size=[dict_size, 32],
                           param_attr='embed', is_sparse=True)
        embs.append(emb)
C
Cheerego 已提交
7135

R
RaindragonD 已提交
7136 7137 7138 7139 7140 7141 7142 7143 7144 7145 7146 7147 7148
    embs = fluid.layers.concat(input=embs, axis=1)
    loss = fluid.layers.nce(input=embs, label=words[label_word],
              num_total_classes=dict_size, param_attr='nce.w_0',
              bias_attr='nce.b_0')

    # 或使用自定义分布
    dist = np.array([0.05,0.5,0.1,0.3,0.05])
    loss = fluid.layers.nce(input=embs, label=words[label_word],
              num_total_classes=5, param_attr='nce.w_1',
              bias_attr='nce.b_1',
              num_neg_samples=3,
              sampler="custom_dist",
              custom_dist=dist)
C
Cheerego 已提交
7149 7150 7151 7152




Z
zy0531 已提交
7153
.. _cn_api_fluid_layers_npair_loss:
C
Cheerego 已提交
7154

Z
zy0531 已提交
7155 7156 7157 7158 7159 7160 7161 7162 7163 7164 7165 7166
npair_loss
-------------------------------

.. py:function:: paddle.fluid.layers.npair_loss(anchor, positive, labels, l2_reg=0.002)

**Npair Loss Layer**

参考阅读 `Improved Deep Metric Learning with Multi class N pair Loss Objective <http://www.nec-labs.com/uploads/images/Department-Images/MediaAnalytics/papers/nips16_npairmetriclearning.pdf>`_

NPair损失需要成对的数据。NPair损失分为两部分:第一部分是嵌入向量上的L2正则化器;第二部分是以anchor的相似矩阵和正的相似矩阵为逻辑的交叉熵损失。

参数:
C
Cheerego 已提交
7167 7168
    - **anchor** (Variable) -  嵌入锚定图像的向量。尺寸=[batch_size, embedding_dims]
    - **positive** (Variable) -  嵌入正图像的向量。尺寸=[batch_size, embedding_dims]
Z
zy0531 已提交
7169 7170 7171 7172 7173 7174 7175 7176 7177
    - **labels** (Variable) - 1维张量,尺寸=[batch_size]
    - **l2_reg** (float32) - 嵌入向量的L2正则化项,默认值:0.002

返回: npair loss,尺寸=[1]

返回类型:npair loss(Variable)

**代码示例**:

C
Cheerego 已提交
7178
.. code-block:: python
Z
zy0531 已提交
7179 7180 7181 7182 7183 7184 7185 7186 7187

    anchor = fluid.layers.data(
              name = 'anchor', shape = [18, 6], dtype = 'float32', append_batch_size=False)
    positive = fluid.layers.data(
              name = 'positive', shape = [18, 6], dtype = 'float32', append_batch_size=False)
    labels = fluid.layers.data(
              name = 'labels', shape = [18], dtype = 'float32', append_batch_size=False)

    npair_loss = fluid.layers.npair_loss(anchor, positive, labels, l2_reg = 0.002)
C
Cheerego 已提交
7188 7189 7190 7191 7192 7193 7194 7195






.. _cn_api_fluid_layers_one_hot:

C
Cheerego 已提交
7196
one_hot
C
Cheerego 已提交
7197 7198 7199 7200 7201 7202 7203 7204 7205 7206 7207 7208 7209 7210 7211 7212
-------------------------------

.. py:function:: paddle.fluid.layers.one_hot(input, depth)

该层创建输入指数的one-hot表示

参数:
    - **input** (Variable)-输入指数,最后维度必须为1
    - **depth** (scalar)-整数,定义one-hot维度的深度

返回:输入的one-hot表示

返回类型:变量(Variable)

**代码示例**:

C
Cheerego 已提交
7213
.. code-block:: python
C
Cheerego 已提交
7214

R
RaindragonD 已提交
7215
    label = fluid.layers.data(name="label", shape=[1], dtype="int64")
H
Hao Wang 已提交
7216
    one_hot_label = fluid.layers.one_hot(input=label, depth=10)
C
Cheerego 已提交
7217 7218 7219 7220 7221 7222 7223 7224 7225 7226 7227 7228 7229 7230 7231 7232 7233 7234









.. _cn_api_fluid_layers_pad:

pad
-------------------------------

.. py:function:: paddle.fluid.layers.pad(x, paddings, pad_value=0.0, name=None)

在张量上加上一个由 ``pad_value`` 给出的常数值,填充宽度由 ``paddings`` 指定。
其中,维度 ``i`` 中 ``x`` 内容前填充的值个数用 ``paddings[i]`` 表示,维度 ``i`` 中 ``x`` 内容后填充的值个数用 ``paddings[i+1]`` 表示。
C
Cheerego 已提交
7235

C
Cheerego 已提交
7236 7237 7238 7239 7240 7241 7242 7243 7244 7245 7246 7247 7248 7249 7250 7251 7252 7253 7254 7255 7256 7257 7258 7259 7260
一个例子:

::

        Given:

         x = [[1, 2], [3, 4]]

        paddings = [0, 1, 1, 2]

        pad_value = 0

        Return:

        out = [[0, 1, 2, 0, 0]
               [0, 3, 4, 0, 0]
               [0, 0, 0, 0, 0]]


参数:
    - **x** (Variable) — —输入张量变量。
    - **paddings** (list) — 一个整数列表。按顺序填充在每个维度上填充元素。 ``padding`` 长度必须是 ``rank(x)×2``
    - **pad_value** (float) — 用来填充的常量值。
    - **name** (str|None) — 这个层的名称(可选)。如果设置为None,该层将被自动命名。

R
RaindragonD 已提交
7261
返回: 填充后的张量变量
C
Cheerego 已提交
7262 7263

返回类型: 变量(Variable)
C
Cheerego 已提交
7264

C
Cheerego 已提交
7265 7266 7267 7268

**代码示例**

..  code-block:: python
C
Cheerego 已提交
7269

R
RaindragonD 已提交
7270 7271 7272
    # x 为一个秩为2的张量
    import paddle.fluid as fluid
    x = fluid.layers.data(name='data', shape=[224], dtype='float32')
C
Cheerego 已提交
7273
    out = fluid.layers.pad(
R
RaindragonD 已提交
7274
        x=x, paddings=[0, 1, 1, 2], pad_value=0.)
C
Cheerego 已提交
7275 7276 7277 7278 7279 7280 7281 7282 7283 7284 7285 7286 7287 7288 7289 7290 7291 7292 7293 7294 7295 7296 7297










.. _cn_api_fluid_layers_pad2d:

pad2d
-------------------------------

.. py:function::  paddle.fluid.layers.pad2d(input, paddings=[0, 0, 0, 0], mode='constant', pad_value=0.0, data_format='NCHW', name=None)

依照 paddings 和 mode 属性对图像进行2维 ``pad``,如果mode是 ``reflection``,则paddings[0]和paddings[1]必须不大于height-1。宽度维数具有相同的条件。

例如:

.. code-block:: text

R
RaindragonD 已提交
7298
  假设X是输入图像:
C
Cheerego 已提交
7299 7300 7301

      X = [[1, 2, 3],
           [4, 5, 6]]
C
Cheerego 已提交
7302

C
Cheerego 已提交
7303 7304 7305 7306 7307 7308 7309
     Case 0:
        paddings = [0, 1, 2, 3],
        mode = 'constant'
        pad_value = 0
        Out = [[0, 0, 1, 2, 3, 0, 0, 0]
               [0, 0, 4, 5, 6, 0, 0, 0]
               [0, 0, 0, 0, 0, 0, 0, 0]]
C
Cheerego 已提交
7310

C
Cheerego 已提交
7311 7312 7313 7314 7315 7316
     Case 1:
        paddings = [0, 1, 2, 1],
        mode = 'reflect'
        Out = [[3, 2, 1, 2, 3, 2]
               [6, 5, 4, 5, 6, 5]
               [3, 2, 1, 2, 3, 2]]
C
Cheerego 已提交
7317

C
Cheerego 已提交
7318 7319 7320 7321 7322 7323 7324 7325
     Case 2:
        paddings = [0, 1, 2, 1],
        mode = 'edge'
        Out = [[1, 1, 1, 2, 3, 3]
               [4, 4, 4, 5, 6, 6]
               [4, 4, 4, 5, 6, 6]]

参数:
R
RaindragonD 已提交
7326 7327 7328 7329 7330 7331 7332
  - **input** (Variable) - 具有[N, C, H, W]格式或[N, H, W, C]格式的输入图像。
  - **paddings** (tuple|list|Variable) - 填充区域的大小。如果填充是一个元组,它必须包含四个整数,
    (padding_top, padding_bottom, padding_left, padding_right)。默认:padding =[0,0,0,0]。
  - **mode** (str) - 三种模式:constant(默认)、reflect、edge。默认值:常数
  - **pad_value** (float32) - 以常量模式填充填充区域的值。默认值:0
  - **data_format** (str)  - 可选字符串,选项有: ``NHWC`` , ``NCHW``。指定输入数据的数据格式。默认值:``NCHW``
  - **name** (str|None) - 此层的名称(可选)。如果没有设置,该层将被自动命名。
C
Cheerego 已提交
7333 7334 7335 7336 7337 7338 7339 7340 7341

返回: tensor变量,按照 padding值 和 mode 进行填充

返回类型:variable

**代码示例:**

.. code-block:: python

R
RaindragonD 已提交
7342 7343 7344
  import paddle.fluid as fluid
  data = fluid.layers.data(name='data', shape=[3, 32, 32], dtype='float32')
  result = fluid.layers.pad2d(input=data, paddings=[1,2,3,4], mode='reflect')
C
Cheerego 已提交
7345 7346 7347 7348 7349 7350 7351 7352 7353 7354 7355 7356 7357 7358 7359 7360 7361 7362 7363 7364 7365 7366 7367 7368 7369 7370 7371 7372 7373 7374 7375 7376 7377 7378 7379 7380 7381 7382 7383 7384 7385 7386 7387











.. _cn_api_fluid_layers_pad_constant_like:

pad_constant_like
-------------------------------

.. py:function:: paddle.fluid.layers.pad_constant_like(x, y, pad_value=0.0, name=None)

使用 ``pad_value`` 填充 ``Y`` ,填充到每个axis(轴)值的数量由X和Y的形不同而指定。((0,shape_x_0 - shape_y_0),...(0,shape_x_n - shape_y_n ))是每个axis唯一pad宽度。输入应该是k维张量(k> 0且k <7)。

**实例如下**

::

    Given:
        X = [[[[ 0,  1,  2],
               [ 3,  4,  5]],
              [[ 6,  7,  8],
               [ 9, 10, 11]],
              [[12, 13, 14],
               [15, 16, 17]]],
             [[[18, 19, 20],
               [21, 22, 23]],
              [[24, 25, 26],
               [27, 28, 29]],
              [[30, 31, 32],
               [33, 34, 35]]]]
        X.shape = (2, 3, 2, 3)

        Y = [[[[35, 36, 37]],
              [[38, 39, 40]],
              [[41, 42, 43]]]]
        Y.shape = (1, 3, 1, 3)
7388

C
Cheerego 已提交
7389 7390 7391 7392 7393 7394 7395 7396 7397 7398 7399 7400 7401 7402
参数:
          - **x** (Variable)- 输入Tensor变量。
          - **y** (Variable)- 输出Tensor变量。
          - **pad_value** (float) - 用于填充的常量值。
          - **name** (str | None) - 这一层的名称(可选)。如果设置为None,则将自动命名这一层。

返回:填充张量(Tensor)变量

返回类型:  变量(Variable)

**示例代码**

..  code-block:: python

R
RaindragonD 已提交
7403 7404 7405 7406 7407
    # x是秩为4的tensor, x.shape = (2, 3, 2, 3)
    # y是秩为4的tensor, y.shape = (1, 3, 1, 3)
    import paddle.fluid as fluid
    x = fluid.layers.data(name='x', shape=[2,3,2,3], dtype='float32')
    y = fluid.layers.data(name='y', shape=[1,3,1,3], dtype='float32')
C
Cheerego 已提交
7408
    out = fluid.layers.pad_constant_like(x=x, y=y, pad_value=0.)
R
RaindragonD 已提交
7409
    # out是秩为4的tensor, out.shape = [2, 3 ,2 , 3]
C
Cheerego 已提交
7410 7411 7412 7413




7414 7415 7416 7417
.. _cn_api_fluid_layers_pixel_shuffle:

pixel_shuffle
-------------------------------
C
Cheerego 已提交
7418

7419
.. py:function:: paddle.fluid.layers.pixel_shuffle(x, upscale_factor)
C
Cheerego 已提交
7420

7421 7422 7423 7424 7425 7426 7427 7428 7429 7430 7431 7432 7433 7434 7435 7436 7437 7438 7439 7440 7441 7442 7443 7444 7445 7446
pixel shuffle 层(像素重组层)

该层将一个形为[N, C, H, W]的张量重新排列成形为 [N, C/r**2, H*r, W*r] 的张量。这样做有利于实现步长(stride)为1/r的高效sub-pixel(亚像素)卷积。详见Shi等人在2016年发表的论文 `Real Time Single Image and Video Super Resolution Using an Efficient Sub Pixel Convolutional Neural Network <https://arxiv.org/abs/1609.05158v2>`_ 。

.. code-block:: text

    给定一个形为  x.shape = [1, 9, 4, 4]  的4-D张量
    设定:upscale_factor=3
    那么输出张量的形为:[1, 1, 12, 12]

参数:
          - **x** (Variable)- 输入Tensor变量。
          - **upscale_factor** (int)- 增大空间分辨率的增大因子


返回:根据新的维度信息进行重组的张量

返回类型:  Variable

抛出异常: ``ValueError``  - 如果upscale_factor的平方不能整除输入的通道维(C)大小。


**示例代码**

..  code-block:: python

R
RaindragonD 已提交
7447
    input = fluid.layers.data(name="input", shape=[9,4,4])
7448
    output = fluid.layers.pixel_shuffle(x=input, upscale_factor=3)
C
Cheerego 已提交
7449 7450 7451 7452 7453 7454 7455 7456 7457 7458 7459 7460 7461 7462 7463 7464 7465 7466 7467 7468 7469 7470 7471 7472 7473 7474 7475 7476 7477 7478 7479 7480 7481 7482 7483 7484 7485 7486 7487 7488 7489 7490





.. _cn_api_fluid_layers_pool2d:

pool2d
-------------------------------

.. py:function:: paddle.fluid.layers.pool2d(input, pool_size=-1, pool_type='max', pool_stride=1, pool_padding=0, global_pooling=False, use_cudnn=True, ceil_mode=False, name=None, exclusive=True)

pooling2d操作符根据 ``input`` , 池化类型 ``pool_type`` , 池化核大小 ``pool_size`` , 步长 ``pool_stride`` ,填充 ``pool_padding`` 这些参数得到输出。

输入X和输出Out是NCHW格式,N为batch尺寸,C是通道数,H是特征高度,W是特征宽度。

参数(ksize,strides,paddings)含有两个元素。这两个元素分别代表高度和宽度。输入X的大小和输出Out的大小可能不一致。

例如:

输入:
    X shape::math:`\left ( N,C,H_{in},W_{in} \right )`

输出:
    Out shape::math:`\left ( N,C,H_{out},W_{out} \right )`

如果 ``ceil_mode`` = false:

.. math::
    H_{out} = \frac{(H_{in} - ksize[0] + 2 * paddings[0])}{strides[0]} + 1

.. math::
    W_{out} = \frac{(W_{in} - ksize[1] + 2 * paddings[1])}{strides[1]} + 1

如果 ``ceil_mode`` = true:

.. math::
    H_{out} = \frac{(H_{in} - ksize[0] + 2 * paddings[0] + strides[0] - 1)}{strides[0]} + 1

.. math::
    W_{out} = \frac{(W_{in} - ksize[1] + 2 * paddings[1] + strides[1] - 1)}{strides[1]} + 1

H
Hao Wang 已提交
7491
如果 ``exclusive`` = false:
C
Cheerego 已提交
7492 7493 7494 7495 7496 7497 7498 7499

.. math::
    hstart &= i * strides[0] - paddings[0] \\
    hend   &= hstart + ksize[0] \\
    wstart &= j * strides[1] - paddings[1] \\
    wend   &= wstart + ksize[1] \\
    Output(i ,j) &= \frac{sum(Input[hstart:hend, wstart:wend])}{ksize[0] * ksize[1]}

H
Hao Wang 已提交
7500
如果 ``exclusive`` = true:
C
Cheerego 已提交
7501 7502 7503 7504 7505 7506 7507 7508 7509 7510 7511 7512

.. math::
    hstart &= max(0, i * strides[0] - paddings[0])\\
    hend &= min(H, hstart + ksize[0]) \\
    wstart &= max(0, j * strides[1] - paddings[1]) \\
    wend & = min(W, wstart + ksize[1]) \\
    Output(i ,j) & = \frac{sum(Input[hstart:hend, wstart:wend])}{(hend - hstart) * (wend - wstart)}



参数:
    - **input** (Variable) - 池化操作的输入张量。输入张量格式为NCHW,N为批尺寸,C是通道数,H是特征高度,W是特征宽度
H
Hao Wang 已提交
7513
    - **pool_size** (int|list|tuple)  - 池化核的大小。如果它是一个元组或列表,它必须包含两个整数值, (pool_size_Height, pool_size_Width)。若为一个整数,则它的平方值将作为池化核大小,比如若pool_size=2, 则池化核大小为2x2。
C
Cheerego 已提交
7514 7515 7516 7517 7518 7519 7520 7521 7522 7523 7524 7525 7526 7527 7528 7529 7530 7531
    - **pool_type** (string) - 池化类型,可以是“max”对应max-pooling,“avg”对应average-pooling
    - **pool_stride** (int|list|tuple)  - 池化层的步长。如果它是一个元组或列表,它将包含两个整数,(pool_stride_Height, pool_stride_Width)。否则它是一个整数的平方值。
    - **pool_padding** (int|list|tuple) - 填充大小。如果它是一个元组或列表,它必须包含两个整数值,(pool_padding_on_Height, pool_padding_on_Width)。否则它是一个整数的平方值。
    - **global_pooling** (bool,默认false)- 是否用全局池化。如果global_pooling = true, ``pool_size`` 和 ``pool_padding`` 将被忽略。
    - **use_cudnn** (bool,默认false)- 只在cudnn核中用,需要下载cudnn
    - **ceil_mode** (bool,默认false)- 是否用ceil函数计算输出高度和宽度。默认False。如果设为False,则使用floor函数
    - **name** (str|None) - 该层名称(可选)。若设为None,则自动为该层命名。
    - **exclusive** (bool) - 是否在平均池化模式忽略填充值。默认为True。

返回:池化结果

返回类型:变量(Variable)

抛出异常:
    - ``ValueError`` - 如果 ``pool_type`` 既不是“max”也不是“avg”
    - ``ValueError`` - 如果 ``global_pooling`` 为False并且‘pool_size’为-1
    - ``ValueError`` - 如果 ``use_cudnn`` 不是bool值

H
Hao Wang 已提交
7532
**代码示例**
C
Cheerego 已提交
7533 7534 7535 7536 7537

.. code-block:: python

    data = fluid.layers.data(
        name='data', shape=[3, 32, 32], dtype='float32')
H
Hao Wang 已提交
7538
    pool2d = fluid.layers.pool2d(
C
Cheerego 已提交
7539 7540 7541 7542 7543 7544 7545 7546 7547 7548 7549 7550 7551 7552 7553 7554 7555 7556 7557
                  input=data,
                  pool_size=2,
                  pool_type='max',
                  pool_stride=1,
                  global_pooling=False)









.. _cn_api_fluid_layers_pool3d:

pool3d
-------------------------------

7558
.. py:function:: paddle.fluid.layers.pool3d(input, pool_size=-1, pool_type='max', pool_stride=1, pool_padding=0, global_pooling=False, use_cudnn=True, ceil_mode=False, name=None, exclusive=True)
C
Cheerego 已提交
7559 7560 7561

函数使用上述输入参数的池化配置,为三维空间添加池化操作

H
Hao Wang 已提交
7562 7563 7564 7565 7566
pooling3d操作根据input,pool_type,pool_size,strides和paddings参数计算输出。 输入(X)和输出(输出)采用NCDHW格式,其中N是批量大小,C是通道数,D,H和W分别是特征的深度,高度和宽度。 参数(ksize,strides,paddings)是三个元素。 这三个元素分别代表深度,高度和宽度。 输入(X)大小和输出(Out)大小可能不同。


例如,

C
Cheerego 已提交
7567
输入X形为 :math:`(N, C, D_{in}, H_{in}, W_{in})` ,输出形为 :math:`(N, C, D_{out}, H_{out}, W_{out})`
H
Hao Wang 已提交
7568 7569 7570 7571 7572 7573 7574 7575 7576 7577 7578 7579 7580 7581 7582 7583 7584 7585 7586 7587 7588 7589 7590 7591 7592 7593 7594 7595 7596 7597 7598 7599 7600 7601 7602 7603 7604 7605 7606 7607 7608 7609 7610 7611

当ceil_mode = false时,

.. math::

    D_{out} &= \frac{(D_{in} - ksize[0] + 2 * paddings[0])}{strides[0]} + 1\\
    H_{out} &= \frac{(H_{in} - ksize[1] + 2 * paddings[1])}{strides[2]} + 1\\
    W_{out} &= \frac{(W_{in} - ksize[2] + 2 * paddings[2])}{strides[2]} + 1

当ceil_mode = true时,

.. math::

    D_{out} &= \frac{(D_{in} - ksize[0] + 2 * paddings[0] + strides[0] -1)}{strides[0]} + 1\\
    H_{out} &= \frac{(H_{in} - ksize[1] + 2 * paddings[1] + strides[1] -1)}{strides[1]} + 1\\
    W_{out} &= \frac{(W_{in} - ksize[2] + 2 * paddings[2] + strides[2] -1)}{strides[2]} + 1

当exclusive = false时,

.. math::

    dstart &= i * strides[0] - paddings[0]\\
    dend &= dstart + ksize[0]\\
    hstart &= j * strides[1] - paddings[1]\\
    hend &= hstart + ksize[1]\\
    wstart &= k * strides[2] - paddings[2]\\
    wend &= wstart + ksize[2]\\
    Output(i ,j, k) &= \frac{sum(Input[dstart:dend, hstart:hend, wstart:wend])}{ksize[0] * ksize[1] * ksize[2]}



当exclusive = true时,

.. math::

    dstart &= max(0, i * strides[0] - paddings[0])\\
    dend &= min(D, dstart + ksize[0])\\
    hstart &= max(0, j * strides[1] - paddings[1])\\
    hend &= min(H, hstart + ksize[1])\\
    wstart &= max(0, k * strides[2] - paddings[2])\\
    wend &= min(W, wstart + ksize[2])\\
    Output(i ,j, k) &= \frac{sum(Input[dstart:dend, hstart:hend, wstart:wend])}{(dend - dstart) * (hend - hstart) * (wend - wstart)}


C
Cheerego 已提交
7612 7613 7614 7615 7616 7617 7618 7619 7620 7621 7622 7623 7624 7625 7626 7627
参数:
    - **input** (Vairable) - 池化运算的输入张量。输入张量的格式为NCDHW, N是批尺寸,C是通道数,D是特征深度,H是特征高度,W是特征宽度。
    - **pool_size** (int|list|tuple) - 池化窗口的大小。如果为元组类型,那么它应该是由三个整数组成:深度,高度,宽度。如果是int类型,它应该是一个整数的立方。
    - **pool_type** (str) - 池化类型, "max" 对应max-pooling, "avg" 对应average-pooling。
    - **pool_stride** (int|list|tuple) - 池化跨越步长。如果为元组类型,那么它应该是由三个整数组成:深度,高度,宽度。如果是int类型,它应该是一个整数的立方。
    - **pool_padding** (int|list|tuple) - 填充大小。如果为元组类型,那么它应该是由三个整数组成:深度,高度,宽度。如果是int类型,它应该是一个整数的立方。
    - **global_pooling** (bool) - 是否使用全局池化。如果global_pooling = true, ``pool_size`` 和 ``pool_padding`` 将被忽略。
    - **use_cudnn** (bool) - 是否用cudnn核,只有在cudnn库安装时有效。
    - **ceil_mode** (bool) - 是否用ceil函数计算输出高度和宽度。默认False。如果设为False,则使用floor函数。
    - **name** (str) - 该层名称(可选)。若为空,则自动为该层命名。
    - **exclusive** (bool) - 是否在平均池化模式忽略填充值。默认为True。

返回:pool3d层的输出

返回类型:变量(Variable)

H
Hao Wang 已提交
7628
**代码示例**
C
Cheerego 已提交
7629

H
Hao Wang 已提交
7630 7631 7632 7633 7634 7635 7636 7637 7638 7639
.. code-block:: python

    data = fluid.layers.data(
        name='data', shape=[3, 32, 32, 32], dtype='float32')
    pool3d = fluid.layers.pool3d(
                      input=data,
                      pool_size=2,
                      pool_type='max',
                      pool_stride=1,
                      global_pooling=False)
C
Cheerego 已提交
7640 7641 7642 7643 7644 7645 7646 7647 7648 7649 7650 7651 7652 7653 7654 7655 7656 7657 7658










.. _cn_api_fluid_layers_pow:

pow
-------------------------------

.. py:function:: paddle.fluid.layers.pow(x, factor=1.0, name=None)

指数激活算子(Pow Activation Operator.)

T
Tink_Y 已提交
7659 7660 7661 7662
.. math::

    out = x^{factor}

C
Cheerego 已提交
7663 7664 7665 7666 7667 7668 7669 7670 7671 7672 7673 7674 7675 7676
参数
    - **x** (Variable) - Pow operator的输入
    - **factor** (FLOAT|1.0) - Pow的指数因子
    - **name** (str|None) -这个层的名称(可选)。如果设置为None,该层将被自动命名。

返回: 输出Pow操作符

返回类型: 输出(Variable)


**代码示例:**

.. code-block:: python

R
RaindragonD 已提交
7677
    import paddle.fluid as fluid
C
Cheerego 已提交
7678 7679 7680 7681 7682 7683 7684 7685 7686 7687 7688 7689 7690 7691 7692 7693 7694 7695 7696 7697
    x = fluid.layers.data(name="x", shape=[3,10,32,32], dtype="float32")
    y = fluid.layers.pow(x, factor=2.0)






.. _cn_api_fluid_layers_prelu:

prelu
-------------------------------

.. py:function:: paddle.fluid.layers.prelu(x, mode, param_attr=None, name=None)

等式:

.. math::
    y = max(0, x) + \alpha min(0, x)

R
RaindragonD 已提交
7698 7699 7700 7701 7702 7703 7704 7705 7706
共提供三种激活方式:

.. code-block:: text

    all: 所有元素使用同一个alpha值
    channel: 在同一个通道中的元素使用同一个alpha值
    element: 每一个元素有一个独立的alpha值


C
Cheerego 已提交
7707 7708
参数:
          - **x** (Variable)- 输入为Tensor。
R
RaindragonD 已提交
7709 7710
          - **mode** (string) - 权重共享模式。
          - **param_attr** (ParamAttr|None) - 可学习权重 :math:`[\alpha]` 的参数属性,可由ParamAttr创建。
C
Cheerego 已提交
7711 7712 7713 7714 7715
          - **name** (str | None)- 这一层的名称(可选)。如果设置为None,则将自动命名这一层。

返回: 输出Tensor与输入shape相同。

返回类型:  变量(Variable)
C
Cheerego 已提交
7716

H
Hao Wang 已提交
7717
**代码示例:**
C
Cheerego 已提交
7718

H
Hao Wang 已提交
7719
.. code-block:: python
C
Cheerego 已提交
7720

R
RaindragonD 已提交
7721 7722 7723
    import paddle.fluid as fluid
    from paddle.fluid.param_attr import ParamAttr
    x = fluid.layers.data(name="x", shape=[5,10,10], dtype="float32")
H
Hao Wang 已提交
7724
    mode = 'channel'
R
RaindragonD 已提交
7725 7726 7727 7728 7729
    output = fluid.layers.prelu(
             x,mode,param_attr=ParamAttr(name='alpha'))



C
Cheerego 已提交
7730

H
Hao Wang 已提交
7731 7732 7733 7734 7735 7736 7737 7738 7739 7740 7741 7742 7743 7744 7745
.. _cn_api_fluid_layers_psroi_pool:

psroi_pool
-------------------------------

.. py:function:: paddle.fluid.layers.psroi_pool(input, rois, output_channels, spatial_scale, pooled_height, pooled_width, name=None)

PSROIPool运算

区分位置的感兴趣区域池化方法(Position sensitive region of interest pooling,也称为PSROIPooling)是对输入的 "感兴趣区域"(RoI)执行按位置的average池化,并将N个按位置评分图(score map)和一个由num_rois个感兴趣区域所组成的列表作为输入。

用于R-FCN的PSROIPooling。 有关更多详细信息,请参阅 https://arxiv.org/abs/1605.06409。

参数:
    - **input** (Variable) - (Tensor),PSROIPoolOp的输入。 输入张量的格式是NCHW。 其中N是批大小batch_size,C是输入通道的数量,H是输入特征图的高度,W是特征图宽度
R
RaindragonD 已提交
7746
    - **rois** (Variable) - 要进行池化的RoI(感兴趣区域)。应为一个形状为(num_rois, 4)的二维LoDTensor,其lod level为1。给出[[x1, y1, x2, y2], ...],(x1, y1)为左上角坐标,(x2, y2)为右下角坐标。
H
Hao Wang 已提交
7747 7748 7749 7750 7751 7752 7753 7754 7755 7756 7757 7758 7759 7760
    - **output_channels** (integer) - (int),输出特征图的通道数。 对于共C个种类的对象分类任务,output_channels应该是(C + 1),该情况仅适用于分类任务。
    - **spatial_scale** (float) - (float,default 1.0),乘法空间比例因子,用于将ROI坐标从其输入比例转换为池化使用的比例。默认值:1.0
    - **pooled_height** (integer) - (int,默认值1),池化输出的高度。默认值:1
    - **pooled_width** (integer) - (int,默认值1),池化输出的宽度。默认值:1
    - **name** (str,default None) - 此层的名称。

返回: (Tensor),PSROIPoolOp的输出是形为 (num_rois,output_channels,pooled_h,pooled_w) 的4-D Tensor。

返回类型:  变量(Variable)

**代码示例:**

.. code-block:: python

R
RaindragonD 已提交
7761 7762 7763 7764
    import paddle.fluid as fluid
    x = fluid.layers.data(name='x', shape=[490, 28, 28], dtype='float32')
    rois = fluid.layers.data(name='rois', shape=[4], lod_level=1, dtype='float32')
    pool_out = fluid.layers.psroi_pool(x, rois, 10, 1.0, 7, 7)
H
Hao Wang 已提交
7765 7766 7767 7768 7769 7770 7771 7772 7773 7774 7775 7776 7777 7778 7779 7780 7781 7782





.. _cn_api_fluid_layers_py_func:

py_func
-------------------------------

.. py:function:: paddle.fluid.layers.py_func(func, x, out, backward_func=None, skip_vars_in_backward_input=None)

PyFunc运算。

用户可以使用 ``py_func`` 在Python端注册operator。 ``func`` 的输入 ``x`` 是LoDTensor,输出可以是numpy数组或LoDTensor。 Paddle将在前向部分调用注册的 ``func`` ,并在反向部分调用 ``backward_func`` (如果 ``backward_func`` 不是None)。

在调用此函数之前,应正确设置 ``out`` 的数据类型和形状。 但是,``out`` 和 ``x`` 对应梯度的数据类型和形状将自动推断而出。

C
Cheerego 已提交
7783
``backward_func`` 的输入顺序为:前向输入x,前向输出 ``out`` 和反向输入 ``out`` 的梯度。 如果 ``out`` 的某些变量没有梯度,则输入张量在Python端将为None。
H
Hao Wang 已提交
7784 7785 7786 7787 7788 7789 7790 7791 7792 7793 7794 7795 7796 7797 7798 7799 7800 7801 7802 7803 7804 7805 7806 7807 7808 7809 7810 7811 7812 7813 7814 7815 7816 7817 7818 7819 7820 7821 7822 7823 7824 7825 7826 7827 7828 7829 7830 7831 7832 7833 7834 7835 7836 7837 7838 7839 7840 7841

如果in的某些变量没有梯度,则用户应返回None。

此功能还可用于调试正在运行的网络,可以通过添加没有输出的py_func运算,并在func中打印输入x。

参数:
    - **func** (callable) - 前向Python函数。
    - **x** (Variable|list(Variable)|tuple(Variable)) -  func的输入。
    - **out** (Variable|list(Variable)|tuple(Variable)) -  func的输出。 Paddle无法自动推断out的形状和数据类型。 应事先创建 ``out`` 。
    - **backward_func** (callable|None) - 反向Python函数。 None意味着没有反向计算。 默认None。
    - **skip_vars_in_backward_input** (Variable|list(Variable)|tuple(Variable)) -  backward_func输入中不需要的变量。 这些变量必须是x和out中的一个。 如果设置,这些变量将不是backward_func的输入,仅在backward_func不是None时有用。 默认None。

返回: 传入的 ``out``

返回类型: out (Variable|list(Variable)|tuple(Variable))

**代码示例**:

..  code-block:: python

    import paddle.fluid as fluid
    import six

    def create_tmp_var(name, dtype, shape):
        return fluid.default_main_program().current_block().create_var(
            name=name, dtype=dtype, shape=shape)

    # Paddle C++ op提供的tanh激活函数
    # 此处仅采用tanh作为示例展示py_func的使用方法
    def tanh(x):
        return np.tanh(x)

    # 跳过前向输入x
    def tanh_grad(y, dy):
        return np.array(dy) * (1 - np.square(np.array(y)))

    def debug_func(x):
        print(x)

    def simple_net(img, label):
        hidden = img
        for idx in six.moves.range(4):
            hidden = fluid.layers.fc(hidden, size=200)
            new_hidden = create_tmp_var(name='hidden_{}'.format(idx),
                dtype=hidden.dtype, shape=hidden.shape)

            # 用户自定义的前向反向计算
            hidden = fluid.layers.py_func(func=tanh, x=hidden,
                out=new_hidden, backward_func=tanh_grad,
                skip_vars_in_backward_input=hidden)

            # 用户自定义的调试层,可以打印出变量细则
            fluid.layers.py_func(func=debug_func, x=hidden, out=None)

        prediction = fluid.layers.fc(hidden, size=10, act='softmax')
        loss = fluid.layers.cross_entropy(input=prediction, label=label)
        return fluid.layers.mean(loss)

C
Cheerego 已提交
7842 7843 7844 7845 7846 7847 7848 7849 7850 7851 7852 7853 7854 7855 7856 7857 7858 7859 7860 7861 7862 7863 7864 7865 7866 7867 7868 7869 7870 7871 7872 7873





.. _cn_api_fluid_layers_random_crop:

random_crop
-------------------------------

.. py:function:: paddle.fluid.layers.random_crop(x, shape, seed=None)

该operator对batch中每个实例进行随机裁剪。这意味着每个实例的裁剪位置不同,裁剪位置由均匀分布随机生成器决定。所有裁剪的实例都具有相同的shape,由参数shape决定。

参数:
    - **x(Variable)** - 一组随机裁剪的实例
    - **shape(int)** - 裁剪实例的形状
    - **seed(int|变量|None)** - 默认情况下,随机种子从randint(-65536,-65536)中取得

返回: 裁剪后的batch

**代码示例**:

..  code-block:: python

   img = fluid.layers.data("img", [3, 256, 256])
   cropped_img = fluid.layers.random_crop(img, shape=[3, 224, 224])





R
RaindragonD 已提交
7874 7875 7876 7877 7878 7879 7880 7881 7882 7883 7884 7885 7886 7887 7888 7889 7890
.. _cn_api_fluid_layers_rank:

rank
-------------------------------

.. py:function::  paddle.fluid.layers.rank(input)

排序层

返回张量的维数,一个数据类型为int32的0-D Tensor。

参数:
    - **input** (Variable):输入变量

返回:输入变量的秩

返回类型: 变量(Variable)
C
Cheerego 已提交
7891

R
RaindragonD 已提交
7892
**代码示例**
C
Cheerego 已提交
7893

R
RaindragonD 已提交
7894
.. code-block:: python
C
Cheerego 已提交
7895

R
RaindragonD 已提交
7896 7897 7898
       input = layers.data(
            name="input", shape=[3, 100, 100], dtype="float32")
       rank = layers.rank(input) # 4
C
Cheerego 已提交
7899 7900 7901 7902 7903 7904 7905 7906 7907 7908 7909 7910 7911 7912 7913 7914 7915 7916 7917


.. _cn_api_fluid_layers_rank_loss:

rank_loss
-------------------------------


.. py:function::  paddle.fluid.layers.rank_loss(label, left, right, name=None)

`RankNet <http://icml.cc/2015/wp-content/uploads/2015/06/icml_ranking.pdf>`_ 是一个成对的
排序模型,训练样本由一对文档组成:A和B。标签P表示a的排名是否高于B:

P 的取值可为: {0, 1} 或 {0, 0.5, 1}, 其中,0.5表示输入的两文档排序相同。

排序的损失函数有三个输入:left(o_i)、right(o_j) 和 label (P\_{i,j})。输入分别表示RankNet对文档A、B的输出得分和标签p的值。由下式计算输入的排序损失C\_{i,j}:

.. math::

R
RaindragonD 已提交
7918
   C_{i,j} &= -\tilde{P_{ij}} * o_{i,j} + \log(1 + e^{o_{i,j}}) \\
C
Cheerego 已提交
7919 7920 7921
      o_{i,j} &=  o_i - o_j  \\
      \tilde{P_{i,j}} &= \left \{0, 0.5, 1 \right \} \ or \ \left \{0, 1 \right \}

H
Hao Wang 已提交
7922
排序损失层的输入带有batch_size (batch_size >= 1)
C
Cheerego 已提交
7923 7924

参数:
R
RaindragonD 已提交
7925 7926 7927 7928
  - **label** (Variable):A的排名是否高于B
  - **left** (Variable):RankNet对doc A的输出分数
  - **right** (Variable):RankNet对doc B的输出分数
  - **name** (str|None):此层的名称(可选)。如果没有设置,层将自动命名。
C
Cheerego 已提交
7929

H
Hao Wang 已提交
7930
返回:rank loss的值
C
Cheerego 已提交
7931

H
Hao Wang 已提交
7932
返回类型: list
C
Cheerego 已提交
7933

H
Hao Wang 已提交
7934
抛出异常: ``ValueError`` - label, left, 和right至少有一者不是variable变量类型。
C
Cheerego 已提交
7935 7936 7937 7938 7939

**代码示例**

.. code-block:: python

R
RaindragonD 已提交
7940 7941 7942
    label = fluid.layers.data(name="label", shape=[-1, 1], dtype="float32")
    left = fluid.layers.data(name="left", shape=[-1, 1], dtype="float32")
    right = fluid.layers.data(name="right", shape=[-1, 1], dtype="float32")
H
Hao Wang 已提交
7943 7944
    out = fluid.layers.rank_loss(label, left, right)

C
Cheerego 已提交
7945 7946


R
RaindragonD 已提交
7947 7948 7949 7950 7951 7952 7953 7954 7955 7956 7957 7958 7959 7960 7961 7962 7963 7964 7965 7966 7967 7968 7969 7970 7971 7972 7973 7974 7975 7976 7977 7978 7979 7980 7981 7982 7983 7984 7985 7986 7987 7988 7989 7990 7991 7992 7993 7994 7995 7996 7997 7998
.. _cn_api_fluid_layers_reduce_all:

reduce_all
-------------------------------

.. py:function:: paddle.fluid.layers.reduce_all(input, dim=None, keep_dim=False, name=None)

计算给定维度上张量(Tensor)元素的与逻辑。

参数:
          - **input** (Variable):输入变量为Tensor或LoDTensor。
          - **dim** (list | int | None):与逻辑运算的维度。如果为None,则计算所有元素的与逻辑并返回包含单个元素的Tensor变量,否则必须在  :math:`[−rank(input),rank(input)]` 范围内。如果 :math:`dim [i] <0` ,则维度将减小为 :math:`rank+dim[i]` 。
          - **keep_dim** (bool | False):是否在输出Tensor中保留减小的维度。除非 ``keep_dim`` 为true,否则结果张量的维度将比输入张量小。
          - **name** (str | None):这一层的名称(可选)。如果设置为None,则将自动命名这一层。

返回:  减少维度之后的Tensor变量。

返回类型:  变量(Variable)

**代码示例**

..  code-block:: python
     
     
        # x是一个布尔型Tensor,元素如下:
        #    [[True, False]
        #     [True, True]]
        # 接下来的示例中,我们在每处函数调用后面都标注出了它的结果张量。
        fluid.layers.reduce_all(x)  # False
        fluid.layers.reduce_all(x, dim=0)  # [True, False]
        fluid.layers.reduce_all(x, dim=-1)  # [False, True]
        fluid.layers.reduce_all(x, dim=1,
                                 keep_dim=True)  # [[False], [True]]
     
.. _cn_api_fluid_layers_reduce_any:

reduce_any
-------------------------------

.. py:function:: paddle.fluid.layers.reduce_any(input, dim=None, keep_dim=False, name=None)

计算给定维度上张量(Tensor)元素的或逻辑。     

参数:
          - **input** (Variable):输入变量为Tensor或LoDTensor。
          - **dim** (list | int | None):或逻辑运算的维度。如果为None,则计算所有元素的或逻辑并返回仅包含单个元素的Tensor变量,否则必须在  :math:`[−rank(input),rank(input)]` 范围内。如果 :math:`dim [i] <0` ,则维度将减小为 :math:`rank+dim[i]` 。
          - **keep_dim** (bool | False):是否在输出Tensor中保留减小的维度。除非 ``keep_dim`` 为true,否则结果张量的维度将比输入张量小。
          - **name** (str | None):这一层的名称(可选)。如果设置为None,则将自动命名这一层。

返回:  减少维度之后的Tensor变量。

返回类型:  变量(Variable)
C
Cheerego 已提交
7999

R
RaindragonD 已提交
8000
**代码示例**
C
Cheerego 已提交
8001

R
RaindragonD 已提交
8002 8003 8004 8005 8006 8007 8008 8009 8010 8011 8012 8013
..  code-block:: python
     
     
        # x是一个布尔型Tensor,元素如下:
        #    [[True, False]
        #     [False, False]]
        # 接下来的示例中,我们在每处函数调用后面都标注出了它的结果张量。
        fluid.layers.reduce_any(x)  # True
        fluid.layers.reduce_any(x, dim=0)  # [True, False]
        fluid.layers.reduce_any(x, dim=-1)  # [True, False]
        fluid.layers.reduce_any(x, dim=1,
                                 keep_dim=True)  # [[True], [False]]
C
Cheerego 已提交
8014 8015 8016 8017 8018 8019 8020 8021 8022 8023 8024 8025 8026 8027 8028 8029 8030






.. _cn_api_fluid_layers_reduce_max:

reduce_max
-------------------------------

.. py:function:: paddle.fluid.layers.reduce_max(input, dim=None, keep_dim=False, name=None)

计算给定维度上张量(Tensor)元素最大值。

参数:
          - **input** (Variable):输入变量为Tensor或LoDTensor。
8031
          - **dim** (list | int | None):函数运算的维度。如果为None,则计算所有元素中的最大值并返回单个元素的Tensor变量,否则必须在  :math:`[−rank(input),rank(input)]` 范围内。如果 :math:`dim [i] <0` ,则维度将减小为 :math:`rank+dim[i]` 。
C
Cheerego 已提交
8032 8033 8034 8035 8036 8037
          - **keep_dim** (bool | False):是否在输出Tensor中保留减小的维度。除非 ``keep_dim`` 为true,否则结果张量将比输入少一个维度。
          - **name** (str | None):这一层的名称(可选)。如果设置为None,则将自动命名这一层。

返回:  运算、减少维度之后的Tensor变量。

返回类型:  变量(Variable)
C
Cheerego 已提交
8038

C
Cheerego 已提交
8039 8040 8041 8042
**代码示例**

..  code-block:: python

R
RaindragonD 已提交
8043
      import paddle.fluid as fluid
C
Cheerego 已提交
8044 8045 8046
      # x是一个Tensor,元素如下:
      #    [[0.2, 0.3, 0.5, 0.9]
      #     [0.1, 0.2, 0.6, 0.7]]
R
RaindragonD 已提交
8047 8048
      # 接下来的示例中,我们在每处函数调用后面都标注出了它的结果张量。
      x = fluid.layers.data(name='x', shape=[4, 2], dtype='float32')
C
Cheerego 已提交
8049 8050 8051 8052 8053
      fluid.layers.reduce_max(x)  # [0.9]
      fluid.layers.reduce_max(x, dim=0)  # [0.2, 0.3, 0.6, 0.9]
      fluid.layers.reduce_max(x, dim=-1)  # [0.9, 0.7]
      fluid.layers.reduce_max(x, dim=1, keep_dim=True)  # [[0.9], [0.7]]

R
RaindragonD 已提交
8054
      # y是一个shape为[2, 2, 2]的Tensor,元素如下:
C
Cheerego 已提交
8055 8056
      #      [[[1.0, 2.0], [3.0, 4.0]],
      #      [[5.0, 6.0], [7.0, 8.0]]]
R
RaindragonD 已提交
8057 8058 8059 8060
      # 接下来的示例中,我们在每处函数调用后面都标注出了它的结果张量。
      y = fluid.layers.data(name='y', shape=[2, 2, 2], dtype='float32')
      fluid.layers.reduce_max(y, dim=[1, 2]) # [4.0, 8.0]
      fluid.layers.reduce_max(y, dim=[0, 1]) # [7.0, 8.0]
C
Cheerego 已提交
8061 8062 8063 8064 8065 8066 8067 8068 8069 8070 8071 8072 8073 8074 8075 8076 8077 8078 8079 8080 8081 8082 8083 8084 8085 8086 8087 8088










.. _cn_api_fluid_layers_reduce_mean:

reduce_mean
-------------------------------

.. py:function:: paddle.fluid.layers.reduce_mean(input, dim=None, keep_dim=False, name=None)

计算给定维度上张量(Tensor)元素平均值。

参数:
          - **input** (Variable):输入变量为Tensor或LoDTensor。
          - **dim** (list | int | None):函数运算的维度。如果为None,则对输入的所有元素求平均值并返回单个元素的Tensor变量,否则必须在  :math:`[−rank(input),rank(input)]` 范围内。如果 :math:`dim [i] <0` ,则维度将减小为 :math:`rank+dim[i]` 。
          - **keep_dim** (bool | False):是否在输出Tensor中保留减小的维度。除非 ``keep_dim`` 为true,否则结果张量将比输入少一个维度。
          - **name** (str | None):这一层的名称(可选)。如果设置为None,则将自动命名这一层。

返回:  运算、减少维度之后的Tensor变量。

返回类型:  变量(Variable)
C
Cheerego 已提交
8089

C
Cheerego 已提交
8090 8091 8092 8093
**代码示例**

..  code-block:: python

R
RaindragonD 已提交
8094
      import paddle.fluid as fluid
C
Cheerego 已提交
8095 8096 8097 8098
      # x是一个Tensor,元素如下:
      #    [[0.2, 0.3, 0.5, 0.9]
      #     [0.1, 0.2, 0.6, 0.7]]
      # 接下来的示例中,我们在每处函数调用后面都标注出了它的结果张量。
R
RaindragonD 已提交
8099
      x = fluid.layers.data(name='x', shape=[4, 2], dtype='float32')
C
Cheerego 已提交
8100 8101 8102
      fluid.layers.reduce_mean(x)  # [0.4375]
      fluid.layers.reduce_mean(x, dim=0)  # [0.15, 0.25, 0.55, 0.8]
      fluid.layers.reduce_mean(x, dim=-1)  # [0.475, 0.4]
R
RaindragonD 已提交
8103
      fluid.layers.reduce_mean(x, dim=1, keep_dim=True)  # [[0.475], [0.4]]
C
Cheerego 已提交
8104

R
RaindragonD 已提交
8105
      # y是一个shape为[2, 2, 2]的Tensor元素如下:
C
Cheerego 已提交
8106 8107 8108
      #      [[[1.0, 2.0], [3.0, 4.0]],
      #      [[5.0, 6.0], [7.0, 8.0]]]
      # 接下来的示例中,我们在每处函数调用后面都标注出了它的结果张量。。
R
RaindragonD 已提交
8109 8110 8111
      y = fluid.layers.data(name='y', shape=[2, 2, 2], dtype='float32')
      fluid.layers.reduce_mean(y, dim=[1, 2]) # [2.5, 6.5]
      fluid.layers.reduce_mean(y, dim=[0, 1]) # [4.0, 5.0]
C
Cheerego 已提交
8112 8113 8114 8115 8116 8117 8118 8119 8120 8121 8122 8123 8124 8125 8126 8127 8128 8129 8130 8131 8132 8133 8134 8135 8136 8137 8138 8139










.. _cn_api_fluid_layers_reduce_min:

reduce_min
-------------------------------

.. py:function:: paddle.fluid.layers.reduce_min(input, dim=None, keep_dim=False, name=None)

计算给定维度上张量元素的最小值。

参数:
          - **input** (Variable):输入变量为Tensor或LoDTensor。
          - **dim** (list | int | None):函数运算的维度。如果为None,则对输入的所有元素做差并返回单个元素的Tensor变量,否则必须在  :math:`[−rank(input),rank(input)]` 范围内。如果 :math:`dim [i] <0` ,则维度将减小为 :math:`rank+dim[i]` 。
          - **keep_dim** (bool | False):是否在输出Tensor中保留减小的维度。除非 ``keep_dim`` 为true,否则结果张量将比输入少一个维度。
          - **name** (str | None):这一层的名称(可选)。如果设置为None,则将自动命名这一层。

返回:  运算、减少维度之后的Tensor变量。

返回类型:  变量(Variable)
C
Cheerego 已提交
8140

C
Cheerego 已提交
8141 8142 8143 8144
**代码示例**

..  code-block:: python

R
RaindragonD 已提交
8145
      import paddle.fluid as fluid
C
Cheerego 已提交
8146 8147 8148 8149
      # x是一个Tensor,元素如下:
      #    [[0.2, 0.3, 0.5, 0.9]
      #     [0.1, 0.2, 0.6, 0.7]]
      # 接下来的示例中,我们在每处函数调用后面都标注出了它的结果张量。
R
RaindragonD 已提交
8150
      x = fluid.layers.data(name='x', shape=[4, 2], dtype='float32')
C
Cheerego 已提交
8151 8152 8153 8154 8155
      fluid.layers.reduce_min(x)  # [0.1]
      fluid.layers.reduce_min(x, dim=0)  # [0.1, 0.2, 0.5, 0.7]
      fluid.layers.reduce_min(x, dim=-1)  # [0.2, 0.1]
      fluid.layers.reduce_min(x, dim=1, keep_dim=True)  # [[0.2], [0.1]]

R
RaindragonD 已提交
8156
      # y是一个shape为[2, 2, 2]的Tensor元素如下:
C
Cheerego 已提交
8157 8158
      #      [[[1.0, 2.0], [3.0, 4.0]],
      #      [[5.0, 6.0], [7.0, 8.0]]]
R
RaindragonD 已提交
8159 8160 8161 8162
      # 接下来的示例中,我们在每处函数调用后面都标注出了它的结果张量。
      y = fluid.layers.data(name='y', shape=[2, 2, 2], dtype='float32')
      fluid.layers.reduce_min(y, dim=[1, 2]) # [1.0, 5.0]
      fluid.layers.reduce_min(y, dim=[0, 1]) # [1.0, 2.0]
C
Cheerego 已提交
8163 8164 8165 8166 8167 8168 8169 8170 8171 8172 8173 8174 8175 8176 8177 8178 8179 8180 8181 8182 8183 8184 8185 8186 8187 8188 8189 8190










.. _cn_api_fluid_layers_reduce_prod:

reduce_prod
-------------------------------

.. py:function:: paddle.fluid.layers.reduce_prod(input, dim=None, keep_dim=False, name=None)

计算给定维度上张量(Tensor)元素乘积。

参数:
          - **input** (Variable):输入变量为Tensor或LoDTensor。
          - **dim** (list | int | None):函数运算的维度。如果为None,则将输入的所有元素相乘并返回单个元素的Tensor变量,否则必须在  :math:`[−rank(input),rank(input)]` 范围内。如果 :math:`dim [i] <0` ,则维度将减小为 :math:`rank+dim[i]` 。
          - **keep_dim** (bool | False):是否在输出Tensor中保留减小的维度。除非 ``keep_dim`` 为true,否则结果张量将比输入少一个维度。
          - **name** (str | None):这一层的名称(可选)。如果设置为None,则将自动命名这一层。

返回:  运算、减少维度之后的Tensor变量。

返回类型:  变量(Variable)
C
Cheerego 已提交
8191

C
Cheerego 已提交
8192 8193 8194 8195
**代码示例**

..  code-block:: python

R
RaindragonD 已提交
8196
      import paddle.fluid as fluid
C
Cheerego 已提交
8197 8198 8199 8200
      # x是一个Tensor,元素如下:
      #    [[0.2, 0.3, 0.5, 0.9]
      #     [0.1, 0.2, 0.6, 0.7]]
      # 接下来的示例中,我们在每处函数调用后面都标注出了它的结果张量。
R
RaindragonD 已提交
8201
      x = fluid.layers.data(name='x', shape=[4, 2], dtype='float32')
C
Cheerego 已提交
8202 8203 8204 8205 8206 8207
      fluid.layers.reduce_prod(x)  # [0.0002268]
      fluid.layers.reduce_prod(x, dim=0)  # [0.02, 0.06, 0.3, 0.63]
      fluid.layers.reduce_prod(x, dim=-1)  # [0.027, 0.0084]
      fluid.layers.reduce_prod(x, dim=1,
                               keep_dim=True)  # [[0.027], [0.0084]]

R
RaindragonD 已提交
8208
      # y 是一个shape为[2, 2, 2]的Tensor元素如下:
C
Cheerego 已提交
8209 8210 8211
      #      [[[1.0, 2.0], [3.0, 4.0]],
      #      [[5.0, 6.0], [7.0, 8.0]]]
      # 接下来的示例中,我们在每处函数调用后面都标注出了它的结果张量。
R
RaindragonD 已提交
8212 8213 8214
      y = fluid.layers.data(name='y', shape=[2, 2, 2], dtype='float32')
      fluid.layers.reduce_prod(y, dim=[1, 2]) # [24.0, 1680.0]
      fluid.layers.reduce_prod(y, dim=[0, 1]) # [105.0, 384.0]
C
Cheerego 已提交
8215 8216 8217 8218 8219 8220 8221 8222 8223 8224 8225 8226 8227 8228 8229 8230 8231 8232 8233 8234 8235 8236 8237 8238 8239 8240 8241 8242










.. _cn_api_fluid_layers_reduce_sum:

reduce_sum
-------------------------------

.. py:function:: paddle.fluid.layers.reduce_sum(input, dim=None, keep_dim=False, name=None)

计算给定维度上张量(Tensor)元素之和。

参数:
          - **input** (Variable)- 输入变量为Tensor或LoDTensor。
          - **dim** (list | int | None)- 求和运算的维度。如果为None,则对输入的所有元素求和并返回单个元素的Tensor变量,否则必须在  :math:`[−rank(input),rank(input)]` 范围内。如果 :math:`dim [i] <0` ,则维度将减小为 :math:`rank+dim[i]` 。
          - **keep_dim** (bool | False)- 是否在输出Tensor中保留减小的维度。除非 ``keep_dim`` 为true,否则结果张量将比输入少一个维度。
          - **name** (str | None)- 这一层的名称(可选)。如果设置为None,则将自动命名这一层。

返回:  运算、减少维度之后的Tensor变量。

返回类型:  变量(Variable)
C
Cheerego 已提交
8243

C
Cheerego 已提交
8244 8245 8246 8247
**代码示例**

..  code-block:: python

R
RaindragonD 已提交
8248
      import paddle.fluid as fluid
C
Cheerego 已提交
8249 8250 8251 8252
      # x是一个Tensor,元素如下:
      #    [[0.2, 0.3, 0.5, 0.9]
      #     [0.1, 0.2, 0.6, 0.7]]
      # 接下来的示例中,我们在每处函数调用后面都标注出了它的结果张量。
R
RaindragonD 已提交
8253
      x = fluid.layers.data(name='x', shape=[4, 2], dtype='float32')
C
Cheerego 已提交
8254 8255 8256 8257 8258
      fluid.layers.reduce_sum(x)  # [3.5]
      fluid.layers.reduce_sum(x, dim=0)  # [0.3, 0.5, 1.1, 1.6]
      fluid.layers.reduce_sum(x, dim=-1)  # [1.9, 1.6]
      fluid.layers.reduce_sum(x, dim=1, keep_dim=True)  # [[1.9], [1.6]]

R
RaindragonD 已提交
8259
      # y 是一个shape为[2, 2, 2]的Tensor元素如下:
C
Cheerego 已提交
8260 8261 8262
      #      [[[1, 2], [3, 4]],
      #      [[5, 6], [7, 8]]]
      # 接下来的示例中,我们在每处函数调用后面都标注出了它的结果张量。
R
RaindragonD 已提交
8263 8264 8265
      y = fluid.layers.data(name='y', shape=[2, 2, 2], dtype='float32')
      fluid.layers.reduce_sum(y, dim=[1, 2]) # [10, 26]
      fluid.layers.reduce_sum(y, dim=[0, 1]) # [16, 20]
C
Cheerego 已提交
8266

C
Cheerego 已提交
8267 8268 8269 8270 8271 8272 8273 8274 8275 8276 8277 8278 8279 8280 8281 8282 8283









.. _cn_api_fluid_layers_relu:

relu
-------------------------------

.. py:function:: paddle.fluid.layers.relu(x, name=None)

Relu接受一个输入数据(张量),输出一个张量。将线性函数y = max(0, x)应用到张量中的每个元素上。
C
Cheerego 已提交
8284 8285

.. math::
C
Cheerego 已提交
8286
              \\Out=\max(0,x)\\
C
Cheerego 已提交
8287

C
Cheerego 已提交
8288 8289 8290 8291 8292 8293 8294 8295 8296 8297 8298 8299

参数:
  - **x** (Variable):输入张量。
  - **name** (str|None,默认None) :如果设置为None,该层将自动命名。

返回: 与输入形状相同的输出张量。

返回类型: 变量(Variable)

**代码示例**:

..  code-block:: python
R
RaindragonD 已提交
8300 8301
      
    x = fluid.layers.data(name="x", shape=[3, 4], dtype="float32")
C
Cheerego 已提交
8302 8303 8304 8305 8306 8307 8308 8309 8310 8311 8312 8313 8314 8315 8316 8317 8318 8319 8320 8321 8322
    output = fluid.layers.relu(x)










.. _cn_api_fluid_layers_relu6:

relu6
-------------------------------

.. py:function:: paddle.fluid.layers.relu6(x, threshold=6.0, name=None)

relu6激活算子(Relu6 Activation Operator)

.. math::
C
Cheerego 已提交
8323

C
Cheerego 已提交
8324 8325 8326 8327 8328 8329 8330 8331 8332 8333 8334 8335 8336 8337 8338 8339 8340 8341 8342 8343 8344 8345 8346 8347 8348 8349 8350 8351 8352 8353 8354 8355 8356 8357 8358 8359 8360 8361 8362 8363 8364
    \\out=min(max(0, x), 6)\\


参数:
    - **x** (Variable) - Relu6 operator的输入
    - **threshold** (FLOAT|6.0) - Relu6的阈值
    - **name** (str|None) -这个层的名称(可选)。如果设置为None,该层将被自动命名。

返回: Relu6操作符的输出

返回类型: 输出(Variable)


**代码示例:**

.. code-block:: python

    x = fluid.layers.data(name="x", shape=[3,10,32,32], dtype="float32")
    y = fluid.layers.relu6(x, threshold=6.0)







.. _cn_api_fluid_layers_reshape:

reshape
-------------------------------

.. py:function::  paddle.fluid.layers.reshape(x, shape, actual_shape=None, act=None, inplace=False, name=None)

保持输入张量数据不变的情况下,改变张量的形状。

目标形状可由 ``shape`` 或 ``actual_shape`` 给出。``shape`` 是一个整数列表,而 ``actual_shape`` 是一个张量变量。
当两个属性同时被指定时,``actual_shape`` 的优先级高于 ``shape`` ,但在编译时仍然应该正确地设置 ``shape`` 以保证形状推断。

在指定目标shape时存在一些技巧:

.. code-block:: text
C
Cheerego 已提交
8365

R
RaindragonD 已提交
8366 8367
  1. -1表示这个维度的值是从x的元素总数和剩余维度推断出来的。因此,有且只有一个维度可以被设置为-1。
  2. 0表示实际的维数是从x的对应维数中复制出来的,因此shape中0的索引值不能超过秩(x)。
C
Cheerego 已提交
8368 8369 8370 8371 8372 8373


这里有一些例子来解释它们:

.. code-block:: text

R
RaindragonD 已提交
8374 8375 8376
  1. 给定一个形状为[2,4,6]的三维张量x,目标形状为[6,8], ``reshape`` 将x变换为形状为[6,8]的二维张量,且x的数据保持不变。
  2. 给定一个形状为[2,4,6]的三维张量x,指定的目标形状为[2,3,-1,2], ``reshape``将x变换为形状为[2,3,4,2]的4- d张量,不改变x的数据。在这种情况下,目标形状的一个维度被设置为-1,这个维度的值是从x的元素总数和剩余维度推断出来的。
  3. 给定一个形状为[2,4,6]的三维张量x,目标形状为[- 1,0,3,2],整形算子将x变换为形状为[2,4,3,2]的四维张量,使x的数据保持不变。在这种情况下,0意味着实际的维值将从x的对应维数中复制,-1位置的维度由x的元素总数和剩余维度计算得来。
C
Cheerego 已提交
8377 8378

参数:
R
RaindragonD 已提交
8379 8380 8381 8382 8383 8384
  - **x** (variable) - 输入张量
  - **shape** (list) - 新的形状。新形状最多只能有一个维度为-1。
  - **actual_shape** (variable) - 一个可选的输入。如果提供,则根据 ``actual_shape`` 进行 reshape,而不是指定 ``shape`` 。也就是说,actual_shape具有比shape更高的优先级。
  - **act** (str) - 对reshpe后的tensor变量执行非线性激活
  - **inplace** (bool) - 如果 ``inplace`` 为True,则 ``layers.reshape`` 的输入和输出是同一个变量,否则, ``layers.reshape`` 的输入和输出是不同的变量。请注意,如果x作为多个层的输入,则 ``inplace`` 必须为False。
  - **name** (str) -  可选变量,此层的名称
C
Cheerego 已提交
8385 8386 8387 8388 8389 8390 8391 8392 8393

返回:如果 ``act`` 为 ``None``,返回reshape后的tensor变量。如果 ``inplace`` 为 ``False`` ,将返回一个新的Tensor变量,否则,将改变x自身。如果 ``act`` 不是 ``None`` ,则返回激活的张量变量。

抛出异常:``TypeError`` - 如果 actual_shape 既不是变量也不是None

**代码示例**

.. code-block:: python

R
RaindragonD 已提交
8394 8395 8396 8397
  data = fluid.layers.data(
      name='data', shape=[2, 4, 6], dtype='float32')
  reshaped = fluid.layers.reshape(
      x=data, shape=[-1, 0, 3, 2], inplace=True)
C
Cheerego 已提交
8398 8399 8400 8401 8402 8403 8404 8405 8406 8407 8408 8409 8410 8411 8412










.. _cn_api_fluid_layers_resize_bilinear:

resize_bilinear
-------------------------------

H
Hao Wang 已提交
8413
.. py:function:: paddle.fluid.layers.resize_bilinear(input, out_shape=None, scale=None, name=None, actual_shape=None, align_corners=True, align_mode=1)
C
Cheerego 已提交
8414 8415 8416 8417 8418 8419


根据指定的out_shape执行双线性插值调整输入大小,输出形状按优先级由actual_shape、out_shape和scale指定。

双线性插值是对线性插值的扩展,即二维变量方向上(如h方向和w方向)插值。关键思想是先在一个方向上执行线性插值,然后再在另一个方向上执行线性插值。

H
Hao Wang 已提交
8420 8421 8422 8423 8424 8425 8426 8427 8428 8429
详情请参阅 `维基百科 <https://en.wikipedia.org/wiki/Bilinear_interpolation>`_ 。

align_corners和align_mode是可选参数,插值的计算方法可以由它们选择。


::

    Example:

      For scale:
C
Cheerego 已提交
8430

H
Hao Wang 已提交
8431 8432 8433
        if align_corners = True && out_size > 1 :

          scale_factor = (in_size-1.0)/(out_size-1.0)
C
Cheerego 已提交
8434

H
Hao Wang 已提交
8435
        else:
C
Cheerego 已提交
8436 8437

          scale_factor = float(in_size/out_size)
H
Hao Wang 已提交
8438 8439 8440 8441

    Bilinear interpolation:

      if align_corners = False , align_mode = 0
C
Cheerego 已提交
8442

H
Hao Wang 已提交
8443 8444
          input : (N,C,H_in,W_in)
          output: (N,C,H_out,W_out) where:
C
Cheerego 已提交
8445

H
Hao Wang 已提交
8446 8447 8448 8449 8450 8451 8452 8453 8454 8455 8456 8457 8458
          H_out = (H_{in}+0.5) * scale_{factor} - 0.5
          W_out = (W_{in}+0.5) * scale_{factor} - 0.5


      else:

          input : (N,C,H_in,W_in)
          output: (N,C,H_out,W_out) where:

          H_out = H_{in} * scale_{factor}
          W_out = W_{in} * scale_{factor}


C
Cheerego 已提交
8459 8460

参数:
C
Cheerego 已提交
8461
    - **input** (Variable) - 双线性插值的输入张量,是一个shape为(N x C x h x w)的4d张量。
R
RaindragonD 已提交
8462 8463
    - **out_shape** (list|tuple|Variable|None) - 调整双线性层的输出形状,形式为(out_h, out_w)。默认值:None。
    - **scale** (float|None) - 用于输入高度或宽度的乘数因子。out_shape和scale至少要设置一个。out_shape的优先级高于scale。默认值:None。
H
Hao Wang 已提交
8464 8465 8466 8467
    - **name** (str|None) - 输出变量名。
    - **actual_shape** (Variable) - 可选输入,用于动态指定输出形状。如果指定actual_shape,图像将根据给定的形状调整大小,而不是根据指定形状的 :code:`out_shape` 和 :code:`scale` 进行调整。也就是说, :code:`actual_shape` 具有最高的优先级。如果希望动态指定输出形状,建议使用 :code:`actual_shape` 而不是 :code:`out_shape` 。在使用actual_shape指定输出形状时,还需要设置out_shape和scale之一,否则在图形构建阶段会出现错误。默认值:None
    - **align_corners** (bool)- 一个可选的bool型参数,如果为True,则将输入和输出张量的4个角落像素的中心对齐,并保留角点像素的值。 默认值:True
    - **align_mode** (int)- 双线性插值的可选项。 可以是'0'代表src_idx = scale *(dst_indx + 0.5)-0.5;可以为'1' ,代表src_idx = scale * dst_index。
C
Cheerego 已提交
8468

H
Hao Wang 已提交
8469

R
RaindragonD 已提交
8470
返回: 插值运算的输出张量,其各维度是(N x C x out_h x out_w)
C
Cheerego 已提交
8471 8472


R
RaindragonD 已提交
8473
**代码示例**
C
Cheerego 已提交
8474 8475

.. code-block:: python
R
RaindragonD 已提交
8476 8477
  
  input = fluid.layers.data(name="input", shape=[3,6,9], dtype="float32")
C
Cheerego 已提交
8478 8479 8480 8481 8482 8483 8484 8485 8486 8487 8488 8489 8490 8491
  out = fluid.layers.resize_bilinear(input, out_shape=[12, 12])








.. _cn_api_fluid_layers_resize_nearest:

resize_nearest
-------------------------------

H
Hao Wang 已提交
8492
.. py:function:: paddle.fluid.layers.resize_nearest(input, out_shape=None, scale=None, name=None, actual_shape=None, align_corners=True)
C
Cheerego 已提交
8493 8494 8495 8496

该层对输入进行放缩,在第三维(高度方向)和第四维(宽度方向)进行最邻近插值(nearest neighbor interpolation)操作。
输出形状按优先级顺序依据 ``actual_shape`` , ``out_shape`` 和 ``scale`` 而定。

H
Hao Wang 已提交
8497 8498 8499 8500 8501
::

    Example:

          For scale:
C
Cheerego 已提交
8502

H
Hao Wang 已提交
8503 8504 8505
            if align_corners = True && out_size > 1 :

              scale_factor = (in_size-1.0)/(out_size-1.0)
C
Cheerego 已提交
8506

H
Hao Wang 已提交
8507
            else:
C
Cheerego 已提交
8508

H
Hao Wang 已提交
8509
              scale_factor = float(in_size/out_size)
C
Cheerego 已提交
8510 8511


H
Hao Wang 已提交
8512
          Nearest neighbor interpolation:
C
Cheerego 已提交
8513

H
Hao Wang 已提交
8514 8515 8516 8517 8518 8519 8520 8521 8522 8523 8524 8525 8526 8527 8528 8529 8530
          if align_corners = False

              input : (N,C,H_in,W_in)
              output: (N,C,H_out,W_out) where:

              H_out = \left \lfloor {H_{in} * scale_{}factor}} \right \rfloor
              W_out = \left \lfloor {W_{in} * scale_{}factor}} \right \rfloor

          else:
              align_corners = True

              input : (N,C,H_in,W_in)
              output: (N,C,H_out,W_out) where:

              H_out = round(H_{in} * scale_{factor})
              W_out = round(W_{in} * scale_{factor})

C
Cheerego 已提交
8531 8532 8533 8534 8535 8536
最邻近插值的详细介绍请参照: `Wiki Nearest-neighbor interpolation <https://en.wikipedia.org/wiki/Nearest-neighbor_interpolation>`_



参数:
  - **input** (Variable) – 插值运算的输入张量, 是一个形为 (N,C,H,W) 的四维张量
R
RaindragonD 已提交
8537
  - **out_shape** (list|tuple|Variable|None) – 调整最近邻层的输出形状,形式为(out_h, out_w)。默认值:None。
C
Cheerego 已提交
8538 8539 8540
  - **scale** (float|None) – 输入高、宽的乘法器。 ``out_shape`` 和 ``scale`` 二者至少设置其一。 ``out_shape`` 具有比 ``scale`` 更高的优先级。 默认: None
  - **name** (str|None) – 输出变量的命名
  - **actual_shape** (Variable) – 可选输入, 动态设置输出张量的形状。 如果提供该值, 图片放缩会依据此形状进行, 而非依据 ``out_shape`` 和 ``scale`` 。 即为, ``actual_shape`` 具有最高的优先级。 如果想动态指明输出形状,推荐使用 ``actual_shape`` 取代 ``out_shape`` 。 当使用 ``actual_shape`` 来指明输出形状, ``out_shape`` 和 ``scale`` 也应该进行设置, 否则在图形生成阶段将会报错。默认: None
H
Hao Wang 已提交
8541
  - **align_corners** (bool)- 一个可选的bool型参数,如果为True,则将输入和输出张量的4个角落像素的中心对齐,并保留角点像素的值。 默认值:True
C
Cheerego 已提交
8542

8543
返回:插值运算的输出张量,是一个形为 [N,C,H,W] 的四维张量
C
Cheerego 已提交
8544 8545 8546 8547

**代码示例**

..  code-block:: python
R
RaindragonD 已提交
8548 8549
    
    input = fluid.layers.data(name="input", shape=[3,6,9], dtype="float32")
C
Cheerego 已提交
8550 8551 8552 8553 8554 8555 8556 8557 8558 8559 8560 8561 8562 8563 8564 8565 8566 8567 8568 8569 8570 8571 8572 8573 8574 8575 8576 8577 8578 8579 8580 8581 8582 8583 8584 8585 8586 8587 8588 8589 8590 8591 8592
    out = fluid.layers.resize_nearest(input, out_shape=[12, 12])










.. _cn_api_fluid_layers_roi_align:

roi_align
-------------------------------

.. py:function:: paddle.fluid.layers.roi_align(input, rois, pooled_height=1, pooled_width=1, spatial_scale=1.0, sampling_ratio=-1, name=None)

**实现RoIAlign操作。**

Region of Interests align(直译:有意义、有价值选区对齐) 用于实现双线性插值,它可以将不均匀大小的输入
变为固定大小的特征图(feature map)。

该运算通过 ``pooled_width`` 和 ``pooled_height`` 将每个推荐区域划分为等大小分块。位置保持不变。

在每个RoI框中,四个常取样位置会通过双线性插值直接计算。输出为这四个位置的平均值从而解决不对齐问题。

参数:
  - **input** (Variable) – (Tensor) 该运算的的输入张量,形为(N,C,H,W)。其中 N 为batch大小, C 为输入通道的个数, H 特征高度, W 特征宽度
  - **rois** (Variable) – 待池化的ROIs (Regions of Interest)
  - **pooled_height** (integer) – (默认为1), 池化后的输出高度
  - **pooled_width** (integer) – (默认为1), 池化后的输出宽度
  - **spatial_scale** (float) – (默认为1.0),乘法性质空间标尺因子,池化时,将RoI坐标变换至运算采用的标度
  - **sampling_ratio** (intger) – (默认为-1),插值格中采样点的数目。 如果它 <=0, 它们将自适应 ``roi_width`` 和 ``pooled_w`` , 在高度上也是同样的道理。

返回:一个形为 (num_rois, channels, pooled_h, pooled_w) 的四维张量

返回类型:Variable

**代码示例**

..  code-block:: python

R
RaindragonD 已提交
8593 8594 8595 8596
    x = fluid.layers.data(
            name='data', shape=[256, 32, 32], dtype='float32')
    rois = fluid.layers.data(
            name='rois', shape=[4], dtype='float32')
C
Cheerego 已提交
8597 8598 8599 8600 8601 8602 8603 8604 8605 8606 8607 8608 8609 8610 8611 8612 8613 8614 8615 8616 8617 8618 8619 8620
    align_out = fluid.layers.roi_align(input=x,
                                       rois=rois,
                                       pooled_height=7,
                                       pooled_width=7,
                                       spatial_scale=0.5,
                                       sampling_ratio=-1)











.. _cn_api_fluid_layers_roi_pool:

roi_pool
-------------------------------

.. py:function:: paddle.fluid.layers.roi_pool(input, rois, pooled_height=1, pooled_width=1, spatial_scale=1.0)

C
Cheerego 已提交
8621

C
Cheerego 已提交
8622
roi池化是对非均匀大小的输入执行最大池化,以获得固定大小的特征映射(例如7*7)。
C
Cheerego 已提交
8623

C
Cheerego 已提交
8624 8625 8626 8627 8628 8629 8630 8631
该operator有三个步骤:

    1. 用pooled_width和pooled_height将每个区域划分为大小相等的部分
    2. 在每个部分中找到最大的值
    3. 将这些最大值复制到输出缓冲区

Faster-RCNN.使用了roi池化。roi关于roi池化请参考 https://stackoverflow.com/questions/43430056/what-is-roi-layer-in-fast-rcnn

C
Cheerego 已提交
8632
参数:
C
Cheerego 已提交
8633 8634 8635 8636
    - **input** (Variable) - 张量,ROIPoolOp的输入。输入张量的格式是NCHW。其中N为batch大小,C为输入通道数,H为特征高度,W为特征宽度
    - **roi** (Variable) -  roi区域。
    - **pooled_height** (integer) - (int,默认1),池化输出的高度。默认:1
    - **pooled_width** (integer) -  (int,默认1) 池化输出的宽度。默认:1
8637
    - **spatial_scale** (float) - (float,默认1.0),用于将ROI coords从输入比例转换为池化时使用的比例。默认1.0
C
Cheerego 已提交
8638 8639

返回: (张量),ROIPoolOp的输出是一个shape为(num_rois, channel, pooled_h, pooled_w)的4d张量。
C
Cheerego 已提交
8640

C
Cheerego 已提交
8641
返回类型: 变量(Variable)
C
Cheerego 已提交
8642

C
Cheerego 已提交
8643 8644 8645 8646 8647

**代码示例**

..  code-block:: python

R
RaindragonD 已提交
8648 8649 8650 8651 8652 8653 8654 8655 8656 8657 8658 8659
  import paddle.fluid as fluid
     
  x = fluid.layers.data(
            name='x', shape=[8, 112, 112], dtype='float32')
  rois = fluid.layers.data(
            name='roi', shape=[4], lod_level=1, dtype='float32')
  pool_out = fluid.layers.roi_pool(
            input=x,
            rois=rois,
            pooled_height=7,
            pooled_width=7,
            spatial_scale=1.0)
C
Cheerego 已提交
8660 8661 8662 8663 8664 8665 8666 8667 8668 8669 8670 8671 8672 8673 8674 8675









.. _cn_api_fluid_layers_row_conv:

row_conv
-------------------------------

.. py:function:: paddle.fluid.layers.row_conv(input, future_context_size, param_attr=None, act=None)

C
Cheerego 已提交
8676 8677 8678
行卷积(Row-convolution operator)称为超前卷积(lookahead convolution)。下面关于DeepSpeech2的paper中介绍了这个operator

    `<http://www.cs.cmu.edu/~dyogatam/papers/wang+etal.iclrworkshop2016.pdf>`_
C
Cheerego 已提交
8679 8680

双向的RNN在深度语音模型中很有用,它通过对整个序列执行正向和反向传递来学习序列的表示。然而,与单向RNNs不同的是,在线部署和低延迟设置中,双向RNNs具有难度。超前卷积将来自未来子序列的信息以一种高效的方式进行计算,以改进单向递归神经网络。 row convolution operator 与一维序列卷积不同,计算方法如下:
C
Cheerego 已提交
8681

H
Hao Wang 已提交
8682
给定输入序列长度为 :math:`t` 的输入序列 :math:`X` 和输入维度 :math:`D` ,以及一个大小为 :math:`context * D` 的滤波器 :math:`W` ,输出序列卷积为:
C
Cheerego 已提交
8683

C
Cheerego 已提交
8684
.. math::
R
RaindragonD 已提交
8685
    out_i = \sum_{j=i}^{i+context-1} X_{j} · W_{j-i}
C
Cheerego 已提交
8686

C
Cheerego 已提交
8687
公式中:
H
Hao Wang 已提交
8688 8689 8690 8691
    - :math:`out_i` : 第i行输出变量形为[1, D].
    - :math:`context` : 下文(future context)大小
    - :math:`X_j` : 第j行输出变量,形为[1,D]
    - :math:`W_{j-i}` : 第(j-i)行参数,其形状为[1,D]。
C
Cheerego 已提交
8692

H
Hao Wang 已提交
8693
详细请参考 `设计文档  <https://github.com/PaddlePaddle/Paddle/issues/2228#issuecomment-303903645>`_  。
C
Cheerego 已提交
8694 8695 8696

参数:
    - **input** (Variable) -- 输入是一个LodTensor,它支持可变时间长度的输入序列。这个LodTensor的内部张量是一个具有形状(T x N)的矩阵,其中T是这个mini batch中的总的timestep,N是输入数据维数。
H
Hao Wang 已提交
8697
    - **future_context_size** (int) -- 下文大小。请注意,卷积核的shape是[future_context_size + 1, D]。
C
Cheerego 已提交
8698 8699
    - **param_attr** (ParamAttr) --  参数的属性,包括名称、初始化器等。
    - **act** (str) -- 非线性激活函数。
C
Cheerego 已提交
8700

C
Cheerego 已提交
8701 8702 8703 8704 8705 8706 8707
返回: 输出(Out)是一个LodTensor,它支持可变时间长度的输入序列。这个LodTensor的内部量是一个形状为 T x N 的矩阵,和X的 shape 一样。


**代码示例**

..  code-block:: python

R
RaindragonD 已提交
8708
  import paddle.fluid as fluid
C
Cheerego 已提交
8709

R
RaindragonD 已提交
8710
  x = fluid.layers.data(name='x', shape=[16],
C
Cheerego 已提交
8711
                        dtype='float32', lod_level=1)
R
RaindragonD 已提交
8712
  out = fluid.layers.row_conv(input=x, future_context_size=2)
C
Cheerego 已提交
8713 8714


Z
zy0531 已提交
8715 8716 8717 8718 8719 8720 8721 8722 8723 8724 8725 8726 8727 8728 8729 8730
.. _cn_api_fluid_layers_sampled_softmax_with_cross_entropy:

sampled_softmax_with_cross_entropy
----------------------------------------------

.. py:function:: paddle.fluid.layers.sampled_softmax_with_cross_entropy(logits, label, num_samples, num_true=1, remove_accidental_hits=True, use_customized_samples=False, customized_samples=None, customized_probabilities=None, seed=0)

**Sampled Softmax With Cross Entropy Operator**

对于较大的输出类,采样的交叉熵损失Softmax被广泛地用作输出层。该运算符为所有示例采样若干个样本,并计算每行采样张量的SoftMax标准化值,然后计算交叉熵损失。

由于此运算符在内部对逻辑执行SoftMax,因此它需要未分级的逻辑。此运算符不应与SoftMax运算符的输出一起使用,因为这样会产生不正确的结果。

对于T真标签(T>=1)的示例,我们假设每个真标签的概率为1/T。对于每个样本,使用对数均匀分布生成S个样本。真正的标签与这些样本连接起来,形成每个示例的T+S样本。因此,假设逻辑的形状是[N x K],样本的形状是[N x(T+S)]。对于每个取样标签,计算出一个概率,对应于[Jean et al., 2014]( `http://arxiv.org/abs/1412.2007 <https://arxiv.org/abs/1412.2007>`_ )中的Q(y|x)。

根据采样标签对逻辑进行采样。如果remove_accidental_hits为“真”,如果sample[i, j] 意外匹配“真”标签,则相应的sampled_logits[i, j]减去1e20,使其SoftMax结果接近零。然后用logQ(y|x)减去采样的逻辑,这些采样的逻辑和重新索引的标签被用来计算具有交叉熵的SoftMax。
C
Cheerego 已提交
8731

Z
zy0531 已提交
8732 8733 8734 8735 8736 8737 8738 8739 8740 8741 8742 8743 8744 8745 8746 8747 8748 8749 8750
参数:
        - **logits** (Variable)- 非比例对数概率,是一个二维张量,形状为[N x K]。N是批大小,K是类别号。
        - **label** (Variable)- 基本事实,是一个二维张量。label是一个张量<int64>,其形状为[N x T],其中T是每个示例的真实标签数。
        - **num_samples** (int)- 每个示例的数目num_samples应该小于类的数目。
        - **num_true** (int)- 每个训练实例的目标类别总数。
        - **remove_accidental_hits** (bool)- 指示采样时是否删除意外命中的标签。如果为真,如果一个sample[i,j]意外地碰到了真标签,那么相应的sampled_logits[i,j]将被减去1e20,使其SoftMax结果接近零。默认值为True。
        - **use_customized_samples** (bool)- 是否使用自定义样本和可能性对logits进行抽样。
        - **customized_samples** (Variable)- 用户定义的示例,它是一个具有形状[N, T + S]的二维张量。S是num_samples,T是每个示例的真标签数。
        - **customized_probabilities** (Variable)- 用户定义的样本概率,与customized_samples形状相同的二维张量。
        - **seed** (int)- 用于生成随机数的随机种子,在采样过程中使用。默认值为0。

返回:交叉熵损失,是一个二维张量,形状为[N x 1]。

返回类型:Variable

**代码示例:**

.. code-block:: python

R
RaindragonD 已提交
8751 8752 8753
    import paddle.fluid as fluid

    input = fluid.layers.data(name='data', shape=[256], dtype='float32')
Z
zy0531 已提交
8754
    label = fluid.layers.data(name='label', shape=[5], dtype='int64')
R
RaindragonD 已提交
8755
    fc = fluid.layers.fc(input=input, size=100)
Z
zy0531 已提交
8756
    out = fluid.layers.sampled_softmax_with_cross_entropy(
R
RaindragonD 已提交
8757
              logits=fc, label=label, num_samples=25)
C
Cheerego 已提交
8758 8759 8760 8761 8762 8763 8764 8765 8766 8767 8768 8769 8770 8771 8772 8773 8774 8775 8776 8777







.. _cn_api_fluid_layers_sampling_id:

sampling_id
-------------------------------

.. py:function:: paddle.fluid.layers.sampling_id(x, min=0.0, max=1.0, seed=0, dtype='float32')

sampling_id算子。用于从输入的多项分布中对id进行采样的图层。为一个样本采样一个id。

参数:
        - **x** (Variable)- softmax的输入张量(Tensor)。2-D形状[batch_size,input_feature_dimensions]
        - **min** (Float)- 随机的最小值。(浮点数,默认为0.0)
        - **max** (Float)- 随机的最大值。(float,默认1.0)
8778
        - **seed** (Float)- 用于随机数引擎的随机种子。0表示使用系统生成的种子。请注意,如果seed不为0,则此算子将始终每次生成相同的随机数。(int,默认为0)
C
Cheerego 已提交
8779 8780 8781 8782 8783 8784 8785
        - **dtype** (np.dtype | core.VarDesc.VarType | str)- 输出数据的类型为float32,float_16,int等。

返回:       Id采样的数据张量。

返回类型:        输出(Variable)。


T
Tink_Y 已提交
8786 8787 8788 8789
**代码示例:**

.. code-block:: python

H
Hao Wang 已提交
8790
    x = fluid.layers.data(
T
Tink_Y 已提交
8791 8792 8793 8794 8795
    name="X",
    shape=[13, 11],
    dtype='float32',
    append_batch_size=False)

H
Hao Wang 已提交
8796
    out = fluid.layers.sampling_id(x)
C
Cheerego 已提交
8797 8798 8799 8800 8801 8802 8803 8804 8805 8806 8807 8808 8809 8810 8811 8812 8813 8814 8815 8816 8817 8818 8819 8820 8821 8822 8823 8824 8825 8826 8827 8828 8829 8830 8831 8832 8833








.. _cn_api_fluid_layers_scale:

scale
-------------------------------

.. py:function:: paddle.fluid.layers.scale(x, scale=1.0, bias=0.0, bias_after_scale=True, act=None, name=None)

缩放算子

对输入张量应用缩放和偏移加法。

if ``bias_after_scale`` = True:

.. math::
                                Out=scale*X+bias

else:

.. math::
                                Out=scale*(X+bias)

参数:
        - **x** (Variable) - (Tensor) 要比例运算的输入张量(Tensor)。
        - **scale** (FLOAT) - 比例运算的比例因子。
        - **bias** (FLOAT) - 比例算子的偏差。
        - **bias_after_scale** (BOOLEAN) - 在缩放之后或之前添加bias。在某些情况下,对数值稳定性很有用。
        - **act** (basestring|None) - 应用于输出的激活函数。
        - **name** (basestring|None)- 输出的名称。

8834
返回:        比例算子的输出张量(Tensor)
C
Cheerego 已提交
8835 8836 8837

返回类型:        变量(Variable)

R
RaindragonD 已提交
8838 8839 8840 8841 8842 8843 8844 8845
**代码示例:**

.. code-block:: python

    import paddle.fluid as fluid
     
    x = fluid.layers.data(name="X", shape=[1, 2, 5, 5], dtype='float32')
    y = fluid.layers.scale(x, scale = 2.0, bias = 1.0)
C
Cheerego 已提交
8846 8847 8848 8849 8850 8851 8852 8853 8854 8855 8856 8857 8858 8859









.. _cn_api_fluid_layers_scatter:

scatter
-------------------------------

R
RaindragonD 已提交
8860
.. py:function:: paddle.fluid.layers.scatter(input, index, updates, name=None, overwrite=True)
C
Cheerego 已提交
8861 8862 8863 8864 8865 8866 8867 8868 8869


通过更新输入在第一维度上指定索引位置处的元素来获得输出。

.. math::
          \\Out=XOut[Ids]=Updates\\


参数:
R
RaindragonD 已提交
8870 8871 8872 8873 8874
  - **input** (Variable) - 秩> = 1的源输入。
  - **index** (Variable) - 秩= 1的索引输入。 它的dtype应该是int32或int64,因为它用作索引。
  - **updates** (Variable) - scatter 要进行更新的变量。
  - **name** (str | None) - 输出变量名称。 默认None。
  - **overwrite** (bool) - 具有相同索引时更新输出的模式。如果为True,则使用覆盖模式更新相同索引的输出,如果为False,则使用accumulate模式更新相同索引的grad。默认值为True。您可以设置overwrite=False以使用scatter_add。
C
Cheerego 已提交
8875 8876 8877 8878 8879 8880 8881 8882 8883

返回:张量变量, 与输入张量的shape相同

返回类型:output(Variable)

**代码示例**

..  code-block:: python

R
RaindragonD 已提交
8884 8885 8886 8887 8888 8889
    import paddle.fluid as fluid
     
    input = fluid.layers.data(name='data', shape=[3, 5, 9], dtype='float32', append_batch_size=False)
    index = fluid.layers.data(name='index', shape=[3], dtype='int64', append_batch_size=False)
    updates = fluid.layers.data(name='update', shape=[3, 5, 9], dtype='float32', append_batch_size=False)
    
C
Cheerego 已提交
8890 8891 8892 8893 8894 8895 8896 8897 8898 8899 8900 8901 8902 8903 8904 8905 8906 8907 8908 8909 8910 8911 8912 8913 8914 8915
    output = fluid.layers.scatter(input, index, updates)











.. _cn_api_fluid_layers_selu:

selu
-------------------------------

.. py:function:: paddle.fluid.layers.selu(x, scale=None, alpha=None, name=None)

**实现Selu运算**

有如下等式:

.. math::
    selu= \lambda*
    \begin{cases}
C
Cheerego 已提交
8916 8917
         x                      &\quad \text{ if } x>0 \\
         \alpha * e^x - \alpha  &\quad \text{ if } x<=0
C
Cheerego 已提交
8918 8919 8920 8921 8922 8923
    \end{cases}

输入 ``x`` 可以选择性携带LoD信息。输出和它共享此LoD信息(如果有)。

参数:
  - **x** (Variable) – 输入张量
C
Cheerego 已提交
8924
  - **scale** (float, None) – 如果标度没有设置,其默认值为 1.0507009873554804934193349852946。 详情请见: `Self-Normalizing Neural Networks <https://arxiv.org/abs/1706.02515.pdf>`_
C
Cheerego 已提交
8925 8926 8927 8928 8929 8930 8931 8932 8933 8934 8935
  - **alpha** (float, None) – 如果没有设置改参数, 其默认值为 1.6732632423543772848170429916717。 详情请见: `Self-Normalizing Neural Networks <https://arxiv.org/abs/1706.02515.pdf>`_
  - **name** (str|None, default None) – 该层命名,若为None则自动为其命名

返回:一个形和输入张量相同的输出张量

返回类型:Variable

**代码示例**

..  code-block:: python

R
RaindragonD 已提交
8936 8937 8938 8939 8940 8941
    import paddle.fluid as fluid
     
    input = fluid.layers.data(
         name="input", shape=[3, 9, 5], dtype="float32")

    output = fluid.layers.selu(input)
C
Cheerego 已提交
8942 8943 8944 8945 8946 8947 8948 8949 8950 8951 8952 8953 8954 8955 8956 8957 8958 8959 8960 8961 8962 8963 8964













.. _cn_api_fluid_layers_sequence_concat:

sequence_concat
-------------------------------

.. py:function:: paddle.fluid.layers.sequence_concat(input, name=None)

sequence_concat操作通过序列信息连接LoD张量(Tensor)。例如:X1的LoD = [0,3,7],X2的LoD = [0,7,9],结果的LoD为[0,(3 + 7),(7 + 9)],即[0,10,16]。

参数:
T
Tink_Y 已提交
8965 8966
        - **input** (list) – 要连接变量的列表
        - **name** (str|None) – 此层的名称(可选)。如果没有设置,该层将被自动命名。
C
Cheerego 已提交
8967

C
Cheerego 已提交
8968 8969 8970 8971 8972 8973 8974 8975 8976
返回:     连接好的输出变量。

返回类型:   变量(Variable)


**代码示例**

..  code-block:: python

R
RaindragonD 已提交
8977 8978 8979 8980
        import paddle.fluid as fluid
        x = fluid.layers.data(name='x', shape=[10], dtype='float32')
        y = fluid.layers.data(name='y', shape=[10], dtype='float32')
        out = fluid.layers.sequence_concat(input=[x, y])
C
Cheerego 已提交
8981

C
Cheerego 已提交
8982 8983 8984 8985 8986 8987 8988 8989 8990 8991 8992









.. _cn_api_fluid_layers_sequence_conv:

C
Cheerego 已提交
8993
sequence_conv
C
Cheerego 已提交
8994 8995 8996 8997 8998 8999 9000 9001 9002 9003 9004 9005 9006 9007 9008 9009 9010 9011 9012 9013
-------------------------------

.. py:function:: paddle.fluid.layers.sequence_conv(input, num_filters, filter_size=3, filter_stride=1, padding=None, bias_attr=None, param_attr=None, act=None, name=None)

该函数的输入参数中给出了滤波器和步长,通过利用输入以及滤波器和步长的常规配置来为sequence_conv创建操作符。

参数:
    - **input** (Variable) - (LoD张量)输入X是LoD张量,支持可变的时间量的长度输入序列。该LoDTensor的标记张量是一个维度为(T,N)的矩阵,其中T是mini-batch的总时间步数,N是input_hidden_size
    - **num_filters** (int) - 滤波器的数量
    - **filter_size** (int) - 滤波器大小(H和W)
    - **filter_stride** (int) - 滤波器的步长
    - **padding** (bool) - 若为真,添加填充
    - **bias_attr** (ParamAttr|bool|None) - sequence_conv偏离率参数属性。若设为False,输出单元则不加入偏离率。若设为None或ParamAttr的一个属性,sequence_conv将创建一个ParamAttr作为bias_attr。如果未设置bias_attr的初始化函数,则将bias初始化为0.默认:None
    - **param_attr** (ParamAttr|None) - 可学习参数/sequence_conv的权重参数属性。若设置为None或ParamAttr的一个属性,sequence_conv将创建ParamAttr作为param_attr。
    若未设置param_attr的初始化函数,则用Xavier初始化参数。默认:None

返回:sequence_conv的输出

返回类型:变量(Variable)

R
RaindragonD 已提交
9014
**代码示例**
C
Cheerego 已提交
9015

R
RaindragonD 已提交
9016 9017 9018 9019 9020
..  code-block:: python

    import paddle.fluid as fluid
    x = fluid.layers.data(name='x', shape=[10,10], append_batch_size=False, dtype='float32')
    x_conved = fluid.layers.sequence_conv(x,2)
C
Cheerego 已提交
9021 9022 9023 9024 9025 9026 9027 9028 9029 9030 9031 9032 9033 9034 9035 9036 9037 9038 9039 9040 9041 9042 9043 9044 9045 9046







.. _cn_api_fluid_layers_sequence_enumerate:

sequence_enumerate
-------------------------------

.. py:function:: paddle.fluid.layers.sequence_enumerate(input, win_size, pad_value=0, name=None)

为输入索引序列生成一个新序列,该序列枚举输入长度为 ``win_size`` 的所有子序列。 输入序列和枚举序列第一维上维度相同,第二维是 ``win_size`` ,在生成中如果需要,通过设置 ``pad_value`` 填充。

**例子:**

::

        输入:
            X.lod = [[0, 3, 5]]  X.data = [[1], [2], [3], [4], [5]]  X.dims = [5, 1]
        属性:
            win_size = 2  pad_value = 0
        输出:
            Out.lod = [[0, 3, 5]]  Out.data = [[1, 2], [2, 3], [3, 0], [4, 5], [5, 0]]  Out.dims = [5, 2]
C
Cheerego 已提交
9047 9048

参数:
C
Cheerego 已提交
9049 9050 9051
        - **input** (Variable)- 作为索引序列的输入变量。
        - **win_size** (int)- 枚举所有子序列的窗口大小。
        - **pad_value** (int)- 填充值,默认为0。
C
Cheerego 已提交
9052

C
Cheerego 已提交
9053 9054 9055
返回:      枚举序列变量是LoD张量(LoDTensor)。

返回类型:   Variable
C
Cheerego 已提交
9056

C
Cheerego 已提交
9057 9058 9059 9060
**代码示例**

..  code-block:: python

R
RaindragonD 已提交
9061
      x = fluid.layers.data(shape[-1, 1], dtype='int32', lod_level=1)
C
Cheerego 已提交
9062 9063 9064 9065 9066 9067 9068 9069 9070 9071 9072 9073
      out = fluid.layers.sequence_enumerate(input=x, win_size=3, pad_value=0)









.. _cn_api_fluid_layers_sequence_expand:

C
Cheerego 已提交
9074
sequence_expand
C
Cheerego 已提交
9075 9076 9077 9078 9079 9080 9081 9082 9083 9084 9085 9086
-------------------------------

.. py:function:: paddle.fluid.layers.sequence_expand(x, y, ref_level=-1, name=None)

序列扩张层(Sequence Expand Layer)

将根据指定 y 的 level lod 展开输入变量x,请注意 x 的 lod level 最多为1,而 x 的秩最少为2。当 x 的秩大于2时,它就被看作是一个二维张量。下面的例子将解释 sequence_expand 是如何工作的:

::


    * 例1
R
RaindragonD 已提交
9087 9088 9089 9090
      x is a LoDTensor:
    x.lod  = [[2,        2]]
    x.data = [[a], [b], [c], [d]]
    x.dims = [4, 1]
C
Cheerego 已提交
9091

R
RaindragonD 已提交
9092 9093 9094
      y is a LoDTensor:
    y.lod = [[2,    2],
             [3, 3, 1, 1]]
C
Cheerego 已提交
9095

R
RaindragonD 已提交
9096
      ref_level: 0
C
Cheerego 已提交
9097

R
RaindragonD 已提交
9098 9099 9100 9101
      then output is a 1-level LoDTensor:
    out.lod =  [[2,        2,        2,        2]]
    out.data = [[a], [b], [a], [b], [c], [d], [c], [d]]
    out.dims = [8, 1]
C
Cheerego 已提交
9102 9103

    * 例2
R
RaindragonD 已提交
9104 9105 9106
      x is a Tensor:
    x.data = [[a], [b], [c]]
    x.dims = [3, 1]
C
Cheerego 已提交
9107

R
RaindragonD 已提交
9108 9109
      y is a LoDTensor:
    y.lod = [[2, 0, 3]]
C
Cheerego 已提交
9110

R
RaindragonD 已提交
9111
      ref_level: -1
C
Cheerego 已提交
9112

R
RaindragonD 已提交
9113 9114 9115
      then output is a Tensor:
    out.data = [[a], [a], [c], [c], [c]]
    out.dims = [5, 1]
C
Cheerego 已提交
9116 9117 9118 9119 9120 9121 9122 9123 9124 9125 9126 9127 9128 9129 9130

参数:
    - **x** (Variable) - 输入变量,张量或LoDTensor
    - **y** (Variable) - 输入变量,为LoDTensor
    - **ref_level** (int) - x表示的y的Lod层。若设为-1,表示lod的最后一层
    - **name** (str|None) - 该层名称(可选)。如果设为空,则自动为该层命名

返回:扩展变量,LoDTensor

返回类型:变量(Variable)

**代码示例**:

.. code-block:: python

R
RaindragonD 已提交
9131
    import paddle.fluid.layers as layers
C
Cheerego 已提交
9132 9133 9134
    x = fluid.layers.data(name='x', shape=[10], dtype='float32')
    y = fluid.layers.data(name='y', shape=[10, 20],
                 dtype='float32', lod_level=1)
H
Hao Wang 已提交
9135
    out = fluid.layers.sequence_expand(x=x, y=y, ref_level=0)
C
Cheerego 已提交
9136 9137 9138 9139 9140 9141 9142 9143 9144 9145 9146









.. _cn_api_fluid_layers_sequence_expand_as:

C
Cheerego 已提交
9147
sequence_expand_as
C
Cheerego 已提交
9148 9149 9150 9151 9152 9153
-------------------------------

.. py:function:: paddle.fluid.layers.sequence_expand_as(x, y, name=None)

Sequence Expand As Layer

T
Tink_Y 已提交
9154
这一层将根据y的第0级lod扩展输入变量x。当前实现要求输入(Y)的lod层数必须为1,输入(X)的第一维应当和输入(Y)的第0层lod的大小相同,不考虑输入(X)的lod。
C
Cheerego 已提交
9155 9156 9157 9158 9159 9160 9161 9162 9163 9164 9165 9166 9167 9168 9169 9170 9171

以下示例解释sequence_expand如何工作:

::

    * 例1:
    给定一维LoDTensor input(X)
        X.data = [[a], [b], [c], [d]]
        X.dims = [4, 1]
    和 input(Y)
        Y.lod = [[0, 3, 6, 7, 8]]
    ref_level: 0
    得到1级 LoDTensor
        Out.lod =  [[0,            3,              6,  7,  8]]
        Out.data = [[a], [a], [a], [b], [b], [b], [c], [d]]
        Out.dims = [8, 1]

T
Tink_Y 已提交
9172 9173 9174 9175 9176
    *例2

    给定一个 input(X):
        X.data = [[a, b], [c, d], [e, f]]
        X.dims = [3, 2]
C
Cheerego 已提交
9177

T
Tink_Y 已提交
9178 9179 9180 9181 9182
    和 input(Y):
        Y.lod = [[0, 2, 3, 6]]
    ref_level: 0

    得到输出张量:
C
Cheerego 已提交
9183

T
Tink_Y 已提交
9184 9185 9186 9187 9188
        Out.lod =  [[0,             2,     3,                    6]]
        Out.data = [[a, b], [a, b] [c, d], [e, f], [e, f], [e, f]]
        Out.dims = [6, 2]


C
Cheerego 已提交
9189 9190 9191 9192 9193 9194 9195 9196 9197
参数:
    - **x** (Variable) - 输入变量,类型为Tensor或LoDTensor
    - **y** (Variable) - 输入变量,为LoDTensor
    - **name** (str|None) - 该层名称(可选)。如果设为空,则自动为该层命名

返回:扩展变量,LoDTensor

返回类型:变量(Variable)

R
RaindragonD 已提交
9198

C
Cheerego 已提交
9199 9200 9201 9202
**代码示例**:

.. code-block:: python

R
RaindragonD 已提交
9203 9204 9205
    x = fluid.layers.data(name='x', shape=[7, 1],
                     dtype='float32', lod_level=1)
    x_first_step = fluid.layers.sequence_first_step(input=x)
C
Cheerego 已提交
9206 9207 9208 9209 9210 9211 9212 9213 9214 9215 9216 9217 9218 9219 9220 9221 9222 9223 9224 9225 9226 9227 9228 9229 9230 9231 9232 9233 9234 9235 9236 9237 9238 9239 9240 9241 9242 9243 9244 9245 9246 9247 9248 9249 9250 9251 9252 9253 9254 9255 9256 9257 9258 9259 9260 9261 9262 9263 9264 9265 9266 9267 9268 9269 9270 9271 9272 9273 9274 9275 9276 9277 9278






.. _cn_api_fluid_layers_sequence_first_step:

sequence_first_step
-------------------------------

.. py:function:: paddle.fluid.layers.sequence_first_step(input)

该功能获取序列的第一步

::

    x是1-level LoDTensor:

      x.lod = [[2, 3, 2]]

      x.data = [1, 3, 2, 4, 6, 5, 1]

      x.dims = [7, 1]

    输出为张量:

      out.dim = [3, 1]
      with condition len(x.lod[-1]) == out.dims[0]
      out.data = [1, 2, 5], where 1=first(1,3), 2=first(2,4,6), 5=first(5,1)

参数:**input** (variable)-输入变量,为LoDTensor

返回:序列第一步,为张量

**代码示例**:

.. code-block:: python

    x = fluid.layers.data(name='x', shape=[7, 1],
                 dtype='float32', lod_level=1)
    x_first_step = fluid.layers.sequence_first_step(input=x)









.. _cn_api_fluid_layers_sequence_last_step:

sequence_last_step
-------------------------------

.. py:function:: paddle.fluid.layers.sequence_last_step(input)

该API可以获取序列的最后一步

::

    x是level-1的LoDTensor:

        x.lod = [[2, 3, 2]]

        x.data = [1, 3, 2, 4, 6, 5, 1]

        x.dims = [7, 1]

    输出为Tensor:

        out.dim = [3, 1]
C
Cheerego 已提交
9279

C
Cheerego 已提交
9280
        且 len(x.lod[-1]) == out.dims[0]
C
Cheerego 已提交
9281

T
tink2123 已提交
9282
        out.data = [3, 6, 1], where 3=last(1,3), 6=last(2,4,6), 1=last(5,1)
C
Cheerego 已提交
9283 9284 9285 9286 9287 9288 9289 9290 9291 9292 9293 9294 9295 9296 9297 9298 9299 9300 9301 9302 9303 9304 9305 9306 9307 9308

参数:**input** (variable)-输入变量,为LoDTensor

返回:序列的最后一步,为张量

**代码示例**:

.. code-block:: python

    x = fluid.layers.data(name='x', shape=[7, 1],
                 dtype='float32', lod_level=1)
    x_last_step = fluid.layers.sequence_last_step(input=x)









.. _cn_api_fluid_layers_sequence_mask:

sequence_mask
-------------------------------

T
Tink_Y 已提交
9309 9310 9311
.. py:function::  paddle.fluid.layers.sequence_mask(x, maxlen=None, dtype='int64', name=None)

该层根据输入 ``x`` 和 ``maxlen`` 输出一个掩码,数据类型为dtype。
C
Cheerego 已提交
9312

T
Tink_Y 已提交
9313
假设x是一个形状为[d_1, d_2,…, d_n]的张量。, y是一个形为[d_1, d_2,… ,d_n, maxlen]的掩码,其中:
C
Cheerego 已提交
9314 9315 9316

.. math::

R
RaindragonD 已提交
9317
  y(i_1, i_2,..., i_n, j) = (j < x(i_1, i_2,..., i_n))
C
Cheerego 已提交
9318 9319

参数:
R
RaindragonD 已提交
9320 9321 9322 9323
  - **x** (Variable) - sequence_mask层的输入张量,其元素是小于maxlen的整数。
  - **maxlen** (int|None) - 序列的最大长度。如果maxlen为空,则用max(x)替换。
  - **dtype** (np.dtype|core.VarDesc.VarType|str) - 输出的数据类型
  - **name** (str|None) - 此层的名称(可选)。如果没有设置,该层将被自动命名。
C
Cheerego 已提交
9324 9325 9326 9327 9328

返回: sequence mask 的输出

返回类型: Variable

R
RaindragonD 已提交
9329 9330 9331
**代码示例**:

.. code-block:: python
C
Cheerego 已提交
9332

R
RaindragonD 已提交
9333 9334 9335 9336
    import paddle.fluid.layers as layers
    
    x = fluid.layers.data(name='x', shape=[10], dtype='float32', lod_level=1)
    mask = layers.sequence_mask(x=x)
C
Cheerego 已提交
9337 9338 9339 9340 9341 9342 9343 9344 9345 9346 9347 9348 9349 9350 9351 9352 9353 9354 9355 9356 9357 9358 9359 9360 9361 9362 9363 9364










.. _cn_api_fluid_layers_sequence_pad:

sequence_pad
-------------------------------

.. py:function:: paddle.fluid.layers.sequence_pad(x,pad_value,maxlen=None,name=None)

序列填充操作符(Sequence Pad Operator)

这个操作符将同一batch中的序列填充到一个一致的长度。长度由属性padded_length指定。填充的新元素的值具体由输入 ``PadValue`` 指定,并会添加到每一个序列的末尾,使得他们最终的长度保持一致。

以下的例子更清晰地解释此操作符的工作原理:

::

    例1:

    给定 1-level LoDTensor
C
Cheerego 已提交
9365

C
Cheerego 已提交
9366 9367 9368 9369 9370
    input(X):
        X.lod = [[0,2,5]]
        X.data = [a,b,c,d,e]
    input(PadValue):
        PadValue.data = [0]
C
Cheerego 已提交
9371

C
Cheerego 已提交
9372 9373 9374 9375 9376 9377 9378 9379 9380
    'padded_length'=4

    得到LoDTensor:
        Out.data = [[a,b,0,0],[c,d,e,0]]
        Length.data = [[2],[3]]

::

    例2:
C
Cheerego 已提交
9381

C
Cheerego 已提交
9382
    给定 1-level LoDTensor
C
Cheerego 已提交
9383

C
Cheerego 已提交
9384 9385 9386 9387 9388
    input(X):
        X.lod = [[0,2,5]]
        X.data = [[a1,a2],[b1,b2],[c1,c2],[d1,d2],[e1,e2]]
    input(PadValue):
        PadValue.data = [0]
C
Cheerego 已提交
9389

C
Cheerego 已提交
9390
    'padded_length' = -1,表示用最长输入序列的长度(此例中为3)
C
Cheerego 已提交
9391

C
Cheerego 已提交
9392 9393 9394 9395 9396 9397 9398 9399
    得到LoDTensor:
        Out.data = [[[a1,a2],[b1,b2],[0,0]],[[c1,c2],[d1,d2],[e1,e2]]]
        Length.data = [[2],[3]]


::

    例3:
C
Cheerego 已提交
9400

C
Cheerego 已提交
9401
    给定 1-level LoDTensor
C
Cheerego 已提交
9402

C
Cheerego 已提交
9403 9404 9405 9406 9407
    input(X):
        X.lod = [[0,2,5]]
        X.data = [[a1,a2],[b1,b2],[c1,c2],[d1,d2],[e1,e2]]
    input(PadValue):
        PadValue.data = [p1,p2]
C
Cheerego 已提交
9408

C
Cheerego 已提交
9409
    'padded_length' = -1,表示用最长输入序列的长度(此例中为3)
C
Cheerego 已提交
9410

C
Cheerego 已提交
9411 9412 9413 9414 9415 9416 9417 9418 9419 9420 9421 9422 9423 9424 9425 9426 9427 9428 9429 9430 9431 9432 9433 9434 9435 9436 9437 9438 9439 9440 9441 9442 9443 9444 9445 9446 9447
    得到LoDTensor:
        Out.data = [[[a1,a2],[b1,b2],[p1,p2]],[[c1,c2],[d1,d2],[e1,e2]]]
        Length.data = [[2],[3]]


参数:
    - **x** (Vairable) - 输入变量,应包含lod信息
    - **pad_value** (Variable) - 变量,存有放入填充步的值。可以是标量或tensor,维度和序列的时间步长相等。如果是标量,则自动广播到时间步长的维度
    - **maxlen** (int,默认None) - 填充序列的长度。可以为空或者任意正整数。当为空时,以序列中最长序列的长度为准,其他所有序列填充至该长度。当是某个特定的正整数,最大长度必须大于最长初始序列的长度
    - **name** (str|None) – 该层的命名(可选项)。 如果为 None, 则自动命名

返回:填充序列批(batch)和填充前的初始长度。所有输出序列的长度相等

返回类型:变量(Variable)

**代码示例**:

.. code-block:: python

    import numpy

    x = fluid.layers.data(name='y', shape=[10, 5],
                     dtype='float32', lod_level=1)
    pad_value = fluid.layers.assign(
        input=numpy.array([0.0], dtype=numpy.float32))
    out = fluid.layers.sequence_pad(x=x, pad_value=pad_value)









.. _cn_api_fluid_layers_sequence_pool:

C
Cheerego 已提交
9448
sequence_pool
C
Cheerego 已提交
9449 9450
-------------------------------

R
RaindragonD 已提交
9451
.. py:function:: paddle.fluid.layers.sequence_pool(input, pool_type, is_test=False, pad_value=0.0)
C
Cheerego 已提交
9452 9453 9454 9455 9456 9457 9458 9459 9460 9461 9462 9463 9464

该函数为序列的池化添加操作符。将每个实例的所有时间步数特征池化,并用参数中提到的pool_type将特征运用到输入到首部。

支持四种pool_type:

- **average**: :math:`Out[i] = \frac{\sum_{i}X_{i}}{N}`
- **sum**: :math:`Out[i] = \sum _{j}X_{ij}`
- **sqrt**: :math:`Out[i] = \frac{ \sum _{j}X_{ij}}{\sqrt{len(\sqrt{X_{i}})}}`
- **max**: :math:`Out[i] = max(X_{i})`

::


R
RaindragonD 已提交
9465 9466
    x是一级LoDTensor且**pad_value** = 0.0:
        x.lod = [[2, 3, 2, 0]]
C
Cheerego 已提交
9467 9468 9469
        x.data = [1, 3, 2, 4, 6, 5, 1]
        x.dims = [7, 1]
    输出为张量(Tensor):
R
RaindragonD 已提交
9470
        out.dim = [4, 1]
C
Cheerego 已提交
9471 9472
        with condition len(x.lod[-1]) == out.dims[0]
    对于不同的pool_type:
R
RaindragonD 已提交
9473 9474 9475
        average: out.data = [2, 4, 3, 0.0], where 2=(1+3)/2, 4=(2+4+6)/3, 3=(5+1)/2
        sum    : out.data = [4, 12, 6, 0.0], where 4=1+3, 12=2+4+6, 6=5+1
        sqrt   : out.data = [2.82, 6.93, 4.24, 0.0], where 2.82=(1+3)/sqrt(2),
C
Cheerego 已提交
9476
             6.93=(2+4+6)/sqrt(3), 4.24=(5+1)/sqrt(2)
R
RaindragonD 已提交
9477 9478 9479 9480 9481
        max    : out.data = [3, 6, 5, 0.0], where 3=max(1,3), 6=max(2,4,6), 5=max(5,1)
        last   : out.data = [3, 6, 1, 0.0], where 3=last(1,3), 6=last(2,4,6), 1=last(5,1)
        first  : out.data = [1, 2, 5, 0.0], where 1=first(1,3), 2=first(2,4,6), 5=first(5,1)
        
      且以上所有均满足0.0 = **pad_value**
C
Cheerego 已提交
9482 9483 9484 9485

参数:
    - **input** (variable) - 输入变量,为LoDTensor
    - **pool_type** (string) - 池化类型。支持average,sum,sqrt和max
R
RaindragonD 已提交
9486 9487
    - **is_test** (bool, 默认为 False) - 用于区分训练模式和测试评分模式。默认为False。
    - **pad_value** (float) - 用于填充空输入序列的池化结果。
C
Cheerego 已提交
9488 9489 9490 9491 9492 9493 9494

返回:sequence pooling 变量,类型为张量(Tensor)

**代码示例**:

.. code-block:: python

R
RaindragonD 已提交
9495 9496
    import paddle.fluid as fluid

C
Cheerego 已提交
9497 9498 9499 9500 9501 9502 9503 9504 9505 9506 9507 9508 9509 9510 9511 9512 9513 9514 9515 9516 9517 9518
    x = fluid.layers.data(name='x', shape=[7, 1],
                 dtype='float32', lod_level=1)
    avg_x = fluid.layers.sequence_pool(input=x, pool_type='average')
    sum_x = fluid.layers.sequence_pool(input=x, pool_type='sum')
    sqrt_x = fluid.layers.sequence_pool(input=x, pool_type='sqrt')
    max_x = fluid.layers.sequence_pool(input=x, pool_type='max')
    last_x = fluid.layers.sequence_pool(input=x, pool_type='last')
    first_x = fluid.layers.sequence_pool(input=x, pool_type='first')









.. _cn_api_fluid_layers_sequence_reshape:

sequence_reshape
-------------------------------

C
Cheerego 已提交
9519
.. py:function:: paddle.fluid.layers.sequence_reshape(input, new_dim)
C
Cheerego 已提交
9520 9521 9522 9523 9524 9525 9526 9527 9528 9529 9530 9531 9532 9533 9534 9535 9536 9537 9538 9539 9540 9541 9542 9543 9544 9545 9546 9547 9548 9549 9550 9551 9552 9553 9554

Sequence Reshape Layer
该层重排输入序列。用户设置新维度。每一个序列的的长度通过原始长度、原始维度和新的维度计算得出。以下实例帮助解释该层的功能

.. code-block:: python

    x是一个LoDTensor:
        x.lod  = [[0, 2, 6]]
        x.data = [[1,  2], [3,  4],
                [5,  6], [7,  8],
                [9, 10], [11, 12]]
        x.dims = [6, 2]
    设置 new_dim = 4
    输出为LoDTensor:
        out.lod  = [[0, 1, 3]]

        out.data = [[1,  2,  3,  4],
                    [5,  6,  7,  8],
                    [9, 10, 11, 12]]
        out.dims = [3, 4]

目前仅提供1-level LoDTensor,请确保(原长度*原维数)可以除以新的维数,每个序列没有余数。

参数:
    - **input** (Variable)-一个2-D LoDTensor,模型为[N,M],维度为M
    - **new_dim** (int)-新维度,输入LoDTensor重新塑造后的新维度

返回:根据新维度重新塑造的LoDTensor

返回类型:变量(Variable)

**代码示例**:

.. code-block:: python

R
RaindragonD 已提交
9555 9556 9557
    import paddle.fluid as fluid
    x = fluid.layers.data(name='x', shape=[2, 6], append_batch_size=False, dtype='float32', lod_level=1)
    x_reshaped = fluid.layers.sequence_reshape(input=x, new_dim=4)
C
Cheerego 已提交
9558 9559 9560 9561 9562 9563 9564 9565 9566 9567 9568 9569 9570 9571 9572 9573 9574 9575 9576 9577 9578 9579 9580 9581 9582 9583 9584 9585 9586 9587 9588 9589









.. _cn_api_fluid_layers_sequence_reverse:

sequence_reverse
-------------------------------

.. py:function:: paddle.fluid.layers.sequence_reverse(x, name=None)


在第0维上将输入 ``x`` 的各序列倒序。

::

    假设 ``x`` 是一个形为 (5,4) 的LoDTensor, lod信息为 [[0, 2, 5]],其中,


    X.data() = [ [1, 2, 3, 4], [5, 6, 7, 8], # 索引为0,长度为2的序列

                 [9, 10, 11, 12], [13, 14, 15, 16], [17, 18, 19, 20] # 索引为1长度为3的序列

输出 ``Y`` 与 ``x`` 具有同样的维数和LoD信息。 于是有:

::

C
Cheerego 已提交
9590
    Y.data() = [ [5, 6, 7, 8], [1, 2, 3, 4], # 索引为0,长度为2的逆序列
C
Cheerego 已提交
9591 9592 9593 9594 9595 9596 9597 9598 9599 9600 9601 9602 9603 9604
                 [17, 18, 19, 20], [13, 14, 15, 16], [9, 10, 11, 12] # 索引为1,长度为3的逆序列

该运算在建立反dynamic RNN 网络中十分有用。

目前仅支持LoD层次(LoD level)为1的张量倒序。

参数:
  - **x** (Variable) – 输入张量
  - **name** (basestring|None) – 输出变量的命名

返回:输出LoD张量

返回类型:Variable

R
RaindragonD 已提交
9605
**代码示例**:
C
Cheerego 已提交
9606

R
RaindragonD 已提交
9607
.. code-block:: python
C
Cheerego 已提交
9608

R
RaindragonD 已提交
9609 9610 9611
    import paddle.fluid as fluid
    x = fluid.layers.data(name='x', shape=[2, 6], dtype='float32')
    x_reversed = fluid.layers.sequence_reverse(x)
C
Cheerego 已提交
9612 9613 9614 9615 9616 9617 9618 9619 9620 9621 9622 9623 9624 9625 9626 9627 9628 9629 9630







.. _cn_api_fluid_layers_sequence_scatter:

sequence_scatter
-------------------------------

.. py:function:: paddle.fluid.layers.sequence_scatter(input, index, updates, name=None)

序列散射层

这个operator将更新张量X,它使用Ids的LoD信息来选择要更新的行,并使用Ids中的值作为列来更新X的每一行。

**样例**:
C
Cheerego 已提交
9631

C
Cheerego 已提交
9632 9633 9634
::

    输入:
H
Hao Wang 已提交
9635

C
Cheerego 已提交
9636
    input.data = [[1.0, 1.0, 1.0, 1.0, 1.0, 1.0],
H
Hao Wang 已提交
9637 9638
                  [1.0, 1.0, 1.0, 1.0, 1.0, 1.0],
                  [1.0, 1.0, 1.0, 1.0, 1.0, 1.0]]
C
Cheerego 已提交
9639 9640
    input.dims = [3, 6]

H
Hao Wang 已提交
9641 9642
    index.data = [[0], [1], [2], [5], [4], [3], [2], [1], [3], [2], [5], [4]]
    index.lod =  [[0,        3,                       8,                 12]]
C
Cheerego 已提交
9643

H
Hao Wang 已提交
9644 9645
    updates.data = [[0.3], [0.3], [0.4], [0.1], [0.2], [0.3], [0.4], [0.0], [0.2], [0.3], [0.1], [0.4]]
    updates.lod =  [[  0,            3,                                 8,                         12]]
C
Cheerego 已提交
9646 9647

    输出:
H
Hao Wang 已提交
9648

C
Cheerego 已提交
9649
    out.data = [[1.3, 1.3, 1.4, 1.0, 1.0, 1.0],
H
Hao Wang 已提交
9650 9651
                [1.0, 1.0, 1.4, 1.3, 1.2, 1.1],
                [1.0, 1.0, 1.3, 1.2, 1.4, 1.1]]
C
Cheerego 已提交
9652 9653 9654
    out.dims = X.dims = [3, 6]


H
Hao Wang 已提交
9655

C
Cheerego 已提交
9656 9657
参数:
      - **input** (Variable) - input 秩(rank) >= 1。
T
Tink_Y 已提交
9658 9659
      - **index** (Variable) - LoD Tensor, index 是 sequence scatter op 的输入索引,该函数的input将依据index进行更新。 秩(rank)=1。由于用于索引dtype应该是int32或int64。
      - **updates** (Variable) - 一个 LoD Tensor , update 的值将被 sactter 到输入x。update 的 LoD信息必须与index一致。
C
Cheerego 已提交
9660 9661 9662 9663
      - **name** (str|None) - 输出变量名。默认:None。

返回: 输出张量维度应该和输入张量相同

H
Hao Wang 已提交
9664
返回类型:Variable
C
Cheerego 已提交
9665 9666 9667 9668 9669 9670


**代码示例**:

..  code-block:: python

R
RaindragonD 已提交
9671 9672 9673 9674 9675 9676
    import paddle.fluid.layers as layers
     
    input = layers.data( name="x", shape=[3, 6], append_batch_size=False, dtype='float32' )
    index = layers.data( name='index', shape=[1], dtype='int32')
    updates = layers.data( name='updates', shape=[1], dtype='float32')
    output = fluid.layers.sequence_scatter(input, index, updates)
C
Cheerego 已提交
9677 9678 9679 9680 9681 9682 9683 9684 9685 9686 9687 9688 9689 9690 9691 9692 9693 9694 9695 9696 9697 9698 9699 9700 9701 9702 9703 9704 9705 9706 9707 9708 9709 9710 9711 9712 9713 9714










.. _cn_api_fluid_layers_sequence_slice:

sequence_slice
-------------------------------

.. py:function:: paddle.fluid.layers.sequence_slice(input, offset, length, name=None)

**实现Sequence Slice(序列切片)运算**

该层从给定序列中截取子序列。截取依据为所给的开始 ``offset`` (偏移量) 和子序列长 ``length`` 。

仅支持序列数据,LoD level(LoD层次为1)
::
    输入变量:

        input.data = [[a1, a2], [b1, b2], [c1, c2], [d1, d2], [e1, e2]],
        input.lod = [[3, 2]],
        input.dims = (5, 2),

    以及 offset.data = [[0], [1]] and length.data = [[2], [1]],

    则输出变量为:

        out.data = [[a1, a2], [b1, b2], [e1, e2]],
        out.lod = [[2, 1]],
        out.dims = (3, 2).

.. note::
C
Cheerego 已提交
9715
   ``input`` , ``offset`` , ``length`` 的第一维大小应相同。
C
Cheerego 已提交
9716 9717 9718 9719 9720 9721 9722 9723 9724 9725 9726 9727 9728 9729 9730 9731
   ``offset`` 从0开始。

参数:
  - **input** (Variable) – 输入变量 ,承载着完整的序列
  - **offset** (Variable) – 对每个序列切片的起始索引
  - **length** (Variable) – 每个子序列的长度
  - **name** (str|None) – 该层的命名,可选项。 如果None, 则自动命名该层

返回:输出目标子序列

返回类型:Variable

**代码示例**

..  code-block:: python

R
RaindragonD 已提交
9732 9733 9734 9735 9736 9737 9738
  import numpy as np
  seqs = fluid.layers.data(name='x', shape=[10, 5],
       dtype='float32', lod_level=1)
  offset = fluid.layers.assign(input=np.array([[0, 1]]).astype("int32"))
  length = fluid.layers.assign(input=np.array([[2, 1]]).astype("int32"))
  subseqs = fluid.layers.sequence_slice(input=seqs, offset=offset,
                length=length)
C
Cheerego 已提交
9739 9740 9741 9742 9743 9744 9745 9746 9747 9748 9749 9750 9751 9752 9753 9754 9755 9756 9757 9758 9759 9760 9761 9762 9763 9764 9765 9766 9767 9768 9769 9770 9771 9772 9773 9774 9775 9776 9777 9778 9779 9780 9781 9782 9783 9784 9785 9786 9787 9788 9789 9790 9791 9792 9793 9794 9795 9796 9797 9798 9799 9800 9801 9802 9803 9804 9805 9806 9807 9808 9809 9810 9811 9812 9813 9814 9815 9816 9817 9818 9819 9820 9821 9822 9823 9824 9825 9826 9827 9828 9829 9830 9831 9832 9833 9834 9835 9836 9837 9838 9839 9840










.. _cn_api_fluid_layers_sequence_softmax:

sequence_softmax
-------------------------------

.. py:function:: paddle.fluid.layers.sequence_softmax(input, use_cudnn=False, name=None)

该函数计算每一个序列所有时间步中的softmax激活函数。每个时间步的维度应为1。

输入张量的形状可为 :math:`[N,1]` 或者 :math:`[N]` , :math:`N` 是所有序列长度之和。

对mini-batch的第i序列:

.. math::

    Out\left ( X[lod[i]:lod[i+1]],: \right ) = \frac{exp(X[lod[i]:lod[i+1],:])}{\sum (exp(X[lod[i]:lod[i+1],:]))}

例如,对有3个序列(可变长度)的mini-batch,每个包含2,3,2时间步,其lod为[0,2,5,7],则在 :math:`X[0:2,:],X[2:5,:],X[5:7,:]` 中进行softmax运算,并且 :math:`N` 的结果为7.

参数:
    - **input** (Variable) - 输入变量,为LoDTensor
    - **use_cudnn** (bool) - 是否用cudnn核,仅当下载cudnn库才有效。默认:False
    - **name** (str|None) - 该层名称(可选)。若设为None,则自动为该层命名。默认:None

返回:sequence_softmax的输出

返回类型:变量(Variable)

**代码示例**:

.. code-block:: python

    x = fluid.layers.data(name='x', shape=[7, 1],
                 dtype='float32', lod_level=1)
    x_sequence_softmax = fluid.layers.sequence_softmax(input=x)










.. _cn_api_fluid_layers_sequence_unpad:

sequence_unpad
-------------------------------

.. py:function:: paddle.fluid.layers.sequence_unpad(x, length, name=None)

**实现Sequence Unpad(去除序列填充值)运算**

该层从给定序列中删除padding(填充值),并且将该序列转变为未填充时的原序列作为该层的输出,并且实际长度可以在输出的LoD信息中取得。

::

    示例:

    给定输入变量 ``x`` :
        x.data = [[ 1.0,  2.0,  3.0,  4.0,  5.0],
                  [ 6.0,  7.0,  8.0,  9.0, 10.0],
                  [11.0, 12.0, 13.0, 14.0, 15.0]],

    其中包含 3 个被填充到长度为5的序列,实际长度由输入变量 ``length`` 指明:

        length.data = [[2], [3], [4]],

    则去填充(unpad)后的输出变量为:

        out.data = [[1.0, 2.0, 6.0, 7.0, 8.0, 11.0, 12.0, 13.0, 14.0]]
        out.lod = [[2, 3, 4]]



参数:
  - **x** (Variable) – 输入变量,承载着多个填充后等长的序列
  - **length** (Variable) – 变量,指明去填充后各个序列所具有的实际长度
  - **name** (str|None) – 可选项,该层名称。 若为 None, 将自动命名该层

返回:变量,承载着去填充处理后的序列

返回类型:Variable

**代码示例**

..  code-block:: python

    x = fluid.layers.data(name='x', shape=[10, 5], dtype='float32')
    len = fluid.layers.data(name='length', shape=[1], dtype='int64')
    out = fluid.layers.sequence_unpad(x=x, length=len)
C
Cheerego 已提交
9841

C
Cheerego 已提交
9842 9843 9844 9845 9846 9847 9848 9849 9850 9851 9852 9853 9854 9855 9856 9857 9858 9859











.. _cn_api_fluid_layers_shape:

shape
-------------------------------

.. py:function:: paddle.fluid.layers.shape(input)

9860
shape层。
C
Cheerego 已提交
9861

9862
获得输入变量的形状。
C
Cheerego 已提交
9863 9864

参数:
9865
        - **input** (Variable)-  输入的变量
C
Cheerego 已提交
9866

9867
返回: (Tensor),输入变量的形状
C
Cheerego 已提交
9868

9869
返回类型:    Variable
C
Cheerego 已提交
9870

T
Tink_Y 已提交
9871 9872 9873 9874
**代码示例:**

.. code-block:: python

R
RaindragonD 已提交
9875
    import paddle.fluid as fluid
H
Hao Wang 已提交
9876
    input = fluid.layers.data(
T
Tink_Y 已提交
9877
        name="input", shape=[3, 100, 100], dtype="float32")
C
Cheerego 已提交
9878
    out = fluid.layers.shape(input)
C
Cheerego 已提交
9879 9880 9881 9882 9883





H
Hao Wang 已提交
9884 9885 9886 9887 9888 9889 9890 9891 9892
.. _cn_api_fluid_layers_shuffle_channel:

shuffle_channel
-------------------------------

.. py:function:: paddle.fluid.layers.shuffle_channel(x, group, name=None)

**Shuffle Channel 运算(通道重排运算)**

9893
该算子将输入 ``x`` 的通道混洗重排。 它将每个组中的输入通道分成 ``group`` 个子组,并通过逐个从每个子组中选择元素来获得新的顺序。
H
Hao Wang 已提交
9894 9895 9896 9897 9898 9899 9900 9901 9902 9903 9904 9905 9906 9907 9908 9909 9910 9911 9912 9913 9914 9915 9916 9917 9918 9919 9920 9921 9922 9923 9924 9925 9926 9927 9928 9929 9930 9931 9932 9933 9934 9935 9936

请参阅 https://arxiv.org/pdf/1707.01083.pdf

::

    输入一个形为 (N, C, H, W) 的4-D tensor:

    input.shape = (1, 4, 2, 2)
    input.data =[[[[0.1, 0.2],
                   [0.2, 0.3]],

                  [[0.3, 0.4],
                   [0.4, 0.5]],

                  [[0.5, 0.6],
                   [0.6, 0.7]],

                  [[0.7, 0.8],
                   [0.8, 0.9]]]]

    指定组数 group: 2
    可得到与输入同形的输出 4-D tensor:

    out.shape = (1, 4, 2, 2)
    out.data = [[[[0.1, 0.2],
                  [0.2, 0.3]],

                 [[0.5, 0.6],
                  [0.6, 0.7]],

                 [[0.3, 0.4],
                  [0.4, 0.5]],

                 [[0.7, 0.8],
                  [0.8, 0.9]]]]

参数:
  - **x** (Variable) – 输入张量变量。 应是形状为[N,C,H,W]的4-D张量
  - **group** (int) – 表示子组的数目,它应该整除通道数。

返回:通道混洗结果是一个张量变量,其形状和类型与输入相同。

返回类型:输出(Variable)
C
Cheerego 已提交
9937 9938


H
Hao Wang 已提交
9939 9940 9941 9942 9943
**代码示例:**

.. code-block:: python

    input = fluid.layers.data(name='input', shape=[4,2,2], dtype='float32')
C
Cheerego 已提交
9944
    out = fluid.layers.shuffle_channel(x=input, group=2)
H
Hao Wang 已提交
9945 9946 9947 9948 9949 9950






C
Cheerego 已提交
9951 9952 9953 9954 9955 9956 9957 9958



.. _cn_api_fluid_layers_sigmoid_cross_entropy_with_logits:

sigmoid_cross_entropy_with_logits
-------------------------------

H
Hao Wang 已提交
9959
.. py:function:: paddle.fluid.layers.sigmoid_cross_entropy_with_logits(x, label, ignore_index=-100, name=None, normalize=False)
C
Cheerego 已提交
9960

H
Hao Wang 已提交
9961
在类别不相互独立的分类任务中,该函数可以衡量按元素的可能性误差。可以这么认为,为单一数据点预测标签,它们之间不是完全互斥的关系。例如,一篇新闻文章可以同时关于政治,科技,体育或者同时不包含这些内容。
C
Cheerego 已提交
9962 9963 9964 9965 9966

逻辑loss可通过下式计算:

.. math::
    loss = -Labels * log(sigma(X)) - (1 - Labels) * log(1 - sigma(X))
C
Cheerego 已提交
9967

C
Cheerego 已提交
9968 9969 9970 9971 9972 9973 9974 9975 9976 9977 9978 9979 9980 9981 9982
已知:

.. math::
    sigma(X) = \frac{1}{1 + exp(-X)}

代入最开始的式子,

.. math::
    loss = X - X * Labels + log(1 + exp(-X))

为了计算稳定性,防止 :math:`exp(-X)` 溢出,当 :math:`X<0` 时,loss将采用以下公式计算:

.. math::
    loss = max(X, 0) - X * Labels + log(1 + exp(-|X|))

H
Hao Wang 已提交
9983
输入 ``X`` 和 ``label`` 都可以携带LoD信息。然而输出仅采用输入 ``X`` 的LoD。
C
Cheerego 已提交
9984 9985 9986 9987



参数:
C
Cheerego 已提交
9988
  - **x** (Variable) - (Tensor, 默认 Tensor<float>),形为 N x D 的二维张量,N为batch大小,D为类别数目。该输入是一个由先前运算得出的logit组成的张量。logit是未标准化(unscaled)的log概率, 公式为 :math:`log(\frac{p}{1-p})`
C
Cheerego 已提交
9989
  - **label** (Variable) -  (Tensor, 默认 Tensor<float>) 具有和X相同类型,相同形状的二维张量。该输入张量代表了每个logit的可能标签
H
Hao Wang 已提交
9990
  - **ignore_index** (int) - (int,默认kIgnoreIndex)指定被忽略的目标值,它不会影响输入梯度
C
Cheerego 已提交
9991
  - **name** (basestring|None) - 输出的名称
H
Hao Wang 已提交
9992
  - **normalize** (bool) - 如果为true,则将输出除以除去ignore_index对应目标外的目标数
C
Cheerego 已提交
9993

R
RaindragonD 已提交
9994
返回: (Tensor, 默认Tensor<float>), 形为 N x D 的二维张量,其值代表了按元素的逻辑loss
C
Cheerego 已提交
9995

R
RaindragonD 已提交
9996
返回类型:Variable
C
Cheerego 已提交
9997 9998 9999



H
Hao Wang 已提交
10000 10001 10002
**代码示例**

..  code-block:: python
C
Cheerego 已提交
10003

H
Hao Wang 已提交
10004 10005 10006 10007 10008 10009 10010 10011 10012 10013
    input = fluid.layers.data(
        name='data', shape=[10], dtype='float32')
    label = fluid.layers.data(
        name='data', shape=[10], dtype='float32')
    loss = fluid.layers.sigmoid_cross_entropy_with_logits(
        x=input,
        label=label,
        ignore_index=-1,
        normalize=True) # or False
    # loss = fluid.layers.reduce_sum(loss) # loss之和
C
Cheerego 已提交
10014 10015 10016 10017 10018 10019 10020







R
RaindragonD 已提交
10021 10022 10023 10024 10025 10026 10027 10028 10029 10030 10031 10032 10033 10034 10035 10036 10037 10038 10039 10040 10041 10042 10043 10044 10045 10046
.. _cn_api_fluid_layers_sign:

sign
-------------------------------

.. py:function:: paddle.fluid.layers.sign(x)

此函数返回x中每个元素的正负号:1代表正,-1代表负,0代表零。

参数:
    - **x** (Variable|numpy.ndarray) – 输入张量。

返回:输出正负号张量,和x有着相同的形状和数据类型。

返回类型:Variable

**代码示例**

..  code-block:: python

    # [1, 0, -1]
    data = fluid.layers.sign(np.array([3, 0, -2]))




C
Cheerego 已提交
10047 10048 10049 10050 10051 10052 10053 10054 10055 10056 10057 10058 10059 10060 10061 10062 10063 10064 10065 10066 10067

.. _cn_api_fluid_layers_similarity_focus:

similarity_focus
-------------------------------

.. py:function:: paddle.fluid.layers.similarity_focus(input, axis, indexes, name=None)

**实现SimilarityFocus(相似度聚焦)运算**

通过以下三种方式,该层生成一个和输入 ``input`` 同形的mask(掩码):

1. 根据 ``axis`` 和 ``indexes`` 提取一个三维张量,第一维为batch大小。
   例如,如果 ``axis=1, indexes=[a]`` , 将得到矩阵 T=X[:, a, :, :] 。
   该例中,如果输入X的形为 (BatchSize, A, B, C) ,则输出张量T的形为 (BatchSize, B, C) 。
2. 对于每一个索引,在输出T中找到最大值。所以同一行、同一列最多只有一个数字,这意味着如果在第i行,第j列中找到最大值,那么在相应行、列中的其他数值都将被忽略。然后再在剩余的数值中找到下一个最大值。显然,将会产生 min(B,C)个数字,并把三维相似聚焦掩码张量相应位置的元素置为1,其余则置为0。对每个索引按元素进行or运算。
3. 将这个三维相似度聚焦mask调整、适配于输入 ``input`` 的形状

请参照 `Similarity Focus Layer <http://www.aclweb.org/anthology/N16-1108>`_ 。

::
H
Hao Wang 已提交
10068

C
Cheerego 已提交
10069 10070 10071 10072
    例如 :

    给定四维张量 x 形为 (BatchSize, C, A, B), 其中C 为通道Channel数目,
    特征图(feature map)的形为(A,B):
C
Cheerego 已提交
10073

C
Cheerego 已提交
10074 10075 10076 10077 10078 10079 10080 10081 10082 10083 10084 10085 10086 10087 10088 10089 10090 10091 10092 10093 10094 10095 10096 10097 10098 10099 10100 10101 10102 10103 10104 10105 10106 10107 10108 10109 10110 10111 10112 10113 10114 10115 10116 10117 10118 10119 10120 10121 10122 10123 10124 10125 10126 10127 10128 10129 10130 10131 10132
        x.shape = (2, 3, 2, 2)
        x.data = [[[[0.8, 0.1],
                    [0.4, 0.5]],

                   [[0.9, 0.7],
                    [0.9, 0.9]],

                   [[0.8, 0.9],
                    [0.1, 0.2]]],


                  [[[0.2, 0.5],
                    [0.3, 0.4]],

                   [[0.9, 0.7],
                    [0.8, 0.4]],

                   [[0.0, 0.2],
                    [0.4, 0.7]]]]

    给定轴: 1 (即channel轴)
    给定索引: [0]

    于是我们得到一个与输入同形的四维输出张量:
        out.shape = (2, 3, 2, 2)
        out.data = [[[[1.0, 0.0],
                      [0.0, 1.0]],

                     [[1.0, 0.0],
                      [0.0, 1.0]],

                     [[1.0, 0.0],
                      [0.0, 1.0]]],

                    [[[0.0, 1.0],
                      [1.0, 0.0]],

                     [[0.0, 1.0],
                      [1.0, 0.0]],

                     [[0.0, 1.0],
                      [1.0, 0.0]]]]



参数:
  - **input** (Variable) – 输入张量(默认类型为float)。应为一个四维张量,形为[BatchSize, A, B, C]
  - **axis** (int) – 指明要选择的轴。 可能取值为 1, 2 或 3.
  - **indexes** (list) – 指明选择维度的索引列表

返回:一个和输入张量同形、同类型的张量变量

返回类型:Variable

**代码示例**

..  code-block:: python

            data = fluid.layers.data(
R
RaindragonD 已提交
10133 10134
              name='data', shape=[-1, 3, 2, 2], dtype='float32')
            fluid.layers.similarity_focus(input=data, axis=1, indexes=[0])
C
Cheerego 已提交
10135 10136 10137 10138 10139 10140 10141 10142 10143 10144 10145 10146 10147 10148 10149 10150 10151 10152 10153 10154 10155












.. _cn_api_fluid_layers_slice:

slice
-------------------------------

.. py:function:: paddle.fluid.layers.slice(input, axes, starts, ends)

slice算子。

R
RaindragonD 已提交
10156
沿多个轴生成输入张量的切片。与numpy类似: https://docs.scipy.org/doc/numpy/reference/arrays.indexing.html Slice使用 ``axes`` 、 ``starts`` 和 ``ends`` 属性来指定轴列表中每个轴的起点和终点维度,它使用此信息来对输入数据张量切片。如果向 ``starts`` 或 ``ends`` 传递负值,则表示该维度结束之前的元素数目。如果传递给 ``starts`` 或 ``end`` 的值大于n(此维度中的元素数目),则表示n。当切片一个未知数量的唯独时,建议传入INT_MAX. ``axes`` 的大小必须和 ``starts`` 和 ``ends`` 的相等。以下示例将解释切片如何工作:
C
Cheerego 已提交
10157 10158 10159

::

R
RaindragonD 已提交
10160 10161 10162
        案例1:
                给定:
                     data=[[1,2,3,4],[5,6,7,8],]
C
Cheerego 已提交
10163 10164 10165
                     axes=[0,1]
                     starts=[1,0]
                     ends=[2,3]
R
RaindragonD 已提交
10166
                则:
C
Cheerego 已提交
10167 10168
                     result=[[5,6,7],]

R
RaindragonD 已提交
10169 10170
        案例2:
                给定:
C
Cheerego 已提交
10171 10172 10173
                     data=[[1,2,3,4],[5,6,7,8],]
                     starts=[0,1]
                     ends=[-1,1000]
R
RaindragonD 已提交
10174
                则:
C
Cheerego 已提交
10175 10176 10177 10178 10179 10180 10181 10182 10183 10184 10185 10186 10187
                     result=[[2,3,4],]

参数:
        - **input** (Variable)- 提取切片的数据张量(Tensor)。
        - **axes** (List)- (list <int>)开始和结束的轴适用于。它是可选的。如果不存在,将被视为[0,1,...,len(starts)- 1]。
        - **starts** (List)- (list <int>)在轴上开始相应轴的索引。
        - **ends** (List)- (list <int>)在轴上结束相应轴的索引。

返回:        切片数据张量(Tensor).

返回类型:        输出(Variable)。


T
Tink_Y 已提交
10188 10189 10190 10191
**代码示例:**

.. code-block:: python

R
RaindragonD 已提交
10192 10193
    import paddle.fluid as fluid

T
Tink_Y 已提交
10194 10195 10196
    starts = [1, 0, 2]
    ends = [3, 3, 4]
    axes = [0, 1, 2]
C
Cheerego 已提交
10197

H
Hao Wang 已提交
10198
    input = fluid.layers.data(
T
Tink_Y 已提交
10199 10200
        name="input", shape=[3, 4, 5, 6], dtype='float32')

H
Hao Wang 已提交
10201
    out = fluid.layers.slice(input, axes=axes, starts=starts, ends=ends)
C
Cheerego 已提交
10202 10203 10204 10205 10206 10207 10208 10209 10210 10211 10212 10213 10214 10215







.. _cn_api_fluid_layers_smooth_l1:

smooth_l1
-------------------------------

.. py:function:: paddle.fluid.layers.smooth_l1(x, y, inside_weight=None, outside_weight=None, sigma=None)

T
Tink_Y 已提交
10216
该layer计算变量 ``x`` 和 ``y`` 的smooth L1 loss,它以 ``x`` 和 ``y`` 的第一维大小作为批处理大小。对于每个实例,按元素计算smooth L1 loss,然后计算所有loss。输出变量的形状是[batch_size, 1]
C
Cheerego 已提交
10217 10218 10219 10220 10221 10222 10223 10224


参数:
        - **x** (Variable) - rank至少为2的张量。输入x的smmoth L1 loss 的op,shape为[batch_size, dim1,…],dimN]。
        - **y** (Variable) - rank至少为2的张量。与 ``x`` 形状一致的的smooth L1 loss  op目标值。
        - **inside_weight** (Variable|None) - rank至少为2的张量。这个输入是可选的,与x的形状应该相同。如果给定, ``(x - y)`` 的结果将乘以这个张量元素。
        - **outside_weight** (变量|None) - 一个rank至少为2的张量。这个输入是可选的,它的形状应该与 ``x`` 相同。如果给定,那么 smooth L1 loss 就会乘以这个张量元素。
        - **sigma** (float|None) - smooth L1 loss layer的超参数。标量,默认值为1.0。
C
Cheerego 已提交
10225

R
RaindragonD 已提交
10226
返回: smooth L1 loss, shape为 [batch_size, 1]
C
Cheerego 已提交
10227

C
Cheerego 已提交
10228
返回类型:  Variable
C
Cheerego 已提交
10229 10230 10231 10232

**代码示例**

..  code-block:: python
C
Cheerego 已提交
10233

C
Cheerego 已提交
10234 10235 10236 10237 10238 10239 10240 10241 10242 10243 10244 10245 10246 10247 10248 10249 10250 10251 10252 10253 10254 10255 10256 10257 10258
    data = fluid.layers.data(name='data', shape=[128], dtype='float32')
    label = fluid.layers.data(
        name='label', shape=[100], dtype='float32')
    fc = fluid.layers.fc(input=data, size=100)
    out = fluid.layers.smooth_l1(x=fc, y=label)










.. _cn_api_fluid_layers_soft_relu:

soft_relu
-------------------------------

.. py:function:: paddle.fluid.layers.soft_relu(x, threshold=40.0, name=None)

SoftRelu 激活函数

.. math::   out=ln(1+exp(max(min(x,threshold),threshold))
C
Cheerego 已提交
10259

C
Cheerego 已提交
10260 10261 10262 10263 10264 10265 10266 10267 10268
参数:
    - **x** (variable) - SoftRelu operator的输入
    - **threshold** (FLOAT|40.0) - SoftRelu的阈值
    - **name** (str|None) - 该层的名称(可选)。如果设置为None,该层将被自动命名

**代码示例:**

.. code-block:: python

R
RaindragonD 已提交
10269 10270
    import paddle.fluid as fluid

C
Cheerego 已提交
10271
    x = fluid.layers.data(name=”x”, shape=[2,3,16,16], dtype=”float32”)
C
Cheerego 已提交
10272 10273 10274 10275 10276 10277 10278 10279 10280 10281 10282 10283 10284 10285
    y = fluid.layers.soft_relu(x, threshold=20.0)








.. _cn_api_fluid_layers_softmax:

softmax
-------------------------------

10286
.. py:function:: paddle.fluid.layers.softmax(input, use_cudnn=False, name=None, axis=-1)
C
Cheerego 已提交
10287 10288 10289

softmax操作符的输入是任意阶的张量,输出张量和输入张量的维度相同。

10290 10291
输入变量的 ``axis`` 维会被排列到最后一维。然后逻辑上将输入张量压平至二维矩阵。矩阵的第二维(行数)和输入张量的 ``axis`` 维相同。第一维(列数)
是输入张量除最后一维之外的所有维长度乘积。对矩阵的每一行来说,softmax操作将含有任意实数值的K维向量(K是矩阵的宽度,也就是输入张量 ``axis`` 维度的大小)压缩成K维含有取值为[0,1]中实数的向量,并且这些值和为1。
C
Cheerego 已提交
10292 10293 10294 10295 10296 10297 10298 10299


softmax操作符计算k维向量输入中所有其他维的指数和指数值的累加和。维的指数比例和所有其他维的指数值之和作为softmax操作符的输出。

对矩阵中的每行i和每列j有:

.. math::

T
Tink_Y 已提交
10300
    Out[i,j] = \frac{exp(X[i,j])}{\sum_j exp(X[i,j])}
C
Cheerego 已提交
10301 10302 10303

参数:
    - **input** (Variable) - 输入变量
10304
    - **use_cudnn** (bool) - 是否用cudnn核,只有在cudnn库安装时有效。为了数学稳定性,默认该项为False。
C
Cheerego 已提交
10305
    - **name** (str|None) - 该层名称(可选)。若为空,则自动为该层命名。默认:None
10306
    - **axis** (Variable) - 执行softmax计算的维度索引,应该在 :math:`[-1,rank-1]` 范围内,其中rank是输入变量的秩。 默认值:-1。
C
Cheerego 已提交
10307 10308 10309 10310 10311

返回: softmax输出

返回类型:变量(Variable)

10312
**代码示例**
C
Cheerego 已提交
10313 10314 10315

.. code-block:: python

R
RaindragonD 已提交
10316 10317
    import paddle.fluid as fluid
    x = fluid.layers.data(name='x', shape=[2], dtype='float32')
C
Cheerego 已提交
10318
    fc = fluid.layers.fc(input=x, size=10)
10319 10320
    # 在第二维执行softmax
    softmax = fluid.layers.softmax(input=fc, axis=1)
C
Cheerego 已提交
10321
    # 在最后一维执行softmax
10322
    softmax = fluid.layers.softmax(input=fc, axis=-1)
C
Cheerego 已提交
10323 10324 10325 10326 10327 10328 10329 10330 10331 10332 10333 10334 10335 10336









.. _cn_api_fluid_layers_softmax_with_cross_entropy:

softmax_with_cross_entropy
-------------------------------

R
RaindragonD 已提交
10337
.. py:function:: paddle.fluid.layers.softmax_with_cross_entropy(logits, label, soft_label=False, ignore_index=-100, numeric_stable_mode=True, return_softmax=False, axis=-1)
C
Cheerego 已提交
10338

R
RaindragonD 已提交
10339
使用softmax的交叉熵在输出层已被广泛使用。该函数计算输入张量在axis轴上的softmax标准化值,而后计算交叉熵。通过此种方式,可以得到更具数字稳定性的梯度值。
C
Cheerego 已提交
10340 10341 10342 10343 10344 10345 10346 10347 10348 10349 10350 10351 10352 10353 10354 10355 10356 10357 10358 10359 10360 10361 10362 10363 10364 10365

因为该运算是在内部进行logit上的softmax运算,所以它需要未标准化(unscaled)的logit。该运算不应该对softmax运算的输出进行操作,否则会得出错误结果。

当 ``soft_label`` 为 ``False`` 时,该运算接受互斥的硬标签,batch中的每一个样本都以为1的概率分类到一个类别中,并且仅有一个标签。

涉及到的等式如下:

1.硬标签,即 one-hot label, 每个样本仅可分到一个类别

.. math::
   loss_j =  -\text{logit}_{label_j} +\log\left(\sum_{i=0}^{K}\exp(\text{logit}_i)\right), j = 1,..., K

2.软标签,每个样本可能被分配至多个类别中

.. math::
   loss_j =  -\sum_{i=0}^{K}\text{label}_i\left(\text{logit}_i - \log\left(\sum_{i=0}^{K}\exp(\text{logit}_i)\right)\right), j = 1,...,K

3.如果 ``numeric_stable_mode`` 为真,在通过softmax和标签计算交叉熵损失前, softmax 首先经由下式计算得出:

.. math::
    max_j           &= \max_{i=0}^{K}{\text{logit}_i} \\
    log\_max\_sum_j &= \log\sum_{i=0}^{K}\exp(logit_i - max_j)\\
    softmax_j &= \exp(logit_j - max_j - {log\_max\_sum}_j)


参数:
R
RaindragonD 已提交
10366 10367
  - **logits** (Variable) - 未标准化(unscaled)对数概率的输入张量。
  - **label** (Variable) - 真实值张量。如果 ``soft_label`` 为True,则该参数是一个和logits形状相同的的Tensor<float/double> 。如果 ``soft_label`` 为False,label是一个在axis维上形为1,其它维上与logits形对应相同的Tensor<int64>。
10368
  - **soft_label** (bool) - 是否将输入标签当作软标签。默认为False。
R
RaindragonD 已提交
10369 10370
  - **ignore_index** (int) - 指明要无视的目标值,使之不对输入梯度有贡献。仅在 ``soft_label`` 为False时有效,默认为kIgnoreIndex。 
  - **numeric_stable_mode** (bool) – 标志位,指明是否使用一个具有更佳数学稳定性的算法。仅在 ``soft_label`` 为 False的GPU模式下生效。若 ``soft_label`` 为 True 或者执行场所为CPU, 算法一直具有数学稳定性。 注意使用稳定算法时速度可能会变慢。默认为 True。
10371
  - **return_softmax** (bool) – 标志位,指明是否额外返回一个softmax值, 同时返回交叉熵计算结果。默认为False。
R
RaindragonD 已提交
10372
  - **axis** (int) – 执行softmax计算的维度索引。 它应该在范围 :math:`[ -  1,rank  -  1]` 中,而 :math:`rank` 是输入logits的秩。 默认值:-1。
C
Cheerego 已提交
10373

C
Cheerego 已提交
10374
返回:
R
RaindragonD 已提交
10375 10376
  - 如果 ``return_softmax`` 为 False,则返回交叉熵损失
  - 如果 ``return_softmax`` 为 True,则返回元组 (loss, softmax) ,其中softmax和输入logits形状相同;除了axis维上的形为1,其余维上交叉熵损失和输入logits形状相同
C
Cheerego 已提交
10377 10378 10379 10380 10381 10382 10383 10384

返回类型:变量或者两个变量组成的元组


**代码示例**

..  code-block:: python

R
RaindragonD 已提交
10385
  data = fluid.layers.data(name='data', shape=[128], dtype='float32')
C
Cheerego 已提交
10386 10387 10388 10389
        label = fluid.layers.data(name='label', shape=[1], dtype='int64')
        fc = fluid.layers.fc(input=data, size=100)
        out = fluid.layers.softmax_with_cross_entropy(
        logits=fc, label=label)
C
Cheerego 已提交
10390 10391


C
Cheerego 已提交
10392 10393 10394 10395 10396 10397 10398 10399 10400 10401 10402 10403 10404 10405 10406 10407 10408 10409 10410 10411 10412 10413 10414 10415 10416 10417 10418








.. _cn_api_fluid_layers_space_to_depth:

space_to_depth
-------------------------------

.. py:function:: paddle.fluid.layers.space_to_depth(x, blocksize, name=None)

给该函数一个 ``blocksize`` 值,可以对形为[batch, channel, height, width]的输入LoD张量进行space_to_depth(广度至深度)运算。

该运算对成块的空间数据进行重组,形成深度。确切地说,该运算输出一个输入LoD张量的拷贝,其高度,宽度维度上的值移动至通道维度上。

``blocksize`` 参数指明了数据块大小。

重组时,依据 ``blocksize`` , 生成形为 :math:`[batch, channel * blocksize * blocksize, height/blocksize, width/blocksize]` 的输出:

该运算适用于在卷积间重放缩激励函数,并保持所有的数据。

 - 在各位置上,不重叠的,大小为 :math:`block\_size * block\_size` 的块重组入深度depth
 - 输出张量的深度为 :math:`block\_size * block\_size * input\_channel`
C
Cheerego 已提交
10419
 - 输入各个块中的Y,X坐标变为输出张量通道索引的高序部位
C
Cheerego 已提交
10420 10421 10422 10423 10424 10425 10426 10427 10428 10429 10430
 - channel可以被blocksize的平方整除
 - 高度,宽度可以被blocksize整除

参数:
  - **x** (variable) – 输入LoD张量
  - **blocksize** (variable) – 在每个特征图上选择元素时采用的块大小,应该 > 2

返回:输出LoD tensor

返回类型:Variable

C
Cheerego 已提交
10431
抛出异常:
C
Cheerego 已提交
10432 10433 10434 10435 10436 10437
  - ``TypeError`` - ``blocksize`` 必须是long类型

**代码示例**

..  code-block:: python

R
RaindragonD 已提交
10438 10439 10440
    import paddle.fluid as fluid
    import numpy as np

C
Cheerego 已提交
10441
    data = fluid.layers.data(
10442
        name='data', shape=[1, 4, 2, 2], dtype='float32', append_batch_size=False)
C
Cheerego 已提交
10443 10444 10445
    space_to_depthed = fluid.layers.space_to_depth(
        x=data, blocksize=2)

10446 10447 10448 10449 10450 10451 10452
    exe = fluid.Executor(fluid.CUDAPlace(0))
    data_np = np.arange(0,16).reshape((1,4,2,2)).astype('float32')
    out_main = exe.run(fluid.default_main_program(),
                  feed={'data': data_np},
                  fetch_list=[space_to_depthed])


C
Cheerego 已提交
10453 10454 10455



Z
zy0531 已提交
10456 10457 10458 10459 10460 10461 10462 10463 10464 10465 10466 10467
.. _cn_api_fluid_layers_spectral_norm:

spectral_norm
-------------------------------

.. py:function:: paddle.fluid.layers.spectral_norm(weight, dim=0, power_iters=1, eps=1e-12, name=None)

**Spectral Normalization Layer**

该层计算了fc、conv1d、conv2d、conv3d层的权重参数的谱正则值,其参数应分别为2-D, 3-D, 4-D, 5-D。计算结果如下。

步骤1:生成形状为[H]的向量U,以及形状为[W]的向量V,其中H是输入权重的第 ``dim`` 个维度,W是剩余维度的乘积。
C
Cheerego 已提交
10468

C
Cheerego 已提交
10469
步骤2: ``power_iters`` 应该是一个正整数,用U和V迭代计算 ``power_iters`` 轮。
Z
zy0531 已提交
10470 10471 10472 10473 10474 10475 10476 10477 10478 10479 10480 10481

.. math::

    \mathbf{v} &:= \frac{\mathbf{W}^{T} \mathbf{u}}{\|\mathbf{W}^{T} \mathbf{u}\|_2}\\
    \mathbf{u} &:= \frac{\mathbf{W}^{T} \mathbf{v}}{\|\mathbf{W}^{T} \mathbf{v}\|_2}

步骤3:计算 \sigma(\mathbf{W}) 并权重值归一化。

.. math::
    \sigma(\mathbf{W}) &= \mathbf{u}^{T} \mathbf{W} \mathbf{v}\\
    \mathbf{W} &= \frac{\mathbf{W}}{\sigma(\mathbf{W})}

C
Cheerego 已提交
10482
可参考: `Spectral Normalization <https://arxiv.org/abs/1802.05957>`_
Z
zy0531 已提交
10483 10484 10485 10486 10487 10488 10489 10490 10491 10492 10493 10494 10495 10496 10497 10498

参数:
    - **weight** (Variable)-spectral_norm算子的输入权重张量,可以是2-D, 3-D, 4-D, 5-D张量,它是fc、conv1d、conv2d、conv3d层的权重。
    - **dim** (int)-将输入(weight)重塑为矩阵之前应排列到第一个的维度索引,如果input(weight)是fc层的权重,则应设置为0;如果input(weight)是conv层的权重,则应设置为1,默认为0。
    - **power_iters** (int)-将用于计算spectral norm的功率迭代次数,默认值1
    - **eps** (float)-epsilon用于计算规范中的数值稳定性
    - **name** (str)-此层的名称,可选。

返回:谱正则化后权重参数的张量变量

返回类型:Variable

**代码示例**:

.. code-block:: python

R
RaindragonD 已提交
10499 10500 10501 10502
   import paddle.fluid as fluid

   weight = fluid.layers.data(name='weight', shape=[2, 8, 32, 32], append_batch_size=False, dtype='float32')
   x = fluid.layers.spectral_norm(weight=weight, dim=1, power_iters=2)
C
Cheerego 已提交
10503 10504 10505 10506 10507 10508 10509 10510 10511 10512 10513 10514 10515 10516 10517 10518 10519 10520 10521 10522 10523 10524 10525 10526 10527 10528 10529 10530





.. _cn_api_fluid_layers_split:

split
-------------------------------

.. py:function:: paddle.fluid.layers.split(input,num_or_sections,dim=-1,name=None)

将输入张量分解成多个子张量

参数:
    - **input** (Variable)-输入变量,类型为Tensor或者LoDTensor
    - **num_or_sections** (int|list)-如果num_or_sections是整数,则表示张量平均划分为的相同大小子张量的数量。如果num_or_sections是一列整数,列表的长度代表子张量的数量,整数依次代表子张量的dim维度的大小
    - **dim** (int)-将要划分的维。如果dim<0,划分的维为rank(input)+dim
    - **name** (str|None)-该层名称(可选)。如果设置为空,则自动为该层命名

返回:一列分割张量

返回类型:列表(Variable)

**代码示例**:

.. code-block:: python

R
RaindragonD 已提交
10531 10532 10533 10534 10535 10536 10537 10538 10539 10540 10541 10542 10543 10544 10545
    import paddle.fluid as fluid

    # 输入是维为[-1, 3,9,5]的张量:
    input = fluid.layers.data(
         name="input", shape=[3, 9, 5], dtype="float32")

    x0, x1, x2 = fluid.layers.split(x, num_or_sections=3, dim=2)
    # x0.shape  [-1, 3, 3, 5]
    # x1.shape  [-1, 3, 3, 5]
    # x2.shape  [-1, 3, 3, 5]
    
    x0, x1, x2 = fluid.layers.split(input, num_or_sections=[2, 3, 4], dim=2)
    # x0.shape  [-1, 3, 2, 5]
    # x1.shape  [-1, 3, 3, 5]
    # x2.shape  [-1, 3, 4, 5]
C
Cheerego 已提交
10546 10547 10548 10549 10550 10551 10552 10553 10554 10555 10556









.. _cn_api_fluid_layers_square_error_cost:

C
Cheerego 已提交
10557
square_error_cost
C
Cheerego 已提交
10558 10559 10560 10561 10562 10563 10564 10565 10566 10567 10568 10569 10570 10571 10572 10573 10574 10575 10576 10577 10578 10579 10580 10581 10582 10583 10584 10585 10586
-------------------------------

.. py:function:: paddle.fluid.layers.square_error_cost(input,label)

方差估计层(Square error cost layer)

该层接受输入预测值和目标值,并返回方差估计

对于预测值X和目标值Y,公式为:

.. math::

    Out = (X-Y)^{2}

在以上等式中:
    - **X** : 输入预测值,张量(Tensor)
    - **Y** : 输入目标值,张量(Tensor)
    - **Out** : 输出值,维度和X的相同

参数:
    - **input** (Variable) - 输入张量(Tensor),带有预测值
    - **label** (Variable) - 标签张量(Tensor),带有目标值

返回:张量变量,存储输入张量和标签张量的方差

返回类型:变量(Variable)

**代码示例**:

T
Tink_Y 已提交
10587
.. code-block:: python
C
Cheerego 已提交
10588

H
Hao Wang 已提交
10589 10590 10591
    y = fluid.layers.data(name='y', shape=[1], dtype='float32')
    y_predict = fluid.layers.data(name='y_predict', shape=[1], dtype='float32')
    cost = fluid.layers.square_error_cost(input=y_predict, label=y)
C
Cheerego 已提交
10592 10593 10594 10595 10596 10597 10598 10599 10600 10601 10602









.. _cn_api_fluid_layers_squeeze:

C
Cheerego 已提交
10603
squeeze
C
Cheerego 已提交
10604 10605 10606 10607 10608 10609 10610 10611 10612 10613 10614 10615 10616 10617 10618 10619 10620 10621 10622 10623 10624 10625 10626 10627 10628 10629 10630 10631 10632 10633 10634 10635 10636 10637 10638 10639 10640
-------------------------------

.. py:function:: paddle.fluid.layers.squeeze(input, axes, name=None)

向张量维度中移除单维输入。传入用于压缩的轴。如果未提供轴,所有的单一维度将从维中移除。如果选择的轴的形状条目不等于1,则报错。

::


    例如:

    例1:
        给定
            X.shape = (1,3,1,5)
            axes = [0]
        得到
            Out.shape = (3,1,5)
    例2:
        给定
            X.shape = (1,3,1,5)
            axes = []
        得到
            Out.shape = (3,5)

参数:
        - **input** (Variable)-将要压缩的输入变量
        - **axes** (list)-一列整数,代表压缩的维
        - **name** (str|None)-该层名称

返回:输出压缩的变量

返回类型:变量(Variable)

**代码示例**:

.. code-block:: python

R
RaindragonD 已提交
10641
    import paddle.fluid.layers as layers
H
Hao Wang 已提交
10642
    x = fluid.layers.data(name='x', shape=[5, 1, 10])
C
Cheerego 已提交
10643
    y = fluid.layers.sequeeze(input=x, axes=[1])
C
Cheerego 已提交
10644 10645 10646 10647 10648 10649 10650 10651 10652 10653 10654 10655 10656 10657 10658 10659 10660 10661 10662 10663 10664 10665









.. _cn_api_fluid_layers_stack:

stack
-------------------------------

.. py:function:: paddle.fluid.layers.stack(x, axis=0)

实现了stack层。

沿 ``axis`` 轴,该层对输入 ``x`` 进行stack运算。

输入 x 可以是单个变量, 或是多个变量组成的列表或元组。如果 x 是一个列表或元组, 那么这些变量必须同形。 假设每个输入的形都为 :math:`[d_0,d_1,...,d_{n−1}]` , 则输出变量的形为 :math:`[d_0,d_1,...,d_{axis}=len(x),...,d_{n−1}]` 。 如果 ``axis`` < 0, 则将其取代为 :math:`axis+rank(x[0])+1` 。 如果 ``axis`` 为 None, 则认为它是 0。

10666 10667 10668 10669 10670 10671 10672 10673 10674 10675 10676 10677 10678 10679 10680 10681 10682 10683 10684 10685 10686 10687 10688 10689 10690 10691 10692 10693 10694 10695 10696 10697 10698 10699 10700 10701 10702 10703 10704 10705 10706

例如:

.. code-block:: text

    例1:
      输入:
        x[0].data = [ [1.0 , 2.0 ] ]
        x[0].dims = [1, 2]
        x[1].data = [ [3.0 , 4.0 ] ]
        x[1].dims = [1, 2]
        x[2].data = [ [5.0 , 6.0 ] ]
        x[2].dims = [1, 2]

      参数:
        axis = 0

      输出:
        Out.data =[ [ [1.0, 2.0] ],
                    [ [3.0, 4.0] ],
                    [ [5.0, 6.0] ] ]
        Out.dims = [3, 1, 2]

    例2:
      如果
        x[0].data = [ [1.0 , 2.0 ] ]
        x[0].dims = [1, 2]
        x[1].data = [ [3.0 , 4.0 ] ]
        x[1].dims = [1, 2]
        x[2].data = [ [5.0 , 6.0 ] ]
        x[2].dims = [1, 2]

      参数:
        axis = 1 or axis = -2

      输出:
        Out.data =[ [ [1.0, 2.0]
                      [3.0, 4.0]
                      [5.0, 6.0] ] ]
        Out.dims = [1, 3, 2]

C
Cheerego 已提交
10707
参数:
C
Cheerego 已提交
10708

C
Cheerego 已提交
10709 10710 10711 10712 10713 10714 10715
  - **x** (Variable|list(Variable)|tuple(Variable)) – 输入变量
  - **axis** (int|None) – 对输入进行stack运算所在的轴

返回: 经stack运算后的变量

返回类型: Variable

R
RaindragonD 已提交
10716
**代码示例**:
C
Cheerego 已提交
10717

R
RaindragonD 已提交
10718
.. code-block:: python
C
Cheerego 已提交
10719

R
RaindragonD 已提交
10720 10721 10722 10723
    import paddle.fluid.layers as layers
    x1 = layers.data(name='x1', shape=[1, 2], dtype='int32')
    x2 = layers.data(name='x2', shape=[1, 2], dtype='int32')
    data = layers.stack([x1,x2])
C
Cheerego 已提交
10724 10725 10726 10727 10728 10729 10730 10731 10732 10733 10734 10735 10736 10737 10738 10739







.. _cn_api_fluid_layers_stanh:

stanh
-------------------------------

.. py:function:: paddle.fluid.layers.stanh(x, scale_a=0.6666666666666666, scale_b=1.7159, name=None)

STanh 激活算子(STanh Activation Operator.)

C
Cheerego 已提交
10740
.. math::
C
Cheerego 已提交
10741 10742 10743 10744 10745 10746 10747 10748 10749 10750 10751 10752 10753 10754 10755 10756 10757 10758 10759 10760 10761 10762 10763 10764 10765 10766 10767 10768 10769 10770 10771 10772 10773 10774
          \\out=b*\frac{e^{a*x}-e^{-a*x}}{e^{a*x}+e^{-a*x}}\\

参数:
    - **x** (Variable) - STanh operator的输入
    - **scale_a** (FLOAT|2.0 / 3.0) - 输入的a的缩放参数
    - **scale_b** (FLOAT|1.7159) - b的缩放参数
    - **name** (str|None) - 这个层的名称(可选)。如果设置为None,该层将被自动命名。

返回: STanh操作符的输出

返回类型: 输出(Variable)

**代码示例:**

.. code-block:: python

    x = fluid.layers.data(name="x", shape=[3,10,32,32], dtype="float32")
    y = fluid.layers.stanh(x, scale_a=0.67, scale_b=1.72)







.. _cn_api_fluid_layers_sum:

sum
-------------------------------

.. py:function:: paddle.fluid.layers.sum(x)

sum算子。

10775
该算子对输入张量求和。所有输入都可以携带LoD(详细程度)信息,但是输出仅与第一个输入共享LoD信息。
C
Cheerego 已提交
10776 10777

参数:
10778
        - **x** (Variable)- (vector <Tensor>)sum算子的输入张量(Tensor)。
C
Cheerego 已提交
10779 10780 10781 10782 10783 10784

返回:        (Tensor)求和算子的输出张量。

返回类型:        Variable


T
Tink_Y 已提交
10785
**代码示例:**
C
Cheerego 已提交
10786

T
Tink_Y 已提交
10787 10788
.. code-block:: python

R
RaindragonD 已提交
10789 10790 10791 10792
    import paddle.fluid.layers as layers
    input0 = fluid.layers.data(name="input0", shape=[13, 11], dtype='float32')
    input1 = layers.data(name="input1", shape=[13, 11], dtype='float32')
    out = fluid.layers.sum([input0,input1])
C
Cheerego 已提交
10793 10794 10795 10796 10797 10798 10799 10800 10801 10802 10803 10804 10805 10806 10807 10808







.. _cn_api_fluid_layers_swish:

swish
-------------------------------

.. py:function:: paddle.fluid.layers.swish(x, beta=1.0, name=None)

Swish 激活函数

C
Cheerego 已提交
10809
.. math::
T
Tink_Y 已提交
10810
         out = \frac{x}{1 + e^{- beta x}}
C
Cheerego 已提交
10811 10812

参数:
T
Tink_Y 已提交
10813
    - **x** (Variable) -  Swish operator 的输入
C
Cheerego 已提交
10814 10815 10816 10817 10818 10819 10820 10821 10822 10823 10824 10825 10826 10827 10828 10829
    - **beta** (浮点|1.0) - Swish operator 的常量beta
    - **name** (str|None) - 这个层的名称(可选)。如果设置为None,该层将被自动命名。

返回: Swish operator 的输出

返回类型: output(Variable)


**代码示例:**

.. code-block:: python

  x = fluid.layers.data(name="x", shape=[3,10,32,32], dtype="float32")
  y = fluid.layers.swish(x, beta=2.0)


H
Hao Wang 已提交
10830
.. _cn_api_fluid_layers_teacher_student_sigmoid_loss:
C
Cheerego 已提交
10831

H
Hao Wang 已提交
10832 10833 10834 10835 10836 10837 10838 10839 10840 10841 10842 10843 10844 10845 10846 10847 10848 10849 10850 10851 10852 10853 10854 10855 10856 10857
teacher_student_sigmoid_loss
-----------------------------------

.. py:function:: paddle.fluid.layers.teacher_student_sigmoid_loss(input, label, soft_max_up_bound=15.0, soft_max_lower_bound=-15.0)

**Teacher Student Log Loss Layer(教师--学生对数损失层)**

此图层接受输入预测和目标标签,并返回teacher_student损失。

.. math::

    loss = max(x, 0) - x * z + log(1 + exp(-abs(x))) + max(x, 0) - x * z' + log(1 + exp(-abs(x)))


参数:
  - **input**  (Variable|list) – 形状为[N x 1]的二维张量,其中N是批大小batch size。 该输入是由前一个运算计算而得的概率。
  - **label**  (Variable|list) – 具有形状[N x 1]的二维张量的真实值,其中N是批大小batch_size。
  - **soft_max_up_bound**  (float) – 若input > soft_max_up_bound, 输入会被向下限制。默认为15.0
  - **soft_max_lower_bound**  (float) – 若input < soft_max_lower_bound, 输入将会被向上限制。默认为-15.0

返回:具有形状[N x 1]的2-D张量,teacher_student_sigmoid_loss。

返回类型:变量

**代码示例**:

C
Cheerego 已提交
10858
.. code-block:: python
H
Hao Wang 已提交
10859

R
RaindragonD 已提交
10860 10861 10862 10863 10864 10865 10866
    import paddle.fluid as fluid
     
    batch_size = 64
    label = fluid.layers.data(
              name="label", shape=[batch_size, 1], dtype="int64", append_batch_size=False)
    similarity = fluid.layers.data(
              name="similarity", shape=[batch_size, 1], dtype="float32", append_batch_size=False)
H
Hao Wang 已提交
10867
    cost = fluid.layers.teacher_student_sigmoid_loss(input=similarity, label=label)
C
Cheerego 已提交
10868 10869


Z
zy0531 已提交
10870 10871 10872 10873 10874 10875 10876 10877 10878 10879 10880 10881 10882 10883 10884 10885 10886 10887 10888 10889 10890 10891 10892 10893 10894
.. _cn_api_fluid_layers_temporal_shift:

temporal_shift
-------------------------------
.. py:function:: paddle.fluid.layers.temporal_shift(x, seg_num, shift_ratio=0.25, name=None)

**Temporal Shift Operator**

此运算符计算输入(x)的时间移位特征。

输入(x)的形状应为[N*T, C, H, W],N是批大小,T是 ``seg_num`` 指定的时间段号,C是通道号,H和W是特征的高度和宽度。

时间偏移计算如下:

步骤1:将输入(X)重塑为[N、T、C、H、W]。

步骤2:填充0到第二个(T)尺寸的变形结果,填充宽度每边为1,填充结果的形状为[N,T+2,C,H,W]。

步骤3:假设shift_ratio为1/4,切片填充结果如下:

.. math::

    slice1 &= x[:, :T, :C/4, :, :]

    slice2 &= x[:, 2:T+2, C/4:C/2, :, :]
C
Cheerego 已提交
10895

Z
zy0531 已提交
10896 10897 10898 10899
    slice3 &= x[:, 1:T+1, C/2:, :, :]

步骤4:沿第3(C)维连接三个切片,并将结果重塑为[N*T, C, H, W]。

C
Cheerego 已提交
10900
有关时间移动的详细信息,请参阅文件: `Temporal Shift Module <https://arxiv.org/abs/1811.08383>`_
Z
zy0531 已提交
10901 10902 10903 10904 10905 10906 10907 10908 10909 10910 10911 10912 10913 10914 10915 10916

参数:
  - **x**  (Variable) – 时移算符的输入张量。这是一个4维张量,形状为[N*T,C,H,W]。N为批量大小,T为时间段数,C为信道数,H为特征高度,W为特征宽度
  - **seg_num**  (int) – 时间段编号,这应该是一个正整数。
  - **shift_ratio**  (float) – 通道的移位比、通道的第一个 ``shift_ratio`` 部分沿时间维度移动-1,通道的第二个 ``shift_ratio`` 部分沿时间维度移动1。默认值0.25
  - **name**  (str, default None) – 该层名称

返回:时间移位结果是一个与输入形状和类型相同的张量变量

返回类型:out(Variable)

抛出异常: ``TypeError`` – seg_num 必须是int类型


**代码示例**:

C
Cheerego 已提交
10917
.. code-block:: python
Z
zy0531 已提交
10918 10919 10920

    input = fluid.layers.data(name='input', shape=[4,2,2], dtype='float32')
    out = fluid.layers.temporal_shift(x=input, seg_num=2, shift_ratio=0.2)
C
Cheerego 已提交
10921 10922 10923 10924 10925 10926 10927 10928 10929



.. _cn_api_fluid_layers_topk:

topk
-------------------------------
.. py:function:: paddle.fluid.layers.topk(input, k, name=None)

10930
这个算子用于查找最后一维的前k个最大项,返回它们的值和索引。
C
Cheerego 已提交
10931 10932 10933 10934 10935 10936 10937 10938 10939 10940 10941 10942 10943 10944 10945 10946

如果输入是(1-D Tensor),则找到向量的前k最大项,并以向量的形式输出前k最大项的值和索引。values[j]是输入中第j最大项,其索引为indices[j]。
如果输入是更高阶的张量,则该operator会基于最后一维计算前k项

例如:

.. code-block:: text


    如果:
        input = [[5, 4, 2, 3],
                [9, 7, 10, 25],
                [6, 2, 10, 1]]
        k = 2

    则:
H
Hao Wang 已提交
10947
        第一个输出:
C
Cheerego 已提交
10948 10949 10950 10951
        values = [[5, 4],
                [10, 25],
                [6, 10]]

H
Hao Wang 已提交
10952
        第二个输出:
C
Cheerego 已提交
10953 10954 10955 10956 10957 10958
        indices = [[0, 1],
                [2, 3],
                [0, 2]]

参数:
    - **input** (Variable)-输入变量可以是一个向量或者更高阶的张量
H
Hao Wang 已提交
10959
    - **k** (int|Variable)-在输入最后一维中寻找的前项数目
C
Cheerego 已提交
10960 10961 10962 10963 10964 10965
    - **name** (str|None)-该层名称(可选)。如果设为空,则自动为该层命名。默认为空

返回:含有两个元素的元组。元素都是变量。第一个元素是最后维切片的前k项。第二个元素是输入最后维里值索引

返回类型:元组[变量]

T
Tink_Y 已提交
10966
抛出异常: ``ValueError`` - 如果k<1或者k不小于输入的最后维
C
Cheerego 已提交
10967 10968 10969

**代码示例**:

C
Cheerego 已提交
10970
.. code-block:: python
C
Cheerego 已提交
10971

R
RaindragonD 已提交
10972 10973
    import paddle.fluid.layers as layers
    input = layers.data(name="input", shape=[13, 11], dtype='float32')
H
Hao Wang 已提交
10974
    top5_values, top5_indices = fluid.layers.topk(input, k=5)
C
Cheerego 已提交
10975 10976 10977 10978 10979 10980 10981 10982 10983 10984 10985 10986 10987 10988 10989 10990 10991 10992 10993 10994 10995 10996 10997 10998 10999 11000 11001 11002 11003 11004 11005 11006 11007 11008 11009









.. _cn_api_fluid_layers_transpose:

transpose
-------------------------------

.. py:function:: paddle.fluid.layers.transpose(x,perm,name=None)

根据perm对输入矩阵维度进行重排。

返回张量(tensor)的第i维对应输入维度矩阵的perm[i]。

参数:
    - **x** (Variable) - 输入张量(Tensor)
    - **perm** (list) - 输入维度矩阵的转置
    - **name** (str) - 该层名称(可选)

返回: 转置后的张量(Tensor)

返回类型:变量(Variable)

**代码示例**:

.. code-block:: python

    # 请使用 append_batch_size=False 来避免
    # 在数据张量中添加多余的batch大小维度
R
RaindragonD 已提交
11010
    import paddle.fluid as fluid
C
Cheerego 已提交
11011 11012
    x = fluid.layers.data(name='x', shape=[5, 10, 15],
                    dtype='float32', append_batch_size=False)
H
Hao Wang 已提交
11013
    x_transposed = fluid.layers.transpose(x, perm=[1, 0, 2])
C
Cheerego 已提交
11014 11015 11016 11017




H
Hao Wang 已提交
11018 11019 11020 11021 11022 11023 11024 11025 11026 11027 11028 11029 11030 11031 11032 11033 11034 11035 11036 11037 11038 11039 11040 11041 11042 11043 11044 11045 11046 11047
.. _cn_api_fluid_layers_tree_conv:

tree_conv
-------------------------------

.. py:function:: paddle.fluid.layers.tree_conv(nodes_vector, edge_set, output_size, num_filters=1, max_depth=2, act='tanh', param_attr=None, bias_attr=None, name=None)

基于树结构的卷积Tree-Based Convolution运算。

基于树的卷积是基于树的卷积神经网络(TBCNN,Tree-Based Convolution Neural Network)的一部分,它用于对树结构进行分类,例如抽象语法树。 Tree-Based Convolution提出了一种称为连续二叉树的数据结构,它将多路(multiway)树视为二叉树。 提出基于树的卷积论文: https://arxiv.org/abs/1409.5718v1

参数:
    - **nodes_vector**  (Variable) – (Tensor) 树上每个节点的特征向量(vector)。特征向量的形状必须为[max_tree_node_size,feature_size]
    - **edge_set**  (Variable) – (Tensor) 树的边。边必须带方向。边集的形状必须是[max_tree_node_size,2]
    - **output_size**  (int) – 输出特征宽度
    - **num_filters**  (int) – filter数量,默认值1
    - **max_depth**  (int) – filter的最大深度,默认值2
    - **act**  (str) – 激活函数,默认 tanh
    - **param_attr**  (ParamAttr) – filter的参数属性,默认None
    - **bias_attr**  (ParamAttr) – 此层bias的参数属性,默认None
    - **name**  (str) – 此层的名称(可选)。如果设置为None,则将自动命名层,默认为None


返回: (Tensor)子树的特征向量。输出张量的形状是[max_tree_node_size,output_size,num_filters]。输出张量可以是下一个树卷积层的新特征向量

返回类型:out(Variable)

**代码示例**:

.. code-block:: python
R
RaindragonD 已提交
11048 11049 11050 11051
    
    # 10 代表数据集的最大节点大小max_node_size,5 代表向量宽度
    nodes_vector = fluid.layers.data(name='vectors', shape=[10, 5], dtype='float32')
    # 10 代表数据集的最大节点大小max_node_size, 2 代表每条边连接两个节点
H
Hao Wang 已提交
11052
    # 边必须为有向边
R
RaindragonD 已提交
11053 11054 11055 11056 11057 11058
    edge_set = fluid.layers.data(name='edge_set', shape=[10, 2], dtype='float32')

    # 输出的形状会是[None, 10, 6, 1],
    # 10 代表数据集的最大节点大小max_node_size, 6 代表输出大小output size, 1 代表 1 个filter
    
    out_vector = fluid.layers.tree_conv(nodes_vector, edge_set, 6, 1, 2)
C
Cheerego 已提交
11059
    # reshape之后, 输出张量output tensor为下一个树卷积的nodes_vector
R
RaindragonD 已提交
11060 11061 11062 11063 11064
    out_vector = fluid.layers.reshape(out_vector, shape=[-1, 10, 6])
    
    
    out_vector_2 = fluid.layers.tree_conv(out_vector, edge_set, 3, 4, 2)
    
H
Hao Wang 已提交
11065
    # 输出tensor也可以用来池化(论文中称为global pooling)
R
RaindragonD 已提交
11066
    pooled = fluid.layers.reduce_max(out_vector, dims=2) # 全局池化
H
Hao Wang 已提交
11067 11068 11069 11070 11071 11072






R
RaindragonD 已提交
11073 11074 11075 11076 11077 11078 11079 11080 11081 11082 11083 11084 11085 11086 11087 11088 11089 11090 11091 11092 11093 11094 11095 11096 11097
.. _cn_api_fluid_layers_unfold:

unfold
-------------------------------

.. py:function:: paddle.fluid.layers.unfold(x, kernel_sizes, strides=1, paddings=0, dilations=1, name=None)

此函数返回输入x的滑动局域块的col缓冲区,对于批处理的2D图像张量,也称为im2col。 对于卷积核下的每个块,所有元素将重新排列为列。当卷积核在输入特征图上滑动时,将形成一系列这样的列。对于每个形为[N, C, H, W]的输入\(X\),输出形状[N, Cout, Lout计算如下:

\[ \begin{align}\begin{aligned}dkernel[0] &= dilations[0] \times (kernel\_sizes[0] - 1) + 1\\dkernel[1] &= dilations[1] \times (kernel\_sizes[1] - 1) + 1\\hout &= \frac{H + paddings[0] + paddings[2] - dkernel[0]}{strides[0]} + 1\\wout &= \frac{W + paddings[1] + paddings[3] - dkernel[1]}{strides[1]} + 1\\Cout &= C \times kernel\_sizes[0] \times kernel\_sizes[1]\\Lout &= hout \times wout\end{aligned}\end{align} \]


参数:
    - **x**  (Variable) – 输入张量,形式为[N, C, H, W]。
    - **kernel_sizes**  (int|list) – 卷积核大小,应为[k_h, k_w],或整数k(看做[k, k])。
    - **strides**  (int|list) – 步长,应为[stride_h, stride_w]或整数stride(看做[stride, stride])。默认为[1, 1]。
    - **paddings**  (int|list) – 每个维度的paddings,应为
    [padding_top, padding_left, padding_bottom, padding_right]
    或 [padding_h, padding_w] 或一个整数padding。
    如果给出 [padding_h, padding_w] ,它将扩展为
    [padding_h, padding_w, padding_h, padding_w]。如果给出了整数
    padding,则将使用[padding, padding, padding, padding]。默认为[0, 0, 0, 0]。
    - **dilations**  (int|list) – 卷积核膨胀,应为[dilation_h, dilation_w],或整数dilation(看做[dilation, dilation])。默认为[1, 1]。

返回:对应于滑动局域块的张量变量。输出形状为[N, Cout, Lout](如上所述)。 Cout是每个块中的值的总数,Lout是这些块的总数。
H
Hao Wang 已提交
11098

R
RaindragonD 已提交
11099
返回类型:变量(Variable)
H
Hao Wang 已提交
11100

R
RaindragonD 已提交
11101
**代码示例**:
H
Hao Wang 已提交
11102

R
RaindragonD 已提交
11103
.. code-block:: python
C
Cheerego 已提交
11104

R
RaindragonD 已提交
11105 11106 11107
    import paddle.fluid as fluid
    x = fluid.layers.data(name = 'data', shape = [3, 224, 224], dtype = 'float32')
    y = fluid.layers.unfold(x, [3, 3], 1, 1, 1)
C
Cheerego 已提交
11108 11109 11110 11111 11112 11113 11114 11115 11116 11117 11118 11119 11120




.. _cn_api_fluid_layers_uniform_random_batch_size_like:

uniform_random_batch_size_like
-------------------------------

.. py:function:: paddle.fluid.layers.uniform_random_batch_size_like(input, shape, dtype='float32', input_dim_idx=0, output_dim_idx=0, min=-1.0, max=1.0, seed=0)

uniform_random_batch_size_like算子。

11121
此算子使用与输入张量(Tensor)相同的batch_size初始化张量(Tensor),并使用从均匀分布中采样的随机值。
C
Cheerego 已提交
11122 11123 11124 11125 11126 11127 11128 11129

参数:
        - **input** (Variable)- 其input_dim_idx'th维度指定batch_size的张量(Tensor)。
        - **shape** (元组|列表)- 输出的形状。
        - **input_dim_idx** (Int)- 默认值0.输入批量大小维度的索引。
        - **output_dim_idx** (Int)- 默认值0.输出批量大小维度的索引。
        - **min** (Float)- (默认 1.0)均匀随机的最小值。
        - **max** (Float)- (默认 1.0)均匀随机的最大值。
11130
        - **seed** (Int)- (int,default 0)用于生成样本的随机种子。0表示使用系统生成的种子。注意如果seed不为0,则此算子将始终每次生成相同的随机数。
C
Cheerego 已提交
11131 11132 11133 11134 11135 11136 11137
        - **dtype** (np.dtype | core.VarDesc.VarType | str) - 数据类型:float32,float_16,int等。

返回:        指定形状的张量(Tensor)将使用指定值填充。

返回类型:        Variable


T
Tink_Y 已提交
11138
**代码示例:**
C
Cheerego 已提交
11139

T
Tink_Y 已提交
11140
.. code-block:: python
C
Cheerego 已提交
11141

R
RaindragonD 已提交
11142
    import paddle.fluid.layers as layers
C
Cheerego 已提交
11143

H
Hao Wang 已提交
11144 11145
    input = fluid.layers.data(name="input", shape=[13, 11], dtype='float32')
    out = fluid.layers.uniform_random_batch_size_like(input, [-1, 11])
T
Tink_Y 已提交
11146

C
Cheerego 已提交
11147 11148 11149 11150 11151 11152 11153 11154 11155 11156 11157




.. _cn_api_fluid_layers_unsqueeze:

unsqueeze
-------------------------------

.. py:function:: paddle.fluid.layers.unsqueeze(input, axes, name=None)

H
Hao Wang 已提交
11158
向张量shape中插入一个维度。该接口接受axes列表,来指定要插入的维度位置。相应维度变化可以在输出变量中axes指定的索引位置上体现。
C
Cheerego 已提交
11159 11160

比如:
H
Hao Wang 已提交
11161
    给定一个张量,例如维度为[3,4,5]的张量,使用 axes列表为[0,4]来unsqueeze它,则输出维度为[1,3,4,5,1]
C
Cheerego 已提交
11162 11163 11164 11165 11166 11167 11168 11169 11170 11171 11172 11173 11174 11175

参数:
    - **input** (Variable)- 未压缩的输入变量
    - **axes** (list)- 一列整数,代表要插入的维数
    - **name** (str|None) - 该层名称

返回:输出未压缩变量

返回类型:变量(Variable)

**代码示例**:

.. code-block:: python

R
RaindragonD 已提交
11176
    import paddle.fluid as fluid
H
Hao Wang 已提交
11177 11178
    x = fluid.layers.data(name='x', shape=[5, 10])
    y = fluid.layers.unsequeeze(input=x, axes=[1])
C
Cheerego 已提交
11179 11180 11181 11182 11183 11184 11185 11186 11187 11188 11189 11190 11191 11192 11193 11194 11195 11196 11197 11198 11199 11200 11201 11202 11203










.. _cn_api_fluid_layers_unstack:

unstack
-------------------------------

.. py:function:: paddle.fluid.layers.unstack(x, axis=0, num=None)

实现了unstack层。

沿 ``axis`` 轴,该层对输入 ``x`` 进行unstack运算。

如果 ``axis`` <0,则将其以 :math:`axis+rank(x)` 代之。

如果 ``num`` 为 None,则它可以从 ``x.shape[axis]`` 中推断而来。

C
Cheerego 已提交
11204
如果 ``x.shape[axis]`` <= 0或者Unknown, 则抛出异常 ``ValueError`` 。
C
Cheerego 已提交
11205

C
Cheerego 已提交
11206
参数:
C
Cheerego 已提交
11207 11208 11209 11210 11211 11212
  - **x** (Variable|list(Variable)|tuple(Variable)) – 输入变量
  - **axis** (int|None) – 对输入进行unstack运算所在的轴
  - **num** (int|None) - 输出变量的数目

返回: 经unstack运算后的变量

T
Tink_Y 已提交
11213
返回类型: list(Variable)
C
Cheerego 已提交
11214

R
RaindragonD 已提交
11215
**代码示例**:
C
Cheerego 已提交
11216

R
RaindragonD 已提交
11217
.. code-block:: python
C
Cheerego 已提交
11218

R
RaindragonD 已提交
11219 11220 11221
    import paddle.fluid as fluid
    x = fluid.layers.data(name='x', shape=[5, 10], dtype='float32')
    y = fluid.layers.unstack(x, axis=1)
C
Cheerego 已提交
11222 11223 11224 11225 11226 11227 11228 11229 11230 11231 11232 11233







.. _cn_api_fluid_layers_warpctc:

warpctc
-------------------------------

11234
.. py:function:: paddle.fluid.layers.warpctc(input, label, blank=0, norm_by_times=False, use_cudnn=False)
C
Cheerego 已提交
11235 11236 11237 11238 11239 11240 11241 11242 11243 11244 11245 11246 11247 11248 11249 11250 11251 11252

该操作符集成了 `开源Warp-CTC库 <https://github.com/baidu-research/warp-ctc>`_ ,计算基于神经网络的时序类分类(CTC)损失。原生softmax激活函数集成到Wrap-CTC库中,操作符也可称作含CTC的softmax,将输入张量每一行的值正则化。

参数:
    - **input** (Variable) - 变长序列的非尺度化概率,是一个含LoD信息的二维张量。shape为[Lp,num_classes+1],Lp是所有输出序列长度之和,num_classes是实际类别数。(不包括空白标签)
    - **label** (Variable) - 变长序列中正确标记的数据,是一个含LoD信息的二维张量。shape为[Lg,1],Lg是所有标签长度之和
    - **blank** (int,默认0) - 基于神经网络的时序类分类(CTC)损失的空白标签索引,在半开区间间隔内[0,num_classes+1]
    - **norm_by_times** (bool,默认false) - 是否利用时间步长(即序列长度)的数量对梯度进行正则化。如果warpctc层后面跟着mean_op则无需对梯度正则化。
    - **use_cudnn** (bool, 默认false) - 是否使用cudnn

返回:基于神经网络的时序类分类(CTC)损失,是一个shape为[batch_size,1]的二维张量

返回类型:变量(Variable)

**代码示例**:

.. code-block:: python

R
RaindragonD 已提交
11253 11254 11255 11256 11257
    import paddle.fluid as fluid
    label = fluid.layers.data(name='label', shape=[11, 8],
                              dtype='float32', lod_level=1)
    predict = fluid.layers.data(name='predict', shape=[11, 1],
                                dtype='float32')
C
Cheerego 已提交
11258 11259 11260 11261 11262
    cost = fluid.layers.warpctc(input=predict, label=label)




R
RaindragonD 已提交
11263
.. _cn_api_fluid_layers_where:
C
Cheerego 已提交
11264

R
RaindragonD 已提交
11265 11266
where
-------------------------------
C
Cheerego 已提交
11267

R
RaindragonD 已提交
11268 11269 11270 11271 11272 11273 11274 11275 11276 11277 11278 11279 11280 11281 11282 11283 11284 11285 11286 11287 11288 11289 11290 11291 11292
.. py:function:: paddle.fluid.layers.where(condition)
     
返回一个秩为2的int64型张量,指定condition中真实元素的坐标。
     
输出的第一维是真实元素的数量,第二维是condition的秩(维数)。如果没有真实元素,则将生成空张量。
        
参数:
    - **condition** (Variable) - 秩至少为1的布尔型张量。

返回:存储一个二维张量的张量变量

返回类型:变量(Variable)
     
**代码示例**:

.. code-block:: python

        # condition为张量[True, False, True]
        out = fluid.layers.where(condition) # [[0], [2]]
     
        # condition为张量[[True, False], [False, True]]
        out = fluid.layers.where(condition) # [[0, 0], [1, 1]]
     
        # condition为张量[False, False, False]
        out = fluid.layers.where(condition) # [[]]
C
Cheerego 已提交
11293 11294 11295 11296 11297 11298





============
C
Cheerego 已提交
11299
 ops
C
Cheerego 已提交
11300 11301 11302 11303 11304 11305 11306 11307 11308 11309
============


.. _cn_api_fluid_layers_abs:

abs
-------------------------------

.. py:function:: paddle.fluid.layers.abs(x, name=None)

11310
绝对值激活函数。
H
Hao Wang 已提交
11311 11312 11313

.. math::
    out = |x|
C
Cheerego 已提交
11314 11315

参数:
C
Cheerego 已提交
11316

C
Cheerego 已提交
11317
    - **x** - abs算子的输入
11318
    - **use_cudnn** (BOOLEAN) – (bool,默认为false)是否仅用于cudnn核,需要安装cudnn
C
Cheerego 已提交
11319

11320
返回:        abs算子的输出。
C
Cheerego 已提交
11321

R
RaindragonD 已提交
11322
**代码示例**:
C
Cheerego 已提交
11323

R
RaindragonD 已提交
11324
.. code-block:: python
C
Cheerego 已提交
11325

R
RaindragonD 已提交
11326 11327
        data = fluid.layers.data(name="input", shape=[32, 784])
        result = fluid.layers.abs(data)
C
Cheerego 已提交
11328 11329


11330 11331 11332 11333 11334 11335 11336 11337 11338 11339 11340 11341 11342
.. _cn_api_fluid_layers_acos:

acos
-------------------------------

.. py:function:: paddle.fluid.layers.acos(x, name=None)

arccosine激活函数。

.. math::
    out = cos^{-1}(x)

参数:
C
Cheerego 已提交
11343 11344
    - **x** - acos算子的输入

11345 11346
返回:        acos算子的输出。

R
RaindragonD 已提交
11347 11348 11349 11350 11351 11352
**代码示例**:

.. code-block:: python

        data = fluid.layers.data(name="input", shape=[32, 784])
        result = fluid.layers.acos(data)
11353 11354 11355 11356 11357 11358 11359 11360 11361 11362 11363 11364 11365 11366 11367


.. _cn_api_fluid_layers_asin:

asin
-------------------------------

.. py:function:: paddle.fluid.layers.asin(x, name=None)

arcsine激活函数。

.. math::
    out = sin^{-1}(x)

参数:
C
Cheerego 已提交
11368 11369
    - **x** - asin算子的输入

11370 11371
返回:        asin算子的输出。

R
RaindragonD 已提交
11372 11373 11374 11375 11376 11377 11378 11379
**代码示例**:

.. code-block:: python

        data = fluid.layers.data(name="input", shape=[32, 784])
        result = fluid.layers.asin(data)


11380 11381 11382 11383 11384 11385 11386 11387 11388 11389 11390 11391 11392 11393

.. _cn_api_fluid_layers_atan:

atan
-------------------------------

.. py:function:: paddle.fluid.layers.atan(x, name=None)

arctanh激活函数。

.. math::
    out = tanh^{-1}(x)

参数:
C
Cheerego 已提交
11394 11395
    - **x** - atan算子的输入

11396
返回:       atan算子的输出。
C
Cheerego 已提交
11397

R
RaindragonD 已提交
11398 11399 11400 11401 11402 11403
**代码示例**:

.. code-block:: python

        data = fluid.layers.data(name="input", shape=[32, 784])
        result = fluid.layers.atan(data)
C
Cheerego 已提交
11404 11405 11406 11407 11408 11409 11410 11411 11412 11413 11414 11415





.. _cn_api_fluid_layers_ceil:

ceil
-------------------------------

.. py:function:: paddle.fluid.layers.ceil(x, name=None)

11416
向上取整运算激活函数。
H
Hao Wang 已提交
11417 11418 11419 11420 11421

.. math::
    out = \left \lceil x \right \rceil


C
Cheerego 已提交
11422 11423

参数:
C
Cheerego 已提交
11424

C
Cheerego 已提交
11425
    - **x** - Ceil算子的输入
11426
    - **use_cudnn** (BOOLEAN) – (bool,默认为false)是否仅用于cudnn核,需要安装cudnn
C
Cheerego 已提交
11427

11428
返回:        Ceil算子的输出。
C
Cheerego 已提交
11429

R
RaindragonD 已提交
11430 11431 11432 11433 11434 11435
**代码示例**:

.. code-block:: python

        data = fluid.layers.data(name="input", shape=[32, 784])
        result = fluid.layers.ceil(data)
C
Cheerego 已提交
11436

C
Cheerego 已提交
11437 11438 11439 11440 11441 11442 11443 11444 11445 11446 11447 11448 11449 11450 11451








.. _cn_api_fluid_layers_cos:

cos
-------------------------------

.. py:function:: paddle.fluid.layers.cos(x, name=None)

H
Hao Wang 已提交
11452 11453 11454 11455 11456 11457
Cosine余弦激活函数。

.. math::

    out = cos(x)

C
Cheerego 已提交
11458 11459 11460


参数:
C
Cheerego 已提交
11461

C
Cheerego 已提交
11462
    - **x** - cos算子的输入
11463
    - **use_cudnn** (BOOLEAN) – (bool,默认为false)是否仅用于cudnn核,需要安装cudnn
H
Hao Wang 已提交
11464

C
Cheerego 已提交
11465

11466
返回:        Cos算子的输出
C
Cheerego 已提交
11467

R
RaindragonD 已提交
11468 11469 11470
**代码示例**:

.. code-block:: python
C
Cheerego 已提交
11471

R
RaindragonD 已提交
11472 11473
        data = fluid.layers.data(name="input", shape=[32, 784])
        result = fluid.layers.cos(data)
C
Cheerego 已提交
11474 11475 11476 11477 11478 11479 11480 11481 11482 11483 11484 11485 11486








.. _cn_api_fluid_layers_cumsum:

cumsum
-------------------------------

11487
.. py:function:: paddle.fluid.layers.cumsum(x,axis=None,exclusive=None,reverse=None)
C
Cheerego 已提交
11488 11489 11490 11491 11492 11493 11494 11495 11496 11497 11498 11499 11500 11501 11502 11503 11504 11505 11506 11507 11508 11509 11510 11511 11512 11513 11514 11515 11516 11517 11518 11519

沿给定轴的元素的累加和。默认结果的第一个元素和输入的第一个元素一致。如果exlusive为真,结果的第一个元素则为0。

参数:
    - **x** -累加操作符的输入
    - **axis** (INT)-需要累加的维。-1代表最后一维。[默认 -1]。
    - **exclusive** (BOOLEAN)-是否执行exclusive累加。[默认false]。
    - **reverse** (BOOLEAN)-若为true,则以相反顺序执行累加。[默认 false]。

返回:累加器的输出

**代码示例**:

.. code-block:: python

    data = fluid.layers.data(name="input", shape=[32, 784])
    result = fluid.layers.cumsum(data, axis=0)









.. _cn_api_fluid_layers_exp:

exp
-------------------------------

.. py:function:: paddle.fluid.layers.exp(x, name=None)
H
Hao Wang 已提交
11520 11521 11522 11523 11524

Exp激活函数(Exp指以自然常数e为底的指数运算)。

.. math::
    out = e^x
C
Cheerego 已提交
11525 11526

参数:
C
Cheerego 已提交
11527

C
Cheerego 已提交
11528
    - **x** - Exp算子的输入
11529
    - **use_cudnn** (BOOLEAN) – (bool,默认为false)是否仅用于cudnn核,需要安装cudnn
H
Hao Wang 已提交
11530

C
Cheerego 已提交
11531 11532 11533

返回:       Exp算子的输出

R
RaindragonD 已提交
11534 11535 11536 11537 11538 11539
**代码示例**:

.. code-block:: python

        data = fluid.layers.data(name="input", shape=[32, 784])
        result = fluid.layers.exp(data)
C
Cheerego 已提交
11540 11541 11542 11543 11544 11545 11546 11547 11548 11549 11550 11551 11552 11553 11554 11555 11556









.. _cn_api_fluid_layers_floor:

floor
-------------------------------

.. py:function:: paddle.fluid.layers.floor(x, name=None)


11557
向下取整运算激活函数。
H
Hao Wang 已提交
11558 11559 11560 11561

.. math::
    out = \left \lfloor x \right \rfloor

C
Cheerego 已提交
11562 11563

参数:
C
Cheerego 已提交
11564

C
Cheerego 已提交
11565
    - **x** - Floor算子的输入
11566
    - **use_cudnn** (BOOLEAN) – (bool,默认为false)是否仅用于cudnn核,需要安装cudnn
H
Hao Wang 已提交
11567

C
Cheerego 已提交
11568

11569
返回:        Floor算子的输出。
C
Cheerego 已提交
11570

R
RaindragonD 已提交
11571 11572 11573 11574 11575 11576
**代码示例**:

.. code-block:: python

        data = fluid.layers.data(name="input", shape=[32, 784])
        result = fluid.layers.floor(data)
C
Cheerego 已提交
11577 11578 11579 11580 11581 11582 11583 11584 11585 11586 11587 11588 11589 11590 11591 11592 11593 11594 11595 11596 11597










.. _cn_api_fluid_layers_hard_shrink:

hard_shrink
-------------------------------

.. py:function:: paddle.fluid.layers.hard_shrink(x,threshold=None)

HardShrink激活函数(HardShrink activation operator)


.. math::
C
Cheerego 已提交
11598

R
RaindragonD 已提交
11599
  out = \begin{cases}
C
Cheerego 已提交
11600 11601 11602 11603 11604 11605 11606 11607 11608 11609 11610 11611 11612
        x, \text{if } x > \lambda \\
        x, \text{if } x < -\lambda \\
        0,  \text{otherwise}
      \end{cases}

参数:
    - **x** - HardShrink激活函数的输入
    - **threshold** (FLOAT)-HardShrink激活函数的threshold值。[默认:0.5]

返回:HardShrink激活函数的输出

**代码示例**:

T
Tink_Y 已提交
11613
.. code-block:: python
C
Cheerego 已提交
11614

T
Tink_Y 已提交
11615
    data = fluid.layers.data(name="input", shape=[784])
C
Cheerego 已提交
11616
    result = fluid.layers.hard_shrink(x=data, threshold=0.3)
C
Cheerego 已提交
11617 11618 11619 11620 11621 11622 11623 11624 11625 11626 11627 11628 11629 11630 11631









.. _cn_api_fluid_layers_logsigmoid:

logsigmoid
-------------------------------

.. py:function:: paddle.fluid.layers.logsigmoid(x, name=None)
H
Hao Wang 已提交
11632 11633 11634 11635 11636 11637 11638

Logsigmoid激活函数。


.. math::

    out = \log \frac{1}{1 + e^{-x}}
C
Cheerego 已提交
11639 11640 11641


参数:
11642
    - **x** - LogSigmoid算子的输入
C
Cheerego 已提交
11643
    - **use_cudnn** (BOOLEAN) – (bool,默认为false)是否仅用于cudnn核,需要安装cudnn
C
Cheerego 已提交
11644

11645
返回:        LogSigmoid算子的输出
C
Cheerego 已提交
11646

R
RaindragonD 已提交
11647 11648 11649 11650 11651 11652
**代码示例**:

.. code-block:: python

        data = fluid.layers.data(name="input", shape=[32, 784])
        result = fluid.layers.logsigmoid(data)
C
Cheerego 已提交
11653 11654 11655 11656 11657 11658 11659 11660 11661 11662 11663 11664 11665 11666 11667 11668









.. _cn_api_fluid_layers_reciprocal:

reciprocal
-------------------------------

.. py:function:: paddle.fluid.layers.reciprocal(x, name=None)

H
Hao Wang 已提交
11669 11670 11671 11672 11673
Reciprocal(取倒数)激活函数


.. math::
    out = \frac{1}{x}
C
Cheerego 已提交
11674 11675

参数:
C
Cheerego 已提交
11676

C
Cheerego 已提交
11677 11678
    - **x** - reciprocal算子的输入
    - **use_cudnn** (BOOLEAN) – (bool,默认为false)是否仅用于cudnn核,需要安装cudnn
C
Cheerego 已提交
11679

C
Cheerego 已提交
11680
返回:        Reciprocal算子的输出。
C
Cheerego 已提交
11681

R
RaindragonD 已提交
11682 11683 11684 11685 11686 11687 11688 11689 11690
**代码示例**:

.. code-block:: python

        data = fluid.layers.data(name="input", shape=[32, 784])
        result = fluid.layers.reciprocal(data)



C
Cheerego 已提交
11691 11692 11693 11694 11695 11696 11697 11698 11699 11700 11701 11702 11703 11704 11705 11706









.. _cn_api_fluid_layers_round:

round
-------------------------------

.. py:function:: paddle.fluid.layers.round(x, name=None)

H
Hao Wang 已提交
11707 11708 11709 11710 11711 11712
Round取整激活函数。


.. math::
     out = [x]

C
Cheerego 已提交
11713 11714

参数:
C
Cheerego 已提交
11715

C
Cheerego 已提交
11716 11717
    - **x** - round算子的输入
    - **use_cudnn** (BOOLEAN) – (bool,默认为false)是否仅用于cudnn核,需要安装cudnn
C
Cheerego 已提交
11718

11719
返回:        Round算子的输出。
C
Cheerego 已提交
11720

R
RaindragonD 已提交
11721 11722 11723 11724 11725 11726 11727 11728 11729 11730 11731 11732 11733 11734 11735
**代码示例**:

.. code-block:: python

        data = fluid.layers.data(name="input", shape=[32, 784])
        result = fluid.layers.round(data)



.. _cn_api_fluid_layers_rsqrt:

rsqrt
-------------------------------

.. py:function:: paddle.fluid.layers.rsqrt(x, name=None)
C
Cheerego 已提交
11736

R
RaindragonD 已提交
11737 11738 11739 11740 11741 11742 11743 11744 11745
rsqrt激活函数

请确保输入合法以免出现数字错误。

.. math::
    out = \frac{1}{\sqrt{x}}


参数:
C
Cheerego 已提交
11746

R
RaindragonD 已提交
11747 11748
    - **x** - rsqrt算子的输入 
    - **use_cudnn** (BOOLEAN) – (bool,默认为false)是否仅用于cudnn核,需要安装cudnn
C
Cheerego 已提交
11749

R
RaindragonD 已提交
11750
返回:     rsqrt运算输出
C
Cheerego 已提交
11751

R
RaindragonD 已提交
11752
**代码示例**:
C
Cheerego 已提交
11753

R
RaindragonD 已提交
11754
.. code-block:: python
C
Cheerego 已提交
11755

R
RaindragonD 已提交
11756 11757
        data = fluid.layers.data(name="input", shape=[32, 784])
        result = fluid.layers.rsqrt(data)
C
Cheerego 已提交
11758 11759 11760 11761 11762 11763 11764 11765 11766



.. _cn_api_fluid_layers_sigmoid:

sigmoid
-------------------------------

.. py:function:: paddle.fluid.layers.sigmoid(x, name=None)
H
Hao Wang 已提交
11767 11768 11769 11770 11771

sigmoid激活函数

.. math::
    out = \frac{1}{1 + e^{-x}}
C
Cheerego 已提交
11772 11773 11774


参数:
C
Cheerego 已提交
11775

C
Cheerego 已提交
11776
    - **x** - Sigmoid算子的输入
11777
    - **use_cudnn** (BOOLEAN) – (bool,默认为false)是否仅用于cudnn核,需要安装cudnn
C
Cheerego 已提交
11778 11779 11780

返回:     Sigmoid运算输出.

R
RaindragonD 已提交
11781 11782 11783 11784 11785 11786 11787 11788 11789
**代码示例**:

.. code-block:: python

        data = fluid.layers.data(name="input", shape=[32, 784])
        result = fluid.layers.sigmoid(data)



C
Cheerego 已提交
11790

C
Cheerego 已提交
11791

C
Cheerego 已提交
11792 11793 11794 11795 11796 11797 11798 11799 11800 11801 11802 11803 11804 11805







.. _cn_api_fluid_layers_sin:

sin
-------------------------------

.. py:function:: paddle.fluid.layers.sin(x, name=None)

H
Hao Wang 已提交
11806 11807 11808 11809 11810
正弦sine激活函数。

.. math::
     out = sin(x)

C
Cheerego 已提交
11811 11812

参数:
C
Cheerego 已提交
11813

C
Cheerego 已提交
11814
    - **x** - sin算子的输入
11815
    - **use_cudnn** (BOOLEAN) – (bool,默认为false)是否仅用于cudnn核,需要安装cudnn
H
Hao Wang 已提交
11816

C
Cheerego 已提交
11817

11818
返回:        Sin算子的输出。
C
Cheerego 已提交
11819

R
RaindragonD 已提交
11820 11821 11822 11823 11824 11825 11826 11827 11828
**代码示例**:

.. code-block:: python

        data = fluid.layers.data(name="input", shape=[32, 784])
        result = fluid.layers.sin(data)



C
Cheerego 已提交
11829 11830 11831 11832 11833 11834 11835 11836 11837 11838 11839 11840 11841 11842 11843 11844 11845










.. _cn_api_fluid_layers_softplus:

softplus
-------------------------------

.. py:function:: paddle.fluid.layers.softplus(x,name=None)

H
Hao Wang 已提交
11846 11847 11848 11849 11850
softplus激活函数。

.. math::
    out = \ln(1 + e^{x})

C
Cheerego 已提交
11851
参数:
11852 11853
    - **x** - Softplus操作符的输入
    - **use_cudnn** (BOOLEAN) – (bool,默认为false)是否仅用于cudnn核,需要安装cudnn
C
Cheerego 已提交
11854 11855 11856

返回:Softplus操作后的结果

R
RaindragonD 已提交
11857 11858 11859 11860 11861 11862 11863 11864 11865
**代码示例**:

.. code-block:: python

        data = fluid.layers.data(name="input", shape=[32, 784])
        result = fluid.layers.softplus(data)



C
Cheerego 已提交
11866 11867 11868 11869 11870 11871 11872 11873 11874 11875 11876 11877 11878








.. _cn_api_fluid_layers_softshrink:

softshrink
-------------------------------

C
Cheerego 已提交
11879
.. py:function:: paddle.fluid.layers.softshrink(x, name=None)
C
Cheerego 已提交
11880 11881 11882 11883 11884 11885 11886 11887 11888

Softshrink激活算子

.. math::
        out = \begin{cases}
                    x - \lambda, \text{if } x > \lambda \\
                    x + \lambda, \text{if } x < -\lambda \\
                    0,  \text{otherwise}
              \end{cases}
C
Cheerego 已提交
11889

C
Cheerego 已提交
11890
参数:
C
Cheerego 已提交
11891
        - **x** - Softshrink算子的输入
C
Cheerego 已提交
11892 11893
        - **lambda** (FLOAT)- 非负偏移量。

11894
返回:       Softshrink算子的输出
C
Cheerego 已提交
11895

R
RaindragonD 已提交
11896 11897 11898 11899 11900 11901 11902 11903 11904
**代码示例**:

.. code-block:: python

        data = fluid.layers.data(name="input", shape=[32, 784])
        result = fluid.layers.softshrink(data)



C
Cheerego 已提交
11905 11906 11907 11908 11909 11910 11911 11912 11913 11914 11915 11916 11917 11918









.. _cn_api_fluid_layers_softsign:

softsign
-------------------------------

11919
.. py:function:: paddle.fluid.layers.softsign(x,name=None)
C
Cheerego 已提交
11920

H
Hao Wang 已提交
11921 11922 11923 11924 11925 11926

softsign激活函数。

.. math::
    out = \frac{x}{1 + |x|}

C
Cheerego 已提交
11927 11928
参数:
    - **x** : Softsign操作符的输入
11929
    - **use_cudnn** (BOOLEAN) – (bool,默认为false)是否仅用于cudnn核,需要安装cudnn
H
Hao Wang 已提交
11930

C
Cheerego 已提交
11931 11932 11933

返回:Softsign操作后的结果

R
RaindragonD 已提交
11934 11935 11936 11937 11938 11939 11940 11941 11942
**代码示例**:

.. code-block:: python

        data = fluid.layers.data(name="input", shape=[32, 784])
        result = fluid.layers.softsign(data)



C
Cheerego 已提交
11943 11944 11945 11946 11947 11948 11949 11950 11951 11952 11953 11954 11955 11956 11957








.. _cn_api_fluid_layers_sqrt:

sqrt
-------------------------------

.. py:function:: paddle.fluid.layers.sqrt(x, name=None)

H
Hao Wang 已提交
11958 11959
算数平方根激活函数。

11960 11961 11962
请确保输入是非负数。有些训练当中,会出现输入为接近零的负值,此时应加上一个小值epsilon(1e-12)将其变为正数从而正确运算并进行后续的操作。


H
Hao Wang 已提交
11963 11964
.. math::
    out = \sqrt{x}
C
Cheerego 已提交
11965 11966

参数:
C
Cheerego 已提交
11967

C
Cheerego 已提交
11968
    - **x** - Sqrt算子的输入
11969
    - **use_cudnn** (BOOLEAN) – (bool,默认为false)是否仅用于cudnn核,需要安装cudnn
C
Cheerego 已提交
11970 11971 11972

返回:       Sqrt算子的输出。

R
RaindragonD 已提交
11973 11974 11975 11976 11977 11978 11979 11980 11981
**代码示例**:

.. code-block:: python

        data = fluid.layers.data(name="input", shape=[32, 784])
        result = fluid.layers.sqrt(data)



C
Cheerego 已提交
11982 11983 11984 11985 11986 11987 11988 11989 11990 11991 11992 11993 11994 11995 11996 11997 11998










.. _cn_api_fluid_layers_square:

square
-------------------------------

.. py:function:: paddle.fluid.layers.square(x,name=None)

H
Hao Wang 已提交
11999 12000 12001 12002 12003
取平方激活函数。

.. math::
    out = x^2

C
Cheerego 已提交
12004 12005
参数:
    - **x** : 平方操作符的输入
12006
    - **use_cudnn** (BOOLEAN) – (bool,默认为false)是否仅用于cudnn核,需要安装cudnn
C
Cheerego 已提交
12007 12008 12009

返回:平方后的结果

R
RaindragonD 已提交
12010 12011 12012 12013 12014 12015 12016 12017 12018
**代码示例**:

.. code-block:: python

        data = fluid.layers.data(name="input", shape=[32, 784])
        result = fluid.layers.square(data)



C
Cheerego 已提交
12019 12020 12021 12022 12023 12024 12025 12026 12027 12028 12029 12030 12031 12032








.. _cn_api_fluid_layers_tanh:

tanh
-------------------------------

.. py:function:: paddle.fluid.layers.tanh(x, name=None)
H
Hao Wang 已提交
12033 12034 12035 12036 12037 12038 12039 12040




tanh 激活函数。

.. math::
    out = \frac{e^{x} - e^{-x}}{e^{x} + e^{-x}}
C
Cheerego 已提交
12041 12042 12043


参数:
C
Cheerego 已提交
12044

C
Cheerego 已提交
12045
    - **x** - Tanh算子的输入
12046
    - **use_cudnn** (BOOLEAN) – (bool,默认为false)是否仅用于cudnn核,需要安装cudnn
C
Cheerego 已提交
12047 12048 12049

返回:     Tanh算子的输出。

R
RaindragonD 已提交
12050 12051 12052 12053 12054 12055 12056 12057 12058
**代码示例**:

.. code-block:: python

        data = fluid.layers.data(name="input", shape=[32, 784])
        result = fluid.layers.tanh(data)



C
Cheerego 已提交
12059 12060 12061 12062 12063 12064 12065 12066 12067 12068 12069 12070 12071 12072 12073 12074 12075










.. _cn_api_fluid_layers_tanh_shrink:

tanh_shrink
-------------------------------

.. py:function:: paddle.fluid.layers.tanh_shrink(x, name=None)

H
Hao Wang 已提交
12076 12077 12078 12079
tanh_shrink激活函数。

.. math::
    out = x - \frac{e^{x} - e^{-x}}{e^{x} + e^{-x}}
C
Cheerego 已提交
12080 12081

参数:
C
Cheerego 已提交
12082

C
Cheerego 已提交
12083
    - **x** - TanhShrink算子的输入
12084
    - **use_cudnn** (BOOLEAN) – (bool,默认为false)是否仅用于cudnn核,需要安装cudnn
C
Cheerego 已提交
12085 12086 12087

返回:     tanh_shrink算子的输出

R
RaindragonD 已提交
12088 12089 12090 12091 12092 12093 12094
**代码示例**:

.. code-block:: python

        data = fluid.layers.data(name="input", shape=[32, 784])
        result = fluid.layers.tanh_shrink(data)

C
Cheerego 已提交
12095 12096 12097 12098 12099 12100 12101 12102 12103 12104 12105 12106 12107 12108 12109








.. _cn_api_fluid_layers_thresholded_relu:

thresholded_relu
-------------------------------

.. py:function:: paddle.fluid.layers.thresholded_relu(x,threshold=None)

T
Tink_Y 已提交
12110
ThresholdedRelu激活函数
C
Cheerego 已提交
12111

T
Tink_Y 已提交
12112
.. math::
C
Cheerego 已提交
12113

R
RaindragonD 已提交
12114 12115 12116 12117
  out = \left\{\begin{matrix}
      x, &if x > threshold\\
      0, &otherwise
      \end{matrix}\right.
C
Cheerego 已提交
12118 12119

参数:
T
Tink_Y 已提交
12120 12121 12122 12123
- **x** -ThresholdedRelu激活函数的输入
- **threshold** (FLOAT)-激活函数threshold的位置。[默认1.0]。

返回:ThresholdedRelu激活函数的输出
C
Cheerego 已提交
12124

T
Tink_Y 已提交
12125
**代码示例**:
C
Cheerego 已提交
12126

T
Tink_Y 已提交
12127
.. code-block:: python
C
Cheerego 已提交
12128

R
RaindragonD 已提交
12129 12130
  data = fluid.layers.data(name="input", shape=[1])
  result = fluid.layers.thresholded_relu(data, threshold=0.4)
C
Cheerego 已提交
12131 12132 12133 12134 12135 12136 12137 12138 12139 12140 12141 12142 12143 12144









.. _cn_api_fluid_layers_uniform_random:

uniform_random
-------------------------------

12145
.. py:function:: paddle.fluid.layers.uniform_random(shape, dtype='float32', min=-1.0, max=1.0, seed=0)
T
Tink_Y 已提交
12146
该操作符初始化一个张量,该张量的值是从均匀分布中抽样的随机值
C
Cheerego 已提交
12147 12148 12149

参数:
    - **shape** (LONGS)-输出张量的维
12150
    - **dtype** (np.dtype|core.VarDesc.VarType|str) – 数据的类型, 例如float32, float64。 默认: float32.
C
Cheerego 已提交
12151 12152 12153 12154 12155 12156 12157 12158 12159
    - **min** (FLOAT)-均匀随机分布的最小值。[默认 -1.0]
    - **max** (FLOAT)-均匀随机分布的最大值。[默认 1.0]
    - **seed** (INT)-随机种子,用于生成样本。0表示使用系统生成的种子。注意如果种子不为0,该操作符每次都生成同样的随机数。[默认 0]


**代码示例**:

.. code-block:: python

R
RaindragonD 已提交
12160
    import paddle.fluid as fluid
C
Cheerego 已提交
12161 12162 12163 12164 12165 12166 12167 12168 12169 12170 12171 12172 12173
    result = fluid.layers.uniform_random(shape=[32, 784])











============
C
Cheerego 已提交
12174
 tensor
C
Cheerego 已提交
12175 12176 12177 12178 12179 12180 12181 12182
============


.. _cn_api_fluid_layers_argmax:

argmax
-------------------------------

H
Hao Wang 已提交
12183
.. py:function:: paddle.fluid.layers.argmax(x,axis=0)
C
Cheerego 已提交
12184

T
Tink_Y 已提交
12185
**argmax**
C
Cheerego 已提交
12186

T
Tink_Y 已提交
12187 12188 12189 12190 12191
该功能计算输入张量元素中最大元素的索引,张量的元素在提供的轴上。

参数:
    - **x** (Variable)-用于计算最大元素索引的输入
    - **axis** (int)-用于计算索引的轴
C
Cheerego 已提交
12192

T
Tink_Y 已提交
12193 12194 12195
返回:存储在输出中的张量

返回类型:变量(Variable)
C
Cheerego 已提交
12196

T
Tink_Y 已提交
12197
**代码示例**:
C
Cheerego 已提交
12198

T
Tink_Y 已提交
12199
.. code-block:: python
R
RaindragonD 已提交
12200 12201
    
    x = fluid.layers.data(name="x", shape=[3, 4], dtype="float32")
T
Tink_Y 已提交
12202 12203
    out = fluid.layers.argmax(x=in, axis=0)
    out = fluid.layers.argmax(x=in, axis=-1)
C
Cheerego 已提交
12204 12205 12206 12207 12208 12209 12210 12211 12212 12213 12214 12215 12216 12217









.. _cn_api_fluid_layers_argmin:

argmin
-------------------------------

T
Tink_Y 已提交
12218
.. py:function:: paddle.fluid.layers.argmin(x,axis=0)
C
Cheerego 已提交
12219

T
Tink_Y 已提交
12220
**argmin**
C
Cheerego 已提交
12221

T
Tink_Y 已提交
12222 12223 12224 12225 12226
该功能计算输入张量元素中最小元素的索引,张量元素在提供的轴上。

参数:
    - **x** (Variable)-计算最小元素索引的输入
    - **axis** (int)-计算索引的轴
C
Cheerego 已提交
12227

T
Tink_Y 已提交
12228
返回:存储在输出中的张量
C
Cheerego 已提交
12229

T
Tink_Y 已提交
12230
返回类型:变量(Variable)
C
Cheerego 已提交
12231

T
Tink_Y 已提交
12232
**代码示例**:
C
Cheerego 已提交
12233

T
Tink_Y 已提交
12234
.. code-block:: python
R
RaindragonD 已提交
12235 12236
    
    x = fluid.layers.data(name="x", shape=[3, 4], dtype="float32")
T
Tink_Y 已提交
12237 12238
    out = fluid.layers.argmin(x=in, axis=0)
    out = fluid.layers.argmin(x=in, axis=-1)
C
Cheerego 已提交
12239

C
Cheerego 已提交
12240 12241 12242 12243 12244 12245 12246 12247 12248 12249 12250 12251 12252








.. _cn_api_fluid_layers_argsort:

argsort
-------------------------------

T
Tink_Y 已提交
12253
.. py:function:: paddle.fluid.layers.argsort(input,axis=-1,name=None)
C
Cheerego 已提交
12254

T
Tink_Y 已提交
12255
对输入变量沿给定轴进行排序,输出排序好的数据和相应的索引,其维度和输入相同
C
Cheerego 已提交
12256 12257 12258

.. code-block:: text

C
Cheerego 已提交
12259
    例如:
R
RaindragonD 已提交
12260
  给定 input 并指定 axis=-1
C
Cheerego 已提交
12261 12262 12263 12264

        input = [[0.15849551, 0.45865775, 0.8563702 ],
                [0.12070083, 0.28766365, 0.18776911]],

R
RaindragonD 已提交
12265
      执行argsort操作后,得到排序数据:
C
Cheerego 已提交
12266 12267 12268

        out = [[0.15849551, 0.45865775, 0.8563702 ],
            [0.12070083, 0.18776911, 0.28766365]],
C
Cheerego 已提交
12269

R
RaindragonD 已提交
12270
  根据指定axis排序后的数据indices变为:
C
Cheerego 已提交
12271 12272 12273 12274 12275 12276

        indices = [[0, 1, 2],
                [0, 2, 1]]

参数:
    - **input** (Variable)-用于排序的输入变量
T
Tink_Y 已提交
12277
    - **axis** (int)- 沿该参数指定的轴对输入进行排序。当axis<0,实际的轴为axis+rank(input)。默认为-1,即最后一维。
C
Cheerego 已提交
12278 12279
    - **name** (str|None)-(可选)该层名称。如果设为空,则自动为该层命名。

T
Tink_Y 已提交
12280
返回:一组已排序的数据变量和索引
C
Cheerego 已提交
12281 12282 12283 12284 12285 12286 12287

返回类型:元组

**代码示例**:

.. code-block:: python

R
RaindragonD 已提交
12288 12289
    x = fluid.layers.data(name="x", shape=[3, 4], dtype="float32")
    out, indices = fluid.layers.argsort(input=x, axis=0)
C
Cheerego 已提交
12290 12291 12292 12293 12294 12295 12296 12297 12298 12299 12300 12301 12302 12303 12304 12305









.. _cn_api_fluid_layers_assign:

assign
-------------------------------

.. py:function:: paddle.fluid.layers.assign(input,output=None)

R
RaindragonD 已提交
12306
该函数将输入变量复制到输出变量
C
Cheerego 已提交
12307 12308 12309 12310 12311 12312 12313 12314 12315 12316 12317 12318 12319

参数:
    - **input** (Variable|numpy.ndarray)-源变量
    - **output** (Variable|None)-目标变量

返回:作为输出的目标变量

返回类型:变量(Variable)

**代码示例**:

.. code-block:: python

R
RaindragonD 已提交
12320 12321
    import paddle.fluid as fluid
    data = fluid.layers.data(name="data", shape=[3, 32, 32], dtype="float32")
C
Cheerego 已提交
12322 12323 12324 12325 12326 12327 12328 12329 12330 12331 12332 12333 12334 12335
    out = fluid.layers.create_tensor(dtype='float32')
    hidden = fluid.layers.fc(input=data, size=10)
    fluid.layers.assign(hidden, out)









.. _cn_api_fluid_layers_cast:

C
Cheerego 已提交
12336
cast
C
Cheerego 已提交
12337 12338 12339 12340
-------------------------------

.. py:function:: paddle.fluid.layers.cast(x,dtype)

12341
该层传入变量x, 并用x.dtype将x转换成dtype类型,作为输出。如果输出的dtype和输入的dtype相同,则使用cast是没有意义的,但如果真的这么做了也不会报错。
C
Cheerego 已提交
12342 12343 12344 12345 12346 12347 12348 12349 12350 12351 12352 12353 12354 12355 12356 12357 12358 12359 12360 12361 12362 12363 12364 12365 12366 12367 12368 12369 12370 12371 12372

参数:
    - **x** (Variable)-转换函数的输入变量
    - **dtype** (np.dtype|core.VarDesc.VarType|str)-输出变量的数据类型

返回:转换后的输出变量

返回类型:变量(Variable)

**代码示例**:

.. code-block:: python

    data = fluid.layers.data(name='x', shape=[13], dtype='float32')
    result = fluid.layers.cast(x=data, dtype='float64')









.. _cn_api_fluid_layers_concat:

concat
-------------------------------

.. py:function:: paddle.fluid.layers.concat(input,axis=0,name=None)

C
Cheerego 已提交
12373
**Concat**
C
Cheerego 已提交
12374 12375 12376 12377 12378 12379 12380 12381 12382 12383 12384 12385 12386 12387 12388

这个函数将输入连接在前面提到的轴上,并将其作为输出返回。

参数:
    - **input** (list)-将要联结的张量列表
    - **axis** (int)-数据类型为整型的轴,其上的张量将被联结
    - **name** (str|None)-该层名称(可选)。如果设为空,则自动为该层命名。

返回:输出的联结变量

返回类型:变量(Variable)

**代码示例**:

.. code-block:: python
R
RaindragonD 已提交
12389 12390 12391 12392 12393
    
    a = fluid.layers.data(name='a', shape=[2, 13], dtype='float32')
    b = fluid.layers.data(name='b', shape=[2, 3], dtype='float32')
    c = fluid.layers.data(name='c', shape=[2, 2], dtype='float32')
    d = fluid.layers.data(name='d', shape=[2, 5], dtype='float32')
C
Cheerego 已提交
12394 12395 12396 12397 12398 12399 12400 12401 12402 12403 12404 12405 12406 12407 12408 12409 12410
    out = fluid.layers.concat(input=[Efirst, Esecond, Ethird, Efourth])









.. _cn_api_fluid_layers_create_global_var:

create_global_var
-------------------------------

.. py:function:: paddle.fluid.layers.create_global_var(shape,value,dtype,persistable=False,force_cpu=False,name=None)

T
Tink_Y 已提交
12411
在全局块中创建一个新的带有 ``value`` 的张量。
C
Cheerego 已提交
12412 12413 12414 12415 12416 12417 12418 12419 12420 12421 12422 12423 12424 12425 12426 12427 12428

参数:
    - **shape** (list[int])-变量的维度
    - **value** (float)-变量的值。填充新创建的变量
    - **dtype** (string)-变量的数据类型
    - **persistable** (bool)-如果是永久变量。默认:False
    - **force_cpu** (bool)-将该变量压入CPU。默认:False
    - **name** (str|None)-变量名。如果设为空,则自动创建变量名。默认:None.

返回:创建的变量

返回类型:变量(Variable)

**代码示例**:

.. code-block:: python

R
RaindragonD 已提交
12429 12430
    import paddle.fluid.layers as layers
    var = layers.create_global_var(shape=[2,3], value=1.0, dtype='float32',
C
Cheerego 已提交
12431 12432 12433 12434 12435 12436 12437 12438 12439 12440 12441 12442 12443 12444 12445 12446 12447 12448 12449 12450 12451 12452 12453 12454 12455 12456 12457 12458 12459 12460 12461 12462 12463 12464
                     persistable=True, force_cpu=True, name='new_var')









.. _cn_api_fluid_layers_create_parameter:

create_parameter
-------------------------------

.. py:function:: paddle.fluid.layers.create_parameter(shape,dtype,name=None,attr=None,is_bias=False,default_initializer=None)

创建一个参数。该参数是一个可学习的变量,拥有梯度并且可优化。

注:这是一个低级别的API。如果您希望自己创建新的op,这个API将非常有用,无需使用layers。

参数:
    - **shape** (list[int])-参数的维度
    - **dtype** (string)-参数的元素类型
    - **attr** (ParamAttr)-参数的属性
    - **is_bias** (bool)-当default_initializer为空,该值会对选择哪个默认初始化程序产生影响。如果is_bias为真,则使用initializer.Constant(0.0),否则使用Xavier()。
    - **default_initializer** (Initializer)-参数的初始化程序

返回:创建的参数

**代码示例**:

.. code-block:: python

R
RaindragonD 已提交
12465
    import paddle.fluid.layers as layers
C
Cheerego 已提交
12466 12467 12468 12469 12470 12471 12472 12473 12474 12475 12476 12477 12478 12479 12480 12481 12482 12483 12484 12485 12486 12487
    W = fluid.layers.create_parameter(shape=[784, 200], dtype='float32')









.. _cn_api_fluid_layers_create_tensor:

create_tensor
-------------------------------

.. py:function:: paddle.fluid.layers.create_tensor(dtype,name=None,persistable=False)

创建一个变量,存储数据类型为dtype的LoDTensor。

参数:
    - **dtype** (string)-“float32”|“int32”|..., 创建张量的数据类型。
    - **name** (string)-创建张量的名称。如果未设置,则随机取一个唯一的名称。
T
Tink_Y 已提交
12488
    - **persistable** (bool)-是否将创建的张量设置为 persistable
C
Cheerego 已提交
12489

T
Tink_Y 已提交
12490
返回:一个张量,存储着创建的张量
C
Cheerego 已提交
12491 12492 12493 12494 12495 12496 12497 12498 12499 12500 12501

返回类型:变量(Variable)

**代码示例**:

.. code-block:: python

    tensor = fluid.layers.create_tensor(dtype='float32')



R
RaindragonD 已提交
12502
.. _cn_api_fluid_layers_diag:
C
Cheerego 已提交
12503

R
RaindragonD 已提交
12504 12505 12506 12507
diag
-------------------------------

.. py:function:: paddle.fluid.layers.diag(diagonal)
C
Cheerego 已提交
12508

R
RaindragonD 已提交
12509
该功能创建一个方阵,含有diagonal指定的对角线值。
C
Cheerego 已提交
12510

R
RaindragonD 已提交
12511 12512 12513 12514 12515 12516 12517 12518 12519 12520 12521 12522 12523 12524 12525
参数:
    - **diagonal** (Variable|numpy.ndarray) - 指定对角线值的输入张量,其秩应为1。

返回:存储着方阵的张量变量

返回类型:变量(Variable)

**代码示例**:

.. code-block:: python

        #  [3, 0, 0]
        #  [0, 4, 0]
        #  [0, 0, 5]
        data = fluid.layers.diag(np.arange(3, 6))
C
Cheerego 已提交
12526 12527 12528 12529 12530 12531 12532 12533 12534




.. _cn_api_fluid_layers_fill_constant:

fill_constant
-------------------------------

T
Tink_Y 已提交
12535
.. py:function:: paddle.fluid.layers.fill_constant(shape,dtype,value,force_cpu=False,out=None)
C
Cheerego 已提交
12536

T
Tink_Y 已提交
12537
该功能创建一个张量,含有具体的shape,dtype和batch尺寸。并用 ``value`` 中提供的常量初始化该张量。
C
Cheerego 已提交
12538 12539 12540 12541

创建张量的属性stop_gradient设为True。

参数:
T
Tink_Y 已提交
12542 12543 12544
    - **shape** (tuple|list|None)-输出张量的形状
    - **dtype** (np.dtype|core.VarDesc.VarType|str)-输出张量的数据类型
    - **value** (float)-用于初始化输出张量的常量值
C
Cheerego 已提交
12545 12546 12547
    - **out** (Variable)-输出张量
    - **force_cpu** (True|False)-若设为true,数据必须在CPU上

T
Tink_Y 已提交
12548
返回:存储着输出的张量
C
Cheerego 已提交
12549 12550 12551 12552 12553 12554 12555

返回类型:变量(Variable)

**代码示例**:

.. code-block:: python

R
RaindragonD 已提交
12556
    import paddle.fluid as fluid
C
Cheerego 已提交
12557 12558 12559 12560 12561 12562 12563 12564 12565 12566 12567 12568 12569 12570 12571 12572 12573
    data = fluid.layers.fill_constant(shape=[1], value=0, dtype='int64')









.. _cn_api_fluid_layers_fill_constant_batch_size_like:

fill_constant_batch_size_like
-------------------------------

.. py:function:: paddle.fluid.layers.fill_constant_batch_size_like(input,shape,dtype,value,input_dim_idx=0,output_dim_idx=0)

T
Tink_Y 已提交
12574
该功能创建一个张量,含有具体的shape,dtype和batch尺寸。并用 ``Value`` 中提供的常量初始化该张量。该批尺寸从输入张量中获取。它还将stop_gradient设置为True.
C
Cheerego 已提交
12575 12576

参数:
H
Hao Wang 已提交
12577
    - **input** (Variable)-张量,其第input_dim_idx维可指定batch_size
T
Tink_Y 已提交
12578
    - **shape** (INTS)-输出的形状
C
Cheerego 已提交
12579 12580 12581 12582 12583
    - **dtype** (INT)-可以为numpy.dtype。输出数据类型。默认为float32
    - **value** (FLOAT)-默认为0.将要被填充的值
    - **input_dim_idx** (INT)-默认为0.输入批尺寸维的索引
    - **output_dim_idx** (INT)-默认为0.输出批尺寸维的索引

T
Tink_Y 已提交
12584
返回:具有特定形状和值的张量
C
Cheerego 已提交
12585 12586 12587 12588 12589

**代码示例**:

.. code-block:: python

R
RaindragonD 已提交
12590 12591
    import paddle.fluid as fluid
    like = fluid.layers.data(name='like', shape=[1], dtype='float32')
C
Cheerego 已提交
12592 12593 12594 12595 12596 12597 12598 12599 12600 12601 12602 12603 12604 12605 12606 12607 12608 12609 12610 12611 12612 12613
    data = fluid.layers.fill_constant_batch_size_like(
                input=like, shape=[1], value=0, dtype='int64')










.. _cn_api_fluid_layers_has_inf:

has_inf
-------------------------------

.. py:function:: paddle.fluid.layers.has_inf(x)

测试x是否包括一个无穷数

参数:
R
RaindragonD 已提交
12614
  - **x(variable)** - 用于被检查的Tensor/LoDTensor
C
Cheerego 已提交
12615

H
Hao Wang 已提交
12616
返回: tensor变量存储输出值,包含一个bool型数值
C
Cheerego 已提交
12617

T
Tink_Y 已提交
12618
返回类型:Variable
C
Cheerego 已提交
12619

R
RaindragonD 已提交
12620
**代码示例**:
C
Cheerego 已提交
12621

R
RaindragonD 已提交
12622
.. code-block:: python
C
Cheerego 已提交
12623

R
RaindragonD 已提交
12624 12625 12626
    import paddle.fluid as fluid
    data = fluid.layers.data(name="input", shape=[4, 32, 32], dtype="float32")
    res = fluid.layers.has_inf(data)
C
Cheerego 已提交
12627 12628 12629 12630 12631 12632 12633 12634 12635 12636 12637 12638 12639 12640 12641 12642 12643 12644 12645









.. _cn_api_fluid_layers_has_nan:

has_nan
-------------------------------

.. py:function:: paddle.fluid.layers.has_nan(x)

测试x是否包含NAN

参数:
R
RaindragonD 已提交
12646
  - **x(variable)** - 用于被检查的Tensor/LoDTensor
C
Cheerego 已提交
12647

H
Hao Wang 已提交
12648
返回: tensor变量存储输出值,包含一个bool型数值
C
Cheerego 已提交
12649

T
Tink_Y 已提交
12650
返回类型:Variable
C
Cheerego 已提交
12651

R
RaindragonD 已提交
12652
**代码示例**:
C
Cheerego 已提交
12653

R
RaindragonD 已提交
12654
.. code-block:: python
C
Cheerego 已提交
12655

R
RaindragonD 已提交
12656 12657 12658
    import paddle.fluid as fluid
    data = fluid.layers.data(name="input", shape=[4, 32, 32], dtype="float32")
    res = fluid.layers.has_nan(data)
C
Cheerego 已提交
12659 12660 12661 12662 12663 12664 12665 12666 12667 12668 12669 12670 12671 12672 12673 12674




.. _cn_api_fluid_layers_isfinite:

isfinite
-------------------------------

.. py:function:: paddle.fluid.layers.isfinite(x)

测试x是否包含无穷大/NAN值,如果所有元素都是有穷数,返回Ture,否则返回False

参数:
  - **x(variable)** - 用于被检查的Tensor/LoDTensor

H
Hao Wang 已提交
12675
返回: Variable: tensor变量存储输出值,包含一个bool型数值
C
Cheerego 已提交
12676

T
Tink_Y 已提交
12677
返回类型:Variable
C
Cheerego 已提交
12678

R
RaindragonD 已提交
12679 12680 12681 12682 12683 12684 12685 12686 12687 12688 12689 12690 12691 12692 12693 12694 12695 12696 12697 12698 12699 12700 12701 12702 12703 12704 12705 12706 12707 12708 12709
**代码示例**:

.. code-block:: python

    var = fluid.layers.data(name="data",
                            shape=(4, 6),
                            dtype="float32")
    out = fluid.layers.isfinite(v)



.. _cn_api_fluid_layers_linspace:

linspace
-------------------------------

.. py:function:: paddle.fluid.layers.linspace(start, stop, num, dtype)

在给定区间内返回固定数目的均匀间隔的值。
 
第一个entry是start,最后一个entry是stop。在Num为1的情况下,仅返回start。类似numpy的linspace功能。

参数:
    - **start** (float|Variable)-序列中的第一个entry。 它是一个浮点标量,或是一个数据类型为'float32'|'float64'、形状为[1]的张量。
    - **stop** (float|Variable)-序列中的最后一个entry。 它是一个浮点标量,或是一个数据类型为'float32'|'float64'、形状为[1]的张量。
    - **num** (int|Variable)-序列中的entry数。 它是一个整型标量,或是一个数据类型为int32、形状为[1]的张量。
    - **dtype** (string)-‘float32’|’float64’,输出张量的数据类型。

返回:存储一维张量的张量变量

返回类型:变量(Variable)
C
Cheerego 已提交
12710

R
RaindragonD 已提交
12711 12712 12713
**代码示例**:

.. code-block:: python
C
Cheerego 已提交
12714

R
RaindragonD 已提交
12715 12716
      data = fluid.layers.linspace(0, 10, 5, 'float32') # [0.0,  2.5,  5.0,  7.5, 10.0]
      data = fluid.layers.linspace(0, 10, 1, 'float32') # [0.0]
C
Cheerego 已提交
12717 12718 12719 12720 12721 12722 12723





.. _cn_api_fluid_layers_ones:

C
Cheerego 已提交
12724
ones
C
Cheerego 已提交
12725 12726 12727 12728 12729 12730 12731 12732 12733 12734 12735
-------------------------------

.. py:function:: paddle.fluid.layers.ones(shape,dtype,force_cpu=False)

**ones**

该功能创建一个张量,有具体的维度和dtype,初始值为1。

也将stop_gradient设置为True。

参数:
12736
    - **shape** (tuple|list)-输出张量的维
C
Cheerego 已提交
12737 12738 12739 12740 12741 12742 12743 12744 12745 12746
    - **dtype** (np.dtype|core.VarDesc.VarType|str)-输出张量的数据类型

返回:存储在输出中的张量

返回类型:变量(Variable)

**代码示例**:

.. code-block:: python

R
RaindragonD 已提交
12747
    import paddle.fluid as fluid
C
Cheerego 已提交
12748 12749 12750 12751
    data = fluid.layers.ones(shape=[1], dtype='int64')



12752 12753 12754 12755 12756 12757 12758 12759
.. _cn_api_fluid_layers_range:

range
-------------------------------

.. py:function:: paddle.fluid.layers.range(start, end, step, dtype)

均匀分隔给定数值区间,并返回该分隔结果。
C
Cheerego 已提交
12760

12761 12762 12763 12764 12765 12766 12767 12768 12769 12770 12771 12772 12773 12774 12775 12776 12777
返回值在半开区间[start,stop)内生成(即包括起点start但不包括终点stop的区间)。


参数:
    - **start** (int | float | Variable) - 区间起点,且区间包括此值。
    - **end** (int | float | Variable) - 区间终点,通常区间不包括此值。但当step不是整数,且浮点数取整会影响out的长度时例外。
    - **step** (int | float | Variable) - 返回结果中数值之间的间距(步长)。 对于任何输出变量out,step是两个相邻值之间的距离,即out [i + 1]  -  out [i]。 默认为1。
    - **dtype** (string) - 'float32'|'int32'| ...,输出张量的数据类型。

返回:均匀分割给定数值区间后得到的值组


**代码示例**:

.. code-block:: python

    data = fluid.layers.range(0, 10, 2, 'int32')
C
Cheerego 已提交
12778 12779 12780 12781 12782 12783 12784 12785 12786 12787 12788 12789 12790 12791 12792 12793 12794





.. _cn_api_fluid_layers_reverse:

reverse
-------------------------------

.. py:function:: paddle.fluid.layers.reverse(x,axis)

**reverse**

该功能将给定轴上的输入‘x’逆序

参数:
T
Tink_Y 已提交
12795 12796
  - **x** (Variable)-预逆序的输入
  - **axis** (int|tuple|list) - 元素逆序排列的轴。如果该参数是一个元组或列表,则对该参数中每个元素值所指定的轴上进行逆序运算。
C
Cheerego 已提交
12797 12798 12799 12800 12801 12802 12803 12804 12805

返回:逆序的张量

返回类型:变量(Variable)

**代码示例**:

.. code-block:: python

R
RaindragonD 已提交
12806 12807 12808
        import paddle.fluid as fluid
        data = fluid.layers.data(name="data", shape=[4, 8], dtype="float32")
        out = fluid.layers.reverse(x=data, axis=0)
C
Cheerego 已提交
12809
        # or:
R
RaindragonD 已提交
12810
        out = fluid.layers.reverse(x=data, axis=[0,1])
C
Cheerego 已提交
12811 12812 12813 12814 12815 12816 12817 12818 12819 12820 12821 12822 12823 12824 12825 12826 12827 12828 12829 12830 12831 12832 12833 12834 12835 12836 12837 12838 12839 12840









.. _cn_api_fluid_layers_sums:

sums
-------------------------------

.. py:function:: paddle.fluid.layers.sums(input,out=None)

该函数对输入进行求和,并返回求和结果作为输出。

参数:
    - **input** (Variable|list)-输入张量,有需要求和的元素
    - **out** (Variable|None)-输出参数。求和结果。默认:None

返回:输入的求和。和参数'out'等同

返回类型:变量(Variable)

**代码示例**:

.. code-block:: python

R
RaindragonD 已提交
12841 12842 12843 12844 12845 12846 12847 12848 12849 12850 12851 12852 12853 12854
    import paddle.fluid as fluid
     
    # sum of several tensors
    a0 = fluid.layers.fill_constant(shape=[1], dtype='int64', value=1)
    a1 = fluid.layers.fill_constant(shape=[1], dtype='int64', value=2)
    a2 = fluid.layers.fill_constant(shape=[1], dtype='int64', value=3)
    sums = fluid.layers.sums(input=[a0, a1, a2])

    # sum of a tensor array
    array = fluid.layers.create_array('int64')
    i = fluid.layers.zeros(shape=[1], dtype='int64', force_cpu=True)
    fluid.layers.array_write(a0, array=array, i=i)
    i = fluid.layers.increment(x=i)
    fluid.layers.array_write(a1, array=array, i=i)
H
Hao Wang 已提交
12855
    i = fluid.layers.increment(x=i)
R
RaindragonD 已提交
12856 12857
    fluid.layers.array_write(a2, array=array, i=i)
    sums = fluid.layers.sums(input=array)
C
Cheerego 已提交
12858 12859 12860 12861 12862 12863 12864 12865 12866 12867 12868 12869 12870 12871 12872 12873 12874 12875 12876 12877 12878 12879 12880 12881 12882 12883 12884 12885 12886 12887 12888 12889 12890 12891 12892 12893 12894 12895 12896 12897 12898 12899 12900 12901 12902 12903









.. _cn_api_fluid_layers_tensor_array_to_tensor:

tensor_array_to_tensor
-------------------------------

.. py:function:: paddle.fluid.layers.tensor_array_to_tensor(input, axis=1, name=None)

此函数在指定轴上连接LodTensorArray中的元素,并将其作为输出返回。


简单示例如下:

.. code-block:: text

    Given:
    input.data = {[[0.6, 0.1, 0.3],
                   [0.5, 0.3, 0.2]],
                  [[1.3],
                   [1.8]],
                  [[2.3, 2.1],
                   [2.5, 2.4]]}

    axis = 1

    Then:
    output.data = [[0.6, 0.1, 0.3, 1.3, 2.3, 2.1],
                   [0.5, 0.3, 0.2, 1.8, 2.5, 2.4]]
    output_index.data = [3, 1, 2]

参数:
  - **input** (list) - 输入的LodTensorArray
  - **axis** (int) - 整数轴,tensor将会和它连接在一起
  - **name** (str|None) - 该layer的名字,可选。如果设置为none,layer将会被自动命名

返回:
    Variable: 连接的输出变量,输入LodTensorArray沿指定axis连接。

T
Tink_Y 已提交
12904 12905
返回类型: Variable

C
Cheerego 已提交
12906 12907 12908 12909
**代码示例:**

.. code-block:: python

R
RaindragonD 已提交
12910 12911
   import paddle.fluid as fluid
   tensor_array = fluid.layers.create_parameter(shape=[784, 200], dtype='float32')
C
Cheerego 已提交
12912 12913 12914 12915 12916 12917 12918 12919 12920 12921 12922 12923 12924 12925 12926 12927 12928 12929 12930 12931 12932
   output, output_index = fluid.layers.tensor_array_to_tensor(input=tensor_array)











.. _cn_api_fluid_layers_zeros:

zeros
-------------------------------

.. py:function:: paddle.fluid.layers.zeros(shape,dtype,force_cpu=False)

**zeros**

R
RaindragonD 已提交
12933
该函数创建一个张量,含有具体的维度和dtype,初始值为0.
C
Cheerego 已提交
12934 12935 12936 12937 12938 12939 12940 12941 12942 12943 12944 12945 12946 12947 12948 12949

也将stop_gradient设置为True。

参数:
    - **shape** (tuple|list|None)-输出张量的维
    - **dtype** (np.dtype|core.VarDesc.VarType|str)-输出张量的数据类型
    - **force_cpu** (bool,default False)-是否将输出保留在CPU上

返回:存储在输出中的张量

返回类型:变量(Variable)

**代码示例**:

.. code-block:: python

R
RaindragonD 已提交
12950
    import paddle.fluid as fluid
C
Cheerego 已提交
12951 12952 12953 12954 12955 12956 12957 12958 12959
    data = fluid.layers.zeros(shape=[1], dtype='int64')








R
RaindragonD 已提交
12960 12961 12962 12963 12964 12965 12966 12967 12968 12969 12970 12971 12972 12973 12974 12975 12976 12977 12978 12979 12980 12981 12982 12983 12984 12985 12986 12987
.. _cn_api_fluid_layers_zeros_like:

zeros_like
-------------------------------

.. py:function:: paddle.fluid.layers.zeros_like(x, out=None)

**zeros_like**

该函数创建一个和x具有相同的形状和数据类型的全零张量

参数:
    - **x** (Variable)-指定形状和数据类型的输入张量
    - **out** (Variable)-输出张量
    
返回:存储输出的张量变量

返回类型:变量(Variable)

**代码示例**:

.. code-block:: python

    x = fluid.layers.data(name='x', dtype='float32', shape=[3], append_batch_size=False)
    data = fluid.layers.zeros_like(x) # [0.0, 0.0, 0.0]



C
Cheerego 已提交
12988 12989 12990



C
Cheerego 已提交
12991
==========================
C
Cheerego 已提交
12992
 learning_rate_scheduler
C
Cheerego 已提交
12993
==========================
C
Cheerego 已提交
12994

12995 12996 12997 12998 12999 13000 13001 13002 13003 13004 13005 13006 13007 13008 13009 13010 13011 13012 13013 13014 13015 13016 13017 13018 13019 13020 13021
.. _cn_api_fluid_layers_cosine_decay:

cosine_decay
-------------------------------

.. py:function:: paddle.fluid.layers.cosine_decay(learning_rate, step_each_epoch, epochs)

使用 cosine decay 的衰减方式进行学习率调整。

在训练模型时,建议一边进行训练一边降低学习率。 通过使用此方法,学习速率将通过如下cosine衰减策略进行衰减:

.. math::
    decayed\_lr = learning\_rate * 0.5 * (cos(epoch * math.pi / epochs) + 1)


参数:
    - **learning_rate** (Variable | float) - 初始学习率。
    - **step_each_epoch** (int) - 一次迭代中的步数。
    - **epochs**  - 总迭代次数。




**代码示例**

.. code-block:: python

C
Cheerego 已提交
13022
    base_lr = 0.1
13023
    lr = fluid.layers.cosine_decay( learning_rate = base_lr, step_each_epoch=10000, epochs=120)
C
Cheerego 已提交
13024 13025 13026 13027 13028



.. _cn_api_fluid_layers_exponential_decay:

C
Cheerego 已提交
13029
exponential_decay
C
Cheerego 已提交
13030 13031
-------------------------------

T
Tink_Y 已提交
13032
.. py:function:: paddle.fluid.layers.exponential_decay(learning_rate,decay_steps,decay_rate,staircase=False)
C
Cheerego 已提交
13033

13034
在学习率上运用指数衰减。
C
Cheerego 已提交
13035 13036 13037 13038 13039 13040 13041
训练模型时,在训练过程中通常推荐降低学习率。每次 ``decay_steps`` 步骤中用 ``decay_rate`` 衰减学习率。

.. code-block:: text

    if staircase == True:
        decayed_learning_rate = learning_rate * decay_rate ^ floor(global_step / decay_steps)
    else:
C
Cheerego 已提交
13042
        decayed_learning_rate = learning_rate * decay_rate ^ (global_step / decay_steps)
C
Cheerego 已提交
13043 13044 13045 13046 13047 13048 13049 13050 13051 13052 13053 13054 13055 13056 13057

参数:
    - **learning_rate** (Variable|float)-初始学习率
    - **decay_steps** (int)-见以上衰减运算
    - **decay_rate** (float)-衰减率。见以上衰减运算
    - **staircase** (Boolean)-若为True,按离散区间衰减学习率。默认:False

返回:衰减的学习率

返回类型:变量(Variable)

**代码示例**:

.. code-block:: python

R
RaindragonD 已提交
13058
    import paddle.fluid as fluid
C
Cheerego 已提交
13059 13060 13061 13062 13063 13064 13065
    base_lr = 0.1
    sgd_optimizer = fluid.optimizer.SGD(
        learning_rate=fluid.layers.exponential_decay(
            learning_rate=base_lr,
            decay_steps=10000,
            decay_rate=0.5,
            staircase=True))
R
RaindragonD 已提交
13066

C
Cheerego 已提交
13067 13068 13069 13070 13071 13072 13073 13074 13075 13076 13077 13078 13079 13080 13081 13082 13083 13084 13085 13086 13087 13088 13089 13090 13091 13092 13093 13094 13095 13096









.. _cn_api_fluid_layers_inverse_time_decay:

inverse_time_decay
-------------------------------

.. py:function:: paddle.fluid.layers.inverse_time_decay(learning_rate, decay_steps, decay_rate, staircase=False)

在初始学习率上运用逆时衰减。

训练模型时,在训练过程中通常推荐降低学习率。通过执行该函数,将对初始学习率运用逆向衰减函数。

.. code-block:: python

    if staircase == True:
         decayed_learning_rate = learning_rate / (1 + decay_rate * floor(global_step / decay_step))
     else:
         decayed_learning_rate = learning_rate / (1 + decay_rate * global_step / decay_step)

参数:
    - **learning_rate** (Variable|float)-初始学习率
    - **decay_steps** (int)-见以上衰减运算
13097
    - **decay_rate** (float)-衰减率。见以上衰减运算
C
Cheerego 已提交
13098 13099
    - **staircase** (Boolean)-若为True,按间隔区间衰减学习率。默认:False

T
Tink_Y 已提交
13100
返回:衰减的学习率
C
Cheerego 已提交
13101

T
Tink_Y 已提交
13102
返回类型:变量(Variable)
C
Cheerego 已提交
13103 13104 13105 13106 13107

**示例代码:**

.. code-block:: python

R
RaindragonD 已提交
13108
        import paddle.fluid as fluid
C
Cheerego 已提交
13109 13110
        base_lr = 0.1
        sgd_optimizer = fluid.optimizer.SGD(
R
RaindragonD 已提交
13111
            learning_rate=fluid.layers.natural_exp_decay(
C
Cheerego 已提交
13112 13113 13114 13115 13116 13117 13118 13119 13120
                learning_rate=base_lr,
                decay_steps=10000,
                decay_rate=0.5,
                staircase=True))
        sgd_optimizer.minimize(avg_cost)




13121 13122 13123 13124 13125 13126 13127 13128 13129 13130 13131 13132 13133 13134 13135 13136 13137 13138 13139 13140 13141 13142 13143 13144 13145 13146 13147 13148 13149 13150 13151 13152 13153 13154 13155 13156 13157 13158 13159
.. _cn_api_fluid_layers_linear_lr_warmup:

linear_lr_warmup
-------------------------------

.. py:function:: paddle.fluid.layers.linear_lr_warmup(learning_rate, warmup_steps, start_lr, end_lr)

在正常学习率调整之前先应用线性学习率热身(warm up)进行初步调整。

.. code-block:: text

    if global_step < warmup_steps:
        linear_step = end_lr - start_lr
        lr = start_lr + linear_step * (global_step / warmup_steps)

参数:
    - **learning_rate** (float | Variable) - 学习率,类型为float值或变量。
    - **warmup_steps** (int) - 进行warm up过程的步数。
    - **start_lr** (float) - warm up的起始学习率
    - **end_lr** (float) - warm up的最终学习率。

返回:进行热身衰减后的学习率。


**示例代码**

.. code-block:: python

        boundaries = [100, 200]
        lr_steps = [0.1, 0.01, 0.001]
        warmup_steps = 50
        start_lr = 1. / 3.
        end_lr = 0.1
        decayed_lr = fluid.layers.linear_lr_warmup(
            fluid.layers.piecewise_decay(boundaries, lr_steps),
            warmup_steps, start_lr, end_lr)



C
Cheerego 已提交
13160 13161 13162 13163 13164 13165 13166 13167 13168 13169 13170 13171 13172 13173 13174 13175 13176 13177 13178 13179 13180 13181 13182 13183 13184 13185 13186 13187 13188





.. _cn_api_fluid_layers_natural_exp_decay:

natural_exp_decay
-------------------------------

.. py:function:: paddle.fluid.layers.natural_exp_decay(learning_rate, decay_steps, decay_rate, staircase=False)

将自然指数衰减运用到初始学习率上。

.. code-block:: python

    if not staircase:
        decayed_learning_rate = learning_rate * exp(- decay_rate * (global_step / decay_steps))
    else:
        decayed_learning_rate = learning_rate * exp(- decay_rate * (global_step / decay_steps))

参数:
    - **learning_rate** - 标量float32值或变量。是训练过程中的初始学习率。
    - **decay_steps** - Python int32数
    - **decay_rate** - Python float数
    - **staircase** - Boolean.若设为true,每个decay_steps衰减学习率

返回:衰减的学习率

R
RaindragonD 已提交
13189
**示例代码:**
C
Cheerego 已提交
13190

R
RaindragonD 已提交
13191
.. code-block:: python
C
Cheerego 已提交
13192

R
RaindragonD 已提交
13193 13194 13195 13196 13197 13198 13199 13200
    import paddle.fluid as fluid
    base_lr = 0.1
    sgd_optimizer = fluid.optimizer.SGD(
        learning_rate=fluid.layers.natural_exp_decay(
              learning_rate=base_lr,
              decay_steps=10000,
              decay_rate=0.5,
              staircase=True))
C
Cheerego 已提交
13201 13202 13203 13204 13205 13206 13207 13208 13209 13210 13211






.. _cn_api_fluid_layers_noam_decay:

noam_decay
-------------------------------

T
Tink_Y 已提交
13212
.. py:function:: paddle.fluid.layers.noam_decay(d_model,warmup_steps)
C
Cheerego 已提交
13213 13214 13215 13216 13217 13218

Noam衰减方法。noam衰减的numpy实现如下。

.. code-block:: python

    import numpy as np
R
RaindragonD 已提交
13219 13220 13221 13222 13223
    # 设置超参数
    d_model = 2
    current_steps = 20
    warmup_steps = 200
    # 计算
C
Cheerego 已提交
13224 13225 13226 13227
    lr_value = np.power(d_model, -0.5) * np.min([
                           np.power(current_steps, -0.5),
                           np.power(warmup_steps, -1.5) * current_steps])

C
Cheerego 已提交
13228
请参照 `attention is all you need <https://arxiv.org/pdf/1706.03762.pdf>`_
C
Cheerego 已提交
13229 13230 13231 13232 13233 13234 13235

参数:
    - **d_model** (Variable)-模型的输入和输出维度
    - **warmup_steps** (Variable)-超参数

返回:衰减的学习率

R
RaindragonD 已提交
13236
**代码示例**:
C
Cheerego 已提交
13237

R
RaindragonD 已提交
13238
.. code-block:: python
C
Cheerego 已提交
13239

R
RaindragonD 已提交
13240 13241 13242 13243 13244 13245
        import padde.fluid as fluid
        warmup_steps = 100
        learning_rate = 0.01
        lr = fluid.layers.learning_rate_scheduler.noam_decay(
                       1/(warmup_steps *(learning_rate ** 2)),
                       warmup_steps)
C
Cheerego 已提交
13246 13247 13248 13249 13250 13251 13252 13253 13254 13255 13256 13257 13258 13259 13260 13261 13262 13263 13264 13265 13266 13267 13268 13269 13270 13271 13272 13273 13274 13275 13276 13277 13278 13279






.. _cn_api_fluid_layers_piecewise_decay:

piecewise_decay
-------------------------------

.. py:function:: paddle.fluid.layers.piecewise_decay(boundaries,values)

对初始学习率进行分段衰减。

该算法可用如下代码描述。

.. code-block:: text

    boundaries = [10000, 20000]
    values = [1.0, 0.5, 0.1]
    if step < 10000:
        learning_rate = 1.0
    elif 10000 <= step < 20000:
        learning_rate = 0.5
    else:
        learning_rate = 0.1

参数:
    - **boundaries** -一列代表步数的数字
    - **values** -一列学习率的值,从不同的步边界中挑选

返回:衰减的学习率

R
RaindragonD 已提交
13280
**代码示例**:
C
Cheerego 已提交
13281

R
RaindragonD 已提交
13282
.. code-block:: python
C
Cheerego 已提交
13283

R
RaindragonD 已提交
13284 13285 13286 13287 13288 13289 13290
        import paddle.fluid as fluid
        boundaries = [10000, 20000]
        values = [1.0, 0.5, 0.1]
        optimizer = fluid.optimizer.Momentum(
            momentum=0.9,
            learning_rate=fluid.layers.piecewise_decay(boundaries=boundaries, values=values),
            regularization=fluid.regularizer.L2Decay(1e-4))
C
Cheerego 已提交
13291 13292 13293 13294 13295 13296 13297 13298






.. _cn_api_fluid_layers_polynomial_decay:

C
Cheerego 已提交
13299
polynomial_decay
C
Cheerego 已提交
13300 13301 13302 13303 13304 13305 13306 13307 13308 13309 13310 13311 13312 13313 13314 13315 13316 13317 13318 13319 13320 13321 13322 13323 13324 13325
-------------------------------

.. py:function:: paddle.fluid.layers.polynomial_decay(learning_rate,decay_steps,end_learning_rate=0.0001,power=1.0,cycle=False)

对初始学习率使用多项式衰减

.. code-block:: text

    if cycle:
        decay_steps = decay_steps * ceil(global_step / decay_steps)
    else:
        global_step = min(global_step, decay_steps)
        decayed_learning_rate = (learning_rate - end_learning_rate) *
            (1 - global_step / decay_steps) ^ power + end_learning_rate

参数:
    - **learning_rate** (Variable|float32)-标量float32值或变量。是训练过程中的初始学习率。
    - **decay_steps** (int32)-Python int32数
    - **end_learning_rate** (float)-Python float数
    - **power** (float)-Python float数
    - **cycle** (bool)-若设为true,每decay_steps衰减学习率

返回:衰减的学习率

返回类型:变量(Variable)

R
RaindragonD 已提交
13326
**代码示例**:
C
Cheerego 已提交
13327

R
RaindragonD 已提交
13328
.. code-block:: python
C
Cheerego 已提交
13329

R
RaindragonD 已提交
13330 13331 13332 13333 13334 13335
        import paddle.fluid as fluid
        start_lr = 0.01
        total_step = 5000
        end_lr = 0
        lr = fluid.layers.polynomial_decay(
            start_lr, total_step, end_lr, power=1)
C
Cheerego 已提交
13336 13337 13338 13339 13340 13341 13342 13343 13344








============
C
Cheerego 已提交
13345
 detection
C
Cheerego 已提交
13346 13347 13348 13349 13350 13351 13352 13353 13354 13355 13356 13357
============


.. _cn_api_fluid_layers_anchor_generator:

anchor_generator
-------------------------------

.. py:function:: paddle.fluid.layers.anchor_generator(input, anchor_sizes=None, aspect_ratios=None, variance=[0.1, 0.1, 0.2, 0.2], stride=None, offset=0.5, name=None)

**Anchor generator operator**

H
Hao Wang 已提交
13358
为Faster RCNN算法生成anchor,输入的每一位产生N个anchor,N=size(anchor_sizes)*size(aspect_ratios)。生成anchor的顺序首先是aspect_ratios循环,然后是anchor_sizes循环。
C
Cheerego 已提交
13359 13360 13361

参数:
    - **input** (Variable) - 输入特征图,格式为NCHW
H
Hao Wang 已提交
13362
    - **anchor_sizes** (list|tuple|float) - 生成anchor的anchor大小,以绝对像素的形式表示,例如:[64.,128.,256.,512.]。若anchor的大小为64,则意味着这个anchor的面积等于64**2。
H
Hao Wang 已提交
13363
    - **aspect_ratios** (list|tuple|float) - 生成anchor的高宽比,例如[0.5,1.0,2.0]
C
Cheerego 已提交
13364
    - **variance** (list|tuple) - 变量,在框回归delta中使用。默认:[0.1,0.1,0.2,0.2]
H
Hao Wang 已提交
13365
    - **stride** (list|tuple) - anchor在宽度和高度方向上的步长,比如[16.0,16.0]
C
Cheerego 已提交
13366 13367 13368
    - **offset** (float) - 先验框的中心位移。默认:0.5
    - **name** (str) - 先验框操作符名称。默认:None

T
Tink_Y 已提交
13369 13370
返回:
    - Anchors(Varibale): 输出anchor,布局[H,W,num_anchors,4] , ``H``  是输入的高度, ``W`` 是输入的宽度, ``num_priors`` 是输入每位的框数,每个anchor格式(未归一化)为(xmin,ymin,xmax,ymax)
C
Cheerego 已提交
13371

H
Hao Wang 已提交
13372
    - Variances(Variable): anchor的扩展变量布局为 [H,W,num_priors,4]。 ``H`` 是输入的高度, ``W`` 是输入的宽度, ``num_priors`` 是输入每个位置的框数,每个变量的格式为(xcenter,ycenter,w,h)。
C
Cheerego 已提交
13373

H
Hao Wang 已提交
13374
返回类型:Anchors(Variable),Variances(Variable)
C
Cheerego 已提交
13375 13376 13377 13378 13379

**代码示例**:

.. code-block:: python

R
RaindragonD 已提交
13380 13381
    conv1 = fluid.layers.data(name='conv1', shape=[48, 16, 16], dtype='float32')
    anchor, var = fluid.layers.anchor_generator(
C
Cheerego 已提交
13382 13383 13384 13385 13386 13387 13388 13389 13390 13391 13392 13393 13394 13395 13396 13397
    input=conv1,
    anchor_sizes=[64, 128, 256, 512],
    aspect_ratios=[0.5, 1.0, 2.0],
    variance=[0.1, 0.1, 0.2, 0.2],
    stride=[16.0, 16.0],
    offset=0.5)









.. _cn_api_fluid_layers_bipartite_match:
C
Cheerego 已提交
13398

C
Cheerego 已提交
13399 13400 13401 13402 13403
bipartite_match
-------------------------------

.. py:function:: paddle.fluid.layers.bipartite_match(dist_matrix, match_type=None, dist_threshold=None, name=None)

13404
该算子实现了贪心二分匹配算法,该算法用于根据输入距离矩阵获得与最大距离的匹配。对于输入二维矩阵,二分匹配算法可以找到每一行的匹配列(匹配意味着最大距离),也可以找到每列的匹配行。此算子仅计算列到行的匹配索引。对于每个实例,匹配索引的数量是输入距离矩阵的列号。
C
Cheerego 已提交
13405 13406 13407 13408 13409 13410 13411 13412 13413 13414 13415 13416 13417 13418 13419 13420 13421 13422 13423 13424 13425 13426 13427 13428 13429 13430 13431 13432 13433 13434 13435 13436 13437 13438

它有两个输出,匹配的索引和距离。简单的描述是该算法将最佳(最大距离)行实体与列实体匹配,并且匹配的索引在ColToRowMatchIndices的每一行中不重复。如果列实体与任何行实体不匹配,则ColToRowMatchIndices设置为-1。

注意:输入距离矩阵可以是LoDTensor(带有LoD)或Tensor。如果LoDTensor带有LoD,则ColToRowMatchIndices的高度是批量大小。如果是Tensor,则ColToRowMatchIndices的高度为1。

注意:此API是一个非常低级别的API。它由 ``ssd_loss`` 层使用。请考虑使用 ``ssd_loss`` 。

参数:
                - **dist_matrix** (变量)- 该输入是具有形状[K,M]的2-D LoDTensor。它是由每行和每列来表示实体之间的成对距离矩阵。例如,假设一个实体是具有形状[K]的A,另一个实体是具有形状[M]的B. dist_matrix [i] [j]是A[i]和B[j]之间的距离。距离越大,匹配越好。

                注意:此张量可以包含LoD信息以表示一批输入。该批次的一个实例可以包含不同数量的实体。

                - **match_type** (string | None)- 匹配方法的类型,应为'bipartite'或'per_prediction'。[默认'二分']。
                - **dist_threshold** (float | None)- 如果match_type为'per_prediction',则此阈值用于根据最大距离确定额外匹配的bbox,默认值为0.5。

返回:        返回一个包含两个元素的元组。第一个是匹配的索引(matched_indices),第二个是匹配的距离(matched_distance)。

         **matched_indices** 是一个2-D Tensor,int类型的形状为[N,M]。 N是批量大小。如果match_indices[i][j]为-1,则表示B[j]与第i个实例中的任何实体都不匹配。否则,这意味着在第i个实例中B[j]与行match_indices[i][j]匹配。第i个实例的行号保存在match_indices[i][j]中。

         **matched_distance** 是一个2-D Tensor,浮点型的形状为[N,M]。 N是批量大小。如果match_indices[i][j]为-1,则match_distance[i][j]也为-1.0。否则,假设match_distance[i][j]=d,并且每个实例的行偏移称为LoD。然后match_distance[i][j]=dist_matrix[d]+ LoD[i]][j]。

返回类型:        元组(tuple)

**代码示例**

..  code-block:: python

         x = fluid.layers.data(name='x', shape=[4], dtype='float32')
         y = fluid.layers.data(name='y', shape=[4], dtype='float32')
         iou = fluid.layers.iou_similarity(x=x, y=y)
         matched_indices, matched_dist = fluid.layers.bipartite_match(iou)



H
Hao Wang 已提交
13439
.. _cn_api_fluid_layers_box_clip:
C
Cheerego 已提交
13440

H
Hao Wang 已提交
13441 13442 13443 13444 13445 13446 13447 13448 13449 13450 13451 13452 13453 13454 13455 13456 13457 13458 13459 13460 13461 13462 13463 13464 13465 13466 13467
box_clip
-------------------------------

.. py:function:: paddle.fluid.layers.box_clip(input, im_info, name=None)

将box框剪切为 ``im_info`` 给出的大小。对于每个输入框,公式如下:

::

    xmin = max(min(xmin, im_w - 1), 0)
    ymin = max(min(ymin, im_h - 1), 0)
    xmax = max(min(xmax, im_w - 1), 0)
    ymax = max(min(ymax, im_h - 1), 0)

其中im_w和im_h是从im_info计算的:

::

    im_h = round(height / scale)
    im_w = round(weight / scale)


参数:
    - **input (variable)**  – 输入框,最后一个维度为4
    - **im_info (variable)**  – 具有(高度height,宽度width,比例scale)排列的形为[N,3]的图像的信息。高度和宽度是输入大小,比例是输入大小和原始大小的比率
    - **name (str)**  – 该层的名称。 为可选项

C
Cheerego 已提交
13468
返回:剪切后的tensor
H
Hao Wang 已提交
13469 13470 13471 13472 13473 13474 13475

返回类型: Variable


**代码示例**

..  code-block:: python
C
Cheerego 已提交
13476

H
Hao Wang 已提交
13477
    boxes = fluid.layers.data(
R
RaindragonD 已提交
13478
        name='boxes', shape=[8, 4], dtype='float32', lod_level=1)
H
Hao Wang 已提交
13479 13480 13481
    im_info = fluid.layers.data(name='im_info', shape=[3])
    out = fluid.layers.box_clip(
        input=boxes, im_info=im_info, inplace=True)
C
Cheerego 已提交
13482 13483 13484 13485 13486 13487 13488 13489 13490 13491 13492 13493 13494 13495 13496










.. _cn_api_fluid_layers_box_coder:

box_coder
-------------------------------

13497
.. py:function:: paddle.fluid.layers.box_coder(prior_box, prior_box_var, target_box, code_type='encode_center_size', box_normalized=True, name=None, axis=0)
C
Cheerego 已提交
13498 13499 13500 13501 13502 13503 13504 13505 13506 13507 13508 13509 13510 13511 13512 13513 13514 13515 13516 13517 13518 13519 13520 13521 13522 13523 13524 13525 13526 13527 13528

Bounding Box Coder

编码/解码带有先验框信息的目标边界框

编码规则描述如下:

.. math::

    ox &= (tx - px)/pw/pxv

    oy &= (ty - py)/ph/pyv

    ow &= log(abs(tw/pw))/pwv

    oh &= log(abs(th/ph))/phv

解码规则描述如下:

.. math::

    ox &= (pw * pxv * tx * + px ) - tw/2

    oy &= (ph * pyv * ty * + py ) - th/2

    ow &= exp(pwv * tw ) * pw + tw/2

    oh &= exp(phv * th ) * ph + th/2

其中tx,ty,tw,th分别表示目标框的中心坐标、宽度和高度。同样地,px,py,pw,ph表示先验框地中心坐标、宽度和高度。pxv,pyv,pwv,phv表示先验框变量,ox,oy,ow,oh表示编码/解码坐标、宽度和高度。

H
Hao Wang 已提交
13529 13530 13531 13532

在Box Decoding期间,支持两种broadcast模式。 假设目标框具有形状[N,M,4],并且prior框的形状可以是[N,4]或[M,4]。 然后,prior框将沿指定的轴broadcast到目标框。


C
Cheerego 已提交
13533 13534
参数:
    - **prior_box** (Variable) - 张量,默认float类型的张量。先验框是二维张量,维度为[M,4],存储M个框,每个框代表[xmin,ymin,xmax,ymax],[xmin,ymin]是先验框的左顶点坐标,如果输入数图像特征图,则接近坐标原点。[xmax,ymax]是先验框的右底点坐标
13535
    - **prior_box_var** (Variable|list|None) - 支持两种输入类型,一是二维张量,维度为[M,4],存储M个prior box。另外是一个含有4个元素的list,所有prior box共用这个list。
C
Cheerego 已提交
13536
    - **target_box** (Variable) - LoDTensor或者Tensor,当code_type为‘encode_center_size’,输入可以是二维LoDTensor,维度为[N,4]。当code_type为‘decode_center_size’输入可以为三维张量,维度为[N,M,4]。每个框代表[xmin,ymin,xmax,ymax],[xmin,ymin]是先验框的左顶点坐标,如果输入数图像特征图,则接近坐标原点。[xmax,ymax]是先验框的右底点坐标。该张量包含LoD信息,代表一批输入。批的一个实例可以包含不同的实体数。
H
Hao Wang 已提交
13537
    - **code_type** (string,默认encode_center_size) - 编码类型用目标框,可以是encode_center_size或decode_center_size
C
Cheerego 已提交
13538
    - **box_normalized** (boolean,默认true) - 是否将先验框作为正则框
H
Hao Wang 已提交
13539 13540 13541
    - **name**  (string) – box编码器的名称
    - **axis**  (int) – 在PriorBox中为axis指定的轴broadcast以进行框解码,例如,如果axis为0且TargetBox具有形状[N,M,4]且PriorBox具有形状[M,4],则PriorBox将broadcast到[N,M,4]用于解码。 它仅在code_type为decode_center_size时有效。 默认设置为0。

C
Cheerego 已提交
13542

H
Hao Wang 已提交
13543
返回:
C
Cheerego 已提交
13544 13545 13546 13547 13548 13549 13550 13551

       - ``code_type`` 为 ``‘encode_center_size’`` 时,形为[N,M,4]的输出张量代表N目标框的结果,目标框用M先验框和变量编码。
       - ``code_type`` 为 ``‘decode_center_size’`` 时,N代表batch大小,M代表解码框数

返回类型:output_box(Variable)



H
Hao Wang 已提交
13552
**代码示例**
C
Cheerego 已提交
13553

H
Hao Wang 已提交
13554
.. code-block:: python
C
Cheerego 已提交
13555

H
Hao Wang 已提交
13556 13557 13558 13559 13560 13561 13562 13563 13564 13565 13566 13567 13568 13569
    prior_box = fluid.layers.data(name='prior_box',
                                  shape=[512, 4],
                                  dtype='float32',
                                  append_batch_size=False)
    target_box = fluid.layers.data(name='target_box',
                                   shape=[512,81,4],
                                   dtype='float32',
                                   append_batch_size=False)
    output = fluid.layers.box_coder(prior_box=prior_box,
                                    prior_box_var=[0.1,0.1,0.2,0.2],
                                    target_box=target_box,
                                    code_type="decode_center_size",
                                    box_normalized=False,
                                    axis=1)
C
Cheerego 已提交
13570 13571 13572 13573




13574 13575 13576 13577 13578 13579 13580 13581 13582 13583 13584 13585 13586 13587 13588 13589 13590 13591 13592 13593 13594 13595 13596 13597 13598 13599 13600 13601 13602 13603 13604 13605 13606 13607 13608 13609 13610 13611 13612 13613 13614 13615 13616 13617 13618 13619 13620 13621 13622 13623 13624
.. _cn_api_fluid_layers_box_decoder_and_assign:

box_decoder_and_assign
-------------------------------

.. py:function:: paddle.fluid.layers.box_decoder_and_assign(prior_box, prior_box_var, target_box, box_score, box_clip, name=None)

边界框编码器。

根据prior_box来解码目标边界框。

解码方案为:

.. math::

    ox &= (pw \times pxv \times tx + px) - \frac{tw}{2}\\
    oy &= (ph \times pyv \times ty + py) - \frac{th}{2}\\
    ow &= \exp (pwv \times tw) \times pw + \frac{tw}{2}\\
    oh &= \exp (phv \times th) \times ph + \frac{th}{2}

其中tx,ty,tw,th分别表示目标框的中心坐标,宽度和高度。 类似地,px,py,pw,ph表示prior_box(anchor)的中心坐标,宽度和高度。 pxv,pyv,pwv,phv表示prior_box的variance,ox,oy,ow,oh表示decode_box中的解码坐标,宽度和高度。

box decode过程得出decode_box,然后分配方案如下所述:

对于每个prior_box,使用最佳non-background(非背景)类的解码值来更新prior_box位置并获取output_assign_box。 因此,output_assign_box的形状与PriorBox相同。




参数:
   - **prior_box** (Variable) - (Tensor,默认Tensor <float>)框列表PriorBox是一个二维张量,形状为[N,4],它包含N个框,每个框表示为[xmin,ymin,xmax,ymax], [xmin,ymin]是anchor框的左上坐标,如果输入是图像特征图,则它们接近坐标系的原点。 [xmax,ymax]是anchor框的右下坐标
   - **prior_box_var** (Variable) - (Tensor,默认Tensor <float>,可选)PriorBoxVar是一个二维张量,形状为[N,4],它包含N组variance。 PriorBoxVar默认将所有元素设置为1
   - **target_box** (Variable) - (LoDTensor或Tensor)此输入可以是形状为[N,classnum * 4]的2-D LoDTensor。它拥有N个框的N个目标
   - **box_score** (变量) - (LoDTensor或Tensor)此输入可以是具有形状[N,classnum]的2-D LoDTensor,每个框表示为[classnum],其中含有各分类概率值
   - **box_clip** (FLOAT) - (float,默认4.135,np.log(1000. / 16.))裁剪框以防止溢出
   - **name** (str | None) - 此算子的自定义名称


返回:两个变量:

     - decode_box(Variable):( LoDTensor或Tensor)op的输出张量,形为[N,classnum * 4],表示用M个prior_box解码的N个目标框的结果,以及每个类上的variance
     - output_assign_box(Variable):( LoDTensor或Tensor)op的输出张量,形为[N,4],表示使用M个prior_box解码的N个目标框的结果和BoxScore的最佳非背景类的方差

返回类型:   decode_box(Variable), output_assign_box(Variable)


**代码示例**

.. code-block:: python

    pb = fluid.layers.data(
R
RaindragonD 已提交
13625
        name='prior_box', shape=[4], dtype='float32')
13626
    pbv = fluid.layers.data(
R
RaindragonD 已提交
13627
        name='prior_box_var', shape=[4], dtype='float32', append_batch_size=False))
13628
    loc = fluid.layers.data(
R
RaindragonD 已提交
13629
        name='target_box', shape=[4*81], dtype='float32')
13630
    scores = fluid.layers.data(
R
RaindragonD 已提交
13631
        name='scores', shape=[81], dtype='float32')
13632
    decoded_box, output_assign_box = fluid.layers.box_decoder_and_assign(
C
Cheerego 已提交
13633
        pb, pbv, loc, scores, 4.135)
C
Cheerego 已提交
13634 13635


R
RaindragonD 已提交
13636 13637 13638 13639 13640 13641 13642 13643 13644 13645 13646 13647 13648 13649 13650 13651 13652 13653 13654 13655 13656 13657 13658 13659 13660 13661 13662 13663 13664 13665 13666 13667 13668 13669 13670 13671 13672 13673 13674 13675 13676 13677 13678 13679 13680 13681 13682 13683 13684 13685 13686


.. _cn_api_fluid_layers_collect_fpn_proposals:

collect_fpn_proposals
-------------------------------

.. py:function:: paddle.fluid.layers.collect_fpn_proposals(multi_rois, multi_scores, min_level, max_level, post_nms_top_n, name=None)

连接多级RoIs(感兴趣区域)并依据multi_scores选择N个RoIs。此操作执行以下步骤:
1、选择num_level个RoIs和scores作为输入:num_level = max_level - min_level
2、连接num_level个RoIs和scores。
3、整理scores并选择post_nms_top_n个scores。
4、通过scores中的选定指数收集RoIs。
5、通过对应的batch_id重新整理RoIs。


参数:
    - **multi_ros** (list) – 要收集的RoIs列表
    - **multi_scores** (list) - 要收集的FPN层的最低级
    - **max_level** (int) – 要收集的FPN层的最高级
    - **post_nms_top_n** (int) – 所选RoIs的数目
    - **name** (str|None) – 该层的名称(可选项)

返回:选定RoIs的输出变量

返回类型:变量(Variable)

**代码示例**

.. code-block:: python

    multi_rois = []
    multi_scores = []
    for i in range(4):
        multi_rois.append(fluid.layers.data(
            name='roi_'+str(i), shape=[4], dtype='float32', lod_level=1))
    for i in range(4):
        multi_scores.append(fluid.layers.data(
            name='score_'+str(i), shape=[1], dtype='float32', lod_level=1))
     
    fpn_rois = fluid.layers.collect_fpn_proposals(
        multi_rois=multi_rois,
        multi_scores=multi_scores,
        min_level=2,
        max_level=5,
        post_nms_top_n=2000)




C
Cheerego 已提交
13687 13688 13689 13690 13691 13692 13693 13694 13695 13696 13697 13698 13699 13700 13701 13702 13703 13704 13705 13706 13707 13708 13709 13710 13711 13712 13713 13714 13715 13716 13717 13718 13719 13720 13721 13722 13723 13724 13725
.. _cn_api_fluid_layers_density_prior_box:

density_prior_box
-------------------------------

.. py:function:: paddle.fluid.layers.density_prior_box(input, image, densities=None, fixed_sizes=None, fixed_ratios=None, variance=[0.1, 0.1, 0.2, 0.2], clip=False, steps=[0.0, 0.0], offset=0.5, flatten_to_2d=False, name=None)


**Density Prior Box Operator**

为SSD算法(Single Shot MultiBox Detector)生成density prior box。
每个input的位置产生N个prior box,其中,N通过densities, fixed_sizes and fixed_ratios
的量来决定。在每个input位置附近的box center格点,通过此op生成。格点坐标由densities决定,
density prior box的量由fixed_sizes and fixed_ratios决定。显然地,fixed_sizes
和densities相等。对于densities中的densities_i:

.. math::

  N\_density\_prior\_box =sum(N\_fixed\_ratios * {densities\_i}^2)


参数:
  - **input** (Variable) - 输入变量,格式为NCHW
  - **image** (Variable) - PriorBoxOp的输入图像数据,格式为NCHW
  - **densities** (list|tuple|None) - 被生成的density prior boxes的densities,此属性应该是一个整数列表或数组。默认值为None
  - **fixed_sizes** (list|tuple|None) - 被生成的density prior boxes的固定大小,此属性应该为和 :attr:`densities` 有同样长度的列表或数组。默认值为None
  - **fixed_ratios** (list|tuple|None) - 被生成的density prior boxes的固定长度,如果该属性未被设置,同时 :attr:`densities` 和 :attr:`fix_sizes` 被设置,则 :attr:`aspect_ratios` 被用于生成 density prior boxes
  - **variance** (list|tuple) - 将被用于density prior boxes编码的方差,默认值为:[0.1, 0.1, 0.2, 0.2]
  - **clip(bool)** - 是否clip超出范围的box。默认值:False
  - **step** (list|turple) - Prior boxes在宽度和高度的步长,如果step[0] == 0.0/step[1] == 0.0, input的the density prior boxes的高度/宽度的步长将被自动计算。默认值:Default: [0., 0.]
  - **offset** (float) - Prior boxes中心补偿值,默认为:0.5
  - **flatten_to_2d** (bool) - 是否将output prior boxes和方差 ``flatten`` 至2维形状,第二个dim为4。默认值:False
  - **name(str)** - density prior box op的名字,默认值: None

返回:
  tuple: 有两个变量的数组 (boxes, variances)

  boxes: PriorBox的输出density prior boxes

R
RaindragonD 已提交
13726
    当flatten_to_2d为False时,形式为[H, W, num_priors, 4]
C
Cheerego 已提交
13727

R
RaindragonD 已提交
13728
    当flatten_to_2d为True时,形式为[H * W * num_priors, 4]
C
Cheerego 已提交
13729

R
RaindragonD 已提交
13730
    H是输入的高度,W是输入的宽度
C
Cheerego 已提交
13731

R
RaindragonD 已提交
13732
    num_priors是输入中每个位置的总box count
C
Cheerego 已提交
13733 13734 13735

  variances:  PriorBox的expanded variance

R
RaindragonD 已提交
13736
    当flatten_to_2d为False时,形式为[H, W, num_priors, 4]
C
Cheerego 已提交
13737

R
RaindragonD 已提交
13738
    当flatten_to_2d为True时,形式为[H * W * num_priors, 4]
C
Cheerego 已提交
13739

R
RaindragonD 已提交
13740
    H是输入的高度,W是输入的宽度
C
Cheerego 已提交
13741

R
RaindragonD 已提交
13742
    num_priors是输入中每个位置的总box count
C
Cheerego 已提交
13743

H
Hao Wang 已提交
13744
**代码示例**
C
Cheerego 已提交
13745 13746

.. code-block:: python
R
RaindragonD 已提交
13747 13748 13749
    
    input = fluid.layers.data(name="input", shape=[3,6,9])
    images = fluid.layers.data(name="images", shape=[3,9,12])
C
Cheerego 已提交
13750
    box, var = fluid.layers.density_prior_box(
R
RaindragonD 已提交
13751
        input=input,
C
Cheerego 已提交
13752 13753 13754 13755 13756 13757 13758 13759 13760 13761 13762 13763 13764 13765 13766 13767 13768 13769
        image=images,
        densities=[4, 2, 1],
        fixed_sizes=[32.0, 64.0, 128.0],
        fixed_ratios=[1.],
        clip=True,
        flatten_to_2d=True)











.. _cn_api_fluid_layers_detection_map:
C
Cheerego 已提交
13770

C
Cheerego 已提交
13771 13772 13773
detection_map
-------------------------------

13774
.. py:function:: paddle.fluid.layers.detection_map(detect_res, label, class_num, background_label=0, overlap_threshold=0.3, evaluate_difficult=True, has_state=None, input_states=None, out_states=None, ap_version='integral')
C
Cheerego 已提交
13775

13776
检测mAP评估算子。一般步骤如下:首先,根据检测输入和标签计算TP(true positive)和FP(false positive),然后计算mAP评估值。支持'11 point'和积分mAP算法。请从以下文章中获取更多信息:
C
Cheerego 已提交
13777 13778

        https://sanchom.wordpress.com/tag/average-precision/
C
Cheerego 已提交
13779

C
Cheerego 已提交
13780 13781 13782 13783 13784 13785 13786 13787 13788 13789 13790 13791 13792
        https://arxiv.org/abs/1512.02325

参数:
        - **detect_res** (LoDTensor)- 用具有形状[M,6]的2-D LoDTensor来表示检测。每行有6个值:[label,confidence,xmin,ymin,xmax,ymax],M是此小批量中检测结果的总数。对于每个实例,第一维中的偏移称为LoD,偏移量为N+1,如果LoD[i+1]-LoD[i]== 0,则表示没有检测到数据。
        - **label** (LoDTensor)- 2-D LoDTensor用来带有标签的真实数据。每行有6个值:[label,xmin,ymin,xmax,ymax,is_difficult]或5个值:[label,xmin,ymin,xmax,ymax],其中N是此小批量中真实数据的总数。对于每个实例,第一维中的偏移称为LoD,偏移量为N + 1,如果LoD [i + 1] - LoD [i] == 0,则表示没有真实数据。
        - **class_num** (int)- 类的数目。
        - **background_label** (int,defalut:0)- background标签的索引,background标签将被忽略。如果设置为-1,则将考虑所有类别。
        - **overlap_threshold** (float)- 检测输出和真实数据下限的重叠阈值。
        - **evaluate_difficult** (bool,默认为true)- 通过切换来控制是否对difficult-data进行评估。
        - **has_state** (Tensor <int>)- 是shape[1]的张量,0表示忽略输入状态,包括PosCount,TruePos,FalsePos。
        - **input_states** - 如果不是None,它包含3个元素:

            1、pos_count(Tensor)是一个shape为[Ncls,1]的张量,存储每类的输入正例的数量,Ncls是输入分类的数量。此输入用于在执行多个小批量累积计算时传递最初小批量生成的AccumPosCount。当输入(PosCount)为空时,不执行累积计算,仅计算当前小批量的结果。
C
Cheerego 已提交
13793

C
Cheerego 已提交
13794
            2、true_pos(LoDTensor)是一个shape为[Ntp,2]的2-D LoDTensor,存储每个类输入的正实例。此输入用于在执行多个小批量累积计算时传递最初小批量生成的AccumPosCount。
C
Cheerego 已提交
13795

C
Cheerego 已提交
13796
            3、false_pos(LoDTensor)是一个shape为[Nfp,2]的2-D LoDTensor,存储每个类输入的负实例。此输入用于在执行多个小批量累积计算时传递最初小批量生成的AccumPosCount。
C
Cheerego 已提交
13797

C
Cheerego 已提交
13798 13799
        - **out_states** - 如果不是None,它包含3个元素:

C
Cheerego 已提交
13800 13801 13802 13803
            1、accum_pos_count(Tensor)是一个shape为[Ncls,1]的Tensor,存储每个类的实例数。它结合了输入(PosCount)和从输入中的(Detection)和(label)计算的正例数。

            2、accum_true_pos(LoDTensor)是一个shape为[Ntp',2]的LoDTensor,存储每个类的正实例。它结合了输入(TruePos)和从输入中(Detection)和(label)计算的正实例数。 。

C
Cheerego 已提交
13804
            3、accum_false_pos(LoDTensor)是一个shape为[Nfp',2]的LoDTensor,存储每个类的负实例。它结合了输入(FalsePos)和从输入中(Detection)和(label)计算的负实例数。
C
Cheerego 已提交
13805

C
Cheerego 已提交
13806 13807 13808 13809 13810 13811 13812 13813 13814 13815 13816 13817 13818 13819 13820 13821 13822 13823
        - **ap_version** (string,默认'integral')- AP算法类型,'integral'或'11 point'。

返回:        具有形状[1]的(Tensor),存储mAP的检测评估结果。

**代码示例**

..  code-block:: python

        detect_res = fluid.layers.data(
            name='detect_res',
            shape=[10, 6],
            append_batch_size=False,
            dtype='float32')
        label = fluid.layers.data(
            name='label',
            shape=[10, 6],
            append_batch_size=False,
            dtype='float32')
H
Hao Wang 已提交
13824

C
Cheerego 已提交
13825 13826 13827 13828 13829 13830 13831 13832 13833 13834 13835 13836 13837 13838 13839 13840 13841 13842 13843 13844 13845 13846 13847
        map_out = fluid.layers.detection_map(detect_res, label, 21)











.. _cn_api_fluid_layers_detection_output:

detection_output
-------------------------------

.. py:function:: paddle.fluid.layers.detection_output(loc, scores, prior_box, prior_box_var, background_label=0, nms_threshold=0.3, nms_top_k=400, keep_top_k=200, score_threshold=0.01, nms_eta=1.0)

Detection Output Layer for Single Shot Multibox Detector(SSD)

该操作符用于获得检测结果,执行步骤如下:

H
Hao Wang 已提交
13848
    1.根据prior box框解码输入边界框(bounding box)预测
C
Cheerego 已提交
13849

H
Hao Wang 已提交
13850
    2.通过运用多类非极大值抑制(NMS)获得最终检测结果
C
Cheerego 已提交
13851 13852 13853 13854 13855 13856 13857 13858 13859 13860 13861 13862 13863 13864 13865 13866

请注意,该操作符不将最终输出边界框剪切至图像窗口。

参数:
    - **loc** (Variable) - 一个三维张量(Tensor),维度为[N,M,4],代表M个bounding bboxes的预测位置。N是批尺寸,每个边界框(boungding box)有四个坐标值,布局为[xmin,ymin,xmax,ymax]
    - **scores** (Variable) - 一个三维张量(Tensor),维度为[N,M,C],代表预测置信预测。N是批尺寸,C是类别数,M是边界框数。对每类一共M个分数,对应M个边界框
    - **prior_box** (Variable) - 一个二维张量(Tensor),维度为[M,4],存储M个框,每个框代表[xmin,ymin,xmax,ymax],[xmin,ymin]是anchor box的左上坐标,如果输入是图像特征图,靠近坐标系统的原点。[xmax,ymax]是anchor box的右下坐标
    - **prior_box_var** (Variable) - 一个二维张量(Tensor),维度为[M,4],存有M变量群
    - **background_label** (float) - 背景标签索引,背景标签将会忽略。若设为-1,将考虑所有类别
    - **nms_threshold** (int) - 用于NMS的临界值(threshold)
    - **nms_top_k** (int) - 基于score_threshold过滤检测后,根据置信数维持的最大检测数
    - **keep_top_k** (int) - NMS步后,每一图像要维持的总bbox数
    - **score_threshold** (float) - 临界函数(Threshold),用来过滤带有低置信数的边界框(bounding box)。若未提供,则考虑所有框
    - **nms_eta** (float) - 适应NMS的参数

返回:
R
RaindragonD 已提交
13867
  输出一个LoDTensor,形为[No,6]。每行有6个值:[label,confidence,xmin,ymin,xmax,ymax]。No是该mini-batch的总检测数。对每个实例,第一维偏移称为LoD,偏移数为N+1,N是batch size。第i个图像有LoD[i+1]-LoD[i]检测结果。如果为0,第i个图像无检测结果。如果所有图像都没有检测结果,LoD会被设置为{1},并且输出张量只包含一个值-1。(1.3版本后对于没有检测结果的boxes, LoD的值由之前的{0}调整为{1})
C
Cheerego 已提交
13868 13869 13870 13871 13872 13873

返回类型:变量(Variable)

**代码示例**:

.. code-block:: python
R
RaindragonD 已提交
13874 13875
    
    import paddle.fluid as fluid
H
Hao Wang 已提交
13876
    pb = fluid.layers.data(name='prior_box', shape=[10, 4],
C
Cheerego 已提交
13877
             append_batch_size=False, dtype='float32')
H
Hao Wang 已提交
13878
    pbv = fluid.layers.data(name='prior_box_var', shape=[10, 4],
C
Cheerego 已提交
13879
              append_batch_size=False, dtype='float32')
H
Hao Wang 已提交
13880
    loc = fluid.layers.data(name='target_box', shape=[2, 21, 4],
C
Cheerego 已提交
13881
              append_batch_size=False, dtype='float32')
H
Hao Wang 已提交
13882
    scores = fluid.layers.data(name='scores', shape=[2, 21, 10],
C
Cheerego 已提交
13883 13884 13885 13886 13887 13888 13889 13890 13891 13892
              append_batch_size=False, dtype='float32')
    nmsed_outs = fluid.layers.detection_output(scores=scores,
                           loc=loc,
                           prior_box=pb,
                           prior_box_var=pbv)





13893 13894 13895 13896 13897 13898 13899 13900 13901 13902 13903 13904 13905 13906 13907 13908 13909 13910 13911 13912 13913 13914 13915 13916 13917 13918 13919 13920 13921 13922 13923 13924 13925 13926 13927 13928 13929 13930 13931 13932 13933 13934 13935 13936 13937

.. _cn_api_fluid_layers_distribute_fpn_proposals:

distribute_fpn_proposals
-------------------------------

.. py:function:: paddle.fluid.layers.distribute_fpn_proposals(fpn_rois, min_level, max_level, refer_level, refer_scale, name=None)

在 Feature Pyramid Networks(FPN)模型中,需要将所有proposal分配到不同的FPN级别,包括proposal的比例,引用比例和引用级别。 此外,为了恢复proposals的顺序,我们返回一个数组,该数组表示当前proposals中的原始RoIs索引。 要计算每个RoI的FPN级别,公式如下:

.. math::
    roi\_scale &= \sqrt{BBoxArea(fpn\_roi)}\\
    level = floor(&\log(\frac{roi\_scale}{refer\_scale}) + refer\_level)

其中BBoxArea方法用来计算每个RoI的区域。


参数:
    - **fpn_rois** (variable) - 输入fpn_rois,第二个维度为4。
    - **min_level** (int) - 产生proposal最低级别FPN层。
    - **max_level** (int) - 产生proposal最高级别FPN层。
    - **refer_level** (int) - 具有指定比例的FPN层的引用级别。
    - **refer_scale** (int) - 具有指定级别的FPN层的引用比例。
    - **name** (str | None) - 此算子的名称。

返回:返回一个元组(multi_rois,restore_ind)。 multi_rois是分段张量变量的列表。 restore_ind是具有形状[N,1]的2D张量,N是总rois的数量。 它用于恢复fpn_rois的顺序。

返回类型:   tuple


**代码示例**:

.. code-block:: python

    fpn_rois = fluid.layers.data(
        name='data', shape=[4], dtype='float32', lod_level=1)
    multi_rois, restore_ind = fluid.layers.distribute_fpn_proposals(
        fpn_rois=fpn_rois,
        min_level=2,
        max_level=5,
        refer_level=4,
        refer_scale=224)



H
Hao Wang 已提交
13938 13939 13940 13941 13942 13943
.. _cn_api_fluid_layers_generate_mask_labels:

generate_mask_labels
-------------------------------

.. py:function:: paddle.fluid.layers.generate_mask_labels(im_info, gt_classes, is_crowd, gt_segms, rois, labels_int32, num_classes, resolution)
C
Cheerego 已提交
13944

H
Hao Wang 已提交
13945 13946
**为Mask-RCNN生成mask标签**

13947
对于给定的 RoI (Regions of Interest) 和相应的标签,该算子可以对前景RoI进行采样。 该mask branch对每个前景RoI还具有 :math:`K*M^{2}` 维输出目标,用于编码分辨率为M×M的K个二进制mask,K个种类中的各种类分别对应一个这样的二进制mask。 此mask输出目标用于计算掩码分支的损失。
H
Hao Wang 已提交
13948 13949 13950 13951 13952 13953 13954 13955 13956 13957 13958 13959 13960 13961 13962 13963 13964 13965 13966 13967 13968 13969 13970 13971 13972 13973 13974 13975

请注意groud-truth(真实值,下简称GT)分段的数据格式。假设分段如下, 第一个实例有两个GT对象。 第二个实例有一个GT对象,该对象有两个GT分段。


::

    #[
    #  [[[229.14, 370.9, 229.14, 370.9, ...]],
    #   [[343.7, 139.85, 349.01, 138.46, ...]]], # 第0个实例对象
    #  [[[500.0, 390.62, ...],[115.48, 187.86, ...]]] # 第1个实例对象
    #]

    batch_masks = []
    for semgs in batch_semgs:
        gt_masks = []
        for semg in semgs:
            gt_segm = []
            for polys in semg:
                gt_segm.append(np.array(polys).reshape(-1, 2))
            gt_masks.append(gt_segm)
        batch_masks.append(gt_masks)


    place = fluid.CPUPlace()
    feeder = fluid.DataFeeder(place=place, feed_list=feeds)
    feeder.feed(batch_masks)


C
Cheerego 已提交
13976
参数:
H
Hao Wang 已提交
13977 13978 13979 13980 13981 13982 13983 13984 13985 13986 13987
    - **im_info**  (Variable) – 具有形状[N,3]的2-D张量。 N是批量大小,其每个元素是图像的[高度,宽度,比例],对应第二维中的3。图像比例是 :math:`\frac{target\_size}{original\_size}` 。
    - **gt_classes**  (Variable) – 形为[M,1]的2-D LoDTensor。 M是真实值的总数,其每个元素都是一个类标签,对应第二维中的1。
    - **is_crowd**  (Variable) – 一个形为 ``gt_classes`` 的2-D LoDTensor,每个元素都是一个标志,指示一个groundtruth是否为crowd(群)。
    - **gt_segms**  (Variable) – 这个输入是一个形状为[S,2]的2D LoDTensor,它的LoD级别为3。通常用户不需要理解LoD,但用户应该在Reader中返回正确的数据格式。LoD [0]表示每个实例中GT对象的数目。 LoD [1]表示每个对象的分段数。 LoD [2]表示每个分段的多边形(polygon)数。S为多边形坐标点的总数。每个元素是(x,y)坐标点。
    - **rois**  (Variable) – 形为[R,4]的2-D LoDTensor。 R是RoI的总数,其中每个元素是在原始图像范围内具有(xmin,ymin,xmax,ymax)格式的边界框(bounding box)。
    - **labels_int32**  (Variable) – 形为[R,1]且类型为int32的2-D LoDTensor。 R与rois中的R含义相同。每个元素都反映了RoI的一个类标签。
    - **num_classes**  (int) – 种类数目
    - **resolution**  (int) – mask预测的分辨率

返回:
    - 形为[P,4]的2D LoDTensor。 P是采样出的RoI总数。每个元素都是在原始图像大小范围内具有[xmin,ymin,xmax,ymax]格式的边界框(bounding box)。
C
Cheerego 已提交
13988
    - mask_rois_has_mask_int32(Variable):形状为[P,1]的2D LoDTensor,其中每个元素为对于输入的RoI进行输出的mask RoI 索引
H
Hao Wang 已提交
13989 13990 13991 13992 13993 13994 13995
    - mask_int32(Variable):形状为[P,K * M * M]的2D LoDTensor,K为种类数,M为mask预测的分辨率,每个元素都是二进制目标mask值。

返回类型:mask_rois (Variable)

**代码示例**:

.. code-block:: python
R
RaindragonD 已提交
13996 13997
    
    import paddle.fluid as fluid
H
Hao Wang 已提交
13998 13999 14000 14001 14002 14003 14004 14005 14006

    im_info = fluid.layers.data(name="im_info", shape=[3],
        dtype="float32")
    gt_classes = fluid.layers.data(name="gt_classes", shape=[1],
        dtype="float32", lod_level=1)
    is_crowd = fluid.layers.data(name="is_crowd", shape=[1],
        dtype="float32", lod_level=1)
    gt_masks = fluid.layers.data(name="gt_masks", shape=[2],
        dtype="float32", lod_level=3)
R
RaindragonD 已提交
14007 14008 14009 14010 14011
    # rois, roi_labels 可以是fluid.layers.generate_proposal_labels的输出
    rois = fluid.layers.data(name="rois", shape=[4],
        dtype="float32", lod_level=1)
    roi_labels = fluid.layers.data(name="roi_labels", shape=[1],
        dtype="int32", lod_level=1)
H
Hao Wang 已提交
14012 14013 14014 14015 14016 14017
    mask_rois, mask_index, mask_int32 = fluid.layers.generate_mask_labels(
        im_info=im_info,
        gt_classes=gt_classes,
        is_crowd=is_crowd,
        gt_segms=gt_masks,
        rois=rois,
R
RaindragonD 已提交
14018
        labels_int32=roi_labels,
H
Hao Wang 已提交
14019 14020
        num_classes=81,
        resolution=14)
C
Cheerego 已提交
14021 14022 14023 14024 14025 14026 14027 14028 14029 14030





.. _cn_api_fluid_layers_generate_proposal_labels:

generate_proposal_labels
-------------------------------

R
RaindragonD 已提交
14031
.. py:function:: paddle.fluid.layers.generate_proposal_labels(rpn_rois, gt_classes, is_crowd, gt_boxes, im_info, batch_size_per_im=256, fg_fraction=0.25, fg_thresh=0.25, bg_thresh_hi=0.5, bg_thresh_lo=0.0, bbox_reg_weights=[0.1, 0.1, 0.2, 0.2], class_nums=None, use_random=True, is_cls_agnostic=False, is_cascade_rcnn=False)
C
Cheerego 已提交
14032 14033 14034 14035 14036

**该函数可以应用于 Faster-RCNN 网络,生成建议标签。**

该函数可以根据 ``GenerateProposals`` 的输出结果,即bounding boxes(区域框),groundtruth(正确标记数据)来对foreground boxes和background boxes进行采样,并计算loss值。

C
Cheerego 已提交
14037
RpnRois 是RPN的输出box, 并由 ``GenerateProposals`` 来进一步处理, 这些box将与groundtruth boxes合并, 并根据 ``batch_size_per_im`` 和 ``fg_fraction`` 进行采样。
C
Cheerego 已提交
14038 14039 14040 14041 14042 14043 14044

如果一个实例具有大于 ``fg_thresh`` (前景重叠阀值)的正确标记重叠,那么它会被认定为一个前景样本。
如果一个实例具有的正确标记重叠大于 ``bg_thresh_lo`` 且小于 ``bg_thresh_hi`` (详见参数说明),那么它将被认定为一个背景样本。
在所有前景、背景框(即Rois regions of interest 直译:有意义的区域)被选择后,我们接着采用随机采样的方法来确保前景框数量不多于 batch_size_per_im * fg_fraction 。

对Rois中的每个box, 我们给它分配类标签和回归目标(box label)。最后 ``bboxInsideWeights`` 和 ``BboxOutsideWeights`` 用来指明是否它将影响训练loss值。

C
Cheerego 已提交
14045
参数:
C
Cheerego 已提交
14046 14047 14048 14049 14050 14051 14052 14053 14054 14055 14056 14057 14058
  - **rpn_rois** (Variable) – 形为[N, 4]的二维LoDTensor。 N 为 ``GenerateProposals`` 的输出结果, 其中各元素为 :math:`[x_{min}, y_{min}, x_{max}, y_{max}]` 格式的边界框
  - **gt_classes** (Variable) – 形为[M, 1]的二维LoDTensor。 M 为正确标记数据数目, 其中各元素为正确标记数据的类别标签
  - **is_crowd** (Variable) – 形为[M, 1]的二维LoDTensor。M 为正确标记数据数目, 其中各元素为一个标志位,表明一个正确标记数据是不是crowd
  - **gt_boxes** (Variable) – 形为[M, 4]的二维LoDTensor。M 为正确标记数据数目, 其中各元素为 :math:`[x_{min}, y_{min}, x_{max}, y_{max}]` 格式的边界框
  - **im_info** (Variable) – 形为[B, 3]的二维LoDTensor。B 为输入图片的数目, 各元素由 im_height, im_width, im_scale 组成.
  - **batch_size_per_im** (int) – 每张图片的Rois batch数目
  - **fg_fraction** (float) – Foreground前景在 ``batch_size_per_im`` 中所占比例
  - **fg_thresh** (float) – 前景重叠阀值,用于选择foreground前景样本
  - **bg_thresh_hi** (float) – 背景重叠阀值的上界,用于筛选背景样本
  - **bg_thresh_lo** (float) – 背景重叠阀值的下界,用于筛选背景样本O
  - **bbox_reg_weights** (list|tuple) – Box 回归权重
  - **class_nums** (int) – 种类数目
  - **use_random** (bool) – 是否使用随机采样来选择foreground(前景)和background(背景) boxes(框)
R
RaindragonD 已提交
14059 14060
  - **is_cls_agnostic** (bool)- 未知类别的bounding box回归,仅标识前景和背景框
  - **is_cascade_rcnn** (bool)- 是否为 cascade RCNN 模型,为True时采样策略发生变化
C
Cheerego 已提交
14061

R
RaindragonD 已提交
14062
**代码示例**:
C
Cheerego 已提交
14063

R
RaindragonD 已提交
14064
.. code-block:: python
C
Cheerego 已提交
14065

R
RaindragonD 已提交
14066 14067 14068 14069 14070 14071 14072 14073 14074 14075 14076 14077 14078 14079 14080
    import paddle.fluid as fluid
    rpn_rois = fluid.layers.data(name='rpn_rois', shape=[2, 4],
                   append_batch_size=False, dtype='float32')
    gt_classes = fluid.layers.data(name='gt_classes', shape=[8, 1],
                   append_batch_size=False, dtype='float32')
    is_crowd = fluid.layers.data(name='is_crowd', shape=[8, 1],
                   append_batch_size=False, dtype='float32')
    gt_boxes = fluid.layers.data(name='gt_boxes', shape=[8, 4],
                   append_batch_size=False, dtype='float32')
    im_info = fluid.layers.data(name='im_info', shape=[10, 3],
                   append_batch_size=False, dtype='float32')
    rois, labels_int32, bbox_targets, bbox_inside_weights,
    bbox_outside_weights = fluid.layers.generate_proposal_labels(
                   rpn_rois, gt_classes, is_crowd, gt_boxes, im_info,
                   class_nums=10)
C
Cheerego 已提交
14081 14082 14083 14084 14085 14086 14087 14088 14089 14090 14091 14092 14093 14094 14095 14096











.. _cn_api_fluid_layers_generate_proposals:

generate_proposals
-------------------------------

C
Cheerego 已提交
14097
.. py:function:: paddle.fluid.layers.generate_proposals(scores, bbox_deltas, im_info, anchors, variances, pre_nms_top_n=6000, post_nms_top_n=1000, nms_thresh=0.5, min_size=0.1, eta=1.0, name=None)
C
Cheerego 已提交
14098 14099 14100

生成proposal的Faster-RCNN

H
Hao Wang 已提交
14101
该操作根据每个框为foreground(前景)对象的概率,并且通过anchors来计算这些框,进而提出RoI。Bbox_deltais和一个objects的分数作为是RPN的输出。最终 ``proposals`` 可用于训练检测网络。
C
Cheerego 已提交
14102 14103 14104 14105

为了生成 ``proposals`` ,此操作执行以下步骤:

        1、转置和调整bbox_deltas的分数和大小为(H * W * A,1)和(H * W * A,4)。
C
Cheerego 已提交
14106

C
Cheerego 已提交
14107
        2、计算方框位置作为 ``proposals`` 候选框。
C
Cheerego 已提交
14108

C
Cheerego 已提交
14109
        3、剪辑框图像。
C
Cheerego 已提交
14110

C
Cheerego 已提交
14111
        4、删除小面积的预测框。
C
Cheerego 已提交
14112

C
Cheerego 已提交
14113
        5、应用NMS以获得最终 ``proposals`` 作为输出。
C
Cheerego 已提交
14114

C
Cheerego 已提交
14115 14116 14117 14118 14119 14120 14121
参数:
        - **scores** (Variable)- 是一个shape为[N,A,H,W]的4-D张量,表示每个框成为object的概率。N是批量大小,A是anchor数,H和W是feature map的高度和宽度。
        - **bbox_deltas** (Variable)- 是一个shape为[N,4 * A,H,W]的4-D张量,表示预测框位置和anchor位置之间的差异。
        - **im_info** (Variable)- 是一个shape为[N,3]的2-D张量,表示N个批次原始图像的信息。信息包含原始图像大小和 ``feature map`` 的大小之间高度,宽度和比例。
        - **anchors** (Variable)- 是一个shape为[H,W,A,4]的4-D Tensor。H和W是 ``feature map`` 的高度和宽度,
        - **num_anchors** - 是每个位置的框的数量。每个anchor都是以非标准化格式(xmin,ymin,xmax,ymax)定义的。
        - **variances** (Variable)- anchor的方差,shape为[H,W,num_priors,4]。每个方差都是(xcenter,ycenter,w,h)这样的格式。
C
Cheerego 已提交
14122 14123 14124
        - **pre_nms_top_n** (float)- 每个图在NMS之前要保留的总框数。默认为6000。
        - **post_nms_top_n** (float)- 每个图在NMS后要保留的总框数。默认为1000。
        - **nms_thresh** (float)- NMS中的阈值,默认为0.5。
C
Cheerego 已提交
14125 14126 14127
        - **min_size** (float)- 删除高度或宽度小于min_size的预测框。默认为0.1。
        - **eta** (float)- 在自适应NMS中应用,如果自适应阈值> 0.5,则在每次迭代中使用adaptive_threshold = adaptive_treshold * eta。

R
RaindragonD 已提交
14128
**代码示例**:
C
Cheerego 已提交
14129

R
RaindragonD 已提交
14130 14131 14132 14133 14134 14135 14136 14137 14138 14139 14140 14141 14142 14143 14144
.. code-block:: python

    import paddle.fluid as fluid
    scores = fluid.layers.data(name='scores', shape=[2, 4, 5, 5],
                 append_batch_size=False, dtype='float32')
    bbox_deltas = fluid.layers.data(name='bbox_deltas', shape=[2, 16, 5, 5],
                 append_batch_size=False, dtype='float32')
    im_info = fluid.layers.data(name='im_info', shape=[2, 3],
                 append_batch_size=False, dtype='float32')
    anchors = fluid.layers.data(name='anchors', shape=[5, 5, 4, 4],
                 append_batch_size=False, dtype='float32')
    variances = fluid.layers.data(name='variances', shape=[5, 5, 10, 4],
                 append_batch_size=False, dtype='float32')
    rois, roi_probs = fluid.layers.generate_proposals(scores, bbox_deltas,
                 im_info, anchors, variances)
C
Cheerego 已提交
14145 14146 14147 14148 14149 14150 14151 14152 14153 14154 14155 14156 14157 14158 14159 14160 14161 14162 14163 14164 14165 14166 14167 14168 14169 14170 14171 14172 14173 14174 14175









.. _cn_api_fluid_layers_iou_similarity:

iou_similarity
-------------------------------

.. py:function:: paddle.fluid.layers.iou_similarity(x, y, name=None)

**IOU Similarity Operator**

计算两个框列表的intersection-over-union(IOU)。框列表‘X’应为LoDTensor,‘Y’是普通张量,X成批输入的所有实例共享‘Y’中的框。给定框A和框B,IOU的运算如下:

.. math::
    IOU(A, B) = \frac{area(A\cap B)}{area(A)+area(B)-area(A\cap B)}

参数:
    - **x** (Variable,默认LoDTensor,float类型) - 框列表X是二维LoDTensor,shape为[N,4],存有N个框,每个框代表[xmin,ymin,xmax,ymax],X的shape为[N,4]。如果输入是图像特征图,[xmin,ymin]市框的左上角坐标,接近坐标轴的原点。[xmax,ymax]是框的右下角坐标。张量可以包含代表一批输入的LoD信息。该批的一个实例能容纳不同的项数
    - **y** (Variable,张量,默认float类型的张量) - 框列表Y存有M个框,每个框代表[xmin,ymin,xmax,ymax],X的shape为[N,4]。如果输入是图像特征图,[xmin,ymin]市框的左上角坐标,接近坐标轴的原点。[xmax,ymax]是框的右下角坐标。张量可以包含代表一批输入的LoD信息。

返回:iou_similarity操作符的输出,shape为[N,M]的张量,代表一对iou分数

返回类型:out(Variable)

R
RaindragonD 已提交
14176 14177 14178
**代码示例**

..  code-block:: python
C
Cheerego 已提交
14179

R
RaindragonD 已提交
14180
        import paddle.fluid as fluid
C
Cheerego 已提交
14181

R
RaindragonD 已提交
14182 14183 14184
        x = fluid.layers.data(name='x', shape=[4], dtype='float32')
        y = fluid.layers.data(name='y', shape=[4], dtype='float32')
        iou = fluid.layers.iou_similarity(x=x, y=y)
C
Cheerego 已提交
14185 14186 14187 14188 14189 14190 14191






.. _cn_api_fluid_layers_multi_box_head:
C
Cheerego 已提交
14192

C
Cheerego 已提交
14193 14194 14195
multi_box_head
-------------------------------

14196
.. py:function:: paddle.fluid.layers.multi_box_head(inputs, image, base_size, num_classes, aspect_ratios, min_ratio=None, max_ratio=None, min_sizes=None, max_sizes=None, steps=None, step_w=None, step_h=None, offset=0.5, variance=[0.1, 0.1, 0.2, 0.2], flip=True, clip=False, kernel_size=1, pad=0, stride=1, name=None, min_max_aspect_ratios_order=False)
C
Cheerego 已提交
14197 14198 14199 14200 14201 14202 14203 14204 14205 14206 14207 14208 14209 14210 14211 14212 14213 14214 14215 14216 14217 14218 14219 14220 14221 14222 14223 14224 14225 14226 14227 14228

生成SSD(Single Shot MultiBox Detector)算法的候选框。有关此算法的详细信息,请参阅SSD论文 `SSD:Single Shot MultiBox Detector <https://arxiv.org/abs/1512.02325>`_ 的2.2节。

参数:
        - **inputs** (list | tuple)- 输入变量列表,所有变量的格式为NCHW。
        - **image** (Variable)- PriorBoxOp的输入图像数据,布局为NCHW。
        - **base_size** (int)- base_size用于根据 ``min_ratio`` 和 ``max_ratio`` 来获取 ``min_size`` 和 ``max_size`` 。
        - **num_classes** (int)- 类的数量。
        - **aspect_ratios** (list | tuple)- 生成候选框的宽高比。 ``input`` 和 ``aspect_ratios`` 的长度必须相等。
        - **min_ratio** (int)- 生成候选框的最小比率。
        - **max_ratio** (int)- 生成候选框的最大比率。
        - **min_sizes** (list | tuple | None)- 如果len(输入)<= 2,则必须设置 ``min_sizes`` ,并且 ``min_sizes`` 的长度应等于输入的长度。默认值:无。
        - **max_sizes** (list | tuple | None)- 如果len(输入)<= 2,则必须设置 ``max_sizes`` ,并且 ``min_sizes`` 的长度应等于输入的长度。默认值:无。
        - **steps** (list | tuple)- 如果step_w和step_h相同,则step_w和step_h可以被steps替换。
        - **step_w** (list | tuple)- 候选框跨越宽度。如果step_w [i] == 0.0,将自动计算输跨越入[i]宽度。默认值:无。
        - **step_h** (list | tuple)- 候选框跨越高度,如果step_h [i] == 0.0,将自动计算跨越输入[i]高度。默认值:无。
        - **offset** (float)- 候选框中心偏移。默认值:0.5
        - **variance** (list | tuple)- 在候选框编码的方差。默认值:[0.1,0.1,0.2,0.2]。
        - **flip** (bool)- 是否翻转宽高比。默认值:false。
        - **clip** (bool)- 是否剪切超出边界的框。默认值:False。
        - **kernel_size** (int)- conv2d的内核大小。默认值:1。
        - **pad** (int | list | tuple)- conv2d的填充。默认值:0。
        - **stride** (int | list | tuple)- conv2d的步长。默认值:1,
        - **name** (str)- 候选框的名称。默认值:无。
        - **min_max_aspect_ratios_order** (bool)- 如果设置为True,则输出候选框的顺序为[min,max,aspect_ratios],这与Caffe一致。请注意,此顺序会影响卷积层后面的权重顺序,但不会影响最终检测结果。默认值:False。

返回:一个带有四个变量的元组,(mbox_loc,mbox_conf,boxes, variances):

    - **mbox_loc** :预测框的输入位置。布局为[N,H * W * Priors,4]。其中 ``Priors`` 是每个输位置的预测框数。

    - **mbox_conf** :预测框对输入的置信度。布局为[N,H * W * Priors,C]。其中 ``Priors`` 是每个输入位置的预测框数,C是类的数量。

14229
    - **boxes** : ``PriorBox`` 的输出候选框。布局是[num_priors,4]。 ``num_priors`` 是每个输入位置的总框数。
C
Cheerego 已提交
14230 14231 14232 14233

    - **variances** : ``PriorBox`` 的方差。布局是[num_priors,4]。 ``num_priors`` 是每个输入位置的总窗口数。

返回类型:元组(tuple)
C
Cheerego 已提交
14234

C
Cheerego 已提交
14235 14236 14237
**代码示例**

..  code-block:: python
R
RaindragonD 已提交
14238 14239 14240 14241 14242 14243 14244 14245 14246 14247 14248
        
        import paddle.fluid as fluid
     
        images = fluid.layers.data(name='data', shape=[3, 300, 300], dtype='float32')
        conv1 = fluid.layers.data(name='conv1', shape=[512, 19, 19], dtype='float32')
        conv2 = fluid.layers.data(name='conv2', shape=[1024, 10, 10], dtype='float32')
        conv3 = fluid.layers.data(name='conv3', shape=[512, 5, 5], dtype='float32')
        conv4 = fluid.layers.data(name='conv4', shape=[256, 3, 3], dtype='float32')
        conv5 = fluid.layers.data(name='conv5', shape=[256, 2, 2], dtype='float32')
        conv6 = fluid.layers.data(name='conv6', shape=[128, 1, 1], dtype='float32')
        
C
Cheerego 已提交
14249
        mbox_locs, mbox_confs, box, var = fluid.layers.multi_box_head(
14250
          inputs=[conv1, conv2, conv3, conv4, conv5, conv6],
C
Cheerego 已提交
14251 14252 14253 14254 14255 14256 14257 14258 14259 14260 14261 14262 14263
          image=images,
          num_classes=21,
          min_ratio=20,
          max_ratio=90,
          aspect_ratios=[[2.], [2., 3.], [2., 3.], [2., 3.], [2.], [2.]],
          base_size=300,
          offset=0.5,
          flip=True,
          clip=True)




H
Hao Wang 已提交
14264
.. _cn_api_fluid_layers_multiclass_nms:
C
Cheerego 已提交
14265

H
Hao Wang 已提交
14266 14267
multiclass_nms
-------------------------------
C
Cheerego 已提交
14268

C
Cheerego 已提交
14269
.. py:function:: paddle.fluid.layers.multiclass_nms(bboxes, scores, score_threshold, nms_top_k, keep_top_k, nms_threshold=0.3, normalized=True, nms_eta=1.0, background_label=0, name=None)
C
Cheerego 已提交
14270

H
Hao Wang 已提交
14271 14272
**多分类NMS**

H
Hao Wang 已提交
14273
该运算用于对边界框(bounding box)和评分进行多类非极大值抑制(NMS)。
H
Hao Wang 已提交
14274

14275
在NMS中,如果提供 ``score_threshold`` 阈值,则此算子贪婪地选择具有高于 ``score_threshold`` 的高分数的检测边界框(bounding box)的子集,然后如果nms_top_k大于-1,则选择最大的nms_top_k置信度分数。 接着,该算子基于 ``nms_threshold`` 和 ``nms_eta`` 参数,通过自适应阈值NMS移去与已经选择的框具有高IOU(intersection over union)重叠的框。
H
Hao Wang 已提交
14276 14277 14278 14279 14280 14281 14282 14283 14284 14285 14286 14287

在NMS步骤后,如果keep_top_k大于-1,则每个图像最多保留keep_top_k个总bbox数。


参数:
    - **bboxes**  (Variable) – 支持两种类型的bbox(bounding box):

      1. (Tensor)具有形[N,M,4]或[8 16 24 32]的3-D张量表示M个边界bbox的预测位置, N是批大小batch size。当边界框(bounding box)大小等于4时,每个边界框有四个坐标值,布局为[xmin,ymin,xmax,ymax]。
      2. (LoDTensor)形状为[M,C,4] M的三维张量是边界框的数量,C是种类数量

    - **scores**  (Variable) – 支持两种类型的分数:

C
Cheerego 已提交
14288
      1. (tensor)具有形状[N,C,M]的3-D张量表示预测的置信度。 N是批量大小 batch size,C是种类数目,M是边界框bounding box的数量。对于每个类别,存在对应于M个边界框的总M个分数。请注意,M等于bboxes的第二维。
H
Hao Wang 已提交
14289
      2. (LoDTensor)具有形状[M,C]的2-D LoDTensor。 M是bbox的数量,C是种类数目。在这种情况下,输入bboxes应该是形为[M,C,4]的第二种情况。
C
Cheerego 已提交
14290 14291

    - **background_label**  (int) – 背景标签(类别)的索引,背景标签(类别)将被忽略。如果设置为-1,则将考虑所有类别。默认值:0
H
Hao Wang 已提交
14292 14293 14294 14295 14296 14297 14298 14299 14300 14301 14302 14303 14304 14305 14306 14307 14308 14309 14310 14311 14312 14313 14314 14315 14316 14317 14318 14319
    - **score_threshold**  (float) – 过滤掉低置信度分数的边界框的阈值。如果没有提供,请考虑所有边界框。
    - **nms_top_k**  (int) – 根据通过score_threshold的过滤后而得的检测(detection)的置信度,所需要保留的最大检测数。
    - **nms_threshold**  (float) – 在NMS中使用的阈值。默认值:0.3 。
    - **nms_eta**  (float) – 在NMS中使用的阈值。默认值:1.0 。
    - **keep_top_k**  (int) – NMS步骤后每个图像要保留的总bbox数。 -1表示在NMS步骤之后保留所有bbox。
    - **normalized**  (bool) –  检测是否已经经过正则化。默认值:True 。
    - **name**  (str) – 多类nms op(此op)的名称,用于自定义op在网络中的命名。默认值:None 。

返回:形为[No,6]的2-D LoDTensor,表示检测(detections)结果。每行有6个值:[标签label,置信度confidence,xmin,ymin,xmax,ymax]。或形为[No,10]的2-D LoDTensor,用来表示检测结果。 每行有10个值:[标签label,置信度confidence,x1,y1,x2,y2,x3,y3,x4,y4]。 No是检测的总数。 如果对所有图像都没有检测到的box,则lod将设置为{1},而Out仅包含一个值-1。 (1.3版本之后,当未检测到box时,lod从{0}更改为{1})

返回类型:Out

**代码示例**

..  code-block:: python

    boxes = fluid.layers.data(name='bboxes', shape=[81, 4],
                              dtype='float32', lod_level=1)
    scores = fluid.layers.data(name='scores', shape=[81],
                              dtype='float32', lod_level=1)
    out = fluid.layers.multiclass_nms(bboxes=boxes,
                                      scores=scores,
                                      background_label=0,
                                      score_threshold=0.5,
                                      nms_top_k=400,
                                      nms_threshold=0.3,
                                      keep_top_k=200,
                                      normalized=False)
C
Cheerego 已提交
14320 14321 14322 14323 14324 14325 14326 14327



.. _cn_api_fluid_layers_polygon_box_transform:

polygon_box_transform
-------------------------------

C
Cheerego 已提交
14328
.. py:function:: paddle.fluid.layers.polygon_box_transform(input, name=None)
C
Cheerego 已提交
14329 14330 14331 14332 14333 14334 14335 14336 14337 14338

PolygonBoxTransform 算子。

该算子用于将偏移坐标转变为真正的坐标。

输入是检测网络的最终几何输出。我们使用 2*n 个数来表示从 polygon_box 中的 n 个顶点(vertice)到像素位置的偏移。由于每个距离偏移包含两个数字 :math:`(x_i, y_i)` ,所以何输出包含 2*n 个通道。

参数:
    - **input** (Variable) - shape 为[batch_size,geometry_channels,height,width]的张量

C
Cheerego 已提交
14339
返回:与输入 shape 相同
C
Cheerego 已提交
14340 14341 14342

返回类型:output(Variable)

R
RaindragonD 已提交
14343
**代码示例**
C
Cheerego 已提交
14344

R
RaindragonD 已提交
14345
..  code-block:: python
C
Cheerego 已提交
14346

R
RaindragonD 已提交
14347 14348 14349 14350
    import paddle.fluid as fluid
    input = fluid.layers.data(name='input', shape=[4, 10, 5, 5],
                              append_batch_size=False, dtype='float32')
    out = fluid.layers.polygon_box_transform(input)
C
Cheerego 已提交
14351 14352 14353 14354 14355 14356 14357 14358 14359







.. _cn_api_fluid_layers_prior_box:

C
Cheerego 已提交
14360
prior_box
C
Cheerego 已提交
14361
-------------------------------
14362
.. py:function:: paddle.fluid.layers.prior_box(input,image,min_sizes=None,max_sizes=None,aspect_ratios=[1.0],variance=[0.1,0.1,0.2,0.2],flip=False,clip=False,steps=[0.0,0.0],offset=0.5,name=None,min_max_aspect_ratios_order=False)
C
Cheerego 已提交
14363

R
RaindragonD 已提交
14364
**Prior Box操作符**
C
Cheerego 已提交
14365 14366 14367 14368 14369 14370 14371

为SSD(Single Shot MultiBox Detector)算法生成先验框。输入的每个位产生N个先验框,N由min_sizes,max_sizes和aspect_ratios的数目决定,先验框的尺寸在(min_size,max_size)之间,该尺寸根据aspect_ratios在序列中生成。

参数:
    - **input** (Variable)-输入变量,格式为NCHW
    - **image** (Variable)-PriorBoxOp的输入图像数据,布局为NCHW
    - **min_sizes** (list|tuple|float值)-生成的先验框的最小尺寸
R
RaindragonD 已提交
14372
    - **max_sizes** (list|tuple|None)-生成的先验框的最大尺寸。默认:None
C
Cheerego 已提交
14373 14374 14375
    - **aspect_ratios** (list|tuple|float值)-生成的先验框的纵横比。默认:[1.]
    - **variance** (list|tuple)-先验框中的变量,会被解码。默认:[0.1,0.1,0.2,0.2]
    - **flip** (bool)-是否忽略纵横比。默认:False。
R
RaindragonD 已提交
14376
    - **clip** (bool)-是否修建溢界框。默认:False。
C
Cheerego 已提交
14377
    - **step** (list|tuple)-先验框在width和height上的步长。如果step[0] == 0.0/step[1] == 0.0,则自动计算先验框在宽度和高度上的步长。默认:[0.,0.]
R
RaindragonD 已提交
14378
    - **offset** (float)-先验框中心位移。默认:0.5
C
Cheerego 已提交
14379 14380 14381 14382 14383
    - **name** (str)-先验框操作符名称。默认:None
    - **min_max_aspect_ratios_order** (bool)-若设为True,先验框的输出以[min,max,aspect_ratios]的顺序,和Caffe保持一致。请注意,该顺序会影响后面卷基层的权重顺序,但不影响最后的检测结果。默认:False。

返回:
    含有两个变量的元组(boxes,variances)
R
RaindragonD 已提交
14384 14385
    boxes:PriorBox的输出先验框。布局是[H,W,num_priors,4]。H是输入的高度,W是输入的宽度,num_priors是输入每位的总框数
    variances:PriorBox的扩展变量。布局上[H,W,num_priors,4]。H是输入的高度,W是输入的宽度,num_priors是输入每位的总框数
C
Cheerego 已提交
14386 14387 14388 14389 14390 14391

返回类型:元组

**代码示例**:

.. code-block:: python
R
RaindragonD 已提交
14392 14393 14394
    
    input = fluid.layers.data(name="input", shape=[3,6,9])
    images = fluid.layers.data(name="images", shape=[3,9,12])
C
Cheerego 已提交
14395
    box, var = fluid.layers.prior_box(
R
RaindragonD 已提交
14396
        input=input,
C
Cheerego 已提交
14397 14398 14399 14400 14401 14402
        image=images,
        min_sizes=[100.],
        flip=True,
        clip=True)


R
RaindragonD 已提交
14403 14404 14405 14406 14407 14408 14409 14410 14411 14412 14413 14414 14415 14416 14417 14418 14419 14420 14421 14422 14423 14424 14425 14426 14427 14428 14429 14430 14431 14432 14433 14434 14435 14436
.. _cn_api_fluid_layers_retinanet_detection_output:

retinanet_detection_output
-------------------------------

.. py:function:: paddle.fluid.layers.retinanet_detection_output(bboxes, scores, anchors, im_info, score_threshold=0.05, nms_top_k=1000, keep_top_k=100, nms_threshold=0.3, nms_eta=1.0)

**Retinanet的检测输出层**

此操作通过执行以下步骤获取检测结果:

1. 根据anchor框解码每个FPN级别的最高得分边界框预测。
2. 合并所有级别的顶级预测并对其应用多级非最大抑制(NMS)以获得最终检测。


参数:
    - **bboxes**  (List) – 来自多个FPN级别的张量列表。每个元素都是一个三维张量,形状[N,Mi,4]代表Mi边界框的预测位置。N是batch大小,Mi是第i个FPN级别的边界框数,每个边界框有四个坐标值,布局为[xmin,ymin,xmax,ymax]。
    - **scores**  (List) – 来自多个FPN级别的张量列表。每个元素都是一个三维张量,各张量形状为[N,Mi,C],代表预测的置信度预测。 N是batch大小,C是类编号(不包括背景),Mi是第i个FPN级别的边界框数。对于每个边界框,总共有C个评分。
    - **anchors**  (List) – 具有形状[Mi,4]的2-D Tensor表示来自所有FPN级别的Mi anchor框的位置。每个边界框有四个坐标值,布局为[xmin,ymin,xmax,ymax]。
    - **im_info**  (Variable) – 形状为[N,3]的2-D LoDTensor表示图像信息。 N是batch大小,每个图像信息包括高度,宽度和缩放比例。
    - **score_threshold**  (float) – 用置信度分数剔除边界框的过滤阈值。
    - **nms_top_k**  (int) – 根据NMS之前的置信度保留每个FPN层的最大检测数。
    - **keep_top_k**  (int) – NMS步骤后每个图像要保留的总边界框数。 -1表示在NMS步骤之后保留所有边界框。
    - **nms_threshold**  (float) – NMS中使用的阈值.
    - **nms_eta**  (float) – adaptive NMS的参数.



返回:
检测输出是具有形状[No,6]的LoDTensor。 每行有六个值:[标签,置信度,xmin,ymin,xmax,ymax]。 No是此mini batch中的检测总数。 对于每个实例,第一维中的偏移称为LoD,偏移值为N + 1,N是batch大小。 第i个图像具有LoD [i + 1]  -  LoD [i]检测结果,如果为0,则第i个图像没有检测到结果。 如果所有图像都没有检测到结果,则LoD将设置为0,输出张量为空(None)。


返回类型:变量(Variable)

14437
**代码示例**
R
RaindragonD 已提交
14438 14439

.. code-block:: python
C
Cheerego 已提交
14440

R
RaindragonD 已提交
14441 14442 14443 14444 14445 14446 14447 14448 14449 14450 14451 14452 14453 14454 14455 14456 14457 14458 14459 14460
  import paddle.fluid as fluid

  bboxes = layers.data(name='bboxes', shape=[1, 21, 4],
      append_batch_size=False, dtype='float32')
  scores = layers.data(name='scores', shape=[1, 21, 10],
      append_batch_size=False, dtype='float32')
  anchors = layers.data(name='anchors', shape=[21, 4],
      append_batch_size=False, dtype='float32')
  im_info = layers.data(name="im_info", shape=[1, 3],
      append_batch_size=False, dtype='float32')
  nmsed_outs = fluid.layers.retinanet_detection_output(
                                          bboxes=[bboxes, bboxes],
                                          scores=[scores, scores],
                                          anchors=[anchors, anchors],
                                          im_info=im_info,
                                          score_threshold=0.05,
                                          nms_top_k=1000,
                                          keep_top_k=100,
                                          nms_threshold=0.3,
                                          nms_eta=1.)
C
Cheerego 已提交
14461 14462 14463



14464 14465 14466 14467 14468 14469 14470 14471 14472 14473 14474 14475 14476 14477 14478 14479 14480 14481 14482 14483 14484 14485 14486 14487 14488 14489 14490 14491 14492 14493 14494 14495 14496 14497 14498 14499 14500 14501 14502 14503 14504 14505 14506 14507 14508 14509 14510 14511 14512 14513 14514 14515 14516 14517 14518 14519 14520 14521 14522 14523 14524 14525 14526 14527 14528 14529 14530 14531 14532
.. _cn_api_fluid_layers_retinanet_target_assign:

retinanet_target_assign
-------------------------------

.. py:function:: paddle.fluid.layers.retinanet_target_assign(bbox_pred, cls_logits, anchor_box, anchor_var, gt_boxes, gt_labels, is_crowd, im_info, num_classes=1, positive_overlap=0.5, negative_overlap=0.4)

**Retinanet的目标分配层**

对于给定anchors和真实(ground-truth)框之间的Intersection-over-Union(IoU)重叠,该层可以为每个anchor分配分类和回归目标,同时这些目标标签用于训练Retinanet。每个anchor都分配有长度为num_classes的一个one-hot分类目标向量,以及一个4向量的框回归目标。分配规则如下:

1.在以下情况下,anchor被分配到真实框:
(i)它与真实框具有最高的IoU重叠,或者(ii)与任何真实框具有高于positive_overlap(0.5)的IoU重叠。

2.对于所有真实框,当其IoU比率低于negative_overlap(0.4)时,将anchor点分配给背景。

当为锚点分配了第i个类别的真实框时,其C向量目标中的第i项设置为1,所有其他条目设置为0.当anchor被分配支背景时,所有项都设置为0。未被分配的锚点不会影响训练目标。回归目标是与指定anchor相关联的已编码真实框。



参数:
    - **bbox_pred**  (Variable) – 具有形状[N,M,4]的3-D张量表示M个边界框(bounding box)的预测位置。 N是batch大小,每个边界框有四个坐标值,为[xmin,ymin,xmax,ymax]。
    - **cls_logits**  (Variable) – 具有形状[N,M,C]的3-D张量,表示预测的置信度。 N是batch大小,C是类别的数量(不包括背景),M是边界框的数量。
    - **anchor_box**  (Variable) – 具有形状[M,4]的2-D张量,存有M个框,每个框表示为[xmin,ymin,xmax,ymax],[xmin,ymin]是anchor的左上顶部坐标,如果输入是图像特征图,则它们接近坐标系的原点。 [xmax,ymax]是anchor的右下坐标。
    - **anchor_var**  (Variable) – 具有形状[M,4]的2-D张量,存有anchor的扩展方差。
    - **gt_boxes**  (Variable) – 真实框是具有形状[Ng,4]的2D LoDTensor,Ng是mini batch中真实框的总数。
    - **gt_labels**  (variable) – 真实值标签是具有形状[Ng,1]的2D LoDTensor,Ng是mini batch输入真实值标签的总数。
    - **is_crowd**  (Variable) – 1-D LoDTensor,标志真实值是聚群。
    - **im_info**  (Variable) – 具有形状[N,3]的2-D LoDTensor。 N是batch大小,3分别为高度,宽度和比例。
    - **num_classes**  (int32) – 种类数量。
    - **positive_overlap**  (float) – 判定(anchor,gt框)对是一个正例的anchor和真实框之间最小重叠阀值。
    - **negative_overlap**  (float) – (锚点,gt框)对是负例时anchor和真实框之间允许的最大重叠阈值。


返回:
返回元组(predict_scores,predict_location,target_label,target_bbox,bbox_inside_weight,fg_num)。 predict_scores和predict_location是Retinanet的预测结果。target_label和target_bbox为真实值。 predict_location是形为[F,4]的2D张量,target_bbox的形状与predict_location的形状相同,F是前景anchor的数量。 predict_scores是具有形状[F + B,C]的2D张量,target_label的形状是[F + B,1],B是背景anchor的数量,F和B取决于此算子的输入。 Bbox_inside_weight标志预测位置是否为假前景,形状为[F,4]。 Fg_num是focal loss所需的前景数(包括假前景)。


返回类型:tuple

**代码示例**

.. code-block:: python

    import paddle.fluid as fluid
    bbox_pred = layers.data(name='bbox_pred', shape=[1, 100, 4],
                      append_batch_size=False, dtype='float32')
    cls_logits = layers.data(name='cls_logits', shape=[1, 100, 10],
                      append_batch_size=False, dtype='float32')
    anchor_box = layers.data(name='anchor_box', shape=[100, 4],
                      append_batch_size=False, dtype='float32')
    anchor_var = layers.data(name='anchor_var', shape=[100, 4],
                      append_batch_size=False, dtype='float32')
    gt_boxes = layers.data(name='gt_boxes', shape=[10, 4],
                      append_batch_size=False, dtype='float32')
    gt_labels = layers.data(name='gt_labels', shape=[10, 1],
                      append_batch_size=False, dtype='float32')
    is_crowd = fluid.layers.data(name='is_crowd', shape=[1],
                      append_batch_size=False, dtype='float32')
    im_info = fluid.layers.data(name='im_infoss', shape=[1, 3],
                      append_batch_size=False, dtype='float32')
    loc_pred, score_pred, loc_target, score_target, bbox_inside_weight, fg_num =
          fluid.layers.retinanet_target_assign(bbox_pred, cls_logits, anchor_box,
          anchor_var, gt_boxes, gt_labels, is_crowd, im_info, 10)





C
Cheerego 已提交
14533 14534 14535 14536 14537 14538 14539 14540 14541 14542 14543 14544 14545 14546 14547 14548 14549





.. _cn_api_fluid_layers_roi_perspective_transform:

roi_perspective_transform
-------------------------------

.. py:function:: paddle.fluid.layers.roi_perspective_transform(input, rois, transformed_height, transformed_width, spatial_scale=1.0)

**ROI perspective transform操作符**

参数:
    - **input** (Variable) - ROI Perspective TransformOp的输入。输入张量的形式为NCHW。N是批尺寸,C是输入通道数,H是特征高度,W是特征宽度
    - **rois** (Variable) - 用来处理的ROIs,应该是shape的二维LoDTensor(num_rois,8)。给定[[x1,y1,x2,y2,x3,y3,x4,y4],...],(x1,y1)是左上角坐标,(x2,y2)是右上角坐标,(x3,y3)是右下角坐标,(x4,y4)是左下角坐标
R
RaindragonD 已提交
14550 14551
    - **transformed_height** (integer) - 输出的高度
    - **transformed_width** (integer) – 输出的宽度
C
Cheerego 已提交
14552 14553 14554
    - **spatial_scale** (float) - 空间尺度因子,用于缩放ROI坐标,默认:1.0。

返回:
T
Tink_Y 已提交
14555
 ``ROIPerspectiveTransformOp`` 的输出,它是一个4维张量,形为 (num_rois,channels,transformed_h,transformed_w)
C
Cheerego 已提交
14556 14557 14558 14559 14560 14561 14562

返回类型:变量(Variable)

**代码示例**:

.. code-block:: python

R
RaindragonD 已提交
14563
    import paddle.fluid as fluid
C
Cheerego 已提交
14564

R
RaindragonD 已提交
14565 14566 14567
    x = fluid.layers.data(name='x', shape=[256, 28, 28], dtype='float32')
    rois = fluid.layers.data(name='rois', shape=[8], lod_level=1, dtype='float32')
    out = fluid.layers.roi_perspective_transform(x, rois, 7, 7, 1.0)
C
Cheerego 已提交
14568 14569 14570 14571 14572 14573 14574 14575 14576 14577 14578 14579 14580 14581 14582 14583 14584 14585 14586 14587 14588 14589







.. _cn_api_fluid_layers_rpn_target_assign:

rpn_target_assign
-------------------------------

.. py:function:: paddle.fluid.layers.rpn_target_assign(bbox_pred, cls_logits, anchor_box, anchor_var, gt_boxes, is_crowd, im_info, rpn_batch_size_per_im=256, rpn_straddle_thresh=0.0, rpn_fg_fraction=0.5, rpn_positive_overlap=0.7, rpn_negative_overlap=0.3, use_random=True)

在Faster-RCNN检测中为区域检测网络(RPN)分配目标层。

对于给定anchors和真实框之间的IoU重叠,该层可以为每个anchors做分类和回归,这些target labels用于训练RPN。classification targets是二进制的类标签(是或不是对象)。根据Faster-RCNN的论文,positive labels有两种anchors:

(i) anchor/anchors与真实框具有最高IoU重叠;

(ii) 具有IoU重叠的anchors高于带有任何真实框(ground-truth box)的rpn_positive_overlap0(0.7)。

H
Hao Wang 已提交
14590
请注意,单个真实框(ground-truth box)可以为多个anchors分配正标签。对于所有真实框(ground-truth box),非正向anchor是指其IoU比率低于rpn_negative_overlap(0.3)。既不是正也不是负的anchors对训练目标没有价值。回归目标是与positive anchors相关联而编码的图片真实框。
C
Cheerego 已提交
14591 14592 14593 14594 14595 14596 14597 14598

参数:
        - **bbox_pred** (Variable)- 是一个shape为[N,M,4]的3-D Tensor,表示M个边界框的预测位置。N是批量大小,每个边界框有四个坐标值,即[xmin,ymin,xmax,ymax]。
        - **cls_logits** (Variable)- 是一个shape为[N,M,1]的3-D Tensor,表示预测的置信度。N是批量大小,1是frontground和background的sigmoid,M是边界框的数量。
        - **anchor_box** (Variable)- 是一个shape为[M,4]的2-D Tensor,它拥有M个框,每个框可表示为[xmin,ymin,xmax,ymax],[xmin,ymin]是anchor框的左上部坐标,如果输入是图像特征图,则它们接近坐标系的原点。 [xmax,ymax]是anchor框的右下部坐标。
        - **anchor_var** (Variable)- 是一个shape为[M,4]的2-D Tensor,它拥有anchor的expand方差。
        - **gt_boxes** (Variable)- 真实边界框是一个shape为[Ng,4]的2D LoDTensor,Ng是小批量输入的真实框(bbox)总数。
        - **is_crowd** (Variable)- 1-D LoDTensor,表示(groud-truth)是密集的。
14599
        - **im_info** (Variable)- 是一个形为[N,3]的2-D LoDTensor。N是batch大小,第二维上的3维分别代表高度,宽度和比例(scale)
C
Cheerego 已提交
14600 14601 14602 14603 14604 14605 14606 14607
        - **rpn_batch_size_per_im** (int)- 每个图像中RPN示例总数。
        - **rpn_straddle_thresh** (float)- 通过straddle_thresh像素删除出现在图像外部的RPN anchor。
        - **rpn_fg_fraction** (float)- 为foreground(即class> 0)RoI小批量而标记的目标分数,第0类是background。
        - **rpn_positive_overlap** (float)- 对于一个正例的(anchor, gt box)对,是允许anchors和所有真实框之间最小重叠的。
        - **rpn_negative_overlap** (float)- 对于一个反例的(anchor, gt box)对,是允许anchors和所有真实框之间最大重叠的。

返回:

C
Cheerego 已提交
14608 14609 14610 14611
返回元组 (predicted_scores, predicted_location, target_label, target_bbox, bbox_inside_weight) :
   - **predicted_scores** 和 **predicted_location** 是RPN的预测结果。 **target_label** 和 **target_bbox** 分别是真实准确数据(ground-truth)。
   - **predicted_location** 是一个形为[F,4]的2D Tensor, **target_bbox** 的形与 **predicted_location** 相同,F是foreground anchors的数量。
   - **predicted_scores** 是一个shape为[F + B,1]的2D Tensor, **target_label** 的形与 **predict_scores** 的形相同,B是background anchors的数量,F和B取决于此算子的输入。
C
Cheerego 已提交
14612 14613 14614 14615 14616 14617 14618 14619 14620
   - **Bbox_inside_weight** 标志着predicted_loction是否为fake_fg(假前景),其形为[F,4]。

返回类型:        元组(tuple)


**代码示例**

..  code-block:: python

R
RaindragonD 已提交
14621
        import paddle.fluid as fluid
H
Hao Wang 已提交
14622
        bbox_pred = fluid.layers.data(name=’bbox_pred’, shape=[100, 4],
C
Cheerego 已提交
14623
                append_batch_size=False, dtype=’float32’)
H
Hao Wang 已提交
14624
        cls_logits = fluid.layers.data(name=’cls_logits’, shape=[100, 1],
C
Cheerego 已提交
14625
                append_batch_size=False, dtype=’float32’)
H
Hao Wang 已提交
14626
        anchor_box = fluid.layers.data(name=’anchor_box’, shape=[20, 4],
C
Cheerego 已提交
14627
                append_batch_size=False, dtype=’float32’)
H
Hao Wang 已提交
14628
        gt_boxes = fluid.layers.data(name=’gt_boxes’, shape=[10, 4],
C
Cheerego 已提交
14629
                append_batch_size=False, dtype=’float32’)
R
RaindragonD 已提交
14630 14631 14632 14633
        is_crowd = fluid.layers.data(name='is_crowd', shape=[1],
                    append_batch_size=False, dtype='float32')
        im_info = fluid.layers.data(name='im_infoss', shape=[1, 3],
                    append_batch_size=False, dtype='float32')
C
Cheerego 已提交
14634
        loc_pred, score_pred, loc_target, score_target, bbox_inside_weight=
R
RaindragonD 已提交
14635 14636
                fluid.layers.rpn_target_assign(bbox_pred, cls_logits,
                        anchor_box, anchor_var, gt_boxes, is_crowd, im_info)
C
Cheerego 已提交
14637 14638 14639



C
Cheerego 已提交
14640 14641


14642 14643 14644 14645 14646 14647 14648 14649 14650 14651 14652 14653 14654 14655 14656 14657 14658 14659 14660 14661 14662 14663 14664 14665 14666 14667 14668 14669 14670 14671 14672 14673 14674 14675 14676 14677 14678 14679 14680 14681
.. _cn_api_fluid_layers_sigmoid_focal_loss:

sigmoid_focal_loss
-------------------------------

.. py:function:: paddle.fluid.layers.sigmoid_focal_loss(x, label, fg_num, gamma=2, alpha=0.25)

**Sigmoid Focal loss损失计算**

focal损失用于解决在one-stage探测器的训练阶段存在的前景 - 背景类不平衡问题。 此运算符计算输入张量中每个元素的sigmoid值,然后计算focal损失。

focal损失计算过程:

.. math::

  loss_j = (-label_j * alpha * {(1 - \sigma(x_j))}^{gamma} * \log(\sigma(x_j)) -
  (1 - labels_j) * (1 - alpha) * {(\sigma(x_j)}^{ gamma} * \log(1 - \sigma(x_j)))
  / fg\_num, j = 1,...,K

其中,已知:

.. math::

  \sigma(x_j) = \frac{1}{1 + \exp(-x_j)}

参数:
    - **x**  (Variable) – 具有形状[N,D]的2-D张量,其中N是batch大小,D是类的数量(不包括背景)。 此输入是由前一个运算符计算出的logits张量。
    - **label**  (Variable) – 形状为[N,1]的二维张量,是所有可能的标签。
    - **fg_num**  (Variable) – 具有形状[1]的1-D张量,是前景的数量。
    - **gamma**  (float) –  用于平衡简单和复杂实例的超参数。 默认值设置为2.0。
    - **alpha**  (float) – 用于平衡正面和负面实例的超参数。 默认值设置为0.25。


返回:  具有形状[N,D]的2-D张量,即focal损失。

返回类型: out(Variable)

**代码示例**

..  code-block:: python
C
Cheerego 已提交
14682 14683


14684 14685 14686 14687 14688 14689 14690 14691 14692 14693 14694 14695 14696
    import paddle.fluid as fluid

    input = fluid.layers.data(
        name='data', shape=[10,80], append_batch_size=False, dtype='float32')
    label = fluid.layers.data(
        name='label', shape=[10,1], append_batch_size=False, dtype='int32')
    fg_num = fluid.layers.data(
        name='fg_num', shape=[1], append_batch_size=False, dtype='int32')
    loss = fluid.layers.sigmoid_focal_loss(x=input,
                                           label=label,
                                           fg_num=fg_num,
                                           gamma=2.,
                                           alpha=0.25)
C
Cheerego 已提交
14697 14698 14699 14700 14701




.. _cn_api_fluid_layers_ssd_loss:
C
Cheerego 已提交
14702

C
Cheerego 已提交
14703 14704 14705
ssd_loss
-------------------------------

C
Cheerego 已提交
14706
.. py:function:: paddle.fluid.layers.ssd_loss(location, confidence, gt_box, gt_label, prior_box, prior_box_var=None, background_label=0, overlap_threshold=0.5, neg_pos_ratio=3.0, neg_overlap=0.5, loc_loss_weight=1.0, conf_loss_weight=1.0, match_type='per_prediction', mining_type='max_negative', normalize=True, sample_size=None)
C
Cheerego 已提交
14707 14708 14709 14710 14711 14712 14713 14714

用于SSD的对象检测算法的多窗口损失层

该层用于计算SSD的损失,给定位置偏移预测,置信度预测,候选框和真实框标签,以及实例挖掘的类型。通过执行以下步骤,返回的损失是本地化损失(或回归损失)和置信度损失(或分类损失)的加权和:

1、通过二分匹配算法查找匹配的边界框。

        1.1、计算真实框与先验框之间的IOU相似度。
C
Cheerego 已提交
14715

C
Cheerego 已提交
14716 14717 14718 14719 14720
        1.2、通过二分匹配算法计算匹配的边界框。

2、计算难分样本的置信度

        2.1、根据匹配的索引获取目标标签。
C
Cheerego 已提交
14721

C
Cheerego 已提交
14722 14723 14724 14725 14726 14727 14728
        2.2、计算置信度损失。

3、应用实例挖掘来获取负示例索引并更新匹配的索引。

4、分配分类和回归目标

        4.1、根据前面的框编码bbox。
C
Cheerego 已提交
14729

C
Cheerego 已提交
14730
        4.2、分配回归目标。
C
Cheerego 已提交
14731

C
Cheerego 已提交
14732
        4.3、分配分类目标。
C
Cheerego 已提交
14733

C
Cheerego 已提交
14734 14735 14736
5、计算总体客观损失。

        5.1计算置信度损失。
C
Cheerego 已提交
14737

C
Cheerego 已提交
14738
        5.1计算本地化损失。
C
Cheerego 已提交
14739

C
Cheerego 已提交
14740
        5.3计算总体加权损失。
C
Cheerego 已提交
14741

C
Cheerego 已提交
14742 14743 14744 14745 14746 14747 14748 14749
参数:
        - **location** (Variable)- 位置预测是具有形状[N,Np,4]的3D张量,N是批量大小,Np是每个实例的预测总数。 4是坐标值的数量,布局是[xmin,ymin,xmax,ymax]。
        - **confidence**  (Variable) - 置信度预测是具有形状[N,Np,C],N和Np的3D张量,它们与位置相同,C是类号。
        - **gt_box** (Variable)- 真实框(bbox)是具有形状[Ng,4]的2D LoDTensor,Ng是小批量输入的真实框(bbox)的总数。
        - **gt_label** (Variable)- ground-truth标签是具有形状[Ng,1]的2D LoDTensor。
        - **prior_box** (Variable)- 候选框是具有形状[Np,4]的2D张量。
        - **prior_box_var** (Variable)- 候选框的方差是具有形状[Np,4]的2D张量。
        - **background_label** (int)- background标签的索引,默认为0。
14750
        - **overlap_threshold** (float)- 当找到匹配的框,如果 ``match_type`` 为'per_prediction',请使用 ``overlap_threshold`` 确定额外匹配的bbox。默认为0.5。
C
Cheerego 已提交
14751 14752 14753 14754 14755 14756 14757 14758 14759 14760 14761 14762 14763 14764 14765 14766 14767 14768 14769 14770 14771 14772 14773 14774 14775 14776 14777 14778 14779 14780 14781 14782 14783 14784
        - **neg_pos_ratio** (float)- 负框与正框的比率,仅在 ``mining_type`` 为'max_negative'时使用,3.0由defalut使用。
        - **neg_overlap** (float)- 不匹配预测的负重叠上限。仅当mining_type为'max_negative'时使用,默认为0.5。
        - **loc_loss_weight** (float)- 本地化丢失的权重,默认为1.0。
        - **conf_loss_weight** (float)- 置信度损失的权重,默认为1.0。
        - **match_type** (str)- 训练期间匹配方法的类型应为'bipartite'或'per_prediction','per_prediction'由defalut提供。
        - **mining_type** (str)- 硬示例挖掘类型应该是'hard_example'或'max_negative',现在只支持max_negative。
        - **normalize** (bool)- 是否通过输出位置的总数将SSD丢失标准化,默认为True。
        - **sample_size** (int)- 负框的最大样本大小,仅在 ``mining_type`` 为'hard_example'时使用。

返回:        具有形状[N * Np,1],N和Np的定位损失和置信度损失的加权和与它们在位置上的相同。

抛出异常:        ``ValueError`` - 如果 ``mining_type`` 是'hard_example',现在只支持 ``max_negative`` 的挖掘类型。

**代码示例**

..  code-block:: python

         pb = fluid.layers.data(
                           name='prior_box',
                           shape=[10, 4],
                           append_batch_size=False,
                           dtype='float32')
         pbv = fluid.layers.data(
                           name='prior_box_var',
                           shape=[10, 4],
                           append_batch_size=False,
                           dtype='float32')
         loc = fluid.layers.data(name='target_box', shape=[10, 4], dtype='float32')
         scores = fluid.layers.data(name='scores', shape=[10, 21], dtype='float32')
         gt_box = fluid.layers.data(
                 name='gt_box', shape=[4], lod_level=1, dtype='float32')
         gt_label = fluid.layers.data(
                 name='gt_label', shape=[1], lod_level=1, dtype='float32')
         loss = fluid.layers.ssd_loss(loc, scores, gt_box, gt_label, pb, pbv)
C
Cheerego 已提交
14785

C
Cheerego 已提交
14786 14787 14788 14789 14790 14791 14792 14793 14794 14795 14796 14797 14798 14799 14800 14801 14802 14803 14804 14805 14806 14807 14808 14809 14810 14811 14812 14813 14814 14815 14816 14817 14818 14819 14820 14821 14822 14823 14824 14825 14826 14827 14828 14829 14830 14831 14832 14833 14834 14835 14836 14837 14838 14839 14840 14841 14842









.. _cn_api_fluid_layers_target_assign:

target_assign
-------------------------------

.. py:function:: paddle.fluid.layers.target_assign(input, matched_indices, negative_indices=None, mismatch_value=None, name=None)

对于给定的目标边界框(bounding box)和标签(label),该操作符对每个预测赋予分类和逻辑回归目标函数以及预测权重。权重具体表示哪个预测无需贡献训练误差。

对于每个实例,根据 ``match_indices`` 和 ``negative_indices`` 赋予输入 ``out`` 和 ``out_weight``。将定输入中每个实例的行偏移称为lod,该操作符执行分类或回归目标函数,执行步骤如下:

1.根据match_indices分配所有输入

.. code-block:: text

    If id = match_indices[i][j] > 0,

        out[i][j][0 : K] = X[lod[i] + id][j % P][0 : K]
        out_weight[i][j] = 1.

    Otherwise,

        out[j][j][0 : K] = {mismatch_value, mismatch_value, ...}
        out_weight[i][j] = 0.

2.如果提供neg_indices,根据neg_indices分配out_weight:

假设neg_indices中每个实例的行偏移称为neg_lod,该实例中第i个实例和neg_indices的每个id如下:

.. code-block:: text

    out[i][id][0 : K] = {mismatch_value, mismatch_value, ...}
    out_weight[i][id] = 1.0

参数:
    - **inputs** (Variable) - 输入为三维LoDTensor,维度为[M,P,K]
    - **matched_indices** (Variable) - 张量(Tensor),整型,输入匹配索引为二维张量(Tensor),类型为整型32位,维度为[N,P],如果MatchIndices[i][j]为-1,在第i个实例中第j列项不匹配任何行项。
    - **negative_indices** (Variable) - 输入负例索引,可选输入,维度为[Neg,1],类型为整型32,Neg为负例索引的总数
    - **mismatch_value** (float32) - 为未匹配的位置填充值

返回:返回一个元组(out,out_weight)。out是三维张量,维度为[N,P,K],N和P与neg_indices中的N和P一致,K和输入X中的K一致。如果match_indices[i][j]存在,out_weight是输出权重,维度为[N,P,1]。

返回类型:元组(tuple)

**代码示例**:

.. code-block:: python

R
RaindragonD 已提交
14843 14844 14845 14846 14847 14848 14849 14850 14851 14852 14853 14854 14855 14856 14857 14858
        import paddle.fluid as fluid
        x = fluid.layers.data(
            name='x',
            shape=[4, 20, 4],
            dtype='float',
            lod_level=1,
            append_batch_size=False)
        matched_id = fluid.layers.data(
            name='indices',
            shape=[8, 20],
            dtype='int32',
            append_batch_size=False)
        trg, trg_weight = fluid.layers.target_assign(
            x,
            matched_id,
            mismatch_value=0)
C
Cheerego 已提交
14859 14860


14861 14862 14863 14864 14865 14866 14867 14868 14869 14870 14871 14872 14873 14874 14875 14876




.. _cn_api_fluid_layers_yolo_box:

yolo_box
-------------------------------

.. py:function:: paddle.fluid.layers.yolo_box(x, img_size, anchors, class_num, conf_thresh, downsample_ratio, name=None)


该运算符从YOLOv3网络的输出生成YOLO检测框。

先前网络的输出形状为[N,C,H,W],而H和W应相同,用来指定网格大小。对每个网格点预测给定的数目的框,这个数目记为S,由anchor的数量指定。 在第二维(通道维度)中,C应该等于S *(5 + class_num),class_num是源数据集中对象类别数目(例如coco数据集中的80),此外第二个(通道)维度中还有4个框位置坐标x,y,w,h,以及anchor box的one-hot key的置信度得分。

C
Cheerego 已提交
14877
假设4个位置坐标是 :math:`t_x` ,:math:`t_y` ,:math:`t_w` , :math:`t_h`
14878 14879 14880 14881 14882 14883 14884 14885 14886 14887 14888 14889 14890 14891 14892 14893 14894 14895 14896 14897 14898 14899 14900 14901 14902 14903 14904 14905 14906 14907 14908 14909 14910 14911 14912 14913 14914 14915 14916 14917 14918 14919
,则框的预测算法为:

.. math::

    b_x &= \sigma(t_x) + c_x\\
    b_y &= \sigma(t_y) + c_y\\
    b_w &= p_w e^{t_w}\\
    b_h &= p_h e^{t_h}\\

在上面的等式中, :math:`c_x` , :math:`c_x` 是当前网格的左上角顶点坐标。 :math:`p_w` , :math:`p_h`  由anchors指定。

每个anchor预测框的第五通道的逻辑回归值表示每个预测框的置信度得分,并且每个anchor预测框的最后class_num通道的逻辑回归值表示分类得分。 应忽略置信度低于conf_thresh的框。另外,框最终得分是置信度得分和分类得分的乘积。


.. math::

    score_{pred} = score_{conf} * score_{class}


参数:
    - **x** (Variable) -  YoloBox算子的输入张量是一个4-D张量,形状为[N,C,H,W]。第二维(C)存储每个anchor box位置坐标,每个anchor box的置信度分数和one hot key。通常,X应该是YOLOv3网络的输出
    - **img_size** (Variable) -  YoloBox算子的图像大小张量,这是一个形状为[N,2]的二维张量。该张量保持每个输入图像的高度和宽度,用于对输出图像按输入图像比例调整输出框的大小
    - **anchors** (list | tuple) - anchor的宽度和高度,它将逐对解析
    - **class_num** (int) - 要预测的类数
    - **conf_thresh** (float) - 检测框的置信度得分阈值。置信度得分低于阈值的框应该被忽略
    - **downsample_ratio** (int) - 从网络输入到YoloBox操作输入的下采样率,因此应依次为第一个,第二个和第三个YoloBox运算设置该值为32,16,8
    - **name** (string) -  yolo box层的名称。默认None。

返回: 具有形状[N,M,4]的三维张量;框的坐标;以及具有形状[N,M,class_num]的三维张量;框的分类得分;

返回类型:   变量(Variable)

抛出异常:
    - TypeError  -  yolov_box的输入x必须是Variable
    - TypeError  -  yolo框的anchors参数必须是list或tuple
    - TypeError  -  yolo box的class_num参数必须是整数
    - TypeError  -  yolo框的conf_thresh参数必须是一个浮点数

**代码示例**

.. code-block:: python

R
RaindragonD 已提交
14920
    import paddle.fluid as fluid
14921 14922
    x = fluid.layers.data(name='x', shape=[255, 13, 13], dtype='float32')
    anchors = [10, 13, 16, 30, 33, 23]
R
RaindragonD 已提交
14923
    loss = fluid.layers.yolo_box(x=x, img_size=608, class_num=80, anchors=anchors,
14924 14925 14926 14927 14928
                                    conf_thresh=0.01, downsample_ratio=32)




H
Hao Wang 已提交
14929 14930 14931 14932 14933
.. _cn_api_fluid_layers_yolov3_loss:

yolov3_loss
-------------------------------

14934
.. py:function:: paddle.fluid.layers.yolov3_loss(x, gt_box, gt_label, anchors, anchor_mask, class_num, ignore_thresh, downsample_ratio, gt_score=None, use_label_smooth=True, name=None)
H
Hao Wang 已提交
14935 14936 14937

该运算通过给定的预测结果和真实框生成yolov3损失。

X
xiaoting 已提交
14938
之前的网络的输出形状为[N,C,H,W],而H和W应该相同,用来指定网格(grid)大小。每个网格点预测给定的数目的边界框(bounding boxes),这个给定的数字由每个尺度中 ``anchors`` 簇的个数指定,我们将它记为S。在第二维(表示通道的维度)中,C的值应为S *(class_num + 5),class_num是源数据集的对象种类数(如coco中为80),另外,除了存储4个边界框位置坐标x,y,w,h,还包括边界框以及每个anchor框的one-hot关键字的置信度得分。
H
Hao Wang 已提交
14939 14940 14941 14942 14943 14944 14945 14946 14947 14948 14949 14950 14951 14952 14953 14954 14955 14956 14957

假设有四个表征位置的坐标为 :math:`t_x, t_y, t_w, t_h` ,那么边界框的预测将会如下定义:

         $$
         b_x = \\sigma(t_x) + c_x
         $$
         $$
         b_y = \\sigma(t_y) + c_y
         $$
         $$
         b_w = p_w e^{t_w}
         $$
         $$
         b_h = p_h e^{t_h}
         $$

在上面的等式中, :math:`c_x, c_y` 是当前网格的左上角, :math:`p_w, p_h` 由anchors指定。
至于置信度得分,它是anchor框和真实框之间的IoU的逻辑回归值,anchor框的得分最高为1,此时该anchor框对应着最大IoU。
如果anchor框之间的IoU大于忽略阀值ignore_thresh,则该anchor框的置信度评分损失将会被忽略。
R
RaindragonD 已提交
14958
         
14959 14960
因此,yolov3损失包括三个主要部分,框位置损失,目标性损失,分类损失。L1损失用于
框坐标(w,h),同时,sigmoid交叉熵损失用于框坐标(x,y),目标性损失和分类损失。
R
RaindragonD 已提交
14961
         
14962
每个真实框在所有anchor中找到最匹配的anchor,预测各anchor框都将会产生所有三种损失的计算,但是没有匹配GT box(ground truth box真实框)的anchor的预测只会产生目标性损失。
H
Hao Wang 已提交
14963 14964 14965 14966 14967 14968 14969 14970 14971 14972 14973 14974

为了权衡大框(box)和小(box)之间的框坐标损失,框坐标损失将与比例权重相乘而得。即:

         $$
         weight_{box} = 2.0 - t_w * t_h
         $$

最后的loss值将如下计算:

         $$
         loss = (loss_{xy} + loss_{wh}) * weight_{box} + loss_{conf} + loss_{class}
         $$
C
Cheerego 已提交
14975

H
Hao Wang 已提交
14976

14977 14978 14979 14980 14981 14982
当 ``use_label_smooth`` 设置为 ``True`` 时,在计算分类损失时将平滑分类目标,将正样本的目标平滑到1.0-1.0 / class_num,并将负样本的目标平滑到1.0 / class_num。

如果给出了 ``GTScore`` 表示真实框的mixup得分,那么真实框所产生的所有损失将乘以其混合得分。



H
Hao Wang 已提交
14983 14984
参数:
    - **x**  (Variable) – YOLOv3损失运算的输入张量,这是一个形状为[N,C,H,W]的四维张量。H和W应该相同,第二维(C)存储框的位置信息,以及每个anchor box的置信度得分和one-hot分类
14985
    - **gt_box**  (Variable) – 真实框,应该是[N,B,4]的形状。第三维用来承载x、y、w、h,其中 x, y是真实框的中心坐标,w, h是框的宽度和高度,且x、y、w、h将除以输入图片的尺寸,缩放到[0,1]区间内。 N是batch size,B是图像中所含有的的最多的box数目
14986
    - **gt_label**  (Variable) – 真实框的类id,应该形为[N,B]。
H
Hao Wang 已提交
14987 14988 14989 14990 14991
    - **anchors**  (list|tuple) – 指定anchor框的宽度和高度,它们将逐对进行解析
    - **anchor_mask**  (list|tuple) – 当前YOLOv3损失计算中使用的anchor的mask索引
    - **class_num**  (int) – 要预测的类数
    - **ignore_thresh**  (float) – 一定条件下忽略某框置信度损失的忽略阈值
    - **downsample_ratio**  (int) – 从网络输入到YOLOv3 loss输入的下采样率,因此应为第一,第二和第三个YOLOv3损失运算设置32,16,8
14992
    - **name** (string) – yolov3损失层的命名
14993
    - **gt_score** (Variable) - 真实框的混合得分,形为[N,B]。 默认None。
14994
    - **use_label_smooth** (bool) - 是否使用平滑标签。 默认为True
H
Hao Wang 已提交
14995 14996


14997
返回: 具有形状[N]的1-D张量,yolov3损失的值
H
Hao Wang 已提交
14998 14999 15000

返回类型:   变量(Variable)

C
Cheerego 已提交
15001
抛出异常:
H
Hao Wang 已提交
15002 15003
    - ``TypeError``  – yolov3_loss的输入x必须是Variable
    - ``TypeError``  – 输入yolov3_loss的gtbox必须是Variable
15004 15005
    - ``TypeError``  – 输入yolov3_loss的gtlabel必须是None或Variable
    - ``TypeError``  – 输入yolov3_loss的gtscore必须是Variable
H
Hao Wang 已提交
15006 15007 15008
    - ``TypeError``  – 输入yolov3_loss的anchors必须是list或tuple
    - ``TypeError``  – 输入yolov3_loss的class_num必须是整数integer类型
    - ``TypeError``  – 输入yolov3_loss的ignore_thresh必须是一个浮点数float类型
15009
    - ``TypeError``  – 输入yolov3_loss的use_label_smooth必须是bool型
H
Hao Wang 已提交
15010 15011 15012 15013

**代码示例**

.. code-block:: python
C
Cheerego 已提交
15014

15015
    x = fluid.layers.data(name='x', shape=[255, 13, 13], dtype='float32')
15016 15017 15018
    gt_box = fluid.layers.data(name='gtbox', shape=[6, 4], dtype='float32')
    gt_label = fluid.layers.data(name='gtlabel', shape=[6], dtype='int32')
    gt_score = fluid.layers.data(name='gtscore', shape=[6], dtype='float32')
15019 15020
    anchors = [10, 13, 16, 30, 33, 23, 30, 61, 62, 45, 59, 119, 116, 90, 156, 198, 373, 326]
    anchor_mask = [0, 1, 2]
15021 15022
    loss = fluid.layers.yolov3_loss(x=x, gt_box=gt_box, gt_label=gt_label,
                                    gt_score=gt_score, anchors=anchors,
15023 15024
                                    anchor_mask=anchor_mask, class_num=80,
                                    ignore_thresh=0.7, downsample_ratio=32)
C
Cheerego 已提交
15025 15026 15027 15028 15029 15030 15031 15032 15033








============
C
Cheerego 已提交
15034
 metric_op
C
Cheerego 已提交
15035 15036 15037 15038 15039 15040 15041 15042 15043 15044 15045 15046 15047 15048 15049 15050 15051 15052 15053 15054 15055
============


.. _cn_api_fluid_layers_accuracy:

accuracy
-------------------------------

.. py:function:: paddle.fluid.layers.accuracy(input, label, k=1, correct=None, total=None)

accuracy layer。 参考 https://en.wikipedia.org/wiki/Precision_and_recall

使用输入和标签计算准确率。 每个类别中top k 中正确预测的个数。注意:准确率的 dtype 由输入决定。 输入和标签 dtype 可以不同。

参数:
    - **input** (Variable)-该层的输入,即网络的预测。支持 Carry LoD。
    - **label** (Variable)-数据集的标签。
    - **k** (int) - 每个类别的 top k
    - **correct** (Variable)-正确的预测个数。
    - **total** (Variable)-总共的样本数。

R
RaindragonD 已提交
15056
返回: 正确率
C
Cheerego 已提交
15057

R
RaindragonD 已提交
15058
返回类型: 变量(Variable)
C
Cheerego 已提交
15059 15060 15061 15062 15063

**代码示例**

.. code-block:: python

R
RaindragonD 已提交
15064
    import paddle.fluid as fluid
C
Cheerego 已提交
15065
    data = fluid.layers.data(name="data", shape=[-1, 32, 32], dtype="float32")
R
RaindragonD 已提交
15066
    label = fluid.layers.data(name="label", shape=[-1,1], dtype="int32")
C
Cheerego 已提交
15067
    predict = fluid.layers.fc(input=data, size=10)
R
RaindragonD 已提交
15068
    accuracy_out = fluid.layers.accuracy(input=predict, label=label, k=5)
C
Cheerego 已提交
15069 15070 15071 15072 15073 15074 15075 15076 15077 15078 15079 15080 15081 15082 15083 15084 15085 15086 15087 15088 15089 15090 15091 15092 15093 15094 15095 15096 15097 15098 15099 15100 15101 15102 15103 15104 15105 15106 15107 15108 15109 15110 15111 15112 15113 15114 15115












.. _cn_api_fluid_layers_auc:

auc
-------------------------------

.. py:function:: paddle.fluid.layers.auc(input, label, curve='ROC', num_thresholds=4095, topk=1, slide_steps=1)

**Area Under the Curve(AUC) Layer**

该层根据前向输出和标签计算AUC,在二分类(binary classification)估计中广泛使用。

注:如果输入标注包含一种值,只有0或1两种情况,数据类型则强制转换成布尔值。相关定义可以在这里: https://en.wikipedia.org/wiki/Receiver_operating_characteristic#Area_under_the_curve 找到

有两种可能的曲线:

1. ROC:受试者工作特征曲线

2. PR:准确率召回率曲线

参数:
    - **input** (Variable) - 浮点二维变量,值的范围为[0,1]。每一行降序排列。输入应为topk的输出。该变量显示了每个标签的概率。
    - **label** (Variable) - 二维整型变量,表示训练数据的标注。批尺寸的高度和宽度始终为1.
    - **curve** (str) - 曲线类型,可以为 ``ROC`` 或 ``PR``,默认 ``ROC``。
    - **num_thresholds** (int) - 将roc曲线离散化时使用的临界值数。默认200
    - **topk** (int) - 只有预测输出的topk数才被用于auc
    - **slide_steps** - 计算批auc时,不仅用当前步也用先前步。slide_steps=1,表示用当前步;slide_steps = 3表示用当前步和前两步;slide_steps = 0,则用所有步

返回:代表当前AUC的scalar

返回类型:变量(Variable)

**代码示例**:

.. code-block:: python

R
RaindragonD 已提交
15116 15117 15118 15119
    import paddle.fluid as fluid
    data = fluid.layers.data(name="data", shape=[32, 32], dtype="float32")
    label = fluid.layers.data(name="label", shape=[1], dtype="int32")
    predict = fluid.layers.fc(input=data, size=2)
C
Cheerego 已提交
15120 15121 15122 15123 15124 15125 15126 15127 15128
    auc_out=fluid.layers.auc(input=prediction, label=label)