Document feedback

Question document fragment

When a question document fragment contains a formula, it is displayed as a space.

Submission type
issue

It's a little complicated...

I'd like to ask someone.

PR

Just a small problem.

I can fix it online!

Please select the submission type

Problem type
Specifications and Common Mistakes

- Specifications and Common Mistakes:

- Misspellings or punctuation mistakes,incorrect formulas, abnormal display.

- Incorrect links, empty cells, or wrong formats.

- Chinese characters in English context.

- Minor inconsistencies between the UI and descriptions.

- Low writing fluency that does not affect understanding.

- Incorrect version numbers, including software package names and version numbers on the UI.

Usability

- Usability:

- Incorrect or missing key steps.

- Missing main function descriptions, keyword explanation, necessary prerequisites, or precautions.

- Ambiguous descriptions, unclear reference, or contradictory context.

- Unclear logic, such as missing classifications, items, and steps.

Correctness

- Correctness:

- Technical principles, function descriptions, supported platforms, parameter types, or exceptions inconsistent with that of software implementation.

- Incorrect schematic or architecture diagrams.

- Incorrect commands or command parameters.

- Incorrect code.

- Commands inconsistent with the functions.

- Wrong screenshots.

- Sample code running error, or running results inconsistent with the expectation.

Risk Warnings

- Risk Warnings:

- Lack of risk warnings for operations that may damage the system or important data.

Content Compliance

- Content Compliance:

- Contents that may violate applicable laws and regulations or geo-cultural context-sensitive words and expressions.

- Copyright infringement.

Please select the type of question

Problem description

Describe the bug so that we can quickly locate the problem.

mindspore_gl.nn.EGConv

View Source On Gitee
class mindspore_gl.nn.EGConv(in_feat_size: int, out_feat_size: int, aggregators: List[str], num_heads: int = 8, num_bases: int = 4, bias: bool = True)[source]

Efficient Graph Convolution. From the paper Adaptive Filters and Aggregator Fusion for Efficient Graph Convolutions .

hi(l+1)=||h=1HAb=1Bwh,,b(l)jN(i)Wb(l)hj(l)

N(i) represents the neighbour node of i, Wb(l) represents a basis weight, represents an aggregator, wh,,b(l) represents per-vertex weighting coefficients across heads, aggregator and bases.

Parameters
  • in_feat_size (int) – Input node feature size.

  • out_feat_size (int) – Output node feature size.

  • aggregators (str, optional) – aggregators to be used. Supported aggregators are 'sum', 'mean', 'max', 'min', 'std', 'var', 'symnorm'.

  • num_heads (int, optional) – Number of heads H. Default: 8. Must have out_feat_size.

  • num_bases (int, optional) – Number of basis weight B. Default: 4.

  • bias (bool, optional) – Whether the layer will learn an additive bias. Default: True.

Inputs:
  • x (Tensor) - The input node features. The shape is (N,Din) where N is the number of nodes, and Din should be equal to in_feat_size in Args.

  • g (Graph) - The input graph.

Outputs:
  • Tensor, output node features with shape of (N,Dout), where (Dout) should be the same as out_feat_size in Args.

Raises
  • TypeError – If in_feat_size or out_feat_size or num_heads is not a positive int.

  • ValueError – If out_feat_size is not divisible by ‘num_heads’.

  • ValueError – If aggregators is not 'sum', 'mean', 'max', 'min', 'symnorm', 'var' or 'std'.

Supported Platforms:

Ascend GPU

Examples

>>> import mindspore as ms
>>> from mindspore_gl.nn import EGConv
>>> from mindspore_gl import GraphField
>>> n_nodes = 4
>>> n_edges = 7
>>> feat_size = 4
>>> src_idx = ms.Tensor([0, 1, 1, 2, 2, 3, 3], ms.int32)
>>> dst_idx = ms.Tensor([0, 0, 2, 1, 3, 0, 1], ms.int32)
>>> ones = ms.ops.Ones()
>>> feat = ones((n_nodes, feat_size), ms.float32)
>>> graph_field = GraphField(src_idx, dst_idx, n_nodes, n_edges)
>>> conv = EGConv(in_feat_size=4, out_feat_size=6, aggregators=['sum'], num_heads=3, num_bases=3)
>>> res = conv(feat, *graph_field.get_graph())
>>> print(res.shape)
(4, 6)