From a8839b60380f1a15c9abab474829a83593f1dbef Mon Sep 17 00:00:00 2001
From: vrushankportkey <134934501+vrushankportkey@users.noreply.github.com>
Date: Sun, 18 Feb 2024 21:00:19 +0530
Subject: [PATCH] Update README.md
---
README.md | 117 ++++++++++++++++++++++++------------------------------
1 file changed, 51 insertions(+), 66 deletions(-)
diff --git a/README.md b/README.md
index 44c3fed..da83a38 100644
--- a/README.md
+++ b/README.md
@@ -1,53 +1,74 @@
-
-
-## Ship Ambitious Gen AI Apps with Portkey's full-stack LLMOps Platform
+
+## Control Panel for AI Apps
```bash
npm install portkey-ai
```
-
-## **💡 Features**
-
-**🚪 AI Gateway:**
-* **Unified API Signature**: If you've used OpenAI, you already know how to use Portkey with any other provider.
-* **Interoperability**: Write once, run with any provider. Switch between _any model_ from _any provider_ seamlessly.
-* **Automated Fallbacks & Retries**: Ensure your application remains functional even if a primary service fails.
-* **Load Balancing & A/B Testing**: Efficiently distribute incoming requests among multiple models and run A/B tests at scale.
-* **Semantic Caching**: Reduce costs and latency by intelligently caching results.
-
-**🔬 Observability:**
-* **Logging**: Keep track of all requests for monitoring and debugging.
-* **Requests Tracing**: Understand the journey of each request for optimization.
-* **Custom Tags**: Segment and categorize requests for better insights.
-
+## Features
+
+### AI Gateway
+
+
+ Unified API Signature If you've used OpenAI, you already know how to use Portkey with any other provider. |
+ Interoperability Write once, run with any provider. Switch between any model from_any provider seamlessly. |
+
+
+ Automated Fallbacks & Retries Ensure your application remains functional even if a primary service fails. |
+ Load Balancing Efficiently distribute incoming requests among multiple models. |
+
+
+ Semantic Caching Reduce costs and latency by intelligently caching results. |
+ Virtual Keys Secure your LLM API keys by storing them in Portkey vault and using disposable virtual keys. |
+
+
+ Request Timeouts Manage unpredictable LLM latencies effectively by setting custom request timeouts on requests. |
+
+
+
+### Observability
+
+
+ Logging Keep track of all requests for monitoring and debugging. |
+ Requests Tracing Understand the journey of each request for optimization. |
+
+
+ Custom Metadata Segment and categorize requests for better insights. |
+ Feedbacks Collect and analyse weighted feedback on requests from users. |
+
+
+ Analytics Track your app & LLM's performance with 40+ production-critical metrics in a single place. |
+
+
+
+## **Usage**
+#### Prerequisites
+1. [Sign up on Portkey](https://app.portkey.ai/) and grab your Portkey API Key
+2. Add your [OpenAI key](https://platform.openai.com/api-keys) to Portkey's Virtual Keys page and keep it handy
-## **🚀 Quick Start**
-
-#### First, install the SDK & export Portkey API Key
-[Get Portkey API key here.](https://app.portkey.ai/signup)
```bash
+# Installing the SDK
+
$ npm install portkey-ai
$ export PORTKEY_API_KEY="PORTKEY_API_KEY"
```
-#### Now, let's make a request with GPT-4
-
+#### Making a Request to OpenAI
+* Portkey fully adheres to the OpenAI SDK signature. You can instantly switch to Portkey and start using our production features right out of the box.
+* Just replace `import OpenAI from 'openai'` with `import Portkey from 'portkey-ai'`:
```js
import Portkey from 'portkey-ai';
-// Construct a client with a virtual key
const portkey = new Portkey({
- apiKey: "PORTKEY_API_KEY",
virtualKey: "VIRTUAL_KEY"
})
async function main() {
const chatCompletion = await portkey.chat.completions.create({
messages: [{ role: 'user', content: 'Say this is a test' }],
- model: 'gpt-3.5-turbo',
+ model: 'gpt-4',
});
console.log(chatCompletion.choices);
@@ -56,46 +77,10 @@ async function main() {
main();
```
-Portkey fully adheres to the OpenAI SDK signature. This means that you can instantly switch to Portkey and start using Portkey's advanced production features right out of the box.
-
-
-
-
-## **📔 List of Portkey Features**
-
-You can set all of these features while constructing your LLMOptions object.
-
-
-| Feature | Config Key | Value(Type) | Required |
-|--|--|--|--|
-| API Key OR Virtual Key | `api_key` OR `virtual_key` | `string` | ✅ Required |
-| Provider Name | `provider` | `openai`, `cohere`, `anthropic`, `azure-openai` | ✅ Required |
-| Model Name | `model` | The relevant model name from the provider. For example, `gpt-3.5-turbo` OR `claude-2` | ❔ Optional |
-| Weight (For Loadbalance) | `weight` | `integer` | ❔ Optional |
-| Cache Type | `cache_status` | `simple`, `semantic` | ❔ Optional |
-| Force Cache Refresh | `cache_force_refresh` | `True`, `False` (Boolean) | ❔ Optional |
-| Cache Age | `cache_age` | `integer` (in seconds) | ❔ Optional |
-| Trace ID | `trace_id` | `string` | ❔ Optional |
-| Retries | `retry` | `integer` [0,5] | ❔ Optional |
-| Metadata | `metadata` | `json object` [More info](https://docs.portkey.ai/key-features/custom-metadata) | ❔ Optional |
-| All Model Params | As per the model/provider | This is params like `top_p`, `temperature`, etc | ❔ Optional |
-
-## **🤝 Supported Providers**
-
-|| Provider | Support Status | Supported Endpoints |
-|---|---|---|---|
-| | OpenAI | ✅ Supported | `/completion`, `/chatcompletion` |
-| | Azure OpenAI | ✅ Supported | `/completion`, `/chatcompletion` |
-| | Anthropic | ✅ Supported | `/complete` |
-| | Cohere | ✅ Supported | `generate` |
-
-
----
-
-#### [📝 Full Documentation](https://docs.portkey.ai/docs) | [🛠️ Integration Requests](https://github.com/Portkey-AI/portkey-node-sdk/issues) |
+#### [Check out Portkey docs for the full list of supported providers](https://portkey.ai/docs/welcome/what-is-portkey#ai-providers-supported)
-## **🛠️ Contributing**
-Get started by checking out Github issues. Feel free to open an issue, or reach out if you would like to add to the project!
\ No newline at end of file
+#### Contributing
+Get started by checking out Github issues. Email us at support@portkey.ai or just ping on Discord to chat.