Skip to main content

This package contains tools to work with Tilores entity resolution database within Langchain.

Project description

LangChain Using Tilores

This repository provides the building blocks for integrating LangChain, LangGraph, and the Tilores entity resolution system.

Developers can use these tools to create powerful systems that leverage entity resolution for record retrieval, search, and entity resolution.

Examples

  • Human-in-the-Loop Chat: examples/chat

    This example demonstrates how to build a chat application using Chainlit and LangGraph to explore a Tilores instance through natural language. It guides users through search functionality and explains the search results.

  • Basic Usage: examples/basic

    This example shows how to use tools with an LLM model in a basic setup.

Usage

from tilores import TiloresAPI
from langchain_tilores import TiloresTools
from langchain_openai import ChatOpenAI
from langchain_core.messages import HumanMessage

# Initialize the Tilores API.
tilores = TiloresAPI.from_environ()
# TiloresTools helps you build typed tools from a specific Tilores instance, typed according to
# the schema of the instance.
tilores_tools = TiloresTools(tilores)

# Setup a LLM model for inference bound with a set of tools.
tools = [tilores_tools.search_tool]
tools_dict = {tool.name: tool for tool in tools}
model = ChatOpenAI(temperature=0, streaming=True, model_name="gpt-4o")
model = model.bind_tools(tools)

# The basic loop works like this, that a list of messages is passed to the LLM
messages = [
    HumanMessage("Find me an entity by the first name Emma, surname Schulz, born on 1988-03-12")
]
ai_message = model.invoke(messages)
messages.append(ai_message)

# And for each AiMessage, you must check if it wants to invoke tools.
for tool_call in ai_message.tool_calls:
    # Perform the tool call and append the ToolMessage to the list of messages
    selected_tool = tools_dict[tool_call['name']]
    tool_message = selected_tool.invoke(tool_call)
    messages.append(tool_message)

# Then continue the basic loop by invoking the LLM with the current state, passing the list of messages.
ai_response = model.invoke(messages)
print(ai_response.content)
$ cd examples/basic/
$ pip install -r requirements.txt
$ python llm_with_tools.py
I found multiple records for an entity with the first name Emma, surname Schulz, born on 1988-03-12. Here are the details:

1. **Record ID:** cc001001-0006-4000-c000-000000000006
   - **First Name:** Emma
   - **Last Name:** Schulz
   - **Date of Birth:** 1988-03-12

2. **Record ID:** cc001001-0002-4000-c000-000000000002
   - **First Name:** Emma
   - **Last Name:** Schulz
   - **Date of Birth:** 1988-03-12

[... snip ...]

If you need more specific information or further assistance, please let me know!

Provided tools

  • tilores_search

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

langchain_tilores-0.3.0.tar.gz (4.5 kB view details)

Uploaded Source

Built Distribution

langchain_tilores-0.3.0-py3-none-any.whl (5.4 kB view details)

Uploaded Python 3

File details

Details for the file langchain_tilores-0.3.0.tar.gz.

File metadata

  • Download URL: langchain_tilores-0.3.0.tar.gz
  • Upload date:
  • Size: 4.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for langchain_tilores-0.3.0.tar.gz
Algorithm Hash digest
SHA256 2af2bbea37c2753559f3803f8dd39dc354a6c8e8f2c1eeabf2aecdead6a4e2ef
MD5 54bfc3f123cbe415e62bd96b7e12cda5
BLAKE2b-256 ec11b671cd04168d76fa8e087baf18327a2be1dbb0c3d10abb6ab06e92a1f7c8

See more details on using hashes here.

File details

Details for the file langchain_tilores-0.3.0-py3-none-any.whl.

File metadata

File hashes

Hashes for langchain_tilores-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 c92b826bff1eb9deb660509757c166522ee5999f833e817e6eb3427002bbe3f9
MD5 648df7e567c9a08dc903c1bd58715154
BLAKE2b-256 2d8707d09259d708c0fbf34dadb90e7bd09b335c5b543d3e2d12b8eb07e971a3

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page