Skip to content

Latest commit

 

History

History
62 lines (41 loc) · 5.08 KB

CONTRIBUTING.md

File metadata and controls

62 lines (41 loc) · 5.08 KB

Contributing to Fast-LLM 🚀

Thank you for your interest in contributing to Fast-LLM! We're thrilled to have you here, and your support is invaluable in helping us accelerate LLM training to full speed. This guide will walk you through the steps to contribute, from reporting issues to submitting changes and setting up your development environment.

If you have questions or want to start a discussion, feel free to open a discussion on our GitHub page.

Getting Started

To get started with contributing to Fast-LLM, follow these steps to set up your environment:

  1. Set Up the Development Environment: Fast-LLM is built on PyTorch and Triton. Check out our setup guide for instructions on getting everything ready, including the development environment and dependencies.
  2. Learn Our Best Practices: Get familiar with our development best practices, which cover code style, pre-commit hooks, and testing strategies.
  3. Launch Fast-LLM Locally or with Docker: Need help getting started? Follow the instructions in the launching section to get Fast-LLM up and running.

How to Report a Bug 🐞

Found a bug? Let's squash it together! Open an issue and select "Bug report." Please include as much information as possible:

  • Steps to reproduce the issue.
  • What you expected to happen versus what actually happened.
  • Screenshots, log files, or error messages (if applicable).
  • Details about your environment setup (e.g., OS, Docker version, and relevant configurations).

If you're familiar with the codebase, consider adding a failing unit test to demonstrate the problem (optional, but helpful!).

Proposing Changes

Before diving into code, open an issue to discuss your proposal. This is especially important if you're planning significant changes or adding new dependencies. Once your idea is approved, follow these steps:

  1. Fork the Repository: Fork Fast-LLM to your own GitHub account.
  2. Clone Your Fork Locally: Use git clone to bring the code to your local machine.
  3. Create a New Branch: Name your branch descriptively, such as feature/awesome-feature or fix/nasty-bug.
  4. Make Your Changes: Work your magic! Don't forget to add or update tests, benchmarks, or configurations as needed.
  5. Create a Properly Titled Pull Request: When you're ready to open a PR, make sure to use a clear and descriptive title that follows our PR title guidelines. This title will become the commit message for the squashed merge.
  6. Push to Your Fork: Push the branch to your GitHub fork.
  7. Open a Pull Request: Submit a pull request to the main branch. Reference the original issue number and provide a brief summary of your changes.

Guidelines for a Successful Pull Request

Here are some tips to ensure your pull request gets reviewed and merged promptly:

  • Follow our coding standards: Stick to our development best practices to keep the code clean and consistent.
  • Write tests: Verify your changes with unit tests for new features or bug fixes.
  • Test on GPUs and real-world workloads: Since Fast-LLM is all about training large language models, make sure your changes work smoothly in GPU environments and on typical training setups.
  • Run benchmarks and performance tests: Make sure your changes don't slow things down. If there's any impact on performance, provide benchmark results to back it up.
  • Avoid introducing new issues: Check that there are no new runtime warnings, type checker errors, linting problems, or unhandled edge cases.
  • Comment non-trivial code: Make your code easy to understand for others.
  • Keep sensitive data out: Make sure your code or commit messages don't expose private or proprietary information.
  • Use the PR template: Complete the checklist to make sure everything is in order before hitting submit.

Seeking Help or Clarification

If you're unsure about something or need help, you've got options:

  • GitHub Discussions: Start a discussion if you need advice or just want to chat.
  • Project Maintainers: Mention a maintainer in an issue or pull request if you need a review or guidance.

Contributors

We're grateful for all the awesome contributors who help make Fast-LLM better. Join our contributors' list and make your first contribution!

To learn more about the team and maintainers, visit our About page.