promptwatch


Namepromptwatch JSON
Version 0.4.5 PyPI version JSON
download
home_pagehttps://github.com/blip-solutions/promptwatch-client
Summarypromptwatch.io python client to trace langchain sessions
upload_time2024-05-06 22:22:28
maintainerNone
docs_urlNone
authorJuraj Bezdek
requires_python>=3.8
licenseMIT License
keywords promptwatch prompt monitoring
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # PromptWatch.io ... session tracking for LangChain 

It enables you to:
- track all the chain executions
- track LLM Prompts and **re-play the LLM runs** with the same input parameters and model settings to tweak your prompt template
- track your costs per **project** and per **tenant** (your customer)

## Installation 
```bash
pip install promptwatch
```

## Basic usage

In order to enable session tracking  wrap you chain executions in PromptWatch block

```python

from langchain import OpenAI, LLMChain, PromptTemplate
from promptwatch import PromptWatch

prompt_template = PromptTemplate.from_template("Finish this sentence {input}")
my_chain = LLMChain(llm=OpenAI(), prompt=prompt_template)

with PromptWatch(api_key="<your-api-key>") as pw:
    my_chain("The quick brown fox jumped over")

```

Here you can get your API key: http://www.promptwatch.io/get-api-key (no registration needed)

You can set it directly into `PromptWatch` constructor, or set is as an *ENV variable* `PROMPTWATCH_API_KEY`

## Comprehensive Chain Execution Tracking

With PromptWatch.io, you can track all chains, actions, retrieved documents, and more to gain complete visibility into your system. This makes it easy to identify issues with your prompts and quickly fix them for optimal performance.

What sets PromptWatch.io apart is its intuitive and visual interface. You can easily drill down into the chains to find the root cause of any problems and get a clear understanding of what's happening in your system.

