Contributions to cuDF fall into the following categories:
- To report a bug, request a new feature, or report a problem with documentation, please file an issue describing the problem or new feature in detail. The RAPIDS team evaluates and triages issues, and schedules them for a release. If you believe the issue needs priority attention, please comment on the issue to notify the team.
- To propose and implement a new feature, please file a new feature request issue. Describe the intended feature and discuss the design and implementation with the team and community. Once the team agrees that the plan looks good, go ahead and implement it, using the code contributions guide below.
- To implement a feature or bug fix for an existing issue, please follow the code contributions guide below. If you need more context on a particular issue, please ask in a comment.
As contributors and maintainers to this project, you are expected to abide by cuDF's code of conduct. More information can be found at: Contributor Code of Conduct.
- Follow the guide at the bottom of this page for Setting up your build environment.
- Find an issue to work on. The best way is to look for the good first issue or help wanted labels.
- Comment on the issue stating that you are going to work on it.
- Create a fork of the cudf repository and check out a branch with a name that
describes your planned work. For example,
fix-documentation
. - Write code to address the issue or implement the feature.
- Add unit tests and unit benchmarks.
- Create your pull request. To run continuous integration (CI) tests without requesting review, open a draft pull request.
- Verify that CI passes all status checks. Fix if needed.
- Wait for other developers to review your code and update code as needed.
- Once reviewed and approved, a RAPIDS developer will merge your pull request.
If you are unsure about anything, don't hesitate to comment on issues and ask for clarification!
Once you have gotten your feet wet and are more comfortable with the code, you can look at the prioritized issues for our next release in our project boards.
Note: Always look at the release board that is currently under development for issues to work on. This is where RAPIDS developers also focus their efforts.
Look at the unassigned issues, and find an issue to which you are comfortable contributing. Start with Step 3 above, commenting on the issue to let 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.
The following instructions are for developers and contributors to cuDF development. These instructions are tested on Ubuntu Linux LTS releases. Use these instructions to build cuDF from source and contribute to its development. Other operating systems may be compatible, but are not currently tested.
Building cudf with the provided conda environment is recommended for users who wish to enable all library features. The following instructions are for building with a conda environment. Dependencies for a minimal build of libcudf without using conda are also listed below.
Compilers:
gcc
version 9.3+nvcc
version 11.5+cmake
version 3.23.1+
CUDA/GPU:
- CUDA 11.5+
- NVIDIA driver 450.80.02+
- Pascal architecture or better
You can obtain CUDA from https://developer.nvidia.com/cuda-downloads.
- Clone the repository:
CUDF_HOME=$(pwd)/cudf
git clone https://github.com/rapidsai/cudf.git $CUDF_HOME
cd $CUDF_HOME
Note: Using a conda environment is the easiest way to satisfy the library's dependencies. Instructions for a minimal build environment without conda are included below.
- Create the conda development environment
cudf_dev
:
# create the conda environment (assuming in base `cudf` directory)
# note: RAPIDS currently doesn't support `channel_priority: strict`;
# use `channel_priority: flexible` instead
conda env create --name cudf_dev --file conda/environments/cudf_dev_cuda11.5.yml
# activate the environment
conda activate cudf_dev
-
Note: the conda environment files are updated frequently, so the development environment may also need to be updated if dependency versions or pinnings are changed.
-
For other CUDA versions, check the corresponding
cudf_dev_cuda*.yml
file inconda/environments/
.
-
libcudf has the following minimal dependencies (in addition to those listed in the General requirements). The packages listed below use Ubuntu package names:
build-essential
libssl-dev
libz-dev
libpython3-dev
(required if building cudf)
- A
build.sh
script is provided in$CUDF_HOME
. Running the script with no additional arguments will install thelibcudf
,cudf
anddask_cudf
libraries. By default, the libraries are installed to the$CONDA_PREFIX
directory. To install into a different location, set the location in$INSTALL_PREFIX
. Finally, note that the script depends on thenvcc
executable being on your path, or defined in$CUDACXX
.
cd $CUDF_HOME
# Choose one of the following commands, depending on whether
# you want to build and install the libcudf C++ library only,
# or include the cudf and/or dask_cudf Python libraries:
./build.sh # libcudf, cudf and dask_cudf
./build.sh libcudf # libcudf only
./build.sh libcudf cudf # libcudf and cudf only
- Other libraries like
cudf-kafka
andcustreamz
can be installed with this script. For the complete list of libraries as well as details about the script usage, run thehelp
command:
./build.sh --help
The general workflow is provided below. Please also see the last section about code formatting.
- If you're only interested in building the library (and not the unit tests):
cd $CUDF_HOME
./build.sh libcudf
- If, in addition, you want to build tests:
./build.sh libcudf tests
- To run the tests:
make test
-
First, build the
libcudf
C++ library following the steps above -
To build and install in edit/develop
cudf
Python package:
cd $CUDF_HOME/python/cudf
python setup.py build_ext --inplace
python setup.py develop
- To run
cudf
tests:
cd $CUDF_HOME/python
pytest -v cudf/cudf/tests
-
First, build the
libcudf
C++ andcudf
Python libraries following the steps above -
To install the
dask-cudf
Python package in editable/develop mode:
cd $CUDF_HOME/python/dask_cudf
python setup.py build_ext --inplace
python setup.py develop
- To run
dask_cudf
tests:
cd $CUDF_HOME/python
pytest -v dask_cudf
- If you're only interested in building the library (and not the unit tests):
cd $CUDF_HOME
./build.sh libcudf_kafka
- If, in addition, you want to build tests:
./build.sh libcudf_kafka tests
- To run the tests:
make test
-
First, build the
libcudf
andlibcudf_kafka
libraries following the steps above -
To install the
cudf-kafka
Python package in editable/develop mode:
cd $CUDF_HOME/python/cudf_kafka
python setup.py build_ext --inplace
python setup.py develop
-
First, build
libcudf
,libcudf_kafka
, andcudf_kafka
following the steps above -
To install the
custreamz
Python package in editable/develop mode:
cd $CUDF_HOME/python/custreamz
python setup.py build_ext --inplace
python setup.py develop
- To run
custreamz
tests :
cd $CUDF_HOME/python
pytest -v custreamz
-
First, build the
libcudf
C++ library following the steps above -
Then, refer to the Java README
Done! You are ready to develop for the cuDF project. Please review the project's code formatting guidelines.
Follow the instructions to build from source and add -g
to the
./build.sh
command.
For example:
./build.sh libcudf -g
This builds libcudf
in debug mode which enables some assert
safety checks and includes symbols
in the library for debugging.
All other steps for installing libcudf
into your environment are the same.
When you have a debug build of libcudf
installed, debugging with the cuda-gdb
and
cuda-memcheck
is easy.
If you are debugging a Python script, run the following:
cuda-gdb -ex r --args python <program_name>.py <program_arguments>
cuda-memcheck python <program_name>.py <program_arguments>
The device debug symbols are not automatically added with the cmake Debug
build type because it
causes a runtime delay of several minutes when loading the libcudf.so library.
Therefore, it is recommended to add device debug symbols only to specific files by setting the -G
compile option locally in your cpp/CMakeLists.txt
for that file. Here is an example of adding the
-G
option to the compile command for src/copying/copy.cu
source file:
set_source_files_properties(src/copying/copy.cu PROPERTIES COMPILE_OPTIONS "-G")
This will add the device debug symbols for this object file in libcudf.so
. You can then use
cuda-dbg
to debug into the kernels in that source file.
cuDF uses clang-format
.
In order to format the C++/CUDA files, navigate to the root (cudf
) directory and run:
python3 ./cpp/scripts/run-clang-format.py -inplace
Additionally, many editors have plugins or extensions that you can set up to automatically run
clang-format
either manually or on file save.
doxygen
is used as documentation generator and also as a documentation linter.
In order to run doxygen as linter on C++/CUDA code, run
./ci/checks/doxygen.sh
cuDF uses pre-commit to execute code linters and formatters such as Black, isort, and flake8. These tools ensure a consistent code format throughout the project. Using pre-commit ensures that linter versions and options are aligned for all developers. Additionally, there is a CI check in place to enforce that committed code follows our standards.
To use pre-commit
, install via conda
or pip
:
conda install -c conda-forge pre-commit
pip install pre-commit
Then run pre-commit hooks before committing code:
pre-commit run
Optionally, you may set up the pre-commit hooks to run automatically when you make a git commit. This can be done by running:
pre-commit install
Now code linters and formatters will be run each time you commit changes.
You can skip these checks with git commit --no-verify
or with the short version git commit -n
.
The C++ Developer Guide includes details on contributing to libcudf C++ code.
The Python Developer Guide includes details on contributing to cuDF Python code.
Portions adopted from https://github.com/pytorch/pytorch/blob/master/CONTRIBUTING.md Portions adopted from https://github.com/dask/dask/blob/master/docs/source/develop.rst