Welcome to the gyselalib++ project! This guide is designed to help new developers understand how to get started with the project. Please bear in mind that developers unfamiliar with C++ will not find the answers to all their questions in the documentation. While we aim to provide documentation where relevant, this is not a replacement for foundational C++ knowledge; instead, it focuses on the specific challenges and paradigms relevant to gyselalib++. If you encounter unfamiliar keywords or concepts in the code, we recommend looking them up online as a first step. This will help you build a deeper understanding and use your time more effectively before seeking further assistance.
There are multiple coding paradigms possible when writing code in C++. Two of the most common are object-oriented programming and functional programming. You may be familiar with object-oriented programming however gyselalib++ uses functional programming.
Object-Oriented Programming (OOP) is built around the concept of objects that encapsulate data and behavior. Developers used to OOP often think in terms of classes, inheritance, and polymorphism. While these are powerful concepts, they are not central to how gyselalib++ is structured. This is notably because inheritance, and polymorphism are often incompatible with GPU programming.
Functional Programming (FP) aims to make code more readable by making it more obvious where data is modified. This is done by separating data storage from operators. This way, data can never be modified inside its class without passing through an operator. In our code the functional programming paradigm was chosen as it allows us to write the code in a way which more closely resembles the equations.
When using functional programming classes fit into one of two groups:
-
Data Structures:
- Serve as containers for data, often passed into operators for processing.
- Avoid embedding behavior directly into data structures; instead, let operators handle transformations.
-
Operators:
- Should implement an
operator()
method, allowing them to be used as callable objects. - Their internal variables should remain constant to align with functional programming principles.
- Break problems into small, composable functions. Avoid the temptation to design large, monolithic classes.
- Can be thought of as a function. Classes are used instead so the functions called by this function can be decided at compile time.
- Should implement an
By separating operators (behavior) from data structures (data), you ensure clarity, reusability, and better adherence to the functional programming style.
For example consider the case of a semi-Lagrangian advection. The operator is similar to a function which modifies a data structure containing the distribution function. By using a class the method used to interpolate the function (e.g. spline interpolation or Lagrange interpolation) can be specified without duplicating code.
The gyselalib++ codebase is organised into several folders. The main folders of interest are:
-
src/ : This folder contains the source code for the library. It contains folders grouping the code by subject. The
src/
folder and each sub-folder contains aREADME.md
detailing its contents. It is simple to navigate within this documentation : src- geometry... : The
src/
folder contains sub-folders whose names begin withgeometry
. These sub-folders contain code which is specific to a given geometry. Each geometry is defined by the dimensions on which its equations are defined. In these folders you will also find sub-folders grouping the code by subject. Eachgeometry...
folder will contain a folder calledgeometry
containing a filegeometry.hpp
. This file contains type aliases which are useful for this geometry. This includes the definition of the classes representing the dimensions. If ageometry.hpp
is included in a file then this file can only be used for that specific geometry. Therefore files in ageometry...
folder cannot be used for other geometries even if the two appear to be compatible at first glance (e.g. files from thegeometryRTheta
folder cannot be used for thegeometryAxi
simulations, files from thegeometryXVx
folder cannot be used for thegeometryXYVxVy
simulations).
- geometry... : The
-
tests/ : This folder contains the unit tests for the library. The folder structure is similar to that found in the
src/
folder. -
simulations/ : This folder contains examples of simulations. In order to use the gyselalib++ library for research applications we usually create a new repository which contains this repository as a sub-module, however there are still some simulations hosted in this repository. This is notably the case for simulations which have known properties that can be used as end-to-end tests. For example the Landau damping case.
-
Familiarize yourself with DDC:
- Gyselalib++ relies heavily on DDC (Discrete Domain Decomposition Library) for data management. Understanding its usage is key to contributing effectively.
- See our detailed guide on DDC integration: Using DDC in Gyselalib++.
-
Build the project:
- Follow the build instructions in the repository's README.
- More detailed instructions especially instructions for specific systems like the CEA's persee can be found in the toolchain documentation: Pre-made build settings.
-
Identify a simple task:
- Start with a small, well-scoped issue to familiarize yourself with the contribution process and code review workflow.
We hope this guide sets you on the right path to contributing to gyselalib++. Happy coding!