快捷方式

torch.trapezoid

torch.trapezoid(y, x=None, *, dx=None, dim=-1) Tensor

沿着 dim 计算 梯形法则。默认情况下,假定元素之间的间距为 1,但可以使用 dx 指定不同的恒定间距,并且可以使用 x 指定沿着 dim 的任意间距。

假设 y 是一个一维张量,其元素为 y0,y1,...,yn{y_0, y_1, ..., y_n}, 则默认计算为

i=1n112(yi+yi1)\begin{aligned} \sum_{i = 1}^{n-1} \frac{1}{2} (y_i + y_{i-1}) \end{aligned}

当指定 dx 时,计算变为

i=1n1Δx2(yi+yi1)\begin{aligned} \sum_{i = 1}^{n-1} \frac{\Delta x}{2} (y_i + y_{i-1}) \end{aligned}

实际上就是将结果乘以 dx。当指定 x 时,假设 x 也是一个一维张量,元素为 x0,x1,...,xn{x_0, x_1, ..., x_n}, 则计算变为

i=1n1(xixi1)2(yi+yi1)\begin{aligned} \sum_{i = 1}^{n-1} \frac{(x_i - x_{i-1})}{2} (y_i + y_{i-1}) \end{aligned}

xy 的大小相同时,计算如上所述,不需要广播。当它们的大小不同时,此函数的广播行为如下。对于 xy,函数计算沿维度 dim 的连续元素之间的差。这实际上创建了两个张量,x_diffy_diff,它们具有与原始张量相同的形状,除了它们沿维度 dim 的长度减少了 1。之后,这两个张量一起广播以计算作为梯形法则的一部分的最终输出。有关详细信息,请参见下面的示例。

注意

梯形法则是一种通过对左右黎曼和取平均值来逼近函数定积分的技术。随着划分分辨率的提高,近似值变得更加准确。

参数
  • y (张量) – 用于计算梯形法则的值。

  • x (张量) – 如果指定,则定义如上所述的值之间的间距。

关键字参数
  • dx (浮点数) – 值之间的恒定间距。如果没有指定 xdx,则默认为 1。实际上将结果乘以其值。

  • dim (整数) – 计算梯形法则的维度。默认情况下为最后一个(最内层)维度。

示例

>>> # Computes the trapezoidal rule in 1D, spacing is implicitly 1
>>> y = torch.tensor([1, 5, 10])
>>> torch.trapezoid(y)
tensor(10.5)

>>> # Computes the same trapezoidal rule directly to verify
>>> (1 + 10 + 10) / 2
10.5

>>> # Computes the trapezoidal rule in 1D with constant spacing of 2
>>> # NOTE: the result is the same as before, but multiplied by 2
>>> torch.trapezoid(y, dx=2)
21.0

>>> # Computes the trapezoidal rule in 1D with arbitrary spacing
>>> x = torch.tensor([1, 3, 6])
>>> torch.trapezoid(y, x)
28.5

>>> # Computes the same trapezoidal rule directly to verify
>>> ((3 - 1) * (1 + 5) + (6 - 3) * (5 + 10)) / 2
28.5

>>> # Computes the trapezoidal rule for each row of a 3x3 matrix
>>> y = torch.arange(9).reshape(3, 3)
tensor([[0, 1, 2],
        [3, 4, 5],
        [6, 7, 8]])
>>> torch.trapezoid(y)
tensor([ 2., 8., 14.])

>>> # Computes the trapezoidal rule for each column of the matrix
>>> torch.trapezoid(y, dim=0)
tensor([ 6., 8., 10.])

>>> # Computes the trapezoidal rule for each row of a 3x3 ones matrix
>>> #   with the same arbitrary spacing
>>> y = torch.ones(3, 3)
>>> x = torch.tensor([1, 3, 6])
>>> torch.trapezoid(y, x)
array([5., 5., 5.])

>>> # Computes the trapezoidal rule for each row of a 3x3 ones matrix
>>> #   with different arbitrary spacing per row
>>> y = torch.ones(3, 3)
>>> x = torch.tensor([[1, 2, 3], [1, 3, 5], [1, 4, 7]])
>>> torch.trapezoid(y, x)
array([2., 4., 6.])

文档

访问 PyTorch 的全面开发者文档

查看文档

教程

获取初学者和高级开发人员的深入教程

查看教程

资源

查找开发资源并获得问题的解答

查看资源