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

Sampling Performance Testing #3584

Merged
merged 490 commits into from
Jan 12, 2024
Merged
Show file tree
Hide file tree
Changes from 91 commits
Commits
Show all changes
490 commits
Select commit Hold shift + click to select a range
c09bb25
bug fix
seunghwak Aug 3, 2023
4edb9ae
Merge branch 'branch-23.08' of github.com:rapidsai/cugraph into bug_mfg
seunghwak Aug 3, 2023
57fb8e5
Merge branch 'bug_mfg' of https://github.com/seunghwak/cugraph into p…
alexbarghi-nv Aug 3, 2023
3b95106
add latest updates
alexbarghi-nv Aug 3, 2023
3269a4f
Merge branch 'perf-testing-v2' of https://github.com/alexbarghi-nv/cu…
alexbarghi-nv Aug 3, 2023
3e009cd
bug fix (when edge list is empty)
seunghwak Aug 3, 2023
622a17a
Merge branch 'branch-23.08' of https://github.com/rapidsai/cugraph in…
alexbarghi-nv Aug 3, 2023
e4d7796
add latest updates
alexbarghi-nv Aug 9, 2023
a226a4e
revert cpp changes
alexbarghi-nv Aug 9, 2023
5d3843f
revert plc changes
alexbarghi-nv Aug 9, 2023
36464a9
revert notebook changes
alexbarghi-nv Aug 9, 2023
c5a81c2
Revert logging change
alexbarghi-nv Aug 9, 2023
95a72ab
correction for dataset name
alexbarghi-nv Aug 9, 2023
aebe742
fix for empty batch issue
alexbarghi-nv Aug 14, 2023
449984d
do merge
alexbarghi-nv Aug 14, 2023
bdaa22f
bring in changes
alexbarghi-nv Aug 15, 2023
223dee3
remove redundant filter function
alexbarghi-nv Aug 15, 2023
0c904ae
construct cugraph graph in CSC format
alexbarghi-nv Aug 16, 2023
399976d
fixes for csc, update tests
alexbarghi-nv Aug 16, 2023
6b1169e
Merge branch 'branch-23.10' into cugraph-pyg-loader-improvements
alexbarghi-nv Aug 16, 2023
3c9afc9
style fix, add comment explaining function
alexbarghi-nv Aug 17, 2023
88831a8
Merge branch 'cugraph-pyg-loader-improvements' of https://github.com/…
alexbarghi-nv Aug 17, 2023
246ac33
Merge branch 'branch-23.10' into cugraph-pyg-loader-improvements
alexbarghi-nv Aug 17, 2023
2fe3fe0
improve docstring
alexbarghi-nv Aug 17, 2023
f89a3fb
Merge branch 'cugraph-pyg-loader-improvements' of https://github.com/…
alexbarghi-nv Aug 17, 2023
072b1ff
Merge branch 'branch-23.10' into cugraph-pyg-loader-improvements
alexbarghi-nv Aug 21, 2023
85a9c88
cleanup ahead of conversion to mg
alexbarghi-nv Aug 21, 2023
53b334b
mg work
alexbarghi-nv Aug 21, 2023
f0e9f1f
move sampling relatd functions in graph_functions.hpp to sampling_fun…
seunghwak Aug 22, 2023
3b1fd23
draft sampling post processing function APIs
seunghwak Aug 22, 2023
5e99823
mg
alexbarghi-nv Aug 23, 2023
7e4d041
resolve merge conflict
alexbarghi-nv Aug 23, 2023
d62f4f0
update to fix hop numbering issue
alexbarghi-nv Aug 24, 2023
67f4d7b
API updates
seunghwak Aug 24, 2023
5a8194e
Merge branch 'branch-23.10' into cugraph-pyg-loader-improvements
alexbarghi-nv Aug 24, 2023
19f66d0
Persist on host memory
alexbarghi-nv Aug 25, 2023
8f521d2
API updates
seunghwak Aug 25, 2023
da3da9b
deprecate the existing renumber_sampeld_edgelist function
seunghwak Aug 25, 2023
0b87ee1
combine renumber & compression/sorting functions
seunghwak Aug 25, 2023
9b5950b
minor documentation updates
seunghwak Aug 25, 2023
5fbb177
mionr documentation updates
seunghwak Aug 25, 2023
b9611ab
deprecate the existing sampling output renumber function
seunghwak Aug 27, 2023
d1c1440
improvements
alexbarghi-nv Aug 29, 2023
846d3fd
Merge branch 'cugraph-pyg-loader-improvements' of https://github.com/…
alexbarghi-nv Aug 29, 2023
e52c614
split homogeneous/heterogeneous for better performance
alexbarghi-nv Aug 29, 2023
2e5479d
Merge branch 'cugraph-pyg-loader-improvements' of https://github.com/…
alexbarghi-nv Aug 29, 2023
6463445
add e2e test, fix a lot of bugs found by test
alexbarghi-nv Aug 29, 2023
c291110
style fix
alexbarghi-nv Aug 30, 2023
e9d1fcc
Merge branch 'branch-23.10' into cugraph-pyg-loader-improvements
alexbarghi-nv Aug 30, 2023
8f95c79
Merge branch 'cugraph-pyg-loader-improvements' of https://github.com/…
alexbarghi-nv Aug 30, 2023
29aa194
correct docstrings
alexbarghi-nv Aug 30, 2023
99b6f48
Merge branch 'cugraph-pyg-loader-improvements' of https://github.com/…
alexbarghi-nv Aug 30, 2023
ebf0d9c
Merge branch 'branch-23.10' into cugraph-pyg-loader-improvements
alexbarghi-nv Aug 30, 2023
26d48dd
rename sampling convert function
alexbarghi-nv Aug 30, 2023
0069d9d
Merge branch 'cugraph-pyg-loader-improvements' of https://github.com/…
alexbarghi-nv Aug 30, 2023
34d6bdc
update loader with new name
alexbarghi-nv Aug 30, 2023
baa8ea8
add comments to renumbering, clarify deprecation, add warning
alexbarghi-nv Aug 30, 2023
c3ee02b
initial implementation of sampling post processing
seunghwak Aug 31, 2023
04c9105
cuda::std::atomic=>cuda::atomic
seunghwak Aug 31, 2023
bdc840c
update API documentation
seunghwak Aug 31, 2023
8c304b3
add additional input testing
seunghwak Aug 31, 2023
b16a071
replace testing for sampling output post processing
seunghwak Aug 31, 2023
09a38d7
cosmetic updates
seunghwak Aug 31, 2023
82ad8e4
bug fixes
seunghwak Aug 31, 2023
e9b39e4
Merge branch 'branch-23.10' into cugraph-pyg-loader-improvements
alexbarghi-nv Sep 1, 2023
d99b512
Merge branch 'fea_mfg' of https://github.com/seunghwak/cugraph into c…
alexbarghi-nv Sep 1, 2023
c15d580
the c api
alexbarghi-nv Sep 1, 2023
2ac8b86
work
alexbarghi-nv Sep 1, 2023
9135629
fix compile errors
alexbarghi-nv Sep 1, 2023
dfd1cb7
reformat
alexbarghi-nv Sep 1, 2023
6dfd4fe
rename test file from .cu to .cpp
seunghwak Sep 5, 2023
f600520
Merge branch 'branch-23.10' into cugraph-pyg-loader-improvements
alexbarghi-nv Sep 6, 2023
7d5821f
bug fixes
seunghwak Sep 6, 2023
58189ed
add fill wrapper
seunghwak Sep 6, 2023
39db98a
undo adding fill wrapper
seunghwak Sep 6, 2023
98c8e0a
sampling test from .cpp to .cu
seunghwak Sep 6, 2023
687d191
latest perf testing
alexbarghi-nv Sep 7, 2023
c151f95
fix a typo
seunghwak Sep 7, 2023
fc5a4f0
Merge branch 'branch-23.10' of github.com:rapidsai/cugraph into fea_mfg
seunghwak Sep 7, 2023
a7d1804
merge
alexbarghi-nv Sep 7, 2023
3cda233
Merge branch 'branch-23.10' of https://github.com/rapidsai/cugraph in…
alexbarghi-nv Sep 7, 2023
0a18cde
do merge
alexbarghi-nv Sep 7, 2023
094aaf9
do not return valid nzd vertices if doubly_compress is false
seunghwak Sep 7, 2023
cf57a6d
bug fix
seunghwak Sep 8, 2023
2b48b7e
test code
seunghwak Sep 8, 2023
79acc8e
Merge branch 'branch-23.10' of github.com:rapidsai/cugraph into fea_mfg
seunghwak Sep 8, 2023
11009c6
Merge branch 'branch-23.10' into cugraph-pyg-loader-improvements
alexbarghi-nv Sep 8, 2023
0481bfb
Merge branch 'branch-23.10' into cugraph-sample-convert
alexbarghi-nv Sep 8, 2023
2af9333
Merge branch 'fea_mfg' of https://github.com/seunghwak/cugraph into c…
alexbarghi-nv Sep 8, 2023
23cd2c2
bug fix
seunghwak Sep 8, 2023
6eaf67e
update documentation
seunghwak Sep 8, 2023
4dc0a92
fix c api issues
alexbarghi-nv Sep 11, 2023
2947b33
Merge branch 'branch-23.10' of https://github.com/rapidsai/cugraph in…
alexbarghi-nv Sep 11, 2023
0a2b2b7
C API fixes, Python/PLC API work
alexbarghi-nv Sep 11, 2023
db35940
adjust hop offsets when there is a jump in major vertex IDs between hops
seunghwak Sep 11, 2023
b8b72be
add sort only function
seunghwak Sep 12, 2023
38dd11e
Merge branch 'branch-23.10' of github.com:rapidsai/cugraph into fea_mfg
seunghwak Sep 12, 2023
2a799a6
Merge branch 'branch-23.10' into cugraph-pyg-loader-improvements
alexbarghi-nv Sep 12, 2023
c86ceac
various improvements
alexbarghi-nv Sep 12, 2023
37a37bf
Merge branch 'fea_mfg' of https://github.com/seunghwak/cugraph into c…
alexbarghi-nv Sep 12, 2023
002fe93
fix merge conflict
alexbarghi-nv Sep 19, 2023
5051dfc
fix bad merge
alexbarghi-nv Sep 19, 2023
6cdf92b
asdf
alexbarghi-nv Sep 19, 2023
6682cb4
clarifying comments
alexbarghi-nv Sep 19, 2023
0d12a28
t
alexbarghi-nv Sep 19, 2023
f5733f2
latest code
alexbarghi-nv Sep 19, 2023
52e2f57
bug fix
seunghwak Sep 19, 2023
befeb25
Merge branch 'branch-23.10' of github.com:rapidsai/cugraph into bug_o…
seunghwak Sep 19, 2023
8781612
additional bug fix
seunghwak Sep 19, 2023
f92b5f5
add additional checking to detect the previously neglected bugs
seunghwak Sep 19, 2023
2bd93d9
Merge branch 'bug_offsets' of https://github.com/seunghwak/cugraph in…
alexbarghi-nv Sep 19, 2023
3195298
wrap up sg API
alexbarghi-nv Sep 20, 2023
74195cb
test fix, cleanup
alexbarghi-nv Sep 20, 2023
374b103
refactor code into new shared utility
alexbarghi-nv Sep 20, 2023
bd625e3
get mg api working
alexbarghi-nv Sep 20, 2023
b2a4ed1
add offset mg test
alexbarghi-nv Sep 20, 2023
9fb7438
fix renumber map issue in C++
alexbarghi-nv Sep 20, 2023
c770a17
verify new compression formats for sg
alexbarghi-nv Sep 20, 2023
b569563
complete csr/csc tests for both sg/mg
alexbarghi-nv Sep 20, 2023
ab2a185
get the bulk sampler working again
alexbarghi-nv Sep 20, 2023
89a1b33
remove unwanted file
alexbarghi-nv Sep 20, 2023
a9d46ef
fix wrong dataframe issue
alexbarghi-nv Sep 21, 2023
17e9013
update sg bulk sampler tests
alexbarghi-nv Sep 21, 2023
c5543b2
fix mg bulk sampler tests
alexbarghi-nv Sep 21, 2023
6581f47
Merge branch 'branch-23.10' into cugraph-pyg-loader-improvements
alexbarghi-nv Sep 21, 2023
16e83bc
write draft of csr bulk sampler
alexbarghi-nv Sep 21, 2023
1e7098d
overhaul the writer methods
alexbarghi-nv Sep 22, 2023
ae94c35
remove unused method
alexbarghi-nv Sep 22, 2023
7beba4b
style
alexbarghi-nv Sep 22, 2023
16ed5ef
Merge branch 'branch-23.10' of https://github.com/rapidsai/cugraph in…
alexbarghi-nv Sep 22, 2023
79e3cef
remove notebook
alexbarghi-nv Sep 22, 2023
fd5cceb
add clarifying comment to c++
alexbarghi-nv Sep 22, 2023
a47691d
add future warnings
alexbarghi-nv Sep 22, 2023
195d063
cleanup
alexbarghi-nv Sep 22, 2023
0af1750
remove print statements
alexbarghi-nv Sep 22, 2023
d65632c
fix c api bug
alexbarghi-nv Sep 22, 2023
247d8d2
revert dataloader change
alexbarghi-nv Sep 22, 2023
72bebc2
fix empty df bug
alexbarghi-nv Sep 22, 2023
4d51751
style
alexbarghi-nv Sep 22, 2023
9dfa3fa
io
alexbarghi-nv Sep 22, 2023
10c8c1f
fix test failures, remove c++ compression enum
alexbarghi-nv Sep 23, 2023
08cf3e1
remove removed api from mg tests
alexbarghi-nv Sep 23, 2023
897e6d6
change to future warning
alexbarghi-nv Sep 23, 2023
bb5e621
resolve checking issues
alexbarghi-nv Sep 23, 2023
d20e593
Merge branch 'cugraph-pyg-loader-improvements' into cugraph-pyg-mfg
alexbarghi-nv Sep 23, 2023
eb3aadc
fix wrong index + off by 1 error, add check in test
alexbarghi-nv Sep 25, 2023
a124964
Merge branch 'branch-23.10' into cugraph-sample-convert
alexbarghi-nv Sep 25, 2023
6990c23
add annotations
alexbarghi-nv Sep 25, 2023
920bed7
docstring correction
alexbarghi-nv Sep 25, 2023
f8df56f
remove empty batch check
alexbarghi-nv Sep 25, 2023
ef2ec5b
fix capi sg test
alexbarghi-nv Sep 25, 2023
8e22ab9
disable broken tests, they are too expensive to fix and redundant
alexbarghi-nv Sep 25, 2023
13bdd43
Merge branch 'cugraph-sample-convert' of https://github.com/alexbargh…
alexbarghi-nv Sep 25, 2023
c48a14b
Merge branch 'branch-23.10' of https://github.com/rapidsai/cugraph in…
alexbarghi-nv Sep 25, 2023
cf612c7
update c code
alexbarghi-nv Sep 25, 2023
09a3bd8
Merge branch 'branch-23.10' into cugraph-pyg-mfg
alexbarghi-nv Sep 26, 2023
140b6e4
Merge branch 'branch-23.10' of https://github.com/rapidsai/cugraph in…
alexbarghi-nv Sep 27, 2023
e4544b6
Merge branch 'branch-23.10' into cugraph-sample-convert
alexbarghi-nv Sep 27, 2023
0ee3798
Resolve merge conflict
alexbarghi-nv Sep 27, 2023
6212869
fix bad merge
alexbarghi-nv Sep 27, 2023
0f1a144
initial rewrite
alexbarghi-nv Sep 27, 2023
b369e97
fixes, more testing
alexbarghi-nv Sep 27, 2023
13be49c
fix issue with num nodes and edges
alexbarghi-nv Sep 27, 2023
185143c
e2e smoke test
alexbarghi-nv Sep 28, 2023
99efb9c
Merge branch 'branch-23.10' into cugraph-pyg-mfg
alexbarghi-nv Sep 28, 2023
bc1f30b
Merge branch 'cugraph-sample-convert' into perf-testing-v2
alexbarghi-nv Sep 28, 2023
9ea6c6b
Merge branch 'branch-23.10' of https://github.com/rapidsai/cugraph in…
alexbarghi-nv Sep 28, 2023
a127643
Merge branch 'cugraph-pyg-mfg' of https://github.com/alexbarghi-nv/cu…
alexbarghi-nv Sep 28, 2023
262d1da
fix test column name issues
alexbarghi-nv Sep 29, 2023
7a05c10
Merge branch 'branch-23.10' into cugraph-pyg-mfg
alexbarghi-nv Sep 29, 2023
c440f64
resolve merge conflicts
alexbarghi-nv Sep 29, 2023
d0d0cb2
copyright
alexbarghi-nv Sep 29, 2023
b4e6d06
testing
alexbarghi-nv Sep 29, 2023
20f138c
Merge branch 'perf-testing-v2' of https://github.com/alexbarghi-nv/cu…
alexbarghi-nv Sep 29, 2023
7e770ad
debugging
alexbarghi-nv Sep 29, 2023
4ac962d
perf testing
alexbarghi-nv Oct 2, 2023
55b4e84
regex
alexbarghi-nv Nov 15, 2023
0fd367a
Merge branch 'perf-testing-v2' of https://github.com/alexbarghi-nv/cu…
alexbarghi-nv Nov 15, 2023
894831e
update to latest
alexbarghi-nv Nov 15, 2023
3cad3f2
fixes
alexbarghi-nv Nov 15, 2023
912d6ca
node loader
alexbarghi-nv Nov 29, 2023
ea60f94
Merge branch 'branch-23.12' of https://github.com/rapidsai/cugraph in…
alexbarghi-nv Nov 29, 2023
9972619
finish patch
alexbarghi-nv Nov 29, 2023
1c401d1
merge latest
alexbarghi-nv Dec 1, 2023
02c7210
bulk sampling
alexbarghi-nv Dec 1, 2023
b67d5ed
perf testing
alexbarghi-nv Dec 5, 2023
da389e0
minor fixes
alexbarghi-nv Dec 6, 2023
e29b4e8
get the native workflow working
alexbarghi-nv Dec 6, 2023
d358257
wrap up first version of cugraph trainer
alexbarghi-nv Dec 7, 2023
e08c46c
remove stats file
alexbarghi-nv Dec 7, 2023
a9fc5af
Fixes
alexbarghi-nv Dec 8, 2023
49094db
x
alexbarghi-nv Dec 12, 2023
b8e2354
output multiple epochs, train/test/val
alexbarghi-nv Dec 12, 2023
0fd156b
remove unwanted file
alexbarghi-nv Dec 12, 2023
663febe
Merge branch 'perf-testing-v2' of https://github.com/alexbarghi-nv/cu…
alexbarghi-nv Dec 12, 2023
2a3ee5a
revert file
alexbarghi-nv Dec 12, 2023
b424e7c
remove unwanted file
alexbarghi-nv Dec 12, 2023
b727fcb
remove cmake files
alexbarghi-nv Dec 12, 2023
d37f0d7
train/test
alexbarghi-nv Dec 12, 2023
d0ca16b
reformat
alexbarghi-nv Dec 12, 2023
06dc14d
add scripts
alexbarghi-nv Dec 13, 2023
a5f1b67
Merge branch 'perf-testing-v2' of https://github.com/alexbarghi-nv/cu…
alexbarghi-nv Dec 13, 2023
ad83725
reorganize, add scripts
alexbarghi-nv Dec 13, 2023
e3d28a6
init
alexbarghi-nv Dec 13, 2023
d15a4d4
update
alexbarghi-nv Dec 14, 2023
70a509a
Merge branch 'pyg-nightly-input-nodes-fix' of https://github.com/alex…
alexbarghi-nv Dec 14, 2023
ecc2db1
cugraph
alexbarghi-nv Dec 26, 2023
726c81d
loader debug
alexbarghi-nv Dec 26, 2023
c095769
fix small bugs in cugraph-pyg
alexbarghi-nv Dec 26, 2023
4be1875
c
alexbarghi-nv Dec 26, 2023
59f030d
fix fanout issues
alexbarghi-nv Dec 26, 2023
4bc7f90
remove experimental warnings
alexbarghi-nv Dec 27, 2023
a58d358
remove test files
alexbarghi-nv Dec 27, 2023
318212d
data preprocessing
alexbarghi-nv Dec 27, 2023
68ca511
commit
alexbarghi-nv Dec 27, 2023
dbbd791
Merge branch 'dlfw-patch-24.01' of https://github.com/alexbarghi-nv/c…
alexbarghi-nv Dec 27, 2023
d47c3ba
comment
alexbarghi-nv Dec 27, 2023
367c79c
fixing issues impacting accuracy
alexbarghi-nv Dec 29, 2023
ac1cfbd
add readme
alexbarghi-nv Dec 29, 2023
cc2635b
refactor
alexbarghi-nv Dec 29, 2023
f1ce3e1
Fix mixed experimental import
alexbarghi-nv Dec 29, 2023
e38fe66
update readme
alexbarghi-nv Dec 29, 2023
f3f68bd
update readme
alexbarghi-nv Dec 29, 2023
d2734c4
fix environment variables
alexbarghi-nv Dec 29, 2023
7222cba
remove unwanted file
alexbarghi-nv Dec 29, 2023
c2e8520
minor change to avoid timeout
alexbarghi-nv Dec 29, 2023
a4dad32
remove stats file
alexbarghi-nv Jan 3, 2024
2109bfb
Merge branch 'perf-testing-v2' of https://github.com/alexbarghi-nv/cu…
alexbarghi-nv Jan 3, 2024
6358f9b
switch versions of simple distributed graph for 24.02
alexbarghi-nv Jan 3, 2024
3898cb2
remove test python file
alexbarghi-nv Jan 3, 2024
3f266f5
remove mg utils dir
alexbarghi-nv Jan 3, 2024
864e55e
wait for workers
alexbarghi-nv Jan 3, 2024
67d6aa0
reformat
alexbarghi-nv Jan 3, 2024
78fc260
add copyrights
alexbarghi-nv Jan 3, 2024
d81a9a8
fix wrong file
alexbarghi-nv Jan 3, 2024
16f225a
remove stats file
alexbarghi-nv Jan 3, 2024
259ec47
Merge branch 'branch-24.02' into perf-testing-v2
alexbarghi-nv Jan 5, 2024
18571fe
fix copyright
alexbarghi-nv Jan 5, 2024
40502de
split off feature transfer time
alexbarghi-nv Jan 5, 2024
ea46748
style
alexbarghi-nv Jan 5, 2024
61f30a2
Merge branch 'branch-24.02' into perf-testing-v2
alexbarghi-nv Jan 5, 2024
89ac530
fixes to scripts
alexbarghi-nv Jan 8, 2024
77b0788
compatibility issues
alexbarghi-nv Jan 8, 2024
4e2a706
reset file
alexbarghi-nv Jan 8, 2024
18e43de
c
alexbarghi-nv Jan 8, 2024
c4c45db
copyright
alexbarghi-nv Jan 8, 2024
8ea5c92
whitespace
alexbarghi-nv Jan 8, 2024
441810c
set nthreads to 8
alexbarghi-nv Jan 9, 2024
c053ed0
Merge branch 'branch-24.02' into perf-testing-v2
alexbarghi-nv Jan 9, 2024
3039843
Merge branch 'branch-24.02' into perf-testing-v2
alexbarghi-nv Jan 11, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
596 changes: 596 additions & 0 deletions benchmarks/cugraph/standalone/cugraph_bulk_sampling.py

