Gradio spaces are the perfect agent tools!

Community Article Published January 17, 2025

TLDR: You can use spaces on the hub as tools for agents, with Gradio and smolagents.

AI agents are becoming increasingly capable of handling complex tasks and interacting with the world in cool ways. To fully realize their potential, AI agents need a wide range of tools. Spaces are a handy platform for building and sharing these tools. Agent tools could perform basic functional tasks like transforming data, all the way up to sophisticated AI tasks like generating images.

Here are some advantages:

  • Existing Capabilities: Access loads of pre-built applications from the AI community.
  • Enhanced Compute: Take advantage of free and scalable compute through ZeroGPU and Pro subscriptions.
  • Easy development: Build and test your tools as Gradio apps, and let Gradio take care of deployment and integration.

How it Works

Three steps to guide you through the setup of a space as an agent tool. Below are some detailed references to tutorials for each step.

Step 1: Identify a suitable space

First, you will need to find or build a space for your project. To help you out, I created a collection of some handy tools for tasks like data visualisation, measurement, and image generation. If you’re looking for something more specific, search the Hugging Face Hub for Spaces that align with your agent's needs.

If you want to build a space of your own, it’s straightforward to start from a Gradio Interface. Almost anything you can build and deploy within the Interface object, is compatible with smolagents. If you’re looking for an example, check out the Plotly visualisation tool I made.

In the next section I will show how Gradio presents an API which smolagents can interact with.

Step 2: Integrate into Agent Framework

Next, you’ll need to integrate your agent with your space as a tool. Use smolagents API to interact with the Gradio app on Spaces. Smolagents can then process the responses from the space to be incorporated into the agent's workflow.

You can directly import a Space from the Hub as a tool using the Tool.from_space() method. Provide the Space's ID on the Hub, its name, and a description to help your agent understand its function. This will handle parameters and responses using the Gradio client integration.

Let's import the FLUX.1-dev Space from the Hub and use it to generate an image:

image_generation_tool = Tool.from_space(
    "black-forest-labs/FLUX.1-schnell", # You can also add localhost url here for testing 🤯
    name="image_generator",
    description="Generate an image from a prompt"
)

image_generation_tool("A sunny beach")

You can then use this tool like a generic python function. The inputs from the Gradio Interface are mapped to function parameters and the outputs are presented in an object.

Step 3: Customise your agent’s tool usage

The smolagents library can handle your space like any other tool so you can customize the prompts to deal with your use case. For example, let's improve the prompt "a rabbit wearing a space suit" and generate an image:

from smolagents import CodeAgent, HfApiModel

model = HfApiModel("Qwen/Qwen2.5-Coder-32B-Instruct")
agent = CodeAgent(tools=[image_generation_tool], model=model)

agent.run(
    "Improve this prompt, then generate an image of it.", additional_args=dict(prompt="A rabbit wearing a space suit")
)

Conclusion

By following these steps using Hugging Face Spaces, Gradio, and smolagents, you can create capable AI agents using existing spaces on the hub. If you want to dive deeper into this problem, check out this material.

Gradio Tutorial on LLM agents
smolagents tutorial on Tools

Community

wow, great idea, i remember a similar project called something something agi when connecting tools to llms were the trend.

Sign up or log in to comment