Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
488 commits
Select commit Hold shift + click to select a range
6765024
ki_truss
BradReesWork May 12, 2020
2e65ff7
updates to run doxygen
BradReesWork May 12, 2020
52ea239
Merge remote-tracking branch 'upstream/branch-0.14' into branch-0.14-…
rlratzel May 12, 2020
3de08b7
changelog
BradReesWork May 12, 2020
96eeb67
Merge pull request #862 from kaatish/fea-katz-raii
BradReesWork May 12, 2020
4675296
Updated to use new marks, enabled more benchmarks, doing additional E…
rlratzel May 12, 2020
d00e543
Removed utility not needed since they're natively supported by cugrap…
rlratzel May 12, 2020
ec5623c
Merge remote-tracking branch 'upstream/branch-0.14' into branch-0.14-…
rlratzel May 12, 2020
f91a09f
added texted on running doc generator
BradReesWork May 12, 2020
93934e1
extra text on manual running
BradReesWork May 12, 2020
e538d3d
Merge branch 'branch-0.14' into branch-0.14
BradReesWork May 12, 2020
f6242e7
Merge pull request #865 from BradReesWork/branch-0.14
BradReesWork May 12, 2020
b801ec0
first working version of louvain
ChuckHastings May 13, 2020
84e656d
graph: replace multigraph value by false
xcadet May 13, 2020
c56a776
Merge branch 'branch-0.14' of github.com:rapidsai/cugraph into fea-kt…
kaatish May 13, 2020
068b158
Merge remote-tracking branch 'upstream/branch-0.14' into branch-0.14-…
rlratzel May 13, 2020
1c4c6e8
Fixed KTruss to work with new graph class
kaatish May 13, 2020
ce9d3c7
Moved ktruss to community in cpp
kaatish May 13, 2020
bebca10
Moved ktruss to community in python
kaatish May 13, 2020
65431fc
CHANGELOG fix
kaatish May 13, 2020
5c9255b
Undo accidental change to run-clang-format.py
kaatish May 13, 2020
8dc5250
clang-format fixes
kaatish May 13, 2020
a048b05
Merge branch 'fea-ktruss-raii' of github.com:kaatish/cugraph into fea…
kaatish May 13, 2020
67384c5
More Louvain work:
ChuckHastings May 13, 2020
698f28a
Documentation fix
kaatish May 13, 2020
c829085
Updates to support the latest flake8 version.
rlratzel May 13, 2020
848e616
Added PR 867 to CHANGELOG.md
rlratzel May 13, 2020
568d292
with louvain moved from nvgraph, remove a bunch of obsolete headers
ChuckHastings May 13, 2020
6f1e723
update changelog
ChuckHastings May 13, 2020
3367ead
bfs: removed extra sizeof multiplication
xcadet May 13, 2020
bce3500
bfs: reorder and allocations
xcadet May 14, 2020
aaaba66
Merge pull request #867 from rlratzel/branch-0.14-fixchecks
BradReesWork May 14, 2020
66fa0cf
Merge remote-tracking branch 'upstream/branch-0.14' into branch-0.14-…
rlratzel May 14, 2020
cd37420
Fixed ktruss_subgraph init
kaatish May 14, 2020
07f4638
Merge branch 'branch-0.14' of github.com:rapidsai/cugraph into fea-kt…
kaatish May 14, 2020
315ef9d
Revert "bfs: updated with rmm device_vector and add CUDA error checking"
xcadet May 14, 2020
47cb378
Merge pull request #866 from kaatish/fea-ktruss-raii
BradReesWork May 14, 2020
be087b2
update setup.py for custom clean
Iroy30 May 14, 2020
d1df324
add changelog
Iroy30 May 14, 2020
328353e
flake8
Iroy30 May 14, 2020
3e50050
review updates
Iroy30 May 15, 2020
f040666
Merge pull request #874 from Iroy30/update_setup.py
BradReesWork May 15, 2020
0a7a2c1
Add interface for force atlas 2
hlinsen Mar 11, 2020
d449f32
Add fa2l dependency to run pytests
hlinsen Mar 11, 2020
4461c56
Use new graph structuring and add initialization list for vertex
hlinsen Mar 11, 2020
6580228
Add python test
hlinsen Mar 12, 2020
3dacf41
Update interface and fix compile errors
hlinsen Mar 12, 2020
3e5e076
Add cuda template
hlinsen Mar 13, 2020
ea41b05
Update fa2 dependency
hlinsen Mar 13, 2020
cb8a5ec
Test passing
hlinsen Mar 13, 2020
399eda5
Check positions are the same for networkx and cugraph
hlinsen Mar 13, 2020
6dcd335
Normalize interface and remove vertex column when returning df
hlinsen Mar 13, 2020
e39ce57
Update doc
hlinsen Mar 13, 2020
8ced917
Remove modified file from pull request
hlinsen Mar 13, 2020
eeee84f
Simple render with Datashader
hlinsen Mar 17, 2020
fc929b6
Add option to run exact force atlas and add vertex
hlinsen Mar 20, 2020
2267525
Create templated functions and kernels
hlinsen Mar 21, 2020
dc4f2f0
Switch to CSR format
hlinsen Mar 23, 2020
e0b96ca
Implement kernels with CSR
hlinsen Mar 24, 2020
7837396
Handle division by zero
hlinsen Mar 31, 2020
53c0ec1
Fix gravity kernel loop
hlinsen Mar 31, 2020
dc7bda2
Compute best jitter tolerance and speed on CPU
hlinsen Mar 31, 2020
3227d0f
Add outbound attraction compensation
hlinsen Apr 1, 2020
75cd991
Switch back to COO
hlinsen Apr 2, 2020
79318e9
Sort and compute degree with COO
hlinsen Apr 3, 2020
78e234e
Fix attraction kernel
hlinsen Apr 3, 2020
ad1533a
Obtain same global speed as networkx
hlinsen Apr 3, 2020
d1f20f6
Working with few iterations
hlinsen Apr 3, 2020
5b6ff36
Fix global speed adaptation
hlinsen Apr 3, 2020
8a10825
Refactor sort and mass initialization
hlinsen Apr 3, 2020
ac1ede8
Refactor headers
hlinsen Apr 3, 2020
2ff8cc8
Update test
hlinsen Apr 4, 2020
32dcc96
Add weight option as template
hlinsen Apr 6, 2020
a3402fa
Add random vector generation
hlinsen Apr 6, 2020
f5c036a
Remove unused headers
hlinsen Apr 6, 2020
b593f30
Add barnes hut
hlinsen Apr 7, 2020
71894c1
Update repulsion kernel
hlinsen Apr 7, 2020
ae66441
Add force update for barnes hut
hlinsen Apr 8, 2020
d769028
Update barnes hut mass initialization
hlinsen Apr 8, 2020
945c1db
Fix kernel launch
hlinsen Apr 8, 2020
4fc74cd
Refactor kernels
hlinsen Apr 8, 2020
1709050
Add restrict to pointers
hlinsen Apr 8, 2020
87a6186
Add check for unsupported options
hlinsen Apr 8, 2020
bf2589c
Update documentation
hlinsen Apr 9, 2020
2ff3021
Add lin log mode
hlinsen Apr 9, 2020
a16b79e
Add internal callback wrappers and implementation
hlinsen Apr 9, 2020
6db64e1
Update doc
hlinsen Apr 10, 2020
18b51cb
Remove duplicate function call
hlinsen Apr 10, 2020
aba20c4
Test trustworthiness instead of positions
hlinsen Apr 10, 2020
18d2a7d
Fix wrapper, bug with the number of edges in COO
hlinsen Apr 11, 2020
f22eea3
Fix swinging and traction memset
hlinsen Apr 13, 2020
ad71a97
Fix exact repulsion
hlinsen Apr 13, 2020
2a9d411
Fix barnes hut nodes creation
hlinsen Apr 14, 2020
a23e1e3
Remove timer
hlinsen Apr 14, 2020
7789607
Fix number of edges
hlinsen Apr 16, 2020
2165d60
Update notebook
hlinsen Apr 17, 2020
274c599
Add unrenumbering in wrapper
hlinsen Apr 17, 2020
94b52a0
Add cpp tests
hlinsen Apr 20, 2020
9c670f5
Clean and fix lin log
hlinsen Apr 29, 2020
18e1523
Update bottom bound for out of cell memory case
hlinsen May 1, 2020
84736a6
Clean up barnes hut and notebook
hlinsen May 1, 2020
fa22546
Implement trustworthiness score
hlinsen May 6, 2020
a79fe86
Integrate 0.14 changes
hlinsen May 6, 2020
c83a70f
Run clang format
hlinsen May 7, 2020
24e7435
Handle directed case
hlinsen May 7, 2020
1cba1bd
Update to graph view
hlinsen May 7, 2020
72aed43
Update changelog
hlinsen May 7, 2020
29ff20a
Update cpp doc
hlinsen May 7, 2020
31ab545
Update copyright
hlinsen May 7, 2020
7a1c2d6
Update copyright
hlinsen May 7, 2020
857a672
Update doc and pytest
hlinsen May 8, 2020
82650c9
Add vertex ids to position list
hlinsen May 8, 2020
baec892
Add fa2 to README and doc
hlinsen May 9, 2020
35e45ca
Add more comments in cpp code
hlinsen May 11, 2020
e1f095e
Remove matrix reader
hlinsen May 11, 2020
4ff7bf3
Fix flake8 errors
hlinsen May 11, 2020
4d5fcd8
Fix more flake8 error
hlinsen May 11, 2020
e606bea
Fix typo in docs
hlinsen May 13, 2020
1fc5e02
Compute distance inside lin log block
hlinsen May 13, 2020
93d15f1
Fix random seed value
hlinsen May 13, 2020
04780db
Update threshold values
hlinsen May 13, 2020
f3460c0
Add check for 0 edge and empty graph
hlinsen May 14, 2020
e0e492b
Rename headers and add rmm exec policy
hlinsen May 14, 2020
fc69231
Revert notebook
hlinsen May 15, 2020
909430b
bc: corrected typo in python doc
xcadet May 15, 2020
3abcba8
Merge pull request #817 from xcadet/fea_bc
BradReesWork May 15, 2020
f7e84f3
UVM notebook
afender May 15, 2020
fa3805b
skip CI for uvm notebook
afender May 15, 2020
ed91c57
Update CHANGELOG.md
afender May 15, 2020
1f64548
bfs: start migrating tests from bc to bfs
xcadet May 15, 2020
5162d58
contributing: corrected typos
xcadet May 15, 2020
938f247
Update uvm.ipynb
afender May 15, 2020
263c17b
Update uvm.ipynb
afender May 15, 2020
ac7e73f
bfs: moved ref bfs to own file, add pred check
xcadet May 15, 2020
5b4fd41
Merge pull request #756 from hlinsen/force-atlas2
BradReesWork May 15, 2020
2ad3465
bfs: add tests bfs_ref, rename generate_graph_csr_from_mtx to generat…
xcadet May 15, 2020
81ed966
bfs: renamed n and nnz, initialized to ptrd to nullptr
xcadet May 15, 2020
d7d4222
updated build for docs
BradReesWork May 17, 2020
8f620f2
chnagelog
BradReesWork May 17, 2020
9b27741
Merge pull request #878 from BradReesWork/branch-0.14-build
BradReesWork May 18, 2020
2c663c1
addressed reviews
afender May 18, 2020
f8af80a
added a couple of emphasis
afender May 18, 2020
5c3662b
Add docs build.sh
dillon-cullinan May 18, 2020
be1e01f
Changelog
dillon-cullinan May 18, 2020
53740b9
Updates to address review feedback: added RMM reinit code, markers, a…
rlratzel May 18, 2020
9b346a0
Merge remote-tracking branch 'upstream/branch-0.14' into branch-0.14-…
rlratzel May 18, 2020
88cd3b2
Merge pull request #879 from dillon-cullinan/gpuci-docs
BradReesWork May 18, 2020
98f32cf
Merge remote-tracking branch 'upstream/branch-0.14' into branch-0.14-…
rlratzel May 18, 2020
f42faf8
Merge pull request #875 from afender/uvm_notebook
BradReesWork May 18, 2020
9be1f8d
Merge pull request #818 from rlratzel/branch-0.14-pytest-benchmark
BradReesWork May 18, 2020
6fc69d9
clean up final gdf_column references, a few more allocations, delete …
ChuckHastings May 18, 2020
a3b6235
merge with latest branch
ChuckHastings May 18, 2020
b129e76
update changelog
ChuckHastings May 18, 2020
9c9ad0a
fix flake8 issue
ChuckHastings May 18, 2020
be5507f
clean up sorting code
ChuckHastings May 18, 2020
a5f1664
missed grmat_wrapper
ChuckHastings May 18, 2020
381981f
fix formatting
ChuckHastings May 18, 2020
27c3171
missed removing test
ChuckHastings May 19, 2020
4cffcf4
bfs: python test use cupy for comparison
xcadet May 19, 2020
9f18481
merge branch 0.14 into enh_bfs_cpp_tests for bench
xcadet May 19, 2020
094e6bf
bc: add to benchmark
xcadet May 19, 2020
ea88aa3
Raft integration infra
Iroy30 May 19, 2020
4fa9b09
setup.py update
Iroy30 May 19, 2020
019a7ad
remove sort test
ChuckHastings May 19, 2020
d9b8721
bfs: update changelog and fix flake8
xcadet May 19, 2020
dc812b4
add changelog
Iroy30 May 19, 2020
023e338
flake8
Iroy30 May 19, 2020
67461ae
Merge branch 'branch-0.14' into raft_integration_infra
afender May 19, 2020
7cae71a
utf-8 encoding
Iroy30 May 20, 2020
ad6e121
remove grmat (not implemented in current version
ChuckHastings May 20, 2020
886928b
Merge pull request #881 from Iroy30/raft_integration_infra
BradReesWork May 20, 2020
a73b954
Merge pull request #876 from xcadet/enh_bfs_cpp_tests
afender May 20, 2020
8e8c906
Update python doc
hlinsen May 18, 2020
8964c92
Add force atlas to benchmarks
hlinsen May 19, 2020
3393f9d
Update changelog
hlinsen May 19, 2020
e44dac0
Update test threshold too high
hlinsen May 20, 2020
7f08e42
Merge pull request #882 from hlinsen/fa2-benchmarks
BradReesWork May 20, 2020
7106481
add back support for int64 -> int32 renumbering
ChuckHastings May 20, 2020
6d3f9fd
remove some debug prints I left in last commit
ChuckHastings May 20, 2020
567bb41
Update CHANGELOG.md
BradReesWork May 20, 2020
8d04b21
Merge branch 'branch-0.14' into bug_gdf_column_dogs_and_cats
ChuckHastings May 20, 2020
58ca41e
Merge branch 'branch-0.14' into bug_gdf_column_dogs_and_cats
ChuckHastings May 20, 2020
9330bf2
update formatting issues
ChuckHastings May 20, 2020
68b6250
Added conftest.py file missing from last commit which adds the --no-r…
rlratzel May 20, 2020
cae7525
Merge remote-tracking branch 'upstream/branch-0.14' into branch-0.14-…
rlratzel May 20, 2020
809a156
Updated CHANGELOG.md with PR 889
rlratzel May 20, 2020
3f21e5d
remove libcudf dependency in cmake, remove old Graph.cu test
ChuckHastings May 20, 2020
dfb7bce
Merge pull request #880 from ChuckHastings/bug_gdf_column_dogs_and_cats
afender May 21, 2020
c22bbeb
A few straggler things to clean up
ChuckHastings May 21, 2020
fef95f6
update changelog
ChuckHastings May 21, 2020
760d132
Merge pull request #889 from rlratzel/branch-0.14-pytest-benchmark
BradReesWork May 21, 2020
8300ca0
add external repositories and raft symlinks to .gitignore
trxcllnt May 21, 2020
50b33d8
changelog
trxcllnt May 21, 2020
6440ca9
Merge pull request #891 from ChuckHastings/bug_missed_some_gdf_column…
BradReesWork May 21, 2020
5e9fd53
Merge branch 'branch-0.14' into git-ignore-external-repositories
BradReesWork May 21, 2020
fd9b046
Merge pull request #893 from trxcllnt/git-ignore-external-repositories
BradReesWork May 21, 2020
2db902d
dask infra updates
Iroy30 May 21, 2020
131da4e
Remove some RMM_ALLOC calls
kaatish May 22, 2020
6d49cab
Merge branch 'branch-0.14' of github.com:rapidsai/cugraph into fix_tw…
kaatish May 22, 2020
5151e91
Removed RMM_ALLOC, RMM_FREE
kaatish May 22, 2020
e52e493
CHANGELOG fix
kaatish May 22, 2020
a0699aa
Clang fixes
kaatish May 22, 2020
51bba23
add ucx-py
Iroy30 May 22, 2020
2cced76
add ucx-py
Iroy30 May 22, 2020
1a59cc8
add ucx-py
Iroy30 May 22, 2020
7ecdf22
Removed references to deleted cudf files
kaatish May 22, 2020
783f36e
PR comment fixes
kaatish May 22, 2020
b564f0e
Removed rmm_utils.h
kaatish May 22, 2020
0900ce1
Clang format fixes
kaatish May 22, 2020
f8a92a7
update include paths for removed cudf headers
trxcllnt May 22, 2020
a292845
changelog
trxcllnt May 22, 2020
be5c53f
Removed rmmInitialize from tests
kaatish May 22, 2020
0963437
Clang style fix and Cuda allocation in tests
kaatish May 23, 2020
0842270
Merge pull request #899 from trxcllnt/remove-experimental-namespace
afender May 23, 2020
e708bbe
Merge branch 'branch-0.14' of github.com:rapidsai/cugraph into fix_tw…
kaatish May 26, 2020
d5fbbf8
Merge pull request #897 from kaatish/fix_two_hop_raii
afender May 26, 2020
3db3622
Louvain optimization
ChuckHastings May 27, 2020
61e8ed6
fix clang format
ChuckHastings May 27, 2020
301684b
Merge branch 'branch-0.14' into fix_louvain
ChuckHastings May 27, 2020
568aa6a
fix flake8 check
ChuckHastings May 27, 2020
7d41b10
deleted unused file
ChuckHastings May 27, 2020
87975fd
move ECG out of nvgraph namespace
ChuckHastings May 27, 2020
a2d22e3
Merge pull request #896 from Iroy30/dask_infra_updates
BradReesWork May 27, 2020
5e024a4
Merge pull request #870 from ChuckHastings/fix_louvain
afender May 27, 2020
f935487
update Louvain notebook to include some documentation about parallel …
ChuckHastings May 27, 2020
fff3dfd
bfS: fix directed missing vertex
xcadet May 27, 2020
db66c86
update changelog
ChuckHastings May 27, 2020
59ece1d
update changelog
xcadet May 27, 2020
5dfed99
Merge pull request #906 from ChuckHastings/update_louvain_notebook
BradReesWork May 27, 2020
04133b9
Merge pull request #907 from xcadet/fix_directed_bfs
BradReesWork May 27, 2020
6ce0f26
get sphinx_markdown_tables from conda
afender May 27, 2020
d1011f5
changelog fix
afender May 27, 2020
f70028a
Merge pull request #911 from afender/env_014
BradReesWork May 28, 2020
ec65777
Reset trustworthiness thresholds
hlinsen May 28, 2020
c9d8481
Update changelog
hlinsen May 28, 2020
d1a75a7
bc: drop gunrock path and cmake rules
xcadet May 28, 2020
031ace8
update changelog
xcadet May 28, 2020
6dffd31
cpp: keep gunrcok dependencies
xcadet May 28, 2020
d13f448
Merge pull request #916 from hlinsen/fa2-fix
BradReesWork May 29, 2020
d5397a5
Merge pull request #917 from xcadet/enh_bc_drop_gunrock
BradReesWork May 29, 2020
ce61111
Updated pagerank with @afender 's temp fix for crash when tmp vector …
rlratzel Jun 1, 2020
7c01960
Added PR 923 to CHANGELOG.md
rlratzel Jun 1, 2020
ad8e6f4
Merge pull request #923 from rlratzel/0.14-pagerank_fix
BradReesWork Jun 2, 2020
9fac1b5
Update CHANGELOG.md
raydouglass Jun 2, 2020
6a82825
Update scikit learn dependency
hlinsen Jun 2, 2020
b764e8c
Update changelog
hlinsen Jun 2, 2020
da0a9f8
Merge pull request #927 from hlinsen/fa2-ci
raydouglass Jun 2, 2020
0b0263f
Update scikit version to support libgcc-ng 7.3
dillon-cullinan Jun 3, 2020
68c5b62
Changelog
dillon-cullinan Jun 3, 2020
8f077b8
Merge pull request #928 from dillon-cullinan/fix-scikitver
raydouglass Jun 3, 2020
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
The table of contents is too big for display.
Diff view
Diff view
  •  
  •  
  •  
11 changes: 11 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -58,11 +58,22 @@ cpp/thirdparty/googletest/
*.ipr
*.iws

## Datasets
datasets/*
!datasets/cyber.csv
!datasets/karate-data.csv
!datasets/karate_undirected.csv
!datasets/netscience.csv


.pydevproject

# Jupyter Notebooks
.ipynb_checkpoints

## Doxygen
cpp/doxygen/html

# Raft symlink
python/cugraph/raft
python/_external_repositories/
55 changes: 50 additions & 5 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,32 +1,77 @@
# cuGraph 0.14.0 (Date TBD)
# cuGraph 0.14.0 (03 Jun 2020)

## New Features
- PR #756 Add Force Atlas 2 layout
- PR #822 Added new functions in python graph class, similar to networkx
- PR #840 OPG degree
- PR #875 UVM notebook
- PR #881 Raft integration infrastructure

## Improvements
- PR #917 Remove gunrock option from Betweenness Centrality
- PR #764 Updated sssp and bfs with GraphCSR, removed gdf_column, added nullptr weights test for sssp
- PR #765 Remove gdf_column from connected components
- PR #780 Remove gdf_column from cuhornet features
- PR #781 Fix compiler argument syntax for ccache
- PR #782 Use Cython's `new_build_ext` (if available)
- PR #788 Added options and config file to enable codecov
- PR #793 Fix legacy cudf imports/cimports
- PR #802 Removed use of gdf_column from db code
- PR #798 Edit return graph type in algorithms return graphs
- PR #799 Refactored graph class with RAII
- PR #802 Removed use of gdf_column from db code
- PR #803 Enable Ninja build
- PR #804 Cythonize in parallel
- PR #807 Updating the Python docs
- PR #817 Add native Betweenness Centrality with sources subset
- PR #818 Initial version of new "benchmarks" folder
- PR #820 OPG infra and all-gather smoke test
- PR #823 Remove gdf column from nvgraph
- PR #829 Updated README and CONTRIBUTIOIN docs
- PR #831 Updated Notebook - Added K-Truss, ECG, and Betweenness Centrality
- PR #832 Removed RMM ALLOC from db subtree
- PR #833 Update graph functions to use new Graph class
- PR #834 Updated local gpuci build
- PR #836 Remove SNMG code
- PR #845 Add .clang-format & format all files
- PR #859 Updated main docs
- PR #862 Katz Centrality : Auto calculation of alpha parameter if set to none
- PR #865 Added C++ docs
- PR #866 Use RAII graph class in KTruss
- PR #867 Updates to support the latest flake8 version
- PR #874 Update setup.py to use custom clean command
- PR #876 Add BFS C++ tests
- PR #878 Updated build script
- PR #879 Add docs build script to repository
- PR #880 Remove remaining gdf_column references
- PR #882 Add Force Atlas 2 to benchmarks
- PR #891 A few gdf_column stragglers
- PR #893 Add external_repositories dir and raft symlink to .gitignore
- PR #897 Remove RMM ALLOC calls
- PR #899 Update include paths to remove deleted cudf headers
- PR #906 Update Louvain notebook

## Bug Fixes
- PR #927 Update scikit learn dependency
- PR #916 Fix CI error on Force Atlas 2 test
- PR #763 Update RAPIDS conda dependencies to v0.14
- PR #795 Fix some documentation
- PR #800 Fix bfs error in optimization path
- PR #825 Fix outdated CONTRIBUTING.md
- PR #827 Fix indexing CI errors due to cudf updates

# cuGraph 0.13.0 (Date TBD)
- PR #827 Fix indexing CI errors due to cudf updates
- PR #844 Fixing tests, converting __getitem__ calls to .iloc
- PR #851 Removed RMM from tests
- PR #852 Fix BFS Notebook
- PR #855 Missed a file in the original SNMG PR
- PR #860 Fix all Notebooks
- PR #870 Fix Louvain
- PR #889 Added missing conftest.py file to benchmarks dir
- PR #896 opg dask infrastructure fixes
- PR #907 Fix bfs directed missing vertices
- PR #911 Env and changelog update
- PR #923 Updated pagerank with @afender 's temp fix for double-free crash
- PR #928 Fix scikit learn test install to work with libgcc-ng 7.3

# cuGraph 0.13.0 (31 Mar 2020)

## New Features
- PR #736 cuHornet KTruss integration
Expand Down
21 changes: 12 additions & 9 deletions CONTRIBUTING.md
Original file line number Diff line number Diff line change
Expand Up @@ -8,9 +8,14 @@ cuGraph, and all of RAPIDS in general, is an open-source project where we encour
If you are ready to contribute, jump right to the [Contribute Code](#code) section.


__Style Formatting Tools:__
* `clang-format` version 8.01+
* `flake8` version 3.5.0+


<a name="issue"></a>
## 1) File an Issue for the RAPIDS cuGraph team to work
To file an issue, go to the RAPIDS cuGraph [issue](https://github.com/rapidsai/cugraph/issues/new/choose) page an select the appropiate issue type. Once an issue is filed the RAPIDS cuGraph team will evaluate and triage the issue. If you believe the issue needs priority attention, please include that in the issue to notify the team.
To file an issue, go to the RAPIDS cuGraph [issue](https://github.com/rapidsai/cugraph/issues/new/choose) page an select the appropriate issue type. Once an issue is filed the RAPIDS cuGraph team will evaluate and triage the issue. If you believe the issue needs priority attention, please include that in the issue to notify the team.

***Bug Report***</pr>
If you notice something not working please file an issue
Expand Down Expand Up @@ -49,20 +54,19 @@ We love when people want to get involved, and if you have a suggestion for a new

If you need more context on a particular issue, please ask.


----
<a name="code"></a>

# So You Want to Contribute Code
# So you want to contribute code

**TL;DR General Development Process**
1. Read the documentation on [building from source](SOURCEBUILD.md) to learn how to setup, and validate, the development environment
2. Read the RAPIDS [Code of Conduct](https://docs.rapids.ai/resources/conduct/)
3. Find or submit an issue to work on (include a comment that you are workign issue)
3. Find or submit an issue to work on (include a comment that you are working issue)
4. Fork the cuGraph [repo](#fork) and Code (make sure to add unit tests)!
5. When done, and code passes local CI, create your pull request (PR)
1. Update the CHANGELOG.md with PR number - see [Changelog formatting](https://docs.rapids.ai/resources/changelog/)
2. Ensure that the PR has the proper [tags](PRTAGS.md)
3. Ensure the code matches out [style guilde](https://docs.rapids.ai/resources/style/)
3. Ensure the code matches out [style guide](https://docs.rapids.ai/resources/style/)
6. Verify that cuGraph CI passes all [status checks](https://help.github.com/articles/about-status-checks/). Fix if needed
7. Wait for other developers to review your code and update code as needed
8. Once reviewed and approved, a RAPIDS developer will merge your pull request
Expand Down Expand Up @@ -144,15 +148,14 @@ others know you are working on it. If you have any questions related to the
implementation of the issue, ask them in the issue instead of the PR.


### Style Guild
### Style Guide
All Python code most pass flake8 style checking
All C++ code must pass clang style checking
All code must adhere to the [RAPIDS Style Guide](https://docs.rapids.ai/resources/style/)

### Tests
All code must have associate test cases. Code without test will not be accepted






14 changes: 13 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@

[![Build Status](https://gpuci.gpuopenanalytics.com/job/rapidsai/job/gpuci/job/cugraph/job/branches/job/cugraph-branch-pipeline/badge/icon)](https://gpuci.gpuopenanalytics.com/job/rapidsai/job/gpuci/job/cugraph/job/branches/job/cugraph-branch-pipeline/)

The [RAPIDS](https://rapids.ai) cuGraph library is a collection of GPU accelerated graph algorithms that process data found in [GPU DataFrames](https://github.com/rapidsai/cudf). The vision of cuGraph is _to make graph analysis ubiquitous to the point that users just think in terms of analysis and not technologies or frameworks_. To realize that vision, cuGraph operators, at the Python layer, on GPU DataFrames, allowing for seamless passing of data between ETL tasks in [cuDF](https://github.com/rapidsai/cudf) and machine learning tasks in [cuML](https://github.com/rapidsai/cuml). Data scientist familiar with Python will quickly pick up how cuGraph integrates with the Pandas-like API of cuDF. Likewise, user familiar with NetworkX will quickly reconnize the NetworkX-like API provided in cuGraph, with the goal being to allow existing code to be ported with minimal effort into RAPIDS. For users familar with C/CUDA and graph structures, a C++ API is also provided. However, there is less type and structure checking at the C layer.
The [RAPIDS](https://rapids.ai) cuGraph library is a collection of GPU accelerated graph algorithms that process data found in [GPU DataFrames](https://github.com/rapidsai/cudf). The vision of cuGraph is _to make graph analysis ubiquitous to the point that users just think in terms of analysis and not technologies or frameworks_. To realize that vision, cuGraph operators, at the Python layer, on GPU DataFrames, allowing for seamless passing of data between ETL tasks in [cuDF](https://github.com/rapidsai/cudf) and machine learning tasks in [cuML](https://github.com/rapidsai/cuml). Data scientist familiar with Python will quickly pick up how cuGraph integrates with the Pandas-like API of cuDF. Likewise, user familiar with NetworkX will quickly reconnize the NetworkX-like API provided in cuGraph, with the goal being to allow existing code to be ported with minimal effort into RAPIDS. For users familiar with C++/CUDA and graph structures, a C++ API is also provided. However, there is less type and structure checking at the C++ layer.

For more project details, see [rapids.ai](https://rapids.ai/).

Expand Down Expand Up @@ -52,6 +52,8 @@ for i in range(len(gdf_page)):
| | K-Core | Single-GPU | |
| | Core Number | Single-GPU | |
| | K-Truss | Single-GPU | |
| Layout | | | |
| | Force Atlas 2 | Single-GPU | |
| Link Analysis| | | |
| | Pagerank | Single-GPU | Multi-GPU on DGX avaible |
| | Personal Pagerank | Single-GPU | |
Expand Down Expand Up @@ -86,6 +88,16 @@ cuGraph provides an auto-renumbering feature, enabled by default, during Graph c

cuGraph is constantly being updatred and improved. Please see the [Transition Guide](TRANSITIONGUIDE.md) if errors are encountered with newer versions

## Graph Sizes and GPU Memory Size
The amount of memory required is dependent on the graph structure and the analytics being executed. As a simple rule of thumb, the amount of GPU memory should be about twice the size of the data size. That gives overhead for the CSV reader and other transform functions. There are ways around the rule but using smaller data chunks.


| Size | Recomended GPU Memory |
|-------------------|-----------------------|
| 500 million edges | 32GB |
| 250 million edges | 16 GB |




## Getting cuGraph
Expand Down
104 changes: 65 additions & 39 deletions SOURCEBUILD.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,27 +4,33 @@ The following instructions are for users wishing to build cuGraph from source co

The cuGraph package include both a C/C++ CUDA portion and a python portion. Both libraries need to be installed in order for cuGraph to operate correctly.

### Prerequisites
## Prerequisites

Compiler requirement:

* `gcc` version 5.4+
* `nvcc` version 10.0+
* `cmake` version 3.12

CUDA requirement:
__Compiler__:
* `gcc` version 5.4+
* `nvcc` version 10.0+
* `cmake` version 3.12+

__CUDA:__
* CUDA 10.0+
* NVIDIA driver 396.44+
* Pascal architecture or better

__Other__
* `git`



You can obtain CUDA from [https://developer.nvidia.com/cuda-downloads](https://developer.nvidia.com/cuda-downloads).

### Build and Install the C/C++ CUDA components

To install cuGraph from source, ensure the dependencies are met and follow the steps below:

1) A cloned version of the repository
## Building cuGraph
To install cuGraph from source, ensure the dependencies are met.


### Clone Repo and Configure Conda Environment
__GIT clone a version of the repository__

```bash
# Set the localtion to cuGraph in an environment variable CUGRAPH_HOME
Expand All @@ -36,7 +42,7 @@ To install cuGraph from source, ensure the dependencies are met and follow the s
cd $CUGRAPH_HOME
```

2) Create the conda development environment
__Create the conda development environment__

```bash
# create the conda environment (assuming in base `cugraph` directory)
Expand Down Expand Up @@ -74,9 +80,50 @@ conda env update --name cugraph_dev --file conda/environments/cugraph_dev_cuda10
conda activate cugraph_dev
```

3) Build and install `libcugraph`. CMake depends on the `nvcc` executable being on your path or defined in `$CUDACXX`.

This project uses cmake for building the C/C++ library. To configure cmake, run:
### Build and Install Using the `build.sh` Script
Using the `build.sh` script make compiling and installig cuGraph a breeze. To build and install, simply do:

```bash
$ cd $CUGRAPH_HOME
$ ./build.sh clean
$ ./build.sh libcugraph
$ ./build.sh cugraph
```

There are several other options available on the build script for advanced users.
`build.sh` options:
```bash
build.sh [<target> ...] [<flag> ...]
clean - remove all existing build artifacts and configuration (start over)
libcugraph - build the cugraph C++ code
cugraph - build the cugraph Python package

and <flag> is:
-v - verbose build mode
-g - build for debug
-n - no install step
--show_depr_warn - show cmake deprecation warnings
-h - print this text

examples:
$ ./build.sh clean # remove prior build artifacts (start over)
$ ./build.sh libcugraph -v # compile and install libcugraph with verbose output
$ ./build.sh libcugraph -g # compile and install libcugraph for debug
$ ./build.sh libcugraph -n # compile libcugraph but do not install

# make parallelism options can also be defined: Example build jobs using 4 threads (make -j4)
$ PARALLEL_LEVEL=4 ./build.sh libcugraph

Note that the libraries will be installed to the location set in `$PREFIX` if set (i.e. `export PREFIX=/install/path`), otherwise to `$CONDA_PREFIX`.
```


## Building each section independently
#### Build and Install the C++/CUDA `libcugraph` Library
CMake depends on the `nvcc` executable being on your path or defined in `$CUDACXX`.

This project uses cmake for building the C/C++ library. To configure cmake, run:

```bash
# Set the localtion to cuGraph in an environment variable CUGRAPH_HOME
Expand All @@ -94,16 +141,10 @@ conda activate cugraph_dev
```
The default installation locations are `$CMAKE_INSTALL_PREFIX/lib` and `$CMAKE_INSTALL_PREFIX/include/cugraph` respectively.

As a convenience, a `build.sh` script is provided in `$CUGRAPH_HOME`. To execute the same build commands above, run the script as shown below. Note that the libraries will be installed to the location set in `$PREFIX` if set (i.e. `export PREFIX=/install/path`), otherwise to `$CONDA_PREFIX`.
```bash
$ cd $CUGRAPH_HOME
$ ./build.sh libcugraph # build the cuGraph libraries and install them to
# $PREFIX if set, otherwise $CONDA_PREFIX
```

### Building and installing the Python package

5. Install the Python package to your Python path:
2) Install the Python package to your Python path:

```bash
cd $CUGRAPH_HOME
Expand All @@ -112,26 +153,11 @@ python setup.py build_ext --inplace
python setup.py install # install cugraph python bindings
```

Like the `libcugraph` build step above, `build.sh` can also be used to build the `cugraph` python package, as shown below:
```bash
$ cd $CUGRAPH_HOME
$ ./build.sh cugraph # build the cuGraph python bindings and install them
# to $PREFIX if set, otherwise $CONDA_PREFIX
```

Note: other `build.sh` options include:
```bash
$ cd $CUGRAPH_HOME
$ ./build.sh clean # remove any prior build artifacts and configuration (start over)
$ ./build.sh libcugraph -v # compile and install libcugraph with verbose output
$ ./build.sh libcugraph -g # compile and install libcugraph for debug
$ PARALLEL_LEVEL=4 ./build.sh libcugraph # compile and install libcugraph limiting parallel build jobs to 4 (make -j4)
$ ./build.sh libcugraph -n # compile libcugraph but do not install
```

### Run tests
## Run tests

6. Run either the C++ or the Python tests with datasets
Run either the C++ or the Python tests with datasets

- **Python tests with datasets**

Expand Down Expand Up @@ -234,4 +260,4 @@ cmake .. -DCMAKE_INSTALL_PREFIX=$CONDA_PREFIX -DCMAKE_CXX11_ABI=OFF
```

## Attribution
Portions adopted from https://github.com/pytorch/pytorch/blob/master/CONTRIBUTING.md
Portions adopted from https://github.com/pytorch/pytorch/blob/master/CONTRIBUTING.md
Loading