Large diffs are not rendered by default.

318 changes: 318 additions & 0 deletions benchmarks/cugraph/standalone/cugraph_pyg_graph_sage.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,318 @@
# Copyright (c) 2023, NVIDIA CORPORATION.
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.


import json
import time
import argparse
import gc
import os

import torch
import numpy as np

from torch_geometric.nn import CuGraphSAGEConv
from torch_geometric.utils.trim_to_layer import TrimToLayer

import torch.nn as nn
import torch.nn.functional as F

from typing import Union

def load_disk_features(meta, node_type, replication_factor=1):
node_type_path = os.path.join(meta['dataset_dir'], meta['dataset'], 'npy', node_type)

if replication_factor == 1:
return np.load(
os.path.join(node_type_path, 'node_feat.npy'),
mmap_mode='r'
)

else:
return np.load(
os.path.join(node_type_path, f'node_feat_{replication_factor}x.npy'),
mmap_mode='r'
)


class CuGraphSAGE(nn.Module):
def __init__(self, in_channels, hidden_channels, out_channels, num_layers):
super().__init__()

self.convs = torch.nn.ModuleList()
self.convs.append(CuGraphSAGEConv(in_channels, hidden_channels, aggr='mean'))
for _ in range(num_layers - 2):
conv = CuGraphSAGEConv(hidden_channels, hidden_channels, aggr='mean')
self.convs.append(conv)

