This document describes some ways in which you can contribute to EvoLP.
- In this way, you contribute to open and reproducible science
- You exercise your coding skills
- You help the community by providing useful contributions
There are many ways in which you can contribute to EvoLP!
Having a clearer documentation benefits everyone. In this sense, you can help either fixing it or expanding it in multiple ways: with wording or clarification, reporting typos, adding corrections or even creating new pages on topics that could need further explanations.
The manuals are written in Markdown, and are built using Documenter.jl. All the source files of the documentation can be found here.
If your submission is small (typos or one or two sentences) then probably using GitHub's online editor is the best idea.
If your submission is big enough (spanning multiple files and adding or modifying several lines of code) then you will need to fork the repository, modify locally, and submit a pull request.
Finding bugs is greatly appreciated, because that means that we can fix them (or you can also help with that).
For now, you can submit a new issue describing the problem in the issue tracker.
Contributing code is also possible via fork & pull request:
- Fork EvoLP
- Make changes (be sure to follow the style guide).
- Make a unit test of your added functionality
- Test your code changes
- Document your code changes
- Push to your fork and make a pull request
EvoLP follows the ColPrac: Contributor's Guide on Collaborative Practices for Community Packages guide from SciML. This guide is a collection of best practices when contributing to packages.
You can read the full guide here.
EvoLP follows Invenia's Blue code style guide. This is a set of style conventions for Julia code that are based on a series of grounding documents (like Julia's own style guide and PEP8).
You can read the full guide here.
The following table shows how the EvoLP code is organised:
Directory | Contents |
---|---|
docs | Documentation |
examples | Examples |
src | Source code |
test | Test suites |
Documentation lives here. src
contains the necessary files for compiling the manual, and make.jl
builds it via a GitHub action.
Examples in .ipynb
form are placed here. This makes it easier for examples to be shown directly in GitHub.
This folder contains all the functionality of EvoLP, spread over several files for clarity.
All these files are included in EvoLP.jl
which is the file which defines the module itself.
An additional subfolder for algorithms
is present, to keep solvers and blocks separated.
This is where all tests reside.
The main test suite runtests.jl
includes functionality to run all other test suites.
Each of these test suites cover all the different categories in EvoLP.
New generators should be tested in the generators.jl
test suite.
New recombinators should be tested in the crossover.jl
test suite.
And so on.
To test algorithms, we solve one of the test functions (in src/testfunctions.jl
) and which solutions are known.
Create a new implementation in a notebook, beautify and put in the src/examples/
directory.
Regardless of what you contribute or how big or small your contribution is, the help is always appreciated.
Get in touch; we will probably be able to help you through the contributing process.