Skip to content

Files

Latest commit

90760b5 · Aug 28, 2024

History

History
128 lines (84 loc) · 7 KB

CONTRIBUTING.md

File metadata and controls

128 lines (84 loc) · 7 KB

Contributing to Advanced RAG Techniques

Welcome to the world's largest and most comprehensive repository of Retrieval-Augmented Generation (RAG) tutorials! 🌟 We're thrilled you're interested in contributing to this ever-growing knowledge base. Your expertise and creativity can help us maintain our position at the forefront of RAG technology.

Join Our Community

We have a vibrant Discord community where contributors can discuss ideas, ask questions, and collaborate on RAG techniques. Join us at:

RAG Techniques Discord Server

Don't hesitate to introduce yourself and share your thoughts!

Ways to Contribute

We welcome contributions of all kinds! Here are some ways you can help:

  1. Add New RAG Techniques: Create new notebooks showcasing novel RAG methods.
  2. Improve Existing Notebooks: Enhance, update, or expand our current tutorials.
  3. Fix Bugs: Help us squash bugs in existing code or explanations.
  4. Enhance Documentation: Improve clarity, add examples, or fix typos in our docs.
  5. Share Creative Ideas: Have an innovative idea? We're all ears!
  6. Engage in Discussions: Participate in our Discord community to help shape the future of RAG.

Remember, no contribution is too small. Every improvement helps make this repository an even better resource for the community.

Reporting Issues

Found a problem or have a suggestion? Please create an issue on GitHub, providing as much detail as possible. You can also discuss issues in our Discord community.

Contributing Code or Content

  1. Fork and Branch: Fork the repository and create your branch from main.
  2. Make Your Changes: Implement your contribution, following our best practices.
  3. Test: Ensure your changes work as expected.
  4. Follow the Style: Adhere to the coding and documentation conventions used throughout the project.
  5. Commit: Make your git commits informative and concise.
  6. Stay Updated: The main branch is frequently updated. Before opening a pull request, make sure your code is up-to-date with the current main branch and has no conflicts.
  7. Push and Pull Request: Push to your fork and submit a pull request.
  8. Discuss: Use the Discord community to discuss your contribution if you need feedback or have questions.

Adding a New RAG Method

When adding a new RAG method to the repository, please follow these additional steps:

  1. Create your notebook in the all_rag_techniques folder.
  2. Update the README.md file:
    • Add your new method to the list of techniques in the README.
    • Place it in the appropriate position based on complexity (methods are sorted from easiest to most complicated).
    • Use the following format for the link:
      ### [Number]. [Your Method Name 🏷️](https://github.com/NirDiamant/RAG_Techniques/blob/main/all_rag_techniques/your_file_name.ipynb)
      
    • Replace [Number] with the appropriate number, [Your Method Name] with your method's name, and your_file_name.ipynb with the actual name of your notebook file.
    • Choose an appropriate emoji that represents your method.
    • After inserting your new method, make sure to update the numbers of all subsequent techniques to maintain the correct order.

For example:

### 1. [Simple RAG 🌱](https://github.com/NirDiamant/RAG_Techniques/blob/main/all_rag_techniques/simple_rag.ipynb)
### 2. [Your New Method 🆕](https://github.com/NirDiamant/RAG_Techniques/blob/main/all_rag_techniques/your_new_method.ipynb)
### 3. [Next Method 🔜](https://github.com/NirDiamant/RAG_Techniques/blob/main/all_rag_techniques/next_method.ipynb)

Remember to increment the numbers of all methods that come after your newly inserted technique.

Notebook Structure

For new notebooks or significant additions to existing ones, please follow this structure:

  1. Title and Overview: Clear title and brief overview of the technique.

  2. Detailed Explanation: Cover motivation, key components, method details, and benefits.

  3. Visual Representation: Include a diagram to visualize the technique. We recommend using Mermaid syntax for creating these diagrams. Here's how to do it:

• Create a graph using Mermaid's graph TD (top-down) syntax
• You can use Claude or other AI assistants to help you design the graph if needed
• Paste your Mermaid code into Mermaid Live Editor
• In the "Actions" tab of Mermaid Live Editor, download the SVG file of your diagram
• Store the SVG file in the images folder of the repository
• Use an appropriate, descriptive name for the file
• In your notebook, display the image using Markdown syntax:

![Your Technique Name](../images/your-technique-name.svg)

This process ensures consistency in our visual representations and makes it easy for others to understand and potentially modify the diagrams in the future.

  1. Implementation: Step-by-step Python implementation with clear comments and explanations.

  2. Usage Example: Demonstrate the technique with a practical example.

  3. Comparison: Compare with basic RAG, both qualitatively and quantitatively if possible.

  4. Additional Considerations: Discuss limitations, potential improvements, or specific use cases.

  5. References: Include relevant citations or resources if you have.

Notebook Best Practices

To ensure consistency and readability across all notebooks:

  1. Code Cell Descriptions: Each code cell should be preceded by a markdown cell with a clear, concise title describing the cell's content or purpose.

  2. Clear Unnecessary Outputs: Before committing your notebook, clear all unnecessary cell outputs. This helps reduce file size and avoids confusion from outdated results.

  3. Consistent Formatting: Maintain consistent formatting throughout the notebook, including regular use of markdown headers, code comments, and proper indentation.

Code Quality and Readability

To ensure the highest quality and readability of our code:

  1. Write Clean Code: Follow best practices for clean, readable code.
  2. Use Comments: Add clear and concise comments to explain complex logic.
  3. Format Your Code: Use consistent formatting throughout your contribution.
  4. Language Model Review: After completing your code, consider passing it through a language model for additional formatting and readability improvements. This extra step can help make your code even more accessible and maintainable.

Documentation

Clear documentation is crucial. Whether you're improving existing docs or adding new ones, follow the same process: fork, change, test, and submit a pull request.

Final Notes

We're grateful for all our contributors and excited to see how you'll help expand the world's most comprehensive RAG resource. Don't hesitate to ask questions in our Discord community if you're unsure about anything.

Let's harness our collective knowledge and creativity to push the boundaries of RAG technology together!

Happy contributing! 🚀