π€ Contributing to TruLens¶
Interested in contributing to TruLens? Here's how to get started!
What can you work on?¶
- πͺ Add new feedback functions
- π€ Add new feedback function providers.
- π Fix bugs
- π Add usage examples
- π§ͺ Add experimental features
- π Improve code quality & documentation
- β Address open issues.
Also, join the AI Quality Slack community for ideas and discussions.
πͺ Add new feedback functions¶
Feedback functions are the backbone of TruLens, and evaluating unique LLM apps may require new evaluations. We'd love your contribution to extend the feedback functions library so others can benefit!
- To add a feedback function for an existing model provider, you can add it to an existing provider module. You can read more about the structure of a feedback function in this guide.
- New methods can either take a single text (str) as a parameter or two different texts (str), such as prompt and retrieved context. It should return a float, or a dict of multiple floats. Each output value should be a float on the scale of 0 (worst) to 1 (best).
π€ Add new feedback function providers¶
Feedback functions often rely on a model provider, such as OpenAI or HuggingFace. If you need a new model provider to utilize feedback functions for your use case, we'd love if you added a new provider class, e.g. Ollama.
You can do so by creating a new provider module in this folder.
Alternatively, we also appreciate if you open a GitHub Issue if there's a model provider you need!
π Fix Bugs¶
Most bugs are reported and tracked in the Github Issues Page. We try our best in triaging and tagging these issues:
Issues tagged as bug are confirmed bugs. New contributors may want to start with issues tagged with good first issue. Please feel free to open an issue and/or assign an issue to yourself.
π Add Usage Examples¶
If you have applied TruLens to track and evaluate a unique use-case, we would love your contribution in the form of an example notebook: e.g. Evaluating Pinecone Configuration Choices on Downstream App Performance
All example notebooks are expected to:
- Start with a title and description of the example
- Include a commented out list of dependencies and their versions, e.g.
# !pip install trulens==0.10.0 langchain==0.0.268
- Include a linked button to a Google colab version of the notebook
- Add any additional requirements
π§ͺ Add Experimental Features¶
If you have a crazy idea, make a PR for it! Whether if it's the latest research, or what you thought of in the shower, we'd love to see creative ways to improve TruLens.
π Improve Code Quality & Documentation¶
We would love your help in making the project cleaner, more robust, and more understandable. If you find something confusing, it most likely is for other people as well. Help us be better!
Big parts of the code base currently do not follow the code standards outlined in Standards index. Many good contributions can be made in adapting us to the standards.
β Address Open Issues¶
See πΌ good first issue or π§ all open issues.
π Things to be Aware Of¶
Development guide¶
See Development guide.
π§ Design Goals and Principles¶
The design of the API is governed by the principles outlined in the Design doc.
Release Policies¶
Versioning and deprecation guidelines are included. Release policies.
β Standards¶
We try to respect various code, testing, and documentation standards outlined in the Standards index.
π£ Tech Debt¶
Parts of the code are nuanced in ways should be avoided by new contributors. Discussions of these points are welcome to help the project rid itself of these problematic designs. See Tech debt index.
β Optional Packages¶
Limit the packages installed by default when installing TruLens. For optional functionality, additional packages can be requested for the user to install and their usage is aided by an optional imports scheme. See Optional Packages for details.
β¨ Database Migration¶
πππ»ππΌππ½ππΎππΏ Contributors¶
TruLens Eval Contributors¶
π§° Maintainers¶
The current maintainers of TruLens are:
Name | Employer | Github Name |
---|---|---|
Corey Hu | Snowflake | sfc-gh-chu |
Daniel Huang | Snowflake | sfc-gh-dhuang |
David Kurokawa | Snowflake | sfc-gh-dkurokawa |
Garett Tok Ern Liang | Snowflake | sfc-gh-gtokernliang |
Josh Reini | Snowflake | sfc-gh-jreini |
Piotr Mardziel | Snowflake | sfc-gh-pmardziel |
Prudhvi Dharmana | Snowflake | sfc-gh-pdharmana |
Ricardo Aravena | Snowflake | sfc-gh-raravena |
Shayak Sen | Snowflake | sfc-gh-shsen |