self.convs.append(CuGraphSAGEConv(hidden_channels, out_channels, aggr='mean'))

self._trim = TrimToLayer()

def forward(self, x, edge, num_sampled_nodes, num_sampled_edges):
print(num_sampled_nodes)
print(num_sampled_edges)

for i, conv in enumerate(self.convs):
edge = edge.cuda()
x = x.cuda().to(torch.float32)

_, edge, _ = self._trim(
i,
num_sampled_nodes,
num_sampled_edges,
x,
edge,
None
)
print(edge.shape)
print(edge)

s = len(edge.unique())
edge_csc = CuGraphSAGEConv.to_csc(edge, (s, s))

print('x shape', x.shape)
print('s: ', s)
x = x[:s]

print(x.shape)
print(edge.shape)
print('----------------')

x = conv(x, edge_csc)
x = F.relu(x)
x = F.dropout(x, p=0.5)

return x


def init_pytorch_worker(device_id: int) -> None:
import cupy
import rmm

rmm.reinitialize(
devices=[device_id],
pool_allocator=False,
)


from rmm.allocators.torch import rmm_torch_allocator
torch.cuda.change_current_allocator(rmm_torch_allocator)

from rmm.allocators.cupy import rmm_cupy_allocator
cupy.cuda.set_allocator(rmm_cupy_allocator)

