Compare commits

...

4 Commits

Author SHA1 Message Date
vowelparrot
44c03b3737 Merge branch 'vwp/add-scenexplain-tool' into add-scenexplain-tool 2023-04-28 16:48:12 -07:00
vowelparrot
5a9f87edfe Squashed commit of the following:
commit ce8db0dfc0
Author: Delgermurun Purevkhuu <delgermurun@users.noreply.github.com>
Date:   Fri Apr 28 10:29:18 2023 +0200

    lint fix

commit 355b430fdc
Author: Delgermurun Purevkhuu <delgermurun@users.noreply.github.com>
Date:   Wed Apr 26 18:17:42 2023 +0200

    add scenexplain tool
2023-04-28 16:45:47 -07:00
Delgermurun Purevkhuu
ce8db0dfc0 lint fix 2023-04-28 10:29:18 +02:00
Delgermurun Purevkhuu
355b430fdc add scenexplain tool 2023-04-28 10:27:26 +02:00
4 changed files with 98 additions and 0 deletions

View File

@@ -26,6 +26,7 @@ from langchain.tools.playwright import (
NavigateTool,
)
from langchain.tools.plugin import AIPluginTool
from langchain.tools.scenexplain.tool import SceneXplainTool
from langchain.tools.shell.tool import ShellTool
__all__ = [
@@ -59,4 +60,6 @@ __all__ = [
"ReadFileTool",
"ShellTool",
"WriteFileTool",
"BaseTool",
"SceneXplainTool",
]

View File

@@ -0,0 +1 @@
"""SceneXplain API toolkit."""

View File

@@ -0,0 +1,26 @@
"""Tool for the SceneXplain API."""
from pydantic import Field
from langchain.tools.base import BaseTool
from langchain.utilities.scenexplain import SceneXplainAPIWrapper
class SceneXplainTool(BaseTool):
"""Tool that adds the capability to explain images."""
name = "Image Explainer"
description = (
"An Image Captioning Tool: Use this tool to generate a detailed caption "
"for an image. The input can be an image file of any format, and "
"the output will be a text description that covers every detail of the image."
)
api_wrapper: SceneXplainAPIWrapper = Field(default_factory=SceneXplainAPIWrapper)
def _run(self, query: str) -> str:
"""Use the tool."""
return self.api_wrapper.run(query)
async def _arun(self, query: str) -> str:
"""Use the tool asynchronously."""
raise NotImplementedError("SceneXplainTool does not support async")

View File

@@ -0,0 +1,68 @@
"""Util that calls SceneXplain.
In order to set this up, you need API key for the SceneXplain API.
You can obtain a key by following the steps below.
- Sign up for a free account at https://scenex.jina.ai/.
- Navigate to the API Access page (https://scenex.jina.ai/api) and create a new API key.
"""
from typing import Dict
import requests
from pydantic import BaseModel, root_validator
from langchain.utils import get_from_dict_or_env
class SceneXplainAPIWrapper(BaseModel):
"""Wrapper for SceneXplain API.
In order to set this up, you need API key for the SceneXplain API.
You can obtain a key by following the steps below.
- Sign up for a free account at https://scenex.jina.ai/.
- Navigate to the API Access page (https://scenex.jina.ai/api)
and create a new API key.
"""
scenex_api_key: str
scenex_api_url: str = (
"https://us-central1-causal-diffusion.cloudfunctions.net/describe"
)
def _describe_image(self, image: str) -> str:
headers = {
"x-api-key": f"token {self.scenex_api_key}",
"content-type": "application/json",
}
payload = {
"data": [
{
"image": image,
"algorithm": "Ember",
"languages": ["en"],
}
]
}
response = requests.post(self.scenex_api_url, headers=headers, json=payload)
response.raise_for_status()
result = response.json().get("result", [])
img = result[0] if result else {}
return img.get("text", "")
@root_validator(pre=True)
def validate_environment(cls, values: Dict) -> Dict:
"""Validate that api key exists in environment."""
scenex_api_key = get_from_dict_or_env(
values, "scenex_api_key", "SCENEX_API_KEY"
)
values["scenex_api_key"] = scenex_api_key
return values
def run(self, image: str) -> str:
"""Run SceneXplain image explainer."""
description = self._describe_image(image)
if not description:
return "No description found."
return description