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

Notebook fixes to formulas and outputs #4272

Merged
merged 10 commits into from
Apr 12, 2024
17 changes: 14 additions & 3 deletions docs/cugraph/source/installation/source_build.md
Original file line number Diff line number Diff line change
Expand Up @@ -13,8 +13,8 @@ __Compilers:__

__CUDA:__
* CUDA 11.2+
* NVIDIA driver 450.80.02+
* Pascal architecture or better
* NVIDIA driver 470.42.01 or newer
* NVIDIA GPU, Volta architecture or later, with [compute capability](https://developer.nvidia.com/cuda-gpus) 7.0+

Further details and download links for these prerequisites are available on the
[RAPIDS System Requirements page](https://docs.rapids.ai/install#system-req).
Expand Down Expand Up @@ -42,6 +42,10 @@ files](https://github.com/rapidsai/cugraph/blob/main/conda/environments).
# for CUDA 11.x
conda env create --name cugraph_dev --file $CUGRAPH_HOME/conda/environments/all_cuda-118_arch-x86_64.yaml

# for CUDA 12.x
conda env create --name cugraph_dev --file $CUGRAPH_HOME/conda/environments/all_cuda-12.2_arch-x86_64.yaml


# activate the environment
conda activate cugraph_dev

Expand All @@ -55,6 +59,13 @@ The environment can be updated as cugraph adds/removes/updates its dependencies.
# for CUDA 11.x
conda env update --name cugraph_dev --file $CUGRAPH_HOME/conda/environments/all_cuda-118_arch-x86_64.yaml
conda activate cugraph_dev

# for CUDA 12.x
conda env update --name cugraph_dev --file $CUGRAPH_HOME/conda/environments/all_cuda-122_arch-x86_64.yaml
conda activate cugraph_dev



```

### Build and Install
Expand Down Expand Up @@ -167,7 +178,7 @@ Run either the C++ or the Python tests with datasets
make test
```

Note: This conda installation only applies to Linux and Python versions 3.8/3.10.
Note: This conda installation only applies to Linux and Python versions 3.8/3.11.

### (OPTIONAL) Set environment variable on activation

Expand Down
2 changes: 1 addition & 1 deletion notebooks/algorithms/centrality/Betweenness.ipynb
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,7 @@
"source": [
"Betweenness centrality of a node 𝑣 is the sum of the fraction of all-pairs shortest paths that pass through 𝑣\n",
"\n",
"<img src=\"https://latex.codecogs.com/png.latex?c_B(v)&space;=\\sum_{s,t&space;\\in&space;V}&space;\\frac{\\sigma(s,&space;t|v)}{\\sigma(s,&space;t)}\" title=\"c_B(v) =\\sum_{s,t \\in V} \\frac{\\sigma(s, t|v)}{\\sigma(s, t)}\" />\n"
"$c_B(v) =\\sum_{s,t \\in V} \\frac{\\sigma(s, t|v)}{\\sigma(s, t)}$"
]
},
{
Expand Down
9 changes: 4 additions & 5 deletions notebooks/algorithms/centrality/Eigenvector.ipynb
Original file line number Diff line number Diff line change
Expand Up @@ -34,13 +34,12 @@
"cell_type": "markdown",
"metadata": {},
"source": [
"The eigenvector centrality for node i is the\n",
"i-th element of the vector x defined by the eigenvector equation.\n",
"For a graph with V vertices where $A = (A_v,t)$ is the adjacency matrix, the Eigenvector centrality score of vertex $v$ is defined as\n",
"\n",
"<img src=\"https://wikimedia.org/api/rest_v1/media/math/render/svg/51c506ef0f23db1086b00ff6e5da847ff53cf5e9\" />\n",
"\n",
"$x_v = \\frac{1}{\\lambda}{\\sum_{t \\in M(v)}}x_t = \\frac{1}{\\lambda}{\\sum_{t \\in V}{a_v,x_t}}$\n",
"\n",
"Where M(v) is the adjacency list for the set of vertices(v) and λ is a constant.\n",
"Where $M(v)$ is the neighbor set for $v$ and λ is a constant.\n",
"\n",
"[Learn more about EigenVector Centrality](https://www.sci.unich.it/~francesc/teaching/network/eigenvector.html)\n"
]
Expand Down Expand Up @@ -314,7 +313,7 @@
"metadata": {},
"source": [
"___\n",
"Copyright (c) 2022-2023, NVIDIA CORPORATION.\n",
"Copyright (c) 2022-2024, NVIDIA CORPORATION.\n",
"\n",
"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\n",
"\n",
Expand Down
18 changes: 9 additions & 9 deletions notebooks/algorithms/centrality/Katz.ipynb
Original file line number Diff line number Diff line change
Expand Up @@ -35,14 +35,14 @@
"\n",
" G: cugraph.Graph object\n",
" alpha: float, Attenuation factor. default is 0.1\n",
" max_iter: int, The maximum number of iterations before an answer is returned. \n",
" This can be used to limit the execution time and do an early exit \n",
" before the solver reaches the convergence tolerance. If this value \n",
" max_iter: int, The maximum number of iterations before an answer is returned.\n",
" This can be used to limit the execution time and do an early exit\n",
" before the solver reaches the convergence tolerance. If this value\n",
" is lower or equal to 0 cuGraph will use the default value, which is 100\n",
" tol: float, Set the tolerance the approximation, this parameter should be a small \n",
" magnitude value. The lower the tolerance the better the approximation. If \n",
" this value is 0.0f, cuGraph will use the default value which is 0.00001. \n",
" Setting too small a tolerance can lead to non-convergence due to numerical \n",
" tol: float, Set the tolerance the approximation, this parameter should be a small\n",
" magnitude value. The lower the tolerance the better the approximation. If\n",
" this value is 0.0f, cuGraph will use the default value which is 0.00001.\n",
" Setting too small a tolerance can lead to non-convergence due to numerical\n",
" roundoff. Usually values between 0.01 and 0.00001 are acceptable.\n",
" nstart: cuDataFrame, GPU Dataframe containing the initial guess for katz centrality. \n",
" Default is None\n",
Expand All @@ -58,8 +58,8 @@
"\n",
"\n",
"The value of _alpha_ should be<br>\n",
"<img src=\"https://latex.codecogs.com/gif.latex?\\alpha&space;<&space;\\frac{1}{\\lambda&space;_{max}&space;}\" title=\"\\alpha < \\frac{1}{\\lambda _{max} }\" />\n",
"currently the user is responsible for setting alpha appropiatly. \n",
"$\\alpha < \\frac{1}{\\lambda _{max} }$\n",
"currently the user is responsible for setting alpha appropriately.\n",
"\n",
"### _NOTICE_\n",
"There is a difference between how cuGraph and how NetworkX computes the Katz centrality score. That difference leads to the scores not matching. cuGraph does not currently support the 'beta' and 'weight' parameters as seen in the corresponding networkX call. The cuGraph implementation is based on a relaxed version of Katz defined by Foster with a reduced computational complexity of O(n+m)\n",
Expand Down
25 changes: 22 additions & 3 deletions notebooks/algorithms/link_analysis/Pagerank.ipynb
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,22 @@
" * For more advanced renumbering support, see the examples in `structure/renumber.ipynb` and `structure/renumber-2.ipynb`\n"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"The formula for Pagerank is:\n",
"\n",
"$PR(A) = \\frac{1 - d}{N} + d \\times \\left( \\sum_{i=1}^{N} \\frac{PR(T_i)}{C(T_i)} \\right)$\n",
"\n",
"In the formula:\n",
"* $PR(A)$ is the pagerank of A\n",
"* $d$ is damping factor which represents the probability of following an outgoing edge. A common default is 0.85\n",
"* $N$ is the total number of webpages\n",
"* $T_i$ are pages containing links to page A\n",
"* $C(T_i)$ is the number of links from node $T_i$"
]
},
{
"attachments": {},
"cell_type": "markdown",
Expand Down Expand Up @@ -306,7 +322,7 @@
"source": [
"----\n",
"\n",
"a PageRank score of _0.10047_ is very low, which can be an indication that there is no more central vertex than any other. Rather than just looking at the top score, let's look at the top three vertices and see if there are any insights that can be inferred. \n",
"a PageRank score of _0.100917324_ is very low, which can be an indication that there is no more central vertex than any other. Rather than just looking at the top score, let's look at the top three vertices and see if there are any insights that can be inferred. \n",
"\n",
"Since this is a very small graph, let's just sort and get the first three records"
]
Expand Down Expand Up @@ -353,6 +369,9 @@
"metadata": {},
"outputs": [],
"source": [
"# this started the vertices with 1 instead of 0 to coincide with the diagram\n",
"d['vertex'] = d['vertex']+1\n",
"\n",
"d.sort_values('out_degree', ascending=False).head(3)"
]
},
Expand Down Expand Up @@ -428,7 +447,7 @@
"metadata": {},
"source": [
"___\n",
"Copyright (c) 2019-2023, NVIDIA CORPORATION.\n",
"Copyright (c) 2019-2024, NVIDIA CORPORATION.\n",
"\n",
"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\n",
"\n",
Expand All @@ -453,7 +472,7 @@
"name": "python",
"nbconvert_exporter": "python",
"pygments_lexer": "ipython3",
"version": "3.9.13"
"version": "3.11.8"
},
"vscode": {
"interpreter": {
Expand Down
Loading