cupy.cuda.Device(device_id).use()
torch.cuda.set_device(device_id)



def train_native(device:int, features_device:Union[str, int] = "cpu", num_epochs=1) -> None:
pass

def train(bulk_samples_dir: str, device: int, features_device: Union[str, int] = "cpu", num_epochs=1) -> None:
"""
Parameters
----------
device: int
The CUDA device where the model, graph data, and node labels will be stored.
features_device: Union[str, int]
The device (CUDA device or CPU) where features will be stored.
"""

init_pytorch_worker(device)

import cudf
import cugraph
from cugraph_pyg.data import CuGraphStore
from cugraph_pyg.loader import BulkSampleLoader

with open(os.path.join(bulk_samples_dir, 'output_meta.json'), 'r') as f:
output_meta = json.load(f)

dataset_path = os.path.join(output_meta['dataset_dir'], output_meta['dataset'])
with open(os.path.join(dataset_path, 'meta.json'), 'r') as f:
input_meta = json.load(f)

replication_factor = output_meta['replication_factor']
G = {tuple(edge_type.split('__')): t * replication_factor for edge_type, t in input_meta['num_edges'].items()}
N = {node_type: t * replication_factor for node_type, t in input_meta['num_nodes'].items()}

fs = cugraph.gnn.FeatureStore(backend="torch")

