You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
swarms/DOCS/C0NTRIBUTING.md

4.7 KiB

Contributing to Swarms

Thank you for your interest in contributing to Swarms! We welcome contributions from the community to help improve usability and readability. By contributing, you can be a part of creating a dynamic and interactive AI system.

To get started, please follow the guidelines below.

Join the Swarms Community

Join the Swarms community on Discord to connect with other contributors, coordinate work, and receive support.

Taking on Tasks

We have a growing list of tasks and issues that you can contribute to. To get started, follow these steps:

  1. Visit the Swarms GitHub repository and browse through the existing issues.

  2. Find an issue that interests you and make a comment stating that you would like to work on it. Include a brief description of how you plan to solve the problem and any questions you may have.

  3. Once a project coordinator assigns the issue to you, you can start working on it.

If you come across an issue that is unclear but still interests you, please post in the Discord server mentioned above. Someone from the community will be able to help clarify the issue in more detail.

We also welcome contributions to documentation, such as updating markdown files, adding docstrings, creating system architecture diagrams, and other related tasks.

Submitting Your Work

To contribute your changes to Swarms, please follow these steps:

  1. Fork the Swarms repository to your GitHub account. You can do this by clicking on the "Fork" button on the repository page.

  2. Clone the forked repository to your local machine using the git clone command.

  3. Before making any changes, make sure to sync your forked repository with the original repository to keep it up to date. You can do this by following the instructions here.

  4. Create a new branch for your changes. This branch should have a descriptive name that reflects the task or issue you are working on.

  5. Make your changes in the branch, focusing on a small, focused change that only affects a few files.

  6. Run any necessary formatting or linting tools to ensure that your changes adhere to the project's coding standards.

  7. Once your changes are ready, commit them to your branch with descriptive commit messages.

  8. Push the branch to your forked repository.

  9. Create a pull request (PR) from your branch to the main Swarms repository. Provide a clear and concise description of your changes in the PR.

  10. Request a review from the project maintainers. They will review your changes, provide feedback, and suggest any necessary improvements.

  11. Make any required updates or address any feedback provided during the review process.

  12. Once your changes have been reviewed and approved, they will be merged into the main branch of the Swarms repository.

  13. Congratulations! You have successfully contributed to Swarms.

Please note that during the review process, you may be asked to make changes or address certain issues. It is important to engage in open and constructive communication with the project maintainers to ensure the quality of your contributions.

Developer Setup

If you are interested in setting up the Swarms development environment, please follow the instructions provided in the developer setup guide. This guide provides an overview of the different tools and technologies used in the project.

Optimization Priorities

To continuously improve Swarms, we prioritize the following design objectives:

  1. Usability: Increase the ease of use and user-friendliness of the swarm system to facilitate adoption and interaction with basic input.

  2. Reliability: Improve the swarm's ability to obtain the desired output even with basic and un-detailed input.

  3. Speed: Reduce the time it takes for the swarm to accomplish tasks by improving the communication layer, critiquing, and self-alignment with meta prompting.

  4. Scalability: Ensure that the system is asynchronous, concurrent, and self-healing to support scalability.

Our goal is to continuously improve Swarms by following this roadmap while also being adaptable to new needs and opportunities as they arise.

Join the Agora Community

Swarms is brought to you by Agora, the open-source AI research organization. Join the Agora community to connect with other researchers and developers working on AI projects.

Thank you for your contributions and for being a part of the Swarms and Agora community! Together, we can advance Humanity through the power of AI.