![](https://docs.promptwatch.io/assets/images/sessions_optimized.gif)

Read more here:
[Chain tracing documentation](https://docs.promptwatch.io/docs/category/chain-tracing)

## LLM Prompt caching
It is often tha case that some of the prompts are repeated over an over. It is costly and slow. 
With PromptWatch you just wrap your LLM model into our CachedLLM interface and it will automatically reuse previously generated values.

Read more here:
[Prompt caching documentation](https://docs.promptwatch.io/docs/caching)

## LLM Prompt Template Tweaking

Tweaking prompt templates to find the optimal variation can be a time-consuming and challenging process, especially when dealing with multi-stage LLM chains. Fortunately, PromptWatch.io can help simplify the process!

With PromptWatch.io, you can easily experiment with different prompt variants by replaying any given LLM chain with the exact same inputs used in real scenarios. This allows you to fine-tune your prompts until you find the variation that works best for your needs.

![](https://docs.promptwatch.io/assets/images/prompt_templates_optmized.gif)

Read more here:
[Prompt tweaking documentation](https://docs.promptwatch.io/docs/prompt_tweaking)


## Keep Track of Your Prompt Template Changes

Making changes to your prompt templates can be a delicate process, and it's not always easy to know what impact those changes will have on your system. Version control platforms like GIT are great for tracking code changes, but they're not always the best solution for tracking prompt changes.

![](https://docs.promptwatch.io/assets/images/prompt_templates_optmized.gif)

Read more here:
[Prompt template versioning documentation](https://docs.promptwatch.io/docs/prompt_template_versioning)



## Unit testing
Unit tests will help you understand what impact your changes in Prompt templates and your code can have on representative sessions examples.

![](https://docs.promptwatch.io/assets/images/unit_tests.png)
Read more here:
[Unit tests documentation](https://docs.promptwatch.io/docs/category/unit-testing)

            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/blip-solutions/promptwatch-client",
    "name": "promptwatch",
    "maintainer": null,
    "docs_url": null,
    "requires_python": ">=3.8",
    "maintainer_email": null,
    "keywords": "promptwatch prompt monitoring",
    "author": "Juraj Bezdek",
    "author_email": "juraj.bezdek@blip.solutions",
    "download_url": "https://files.pythonhosted.org/packages/03/f5/28f83949b891f1ce6c49167c69f80451e4d0cb741e4787b9b466bf073373/promptwatch-0.4.5.tar.gz",
    "platform": null,
    "description": "# PromptWatch.io ... session tracking for LangChain \n\nIt enables you to:\n- track all the chain executions\n- track LLM Prompts and **re-play the LLM runs** with the same input parameters and model settings to tweak your prompt template\n- track your costs per **project** and per **tenant** (your customer)\n\n## Installation \n```bash\npip install promptwatch\n```\n\n## Basic usage\n\nIn order to enable session tracking  wrap you chain executions in PromptWatch block\n\n```python\n\nfrom langchain import OpenAI, LLMChain, PromptTemplate\nfrom promptwatch import PromptWatch\n\nprompt_template = PromptTemplate.from_template(\"Finish this sentence {input}\")\nmy_chain = LLMChain(llm=OpenAI(), prompt=prompt_template)\n\nwith PromptWatch(api_key=\"<your-api-key>\") as pw:\n    my_chain(\"The quick brown fox jumped over\")\n\n```\n\nHere you can get your API key: http://www.promptwatch.io/get-api-key (no registration needed)\n\nYou can set it directly into `PromptWatch` constructor, or set is as an *ENV variable* `PROMPTWATCH_API_KEY`\n\n## Comprehensive Chain Execution Tracking\n\nWith PromptWatch.io, you can track all chains, actions, retrieved documents, and more to gain complete visibility into your system. This makes it easy to identify issues with your prompts and quickly fix them for optimal performance.\n\nWhat sets PromptWatch.io apart is its intuitive and visual interface. You can easily drill down into the chains to find the root cause of any problems and get a clear understanding of what's happening in your system.\n\n![](https://docs.promptwatch.io/assets/images/sessions_optimized.gif)\n\nRead more here:\n[Chain tracing documentation](https://docs.promptwatch.io/docs/category/chain-tracing)\n\n## LLM Prompt caching\nIt is often tha case that some of the prompts are repeated over an over. It is costly and slow. \nWith PromptWatch you just wrap your LLM model into our CachedLLM interface and it will automatically reuse previously generated values.\n\nRead more here:\n[Prompt caching documentation](https://docs.promptwatch.io/docs/caching)\n\n## LLM Prompt Template Tweaking\n\nTweaking prompt templates to find the optimal variation can be a time-consuming and challenging process, especially when dealing with multi-stage LLM chains. Fortunately, PromptWatch.io can help simplify the process!\n\nWith PromptWatch.io, you can easily experiment with different prompt variants by replaying any given LLM chain with the exact same inputs used in real scenarios. This allows you to fine-tune your prompts until you find the variation that works best for your needs.\n\n![](https://docs.promptwatch.io/assets/images/prompt_templates_optmized.gif)\n\nRead more here:\n[Prompt tweaking documentation](https://docs.promptwatch.io/docs/prompt_tweaking)\n\n\n## Keep Track of Your Prompt Template Changes\n\nMaking changes to your prompt templates can be a delicate process, and it's not always easy to know what impact those changes will have on your system. Version control platforms like GIT are great for tracking code changes, but they're not always the best solution for tracking prompt changes.\n\n![](https://docs.promptwatch.io/assets/images/prompt_templates_optmized.gif)\n\nRead more here:\n[Prompt template versioning documentation](https://docs.promptwatch.io/docs/prompt_template_versioning)\n\n\n\n## Unit testing\nUnit tests will help you understand what impact your changes in Prompt templates and your code can have on representative sessions examples.\n\n![](https://docs.promptwatch.io/assets/images/unit_tests.png)\nRead more here:\n[Unit tests documentation](https://docs.promptwatch.io/docs/category/unit-testing)\n",
    "bugtrack_url": null,
    "license": "MIT License",
    "summary": "promptwatch.io python client to trace langchain sessions",
    "version": "0.4.5",
    "project_urls": {
        "Homepage": "https://github.com/blip-solutions/promptwatch-client"
    },
    "split_keywords": [
        "promptwatch",
        "prompt",
        "monitoring"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "a3f9895d9d6e1a9eb3164de444ab65fa15162305c8ab440ca4462e686fbbff1a",
                "md5": "8a395ba55c9408875a15f7af5b6f671e",
                "sha256": "cc5a71db23fcfc3da5fee11d6b939e062994679d79f6a70bb546c4abecdade49"
            },
            "downloads": -1,
            "filename": "promptwatch-0.4.5-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "8a395ba55c9408875a15f7af5b6f671e",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.8",
            "size": 41447,
            "upload_time": "2024-05-06T22:22:25",
            "upload_time_iso_8601": "2024-05-06T22:22:25.983238Z",
            "url": "https://files.pythonhosted.org/packages/a3/f9/895d9d6e1a9eb3164de444ab65fa15162305c8ab440ca4462e686fbbff1a/promptwatch-0.4.5-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "03f528f83949b891f1ce6c49167c69f80451e4d0cb741e4787b9b466bf073373",
                "md5": "428f93a7671f1f67874e0bfcdfd0842d",
                "sha256": "77816ec414484575f0e5428dc9fcb1b3291784c18a9c934d5ed72bbf42d02ae9"
            },
            "downloads": -1,
            "filename": "promptwatch-0.4.5.tar.gz",
            "has_sig": false,
            "md5_digest": "428f93a7671f1f67874e0bfcdfd0842d",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.8",
            "size": 37568,
            "upload_time": "2024-05-06T22:22:28",
            "upload_time_iso_8601": "2024-05-06T22:22:28.042269Z",
            "url": "https://files.pythonhosted.org/packages/03/f5/28f83949b891f1ce6c49167c69f80451e4d0cb741e4787b9b466bf073373/promptwatch-0.4.5.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-05-06 22:22:28",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "blip-solutions",
    "github_project": "promptwatch-client",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": false,
    "lcname": "promptwatch"
}
        
Elapsed time: 3.47767s