num_input_features = 0
num_output_features = 0
for node_type in os.listdir(os.path.join(dataset_path, 'npy')):
feature_data = load_disk_features(output_meta, node_type, replication_factor=replication_factor)
fs.add_data(
torch.as_tensor(feature_data, device=features_device),
node_type,
"x",
)
if feature_data.shape[1] > num_input_features:
num_input_features = feature_data.shape[1]

label_path = os.path.join(dataset_path, 'parquet', node_type, 'node_label.parquet')
if os.path.exists(label_path):
node_label = cudf.read_parquet(label_path)
node_label_tensor = torch.full((N[node_type],), -1, dtype=torch.float32, device='cuda')
node_label_tensor[torch.as_tensor(node_label.node.values, device='cuda')] = \
torch.as_tensor(node_label.label.values, device='cuda')

del node_label
gc.collect()

fs.add_data((node_label_tensor > -1), node_type, 'train')
fs.add_data(node_label_tensor, node_type, 'y')
num_classes = int(node_label_tensor.max()) + 1
if num_classes > num_output_features:
num_output_features = num_classes
print('done loading data')

print(num_input_features, num_output_features, len(output_meta['fanout']))

model = CuGraphSAGE(
in_channels=num_input_features,
hidden_channels=64,
out_channels=num_output_features,
num_layers=len(output_meta['fanout'])
).to(torch.float32).to(device)
print('done creating model')

