Skip to content

JetBrains-Research/on-device-agents

Repository files navigation

TinyAgent: Function Calling at the Edge

Click to open the initial README

Get the desktop app‎ ‎ |‎ ‎ Read the blog post

Thumbnail

TinyAgent aims to enable complex reasoning and function calling capabilities in Small Language Models (SLMs) that can be deployed securely and privately at the edge. Traditional Large Language Models (LLMs) like GPT-4 and Gemini-1.5, while powerful, are often too large and resource-intensive for edge deployment, posing challenges in terms of privacy, connectivity, and latency. TinyAgent addresses these challenges by training specialized SLMs with high-quality, curated data, and focusing on function calling with LLMCompiler. As a driving application, TinyAgent can interact with various macOS applications, helping users with day-to-day tasks such as composing emails, managing contacts, scheduling calendar events, and organizing Zoom meetings.

Demo

TinyAgent Demo

What can TinyAgent do?

TinyAgent is equipped with 16 different functions that can interact with different applications on Mac, which includes:

📧 Mail

  • Compose New Email
    • Start a new email with options for adding recipients and attachments.
    • Example Query: “Email Sid and Nick about the meeting with attachment project.pdf.”
  • Reply to Emails
    • Respond to received emails, optionally adding new recipients and attachments.
    • Example Query: “Reply to Alice's email with the updated budget document attached.”
  • Forward Emails
    • Forward an existing email to other contacts, including additional attachments if necessary.
    • Example Query: “Forward the project briefing to the marketing team.”

📇 Contacts

  • Retrieve phone numbers and email addresses from the contacts database.
  • Example Query: “Get John’s phone number” or “Find Alice’s email address.”

📨 SMS

  • Send text messages to contacts directly from TinyAgent.
  • Example Query: “Send an SMS to Canberk saying ‘I’m running late.’”

📅 Calendar

  • Create new calendar events with specified titles, dates, and times.
  • Example Query: “Create an event called 'Meeting with Sid' on Friday at 3 PM.”

🗺️ Maps

  • Find directions or open map locations for points of interest via Apple Maps.
  • Example Query: “Show me directions to the nearest Starbucks.”

🗒️ Notes

  • Create, open, and append content to notes stored in various folders.
  • Example Query: “Create a note called 'Meeting Notes' in the Meetings folder.”

🗂️ File Management

  • File Reading
    • Open and read files directly through TinyAgent.
    • Example Query: “Open the LLM Compiler.pdf.”
  • PDF Summarization
    • Generate summaries of PDF documents, enhancing content digestion and review efficiency.
    • Example Query: “Summarize the document LLM Compiler.pdf and save the summary in my Documents folder.”

⏰ Reminders

  • Set reminders for various activities or tasks, ensuring nothing is forgotten.
  • Example Query: “Remind me to call Sid at 3 PM about the budget approval.”

🎥 Zoom Meetings

  • Schedule and organize Zoom meetings, including setting names and times.
  • Example Query: “Create a Zoom meeting called 'Team Standup' at 10 AM next Monday.”

💬 Custom Instructions

  • Write and configure specific instructions for your TinyAgent.
  • Example Query: “Always cc team members Nick and Sid in all emails.”

You can choose to enable/disable certain apps by going to the Preferences window.

🤖 Sub-Agents

Depending on the task simplicity, TinyAgent orchestrates the execution of different more specialized or smaller LMs. TinyAgent currently can operate LMs that can summarize a PDF, write emails, or take notes.

See the Customization section to see how to add your own sub-agentx.

🛠️ ToolRAG

When faced with challenging tasks, SLM agents require appropriate tools and in-context examples to guide them. If the model sees irrelevant examples, it can hallucinate. Likewise, if the model sees the descriptions of the tools that it doesn’t need, it usually gets confused, and these tools take up unnecessary prompt space. To tackle this, TinyAgent uses ToolRAG to retrieve the best tools and examples suited for a given query. This process has minimal latency and increases the accuracy of TinyAgent substantially. Please take a look at our blog post and our ToolRAG model for more details.

You need to first install our ToolRAG model from Hugging Face and enable it from the TinyAgent settings to use it.

🎙️ Whisper

TinyAgent also accepts voice commands through both the OpenAI Whisper API and local whisper.cpp deployment. For whisper.cpp, you need to setup the local whisper server and provide the server port number in the TinyAgent settings.

Providers

You can use with your OpenAI key, Azure deployments, or even your own local models!

OpenAI

You need to provide OpenAI API Key and the models you want to use in the 'Preferences' window.

Azure Deployments

You need to provide your deployment name and the endpoints for the main agent/sub-agents/embedding model as well as the context length of the agent models in the 'Preferences' window.

Local Models

You can plug-and-play every part of TinyAgent with your local models! TinyAgent can use an OpenAI-compatible server to run models locally. There are several options you can take:

  • LMStudio : For models already on Huggingface, LMStudio provides an easy-to-use to interface to get started with locally served models.

  • llama.cpp server: However, if you want more control over your models, we recommend using the official llama.cpp server to get started. Please read through the tagged documentation to get started with it.

All TinyAgent needs is the port numbers that you are serving your model at and its context length.

Fine-tuned TinyAgents

We also provide our own fine-tuned open source models, TinyAgent-1.1B and TinyAgent-7B! We curated a dataset of 40.000 real-life use cases for TinyAgent and fine-tuned two small open-source language models on this dataset with LoRA. After fine-tuning and using ToolRAG, both TinyAgent-1.1B and TinyAgent-7B exceed the performance of GPT-4-turbo. Check out our for the specifics of dataset generation, evaluation, and fine-tuning.

Model Success Rate
GPT-3.5-turbo 65.04%
GPT-4-turbo 79.08%
TinyLLama-1.1B-32K-Instruct 12.71%
WizardLM-2-7b 41.25%
TinyAgent-1.1B + ToolRAG / [hf] [gguf] 80.06%
TinyAgent-7B + ToolRAG / [hf] [gguf] 84.95%

Customization

You can customize your TinyAgent by going to ~/Library/Application Support/TinyAgent/tinyagent-llmcompiler directory and changing the code yourself.

Using TinyAgent programmatically

You can use TinyAgent programmatically by just passing in a config file.

from src.tiny_agent.tiny_agent import TinyAgent
from src.tiny_agent.config import get_tiny_agent_config

config_path = "..."
tiny_agent_config = get_tiny_agent_config(config_path=config_path)
tiny_agent = TinyAgent(tiny_agent_config)

await TinyAgent.arun(query="Create a meeting with Sid and Lutfi for tomorrow 2pm to discuss the meeting notes.")

Adding your own tools

  1. Navigate to src/tiny_agent/models.py and add your tool;s name to TinyAgentToolName(Enum)
class TinyAgentToolName(Enum):
    ...


CUSTOM_TOOL_NAME = "custom_tool"
  1. Navigate to src/tiny_agent/tiny_agent_tools.py and define your tool.
def get_custom_tool(...) -> list[Tool]:
    async def tool_coroutine(...) -> str:  # Needs to return a string

    ...


return ...

custom_tool = Tool(
    name=TinyAgentToolName.CUSTOM_TOOL_NAME,
    func=tool_coroutine,
    description=(
        f"{TinyAgentToolName.CUSTOM_TOOL_NAME.value}(...) -> str\n"
        "<The description of the tool>"
    )
)

return [custom_tool]
  1. Add your tools to the get_tiny_agent_tools function.
def get_tiny_agent_tools(...):
    ...


tools += get_custom_tools(...)
...

Note: Adding your own tools only works for GPT models since our open-source models and ToolRAG were only fine-tuned on the original TinyAgent toolset.

Adding your own sub-agents

You can also add your own custom subagents. To do so, please follow these steps:

  1. All sub-agents inherit from SubAgent class in src/tiny_agent/sub_agents/sub_agent.py. Your custom agent should inherit from this abstract class and define the __call__ method.
class CustomSubAgent(SubAgent):

    async def __call__(self, ...) -> str:
        ...
        return response
  1. Add your custom agent to TinyAgent in src/tiny_agent/tiny_agent.py
from src.tiny_agent.sub_agents.custom_agent import CustomAgent


class TinyAgent:
    ...


custom_agent: CustomAgent


def __init__(...):
    ...
    self.custom_agent = CustomAgent(
        sub_agent_llm, config.sub_agent_config, config.custom_instructions
    )
    ...
  1. After defining your custom agent and adding it to TinyAgent, you should create a tool that calls this agent. Please refer to the Adding your own tools section to see how to do so

Citation

We would appreciate it if you could please cite our blog post if you found TinyAgent useful for your work:

@misc{tiny-agent,
  title={TinyAgent: Function Calling at the Edge},
  author={Erdogan, Lutfi Eren and Lee, Nicholas and Jha, Siddharth and Kim, Sehoon and Tabrizi, Ryan and Moon, Suhong and Hooper, Coleman and Anumanchipalli, Gopala and Keutzer, Kurt and Gholami, Amir},
  howpublished={\url{https://bair.berkeley.edu/blog/2024/05/29/tiny-agent/}},
  year={2024}
}

Quick Start

Environment Setup

As a Python environment Poetry is used. To create a new environment use the poetry shell command. Once the virtual environment is started, install all the necessary dependencies using the poetry install command.

Declare Environmental Variables

To use OpenAI models please specify OPENAI_API_KEY in the .env file in the root of the repository. To use Open-Source models you should additionally specify HF_TOKEN in the .env file. Example of the .env file is .env-sample and located in the root of the repository.

Also, the keys for OpenAI API or HuggingFace API should be specified in the configs (config_mistral.json or config_openai.json).

Possible Problems

If you encountered with the following problem:

UnboundLocalError: local variable 'llm_response' referenced before assignment

Most likely that you didn't specify the key in the configuration file.

Setup Local LLM Server

To use an agent fully, locally you have to set up a dedicated LLM server. The easiest way to do that is to use LM Studio or vllm (TODO)

Run the Agent Programmatically

Once you have installed all the necessary dependencies, declared environmental variables and started the local server, you can finally use the agent. To run an agent programmatically, run the run_programmatically.py script using poetry:

 poetry run python3 run_programmatically.py

During the first start, an agent will ask you for a permission to the internal directories or macOS applications.

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 3

  •  
  •  
  •  

Languages