mirror of
https://github.com/hwchase17/langchain.git
synced 2025-06-19 21:33:51 +00:00
Harrison/wolfram alpha (#579)
Co-authored-by: Nicolas <nicolascamara29@gmail.com>
This commit is contained in:
parent
94765e7487
commit
ffc7e04d44
34
docs/ecosystem/wolfram_alpha.md
Normal file
34
docs/ecosystem/wolfram_alpha.md
Normal file
@ -0,0 +1,34 @@
|
|||||||
|
# Wolfram Alpha Wrapper
|
||||||
|
|
||||||
|
This page covers how to use the Wolfram Alpha API within LangChain.
|
||||||
|
It is broken into two parts: installation and setup, and then references to specific Wolfram Alpha wrappers.
|
||||||
|
|
||||||
|
## Installation and Setup
|
||||||
|
- Install requirements with `pip install wolframalpha`
|
||||||
|
- Go to wolfram alpha and sign up for a developer account [here](https://developer.wolframalpha.com/)
|
||||||
|
- Create an app and get your APP ID
|
||||||
|
- Set your APP ID as an environment variable `WOLFRAM_ALPHA_APPID`
|
||||||
|
|
||||||
|
|
||||||
|
## Wrappers
|
||||||
|
|
||||||
|
### Utility
|
||||||
|
|
||||||
|
There exists a WolframAlphaAPIWrapper utility which wraps this API. To import this utility:
|
||||||
|
|
||||||
|
```python
|
||||||
|
from langchain.utilities.wolfram_alpha import WolframAlphaAPIWrapper
|
||||||
|
```
|
||||||
|
|
||||||
|
For a more detailed walkthrough of this wrapper, see [this notebook](../modules/utils/examples/wolfram_alpha.ipynb).
|
||||||
|
|
||||||
|
### Tool
|
||||||
|
|
||||||
|
You can also easily load this wrapper as a Tool (to use with an Agent).
|
||||||
|
You can do this with:
|
||||||
|
```python
|
||||||
|
from langchain.agents import load_tools
|
||||||
|
tools = load_tools(["wolfram-alpha"])
|
||||||
|
```
|
||||||
|
|
||||||
|
For more information on this, see [this page](../modules/agents/tools.md)
|
@ -43,6 +43,12 @@ Below is a list of all supported tools and relevant information:
|
|||||||
- Notes: Calls the Serp API and then parses results.
|
- Notes: Calls the Serp API and then parses results.
|
||||||
- Requires LLM: No
|
- Requires LLM: No
|
||||||
|
|
||||||
|
**wolfram-alpha**
|
||||||
|
- Tool Name: Wolfram Alpha
|
||||||
|
- Tool Description: A wolfram alpha search engine. Useful for when you need to answer questions about Math, Science, Technology, Culture, Society and Everyday Life. Input should be a search query.
|
||||||
|
- Notes: Calls the Wolfram Alpha API and then parses results.
|
||||||
|
- Requires LLM: No
|
||||||
|
|
||||||
**requests**
|
**requests**
|
||||||
- Tool Name: Requests
|
- Tool Name: Requests
|
||||||
- Tool Description: A portal to the internet. Use this when you need to get specific content from a site. Input should be a specific url, and the output will be all the text on that page.
|
- Tool Description: A portal to the internet. Use this when you need to get specific content from a site. Input should be a specific url, and the output will be all the text on that page.
|
||||||
|
124
docs/modules/utils/examples/wolfram_alpha.ipynb
Normal file
124
docs/modules/utils/examples/wolfram_alpha.ipynb
Normal file
@ -0,0 +1,124 @@
|
|||||||
|
{
|
||||||
|
"cells": [
|
||||||
|
{
|
||||||
|
"attachments": {},
|
||||||
|
"cell_type": "markdown",
|
||||||
|
"id": "245a954a",
|
||||||
|
"metadata": {},
|
||||||
|
"source": [
|
||||||
|
"# Wolfram Alpha\n",
|
||||||
|
"\n",
|
||||||
|
"This notebook goes over how to use the wolfram alpha component.\n",
|
||||||
|
"\n",
|
||||||
|
"First, you need to set up your Wolfram Alpha developer account and get your APP ID:\n",
|
||||||
|
"\n",
|
||||||
|
"1. Go to wolfram alpha and sign up for a developer account [here](https://developer.wolframalpha.com/)\n",
|
||||||
|
"2. Create an app and get your APP ID\n",
|
||||||
|
"3. pip install wolframalpha\n",
|
||||||
|
"\n",
|
||||||
|
"Then we will need to set some environment variables:\n",
|
||||||
|
"1. Save your APP ID into WOLFRAM_ALPHA_APPID env variable"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"cell_type": "code",
|
||||||
|
"execution_count": null,
|
||||||
|
"id": "961b3689",
|
||||||
|
"metadata": {
|
||||||
|
"vscode": {
|
||||||
|
"languageId": "shellscript"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"outputs": [],
|
||||||
|
"source": [
|
||||||
|
"pip install wolframalpha"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"cell_type": "code",
|
||||||
|
"execution_count": 6,
|
||||||
|
"id": "34bb5968",
|
||||||
|
"metadata": {},
|
||||||
|
"outputs": [],
|
||||||
|
"source": [
|
||||||
|
"import os\n",
|
||||||
|
"os.environ[\"WOLFRAM_ALPHA_APPID\"] = \"\"\n"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"cell_type": "code",
|
||||||
|
"execution_count": 9,
|
||||||
|
"id": "ac4910f8",
|
||||||
|
"metadata": {},
|
||||||
|
"outputs": [],
|
||||||
|
"source": [
|
||||||
|
"from langchain.utilities.wolfram_alpha import WolframAlphaAPIWrapper"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"cell_type": "code",
|
||||||
|
"execution_count": 10,
|
||||||
|
"id": "84b8f773",
|
||||||
|
"metadata": {},
|
||||||
|
"outputs": [],
|
||||||
|
"source": [
|
||||||
|
"wolfram = WolframAlphaAPIWrapper()"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"cell_type": "code",
|
||||||
|
"execution_count": 11,
|
||||||
|
"id": "068991a6",
|
||||||
|
"metadata": {},
|
||||||
|
"outputs": [
|
||||||
|
{
|
||||||
|
"data": {
|
||||||
|
"text/plain": [
|
||||||
|
"'x = 2/5'"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"execution_count": 11,
|
||||||
|
"metadata": {},
|
||||||
|
"output_type": "execute_result"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"source": [
|
||||||
|
"wolfram.run(\"What is 2x+5 = -3x + 7?\")"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"cell_type": "code",
|
||||||
|
"execution_count": null,
|
||||||
|
"id": "028f4cba",
|
||||||
|
"metadata": {},
|
||||||
|
"outputs": [],
|
||||||
|
"source": []
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"metadata": {
|
||||||
|
"kernelspec": {
|
||||||
|
"display_name": ".venv",
|
||||||
|
"language": "python",
|
||||||
|
"name": "python3"
|
||||||
|
},
|
||||||
|
"language_info": {
|
||||||
|
"codemirror_mode": {
|
||||||
|
"name": "ipython",
|
||||||
|
"version": 3
|
||||||
|
},
|
||||||
|
"file_extension": ".py",
|
||||||
|
"mimetype": "text/x-python",
|
||||||
|
"name": "python",
|
||||||
|
"nbconvert_exporter": "python",
|
||||||
|
"pygments_lexer": "ipython3",
|
||||||
|
"version": "3.9.7"
|
||||||
|
},
|
||||||
|
"vscode": {
|
||||||
|
"interpreter": {
|
||||||
|
"hash": "53f3bc57609c7a84333bb558594977aa5b4026b1d6070b93987956689e367341"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"nbformat": 4,
|
||||||
|
"nbformat_minor": 5
|
||||||
|
}
|
@ -21,6 +21,9 @@ The following use cases require specific installs and api keys:
|
|||||||
- _GoogleSearchAPI_:
|
- _GoogleSearchAPI_:
|
||||||
- Install requirements with `pip install google-api-python-client`
|
- Install requirements with `pip install google-api-python-client`
|
||||||
- Get a Google api key and either set it as an environment variable (`GOOGLE_API_KEY`) or pass it to the LLM constructor as `google_api_key`. You will also need to set the `GOOGLE_CSE_ID` environment variable to your custom search engine id. You can pass it to the LLM constructor as `google_cse_id` as well.
|
- Get a Google api key and either set it as an environment variable (`GOOGLE_API_KEY`) or pass it to the LLM constructor as `google_api_key`. You will also need to set the `GOOGLE_CSE_ID` environment variable to your custom search engine id. You can pass it to the LLM constructor as `google_cse_id` as well.
|
||||||
|
- _WolframAlphaAPI_:
|
||||||
|
- Install requirements with `pip install wolframalpha`
|
||||||
|
- Get a Wolfram Alpha api key and either set it as an environment variable (`WOLFRAM_ALPHA_APPID`) or pass it to the LLM constructor as `wolfram_alpha_appid`.
|
||||||
- _NatBot_:
|
- _NatBot_:
|
||||||
- Install requirements with `pip install playwright`
|
- Install requirements with `pip install playwright`
|
||||||
- _Wikipedia_:
|
- _Wikipedia_:
|
||||||
|
@ -29,6 +29,7 @@ from langchain.prompts import (
|
|||||||
from langchain.serpapi import SerpAPIChain, SerpAPIWrapper
|
from langchain.serpapi import SerpAPIChain, SerpAPIWrapper
|
||||||
from langchain.sql_database import SQLDatabase
|
from langchain.sql_database import SQLDatabase
|
||||||
from langchain.utilities.google_search import GoogleSearchAPIWrapper
|
from langchain.utilities.google_search import GoogleSearchAPIWrapper
|
||||||
|
from langchain.utilities.wolfram_alpha import WolframAlphaAPIWrapper
|
||||||
from langchain.vectorstores import FAISS, ElasticVectorSearch
|
from langchain.vectorstores import FAISS, ElasticVectorSearch
|
||||||
|
|
||||||
verbose: bool = False
|
verbose: bool = False
|
||||||
@ -44,6 +45,7 @@ __all__ = [
|
|||||||
"SerpAPIWrapper",
|
"SerpAPIWrapper",
|
||||||
"SerpAPIChain",
|
"SerpAPIChain",
|
||||||
"GoogleSearchAPIWrapper",
|
"GoogleSearchAPIWrapper",
|
||||||
|
"WolframAlphaAPIWrapper",
|
||||||
"Cohere",
|
"Cohere",
|
||||||
"OpenAI",
|
"OpenAI",
|
||||||
"BasePromptTemplate",
|
"BasePromptTemplate",
|
||||||
|
@ -13,6 +13,7 @@ from langchain.requests import RequestsWrapper
|
|||||||
from langchain.serpapi import SerpAPIWrapper
|
from langchain.serpapi import SerpAPIWrapper
|
||||||
from langchain.utilities.bash import BashProcess
|
from langchain.utilities.bash import BashProcess
|
||||||
from langchain.utilities.google_search import GoogleSearchAPIWrapper
|
from langchain.utilities.google_search import GoogleSearchAPIWrapper
|
||||||
|
from langchain.utilities.wolfram_alpha import WolframAlphaAPIWrapper
|
||||||
|
|
||||||
|
|
||||||
def _get_python_repl() -> Tool:
|
def _get_python_repl() -> Tool:
|
||||||
@ -39,6 +40,14 @@ def _get_google_search() -> Tool:
|
|||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
def _get_wolfram_alpha() -> Tool:
|
||||||
|
return Tool(
|
||||||
|
"Wolfram Alpha",
|
||||||
|
WolframAlphaAPIWrapper().run,
|
||||||
|
"A wrapper around Wolfram Alpha. Useful for when you need to answer questions about Math, Science, Technology, Culture, Society and Everyday Life. Input should be a search query.",
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
def _get_requests() -> Tool:
|
def _get_requests() -> Tool:
|
||||||
return Tool(
|
return Tool(
|
||||||
"Requests",
|
"Requests",
|
||||||
@ -61,6 +70,7 @@ _BASE_TOOLS = {
|
|||||||
"requests": _get_requests,
|
"requests": _get_requests,
|
||||||
"terminal": _get_terminal,
|
"terminal": _get_terminal,
|
||||||
"google-search": _get_google_search,
|
"google-search": _get_google_search,
|
||||||
|
"wolfram-alpha": _get_wolfram_alpha,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -4,11 +4,13 @@ from langchain.requests import RequestsWrapper
|
|||||||
from langchain.serpapi import SerpAPIWrapper
|
from langchain.serpapi import SerpAPIWrapper
|
||||||
from langchain.utilities.bash import BashProcess
|
from langchain.utilities.bash import BashProcess
|
||||||
from langchain.utilities.google_search import GoogleSearchAPIWrapper
|
from langchain.utilities.google_search import GoogleSearchAPIWrapper
|
||||||
|
from langchain.utilities.wolfram_alpha import WolframAlphaAPIWrapper
|
||||||
|
|
||||||
__all__ = [
|
__all__ = [
|
||||||
"BashProcess",
|
"BashProcess",
|
||||||
"RequestsWrapper",
|
"RequestsWrapper",
|
||||||
"PythonREPL",
|
"PythonREPL",
|
||||||
"GoogleSearchAPIWrapper",
|
"GoogleSearchAPIWrapper",
|
||||||
|
"WolframAlphaAPIWrapper",
|
||||||
"SerpAPIWrapper",
|
"SerpAPIWrapper",
|
||||||
]
|
]
|
||||||
|
59
langchain/utilities/wolfram_alpha.py
Normal file
59
langchain/utilities/wolfram_alpha.py
Normal file
@ -0,0 +1,59 @@
|
|||||||
|
"""Util that calls WolframAlpha."""
|
||||||
|
from typing import Any, Dict, Optional
|
||||||
|
|
||||||
|
from pydantic import BaseModel, Extra, root_validator
|
||||||
|
|
||||||
|
from langchain.utils import get_from_dict_or_env
|
||||||
|
|
||||||
|
|
||||||
|
class WolframAlphaAPIWrapper(BaseModel):
|
||||||
|
"""Wrapper for Wolfram Alpha.
|
||||||
|
|
||||||
|
Docs for using:
|
||||||
|
|
||||||
|
1. Go to wolfram alpha and sign up for a developer account
|
||||||
|
2. Create an app and get your APP ID
|
||||||
|
3. Save your APP ID into WOLFRAM_ALPHA_APPID env variable
|
||||||
|
4. pip install wolframalpha
|
||||||
|
|
||||||
|
"""
|
||||||
|
|
||||||
|
wolfram_client: Any #: :meta private:
|
||||||
|
wolfram_alpha_appid: Optional[str] = None
|
||||||
|
|
||||||
|
class Config:
|
||||||
|
"""Configuration for this pydantic object."""
|
||||||
|
|
||||||
|
extra = Extra.forbid
|
||||||
|
|
||||||
|
@root_validator()
|
||||||
|
def validate_environment(cls, values: Dict) -> Dict:
|
||||||
|
"""Validate that api key and python package exists in environment."""
|
||||||
|
wolfram_alpha_appid = get_from_dict_or_env(
|
||||||
|
values, "wolfram_alpha_appid", "WOLFRAM_ALPHA_APPID"
|
||||||
|
)
|
||||||
|
values["wolfram_alpha_appid"] = wolfram_alpha_appid
|
||||||
|
|
||||||
|
try:
|
||||||
|
import wolframalpha
|
||||||
|
|
||||||
|
except ImportError:
|
||||||
|
raise ImportError(
|
||||||
|
"wolframalpha is not installed. "
|
||||||
|
"Please install it with `pip install wolframalpha`"
|
||||||
|
)
|
||||||
|
client = wolframalpha.Client(wolfram_alpha_appid)
|
||||||
|
|
||||||
|
values["wolfram_client"] = client
|
||||||
|
|
||||||
|
# TODO: Add error handling if keys are missing
|
||||||
|
return values
|
||||||
|
|
||||||
|
def run(self, query: str) -> str:
|
||||||
|
"""Run query through WolframAlpha and parse result."""
|
||||||
|
res = self.wolfram_client.query(query)
|
||||||
|
# Includes only text from the response
|
||||||
|
answer = next(res.results).text
|
||||||
|
if answer is None or answer == "":
|
||||||
|
return "No good Wolfram Alpha Result was found"
|
||||||
|
return answer
|
896
poetry.lock
generated
896
poetry.lock
generated
File diff suppressed because it is too large
Load Diff
@ -29,6 +29,7 @@ tiktoken = {version = "^0", optional = true, python="^3.9"}
|
|||||||
pinecone-client = {version = "^2", optional = true}
|
pinecone-client = {version = "^2", optional = true}
|
||||||
weaviate-client = {version = "^3", optional = true}
|
weaviate-client = {version = "^3", optional = true}
|
||||||
google-api-python-client = {version = "2.70.0", optional = true}
|
google-api-python-client = {version = "2.70.0", optional = true}
|
||||||
|
wolframalpha = {version = "5.0.0", optional = true}
|
||||||
|
|
||||||
[tool.poetry.group.docs.dependencies]
|
[tool.poetry.group.docs.dependencies]
|
||||||
autodoc_pydantic = "^1.8.0"
|
autodoc_pydantic = "^1.8.0"
|
||||||
@ -73,7 +74,7 @@ playwright = "^1.28.0"
|
|||||||
|
|
||||||
[tool.poetry.extras]
|
[tool.poetry.extras]
|
||||||
llms = ["cohere", "openai", "nlpcloud", "huggingface_hub", "manifest-ml", "torch", "transformers"]
|
llms = ["cohere", "openai", "nlpcloud", "huggingface_hub", "manifest-ml", "torch", "transformers"]
|
||||||
all = ["cohere", "openai", "nlpcloud", "huggingface_hub", "manifest-ml", "elasticsearch", "google-search-results", "faiss-cpu", "sentence_transformers", "transformers", "spacy", "nltk", "wikipedia", "beautifulsoup4", "tiktoken", "torch", "jinja2", "pinecone-client", "weaviate-client", "redis", "google-api-python-client"]
|
all = ["cohere", "openai", "nlpcloud", "huggingface_hub", "manifest-ml", "elasticsearch", "google-search-results", "faiss-cpu", "sentence_transformers", "transformers", "spacy", "nltk", "wikipedia", "beautifulsoup4", "tiktoken", "torch", "jinja2", "pinecone-client", "weaviate-client", "redis", "google-api-python-client", "wolframalpha"]
|
||||||
|
|
||||||
[tool.isort]
|
[tool.isort]
|
||||||
profile = "black"
|
profile = "black"
|
||||||
|
9
tests/integration_tests/test_wolfram_alpha_api.py
Normal file
9
tests/integration_tests/test_wolfram_alpha_api.py
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
"""Integration test for Wolfram Alpha API Wrapper."""
|
||||||
|
from langchain.utilities.wolfram_alpha import WolframAlphaAPIWrapper
|
||||||
|
|
||||||
|
|
||||||
|
def test_call() -> None:
|
||||||
|
"""Test that call gives the correct answer."""
|
||||||
|
search = WolframAlphaAPIWrapper()
|
||||||
|
output = search.run("what is 2x+18=x+5?")
|
||||||
|
assert "x = -13" in output
|
Loading…
Reference in New Issue
Block a user