cugraph_store = CuGraphStore(fs, G, N)
print('done creating store')

optimizer = torch.optim.Adam(model.parameters(), lr=0.01)

for epoch in range(num_epochs):
start_time_train = time.perf_counter_ns()
model.train()

cugraph_loader = BulkSampleLoader(
cugraph_store,
cugraph_store,
input_nodes=None,
directory=os.path.join(bulk_samples_dir, 'samples'),
)
print('done creating loader')

total_loss = 0
num_batches = 0

for epoch in range(num_epochs):
t = time.perf_counter()
for iter_i, data in enumerate(cugraph_loader):
print(time.perf_counter() - t)
print(len(data.edge_index_dict['paper','cites','paper'][0].unique()))
print(len(data.edge_index_dict['paper','cites','paper'][1].unique()))
print('*********************************************************')
data = data.to_homogeneous()

num_batches += 1
if iter_i % 20 == 0:
print(f"iteration {iter_i}")

# train
y_true = data.y

y_pred = model(
data.x,
data.edge_index,
data.num_sampled_nodes,
data.num_sampled_edges,
)

if y_pred.shape[0] > len(y_true):
raise ValueError(f"illegal shape: {y_pred.shape}; {y_true.shape}")

y_true = y_true[:y_pred.shape[0]]

y_true = F.one_hot(
y_true.to(torch.int64), num_classes=y_pred.shape[1]
).to(torch.float32)
print('shape: ', y_true.shape)
"""

loss = F.cross_entropy(y_pred, y_true)

optimizer.zero_grad()
loss.backward()
optimizer.step()
total_loss += loss.item()


del y_true
del y_pred
del loss
del data
gc.collect()
"""
t = time.perf_counter()

end_time_train = time.perf_counter_ns()
print(
f"epoch {epoch} time: "
f"{(end_time_train - start_time_train) / 1e9:3.4f} s"
)
print(f"loss after epoch {epoch}: {total_loss / num_batches}")


def parse_args():
parser = argparse.ArgumentParser()
parser.add_argument(
"--device",
type=int,
default=0,
help="GPU to allocate to pytorch for model, graph data, and node label storage",
required=False,
)

parser.add_argument(
"--features_device",
type=str,
default="0",
help="Device to allocate to pytorch for feature storage",
required=False,
)

parser.add_argument(
"--num_epochs",
type=int,
default=1,
help="Number of training epochs",
required=False,
)

parser.add_argument(
"--sample_dir",
type=str,
help="Directory with stored bulk samples",
required=True,
)

return parser.parse_args()


def main():
args = parse_args()

try:
features_device = int(args.features_device)
except ValueError:
features_device = args.features_device

train(args.sample_dir, device=args.device, features_device=features_device, num_epochs=args.num_epochs)


if __name__ == "__main__":
main()
Loading