Skip to content

Web & CLI capable LLM agent (research prototype, no framework dependencies).

License

Notifications You must be signed in to change notification settings

kir-gadjello/picoagent-rnd

Repository files navigation

Picoagent-RnD

Web & CLI capable LLM agent (very early research prototype). Fresh implementation that does not rely on and isn't constrained by legacy frameworks.

Note: Once the code stabilizes, the "-RnD" suffix will be removed.

Motivation

I believe that LLM agents have massive long-term potential. It appears that contexts arising from agentic usecases remain challenging for even the most intelligent chat-tuned LLMs, but this will improve over time as new open and private models, datasets, agent engines, and training regimens become available, as seen recently with SWE-Bench. In terms of the Gartner cycle, we are still climbing out of the Trough of Disillusionment that followed the early 2023 bubble, but this sentiment is already out of date.

The aim of this project is to explore the solution space of a "second generation" agent engine which synergizes well (via specialized prompts, agent loop hyperparams and finetunes) with the empirically observed cognitive profile of the best available open-weights LLMs, to demonstrate good (or at least significantly superior, compared to the first generation) performance on a diverse set of outcome-oriented tasks, some of which are:

  • using cli to manipulate data and run programs
  • debugging failing programs in the context of a git repo with tests
  • basic project-level software development, i.e. SWE-bench-lite
  • basic web browsing, i.e. searching for useful github projects and tools according to fine-grained user requirements
  • question answering over unstructured data directories and databases

Project desiderata

Stage 0: Proof-of-Concept

  1. A showcase of 0-shot agentic capability of modern LLMs like Llama3 8B & 70B.
  2. 0-shot tool use with several non-toy usecases
  3. Basic ReAct-like agentic loop with optional basic critic
  4. (A11y+OCR)-based web agent scaffolding
  5. Adaptive context length management a-la MemGPT: log & web page summarization
  6. Realistic VibeEval-like evals for terminal & basic web tasks

Stage 1: Pushing the envelope

  1. Evals stressing foundational agent capabilities, such as effective context size and robustness to lost-in-the-middle failure modes, ICL-RL etc
  2. Advanced scaffolding and optimized toolkit + function calling format
  3. Episodic memory (better than MemGPT)
  4. Episodic RL (effective [👍,👎] without backprop)
  5. Adaptive computation effort
  6. Advanced critic, offline batch self-criticism
  7. Agentic finetune & dataset...
  8. Nontrivial SWE-bench score with the same general purpose agent engine

Current state and recommendations

Architecture

The current agent demo uses a ReAct-like interaction template with inner monologue and JSON grammar to implement function calling. Available tools are defined in tool_defs.py and get automatically converted into LLM prompt specifications and JSON schemas for the llama.cpp grammar engine. Even in this very simple configuration the agent is capable of chaining diverse behaviors, as examples show.

LLM requirements

Use of a self-hosted or OpenAI-like API (GROQ, Together) with a recently released strong chat LLM is recommended. Main LLMs I use developing this project are 8B and 70B variants of Meta's Llama-3-Instruct via local llama.cpp.

Currently, the 0-shot function calling framework heavily relies on JSON grammar feature of llama.cpp; I intend to relax this requirement in the future.

I aim to make all Stage 0 and as much of Stage 1 project features as possible supported with Llama-3-70B-Instruct (even quantized to fit in a single 24GiB GPU), with the rest of the features requiring no more than a special finetune of the same 70B model.

Install

Currently you can start working with the project by cloning this git repo and creating a python virtual environment (venv, pyenv, conda) and installing the dependencies (soon: running inside docker environment): pip install -r requirements.txt'

Configuration

The agent can be configured via environment variables, command line arguments or a YAML configuration file. The configuration file will be looked for in the following locations (in order):

  1. picoagent.yaml in the current directory
  2. ~/.picoagent.yaml in user's home directory
  3. ~/.config/picoagent.yaml in user's config directory

Example configuration file for Openrouter :

api_base: "https://openrouter.ai/api/v1"        # LLM API endpoint
api_key: "sk-or-v1-xxxxxxxxxxxxxxxxxxxxxxxxxx"  # API key if required
api_model: "deepseek/deepseek-chat"             # Model identifier

Command line arguments will override any values from the config file.

Make sure you have valid OPENAI_API_BASE and OPENAI_API_KEY environment variables pointing to a working LLM backend, if not using a config file. For now the recommended inference engine is llama.cpp and the tested LLM checkpoint is Meta-Llama-3-70B-Instruct-IQ2_XS.gguf.

Examples

Using openrouter with deepseek-2.5 LLM:

CLI chat-style invocations of the current basic agent demo:

  • python main.py -v "browse HN and tell me the most salient AI/LLM stories of today"
  • python main.py -v "find a ready to use github repo implementing suffix trees in python"
  • python main.py -v "write and run a basic python http api with helloworld endpoint"
  • python main.py -v "help me answer questions about my obsidian vault located at <...>"

Source code licensing, etc

Picoagent uses some basic functions from MemGPT project, where the author is a minor contributor (thanks btw!) - these parts of source code inherit the MemGPT license. The license for the code written by Kirill Gadjello in this project is GPLv3, as included in LICENSE file (mostly to encourage the occasional hacker to share prompts & hyperparameters, which is important for the LLM agent craft).

I plan to rewrite the useful part of said functions once it becomes apparent that this project is about to exit the experimentation phase.

Honorable mentions

A necessarily incomplete and in-flux list of projects that influenced me:

Projects

Research

About

Web & CLI capable LLM agent (research prototype, no framework dependencies).

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages