Skip to content
GitLab
Menu
Projects
Groups
Snippets
Loading...
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
Menu
Open sidebar
OpenDAS
torch-scatter
Commits
4e4993c7
"git@developer.sourcefind.cn:OpenDAS/ollama.git" did not exist on "16c75484604a7f5f0acf50961fc026e04ddec464"
Commit
4e4993c7
authored
Dec 21, 2017
by
rusty1s
Browse files
scatter add doc
parent
06192594
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
28 additions
and
10 deletions
+28
-10
docs/source/functions/add.rst
docs/source/functions/add.rst
+7
-0
docs/source/index.rst
docs/source/index.rst
+3
-1
torch_scatter/functions/add.py
torch_scatter/functions/add.py
+18
-9
No files found.
docs/source/functions/add.rst
0 → 100644
View file @
4e4993c7
Scatter Add
===========
.. automodule:: torch_scatter
.. autofunction:: scatter_add_
.. autofunction:: scatter_add
docs/source/index.rst
View file @
4e4993c7
...
@@ -6,7 +6,9 @@ PyTorch Scatter documentation
...
@@ -6,7 +6,9 @@ PyTorch Scatter documentation
.. toctree::
.. toctree::
:glob:
:glob:
:maxdepth: 1
:maxdepth: 1
:caption: PackageReference
:caption: Package reference
functions/*
Indices and tables
Indices and tables
==================
==================
...
...
torch_scatter/functions/add.py
View file @
4e4993c7
...
@@ -7,8 +7,8 @@ def scatter_add_(output, index, input, dim=0):
...
@@ -7,8 +7,8 @@ def scatter_add_(output, index, input, dim=0):
Sums up all values from the tensor :attr:`input` into :attr:`output` at
Sums up all values from the tensor :attr:`input` into :attr:`output` at
the indices specified in the :attr:`index` tensor along an given axis
the indices specified in the :attr:`index` tensor along an given axis
:attr:`dim`. For each value in :attr:`input`, its output index is specified
:attr:`dim`. For each value in :attr:`input`, its output index is specified
by its index in :attr:`input` for dimension
!=
:attr:`dim` and by
the
by its index in :attr:`input` for dimension
s outside of
:attr:`dim` and by
corresponding value in :attr:`index` for dimension
=
:attr:`dim`. If
the
corresponding value in :attr:`index` for dimension :attr:`dim`. If
multiple indices reference the same location, their contributions add.
multiple indices reference the same location, their contributions add.
If :attr:`input` and :attr:`index` are n-dimensional tensors with size
If :attr:`input` and :attr:`index` are n-dimensional tensors with size
...
@@ -18,8 +18,11 @@ def scatter_add_(output, index, input, dim=0):
...
@@ -18,8 +18,11 @@ def scatter_add_(output, index, input, dim=0):
values of :attr:`index` must be between `0` and `output.size(dim) - 1`.
values of :attr:`index` must be between `0` and `output.size(dim) - 1`.
For one-dimensional tensors, the operation computes
For one-dimensional tensors, the operation computes
:math:`output_i = output_i + \sum_j input_j`, where sum is over
:math:`j` such that :math:`index_j = i`.
.. math::
\mathrm{output}_i = \mathrm{output}_i + \sum_j \mathrm{input}_j
where sum is over :math:`j` such that :math:`\mathrm{index}_j = i`.
Args:
Args:
output (Tensor): The destination tensor
output (Tensor): The destination tensor
...
@@ -28,10 +31,12 @@ def scatter_add_(output, index, input, dim=0):
...
@@ -28,10 +31,12 @@ def scatter_add_(output, index, input, dim=0):
dim (int, optional): The axis along which to index
dim (int, optional): The axis along which to index
Example::
Example::
>> input = torch.Tensor([[2, 0, 1, 4, 3], [0,2, 1, 3, 4]])
>> input = torch.Tensor([[2, 0, 1, 4, 3], [0,2, 1, 3, 4]])
>> index = torch.LongTensor([[4, 5, 2, 3], [0, 0, 2, 2, 1]])
>> index = torch.LongTensor([[4, 5, 2, 3], [0, 0, 2, 2, 1]])
>> output = torch.zeros(2, 6)
>> output = torch.zeros(2, 6)
>> scatter_add_(output, index, input, dim=1)
>> scatter_add_(output, index, input, dim=1)
0 0 4 3 3 0
0 0 4 3 3 0
2 4 4 0 0 0
2 4 4 0 0 0
[torch.FloatTensor of size 2x6]
[torch.FloatTensor of size 2x6]
...
@@ -46,14 +51,18 @@ def scatter_add(index, input, dim=0, size=None, fill_value=0):
...
@@ -46,14 +51,18 @@ def scatter_add(index, input, dim=0, size=None, fill_value=0):
specified in the :attr:`index` tensor along an given axis :attr:`dim`.
specified in the :attr:`index` tensor along an given axis :attr:`dim`.
The output size at dimension :attr:`dim` is given by :attr:`size` and must
The output size at dimension :attr:`dim` is given by :attr:`size` and must
be at least size `index.max(dim) - 1`. If :attr:`size` is not given, a
be at least size `index.max(dim) - 1`. If :attr:`size` is not given, a
minimal sized output tensor is returned. The output tensor is
initially
minimal sized output tensor is returned. The output tensor is
prefilled
filled
with the specified value
at
:attr:`fill_value`.
with the specified value
from
:attr:`fill_value`.
For one-dimensional tensors, the operation computes
For one-dimensional tensors, the operation computes
:math:`output_i = fill_value + \sum_j input_j`, where sum is over
:math:`j` such that :math:`index_j = i`.
A more detailed explanation is described in :meth:`~scatter_add_`.
.. math::
\mathrm{output}_i = \mathrm{fill\_value} + \sum_j \mathrm{input}_j
where sum is over :math:`j` such that :math:`\mathrm{index}_j = i`.
A more detailed explanation is described in
:meth:`~torch_scatter.scatter_add_`.
Args:
Args:
index (LongTensor): The indices of elements to scatter
index (LongTensor): The indices of elements to scatter
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment