/LaVague

Automate automation with Large Action Model framework

Primary LanguagePythonApache License 2.0Apache-2.0

Stargazers Issues Forks Contributors Apache License


LaVague Logo

Welcome to LaVague

Redefining internet surfing by transforming natural language instructions into seamless browser interactions.

πŸ„β€β™€οΈ See LaVague in Action

Here are examples to show how LaVague can execute natural instructions on a browser to automate interactions with a website:

LaVague Interaction Example LaVague interacting with Hugging Face's website.

LaVague Workflow Example LaVague interacting with the IRS's website.

🎯 Motivations

LaVague is designed to automate menial tasks on behalf of its users. Many of these tasks are repetitive, time-consuming, and require little to no cognitive effort. By automating these tasks, LaVague aims to free up time for more meaningful endeavors, allowing users to focus on what truly matters to them.

By providing an engine turning natural language queries into Selenium code, LaVague is designed to make it easy for users or other AIs to automate easily express web workflows and execute them on a browser.

One of the key usages we see is to automate tasks that are personal to users and require them to be logged in, for instance automating the process of paying bills, filling out forms or pulling data from specific websites.

LaVague is built on open-source projects and leverages open-sources models, either locally or remote, to ensure the transparency of the agent and ensures that it is aligned with users' interests.

✨ Features

  • Natural Language Processing: Understands instructions in natural language to perform browser interactions.
  • Selenium Integration: Seamlessly integrates with Selenium for automating web browsers.
  • Open-Source: Built on open-source projects such as transformers and llama-index, and leverages open-source models, either locally or remote, to ensure the transparency of the agent and ensures that it is aligned with users' interests.
  • Local models for privacy and control: Supports local models like Gemma-7b so that users can fully control their AI assistant and have privacy guarantees.
  • Advanced AI techniques: Uses a local embedding (bge-small-en-v1.5) first to perform RAG to extract the most relevant HTML pieces to feed the LLM answering the query, as directly dropping the full HTML code would not fit in context. Then leverages Few-shot learning and Chain of Thought to elicit the most relevant Selenium code to perform the action without having to finetune the LLM (Nous-Hermes-2-Mixtral-8x7B-DPO) for code generation.

πŸš€ Getting Started

You can try LaVague in the following Colab notebook:

Open In Colab

πŸ—ΊοΈ Roadmap

This is an early project but could grow to democratize transparent and aligned AI models to undertake actions for the sake of users on the internet.

We see the following key areas to explore:

  • Fine-tune local models like a gemma-7b-it to be expert in Text2Action
  • Improve retrieval to make sure only relevant pieces of code are used for code generation
  • Support other browser engines (playwright) or even other automation frameworks

Keep up to date with our project backlog here.

πŸ™‹ Contributing

We would love your help in making La Vague a reality.

Please check out our contributing guide to see how you can get involved!

If you are interested by this project, want to ask questions, contribute, or have proposals, please come on our Discord to chat!

Set up your dev environment

Install the chrome browser and driver on linux with bash install-dependencies.sh. You will need admin privileges if you're missing system dependencies.

Set up a development environment by running the following command in a virtual environment: pip install -e .[dev]