Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Is there a feature similar to node_subgraph in dgl #9800

Open
Ziyang-Yu opened this issue Nov 21, 2024 · 3 comments
Open

Is there a feature similar to node_subgraph in dgl #9800

Ziyang-Yu opened this issue Nov 21, 2024 · 3 comments
Labels

Comments

@Ziyang-Yu
Copy link

Ziyang-Yu commented Nov 21, 2024

🚀 The feature, motivation and pitch

Background:
In PyG, the subgraph function allows for extracting a subgraph based on a subset of nodes or edges. However, during subgraph extraction, the correspondence between the extracted subgraph and the original node features is not explicitly preserved. In contrast, DGL's node_subgraph function retains the original node features for the extracted subgraph, ensuring feature consistency.

Proposed Feature:
I propose adding a similar feature to PyG, which retains the original node features while constructing a subgraph from a subset of nodes. The function should:

  1. Extract a subgraph based on a node subset.
  2. Maintain the correspondence of node features from the original graph.
  3. Optionally provide mappings between the original and subgraph node indices for reference.
# Given a graph with node features, graph is of typle Data
sub_nodes = torch.tensor([0, 2, 4])  # Selected nodes
subgraph = graph.node_subgraph(sub_nodes)

Benefits:
Streamlined workflow for handling subgraphs while preserving node features.
Enhanced compatibility with downstream tasks like node classification or graph neural networks where node features play a critical role.

References:
DGL's node_subgraph documentation: https://docs.dgl.ai/en/0.9.x/generated/dgl.node_subgraph.html#dgl.node_subgraph

Thank you!
This feature would improve the usability of PyG, especially for workflows involving complex feature mappings. Let me know if further clarification is needed.

Alternatives

No response

Additional context

No response

@xnuohz
Copy link
Contributor

xnuohz commented Nov 22, 2024

I guess this is what you need^^
https://pytorch-geometric.readthedocs.io/en/latest/modules/utils.html#torch_geometric.utils.subgraph

@Ziyang-Yu
Copy link
Author

Thanks for your reply. I have looked into it. But it only returns (edge_index, edge_attr), which seems missing node features.

@rusty1s
Copy link
Member

rusty1s commented Dec 9, 2024

You can also use Data.subgraph() or HeteroData.subgraph().

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

No branches or pull requests

3 participants