General AI Agent System
Project description
Ouro is derived from Ouroboros—the ancient symbol of a serpent consuming its own tail to form a perfect circle. It represents the ultimate cycle: a closed loop of self-consumption, constant renewal, and infinite iteration.
At Ouro AI Lab, this is our blueprint. We are building the next generation of AI agents capable of autonomous evolution—systems that learn from their own outputs, refine their own logic, and achieve a state of infinite self-improvement.
Installation
Prerequisites: Python 3.12+.
pip install ouro-ai
Or install from source (for development):
git clone https://github.com/ouro-ai-labs/ouro.git
cd ouro
./scripts/bootstrap.sh # requires uv
Quick Start
1. Configure Models
On first run, ~/.ouro/models.yaml is created with a template. Edit it to add your provider and API key:
models:
openai/gpt-4o:
api_key: sk-...
anthropic/claude-sonnet-4:
api_key: sk-ant-...
chatgpt/gpt-5.2-codex:
timeout: 600
ollama/llama2:
api_base: http://localhost:11434
default: openai/gpt-4o
current: openai/gpt-4o
For chatgpt/* subscription models, run ouro --login (or /login in interactive mode) and select provider before use.
OAuth models shown in /model are seeded from ouro's bundled catalog (synced from pi-ai openai-codex model list).
Maintainer note: refresh this catalog via python scripts/update_oauth_model_catalog.py.
Login uses a browser-based OAuth (PKCE) flow with a localhost callback server. If browser auto-open fails, ouro prints a URL you can open manually (for remote machines, SSH port-forwarding may be required).
Advanced OAuth overrides (rarely needed) are documented in docs/configuration.md.
See LiteLLM Providers for the full list.
2. Run
# Interactive mode
ouro
# Single task (returns raw result)
ouro --task "Calculate 123 * 456"
# Resume last session
ouro --resume
# Resume specific session (ID prefix)
ouro --resume a1b2c3d4
CLI Reference
| Flag | Short | Description |
|---|---|---|
--task TEXT |
-t |
Run a single task and exit |
--model ID |
-m |
LiteLLM model ID to use |
--resume [ID] |
-r |
Resume a session (latest if no ID given) |
--login |
- | Open OAuth provider selector and login |
--logout |
- | Open OAuth provider selector and logout |
--verify |
Enable self-verification (Ralph Loop) in --task mode |
|
--reasoning-effort LEVEL |
- | Set run-scoped reasoning effort (`default |
--verbose |
-v |
Enable verbose logging to ~/.ouro/logs/ |
Interactive Commands
Slash Commands
| Command | Description |
|---|---|
/help |
Show help |
/reset |
Clear conversation and start fresh |
/stats |
Show memory and token usage statistics |
/resume [id] |
List or resume a previous session |
/model |
Pick a model (arrow keys + Enter) |
/model edit |
Open ~/.ouro/models.yaml in editor (auto-reload on save) |
/login |
Open OAuth provider selector and login |
/logout |
Open OAuth provider selector and logout |
/theme |
Toggle dark/light theme |
/verbose |
Toggle thinking display |
/reasoning |
Open reasoning menu |
/compact |
Trigger memory compression and show token savings |
/exit |
Exit (also /quit) |
Keyboard Shortcuts
| Key | Action |
|---|---|
/ |
Command autocomplete |
Ctrl+C |
Graceful interrupt (cancels current operation, rolls back incomplete memory) |
Ctrl+L |
Clear screen |
Ctrl+T |
Toggle thinking display |
Ctrl+S |
Show quick stats |
| Up/Down | Navigate command history |
Features
- Unified agent loop: Think-Act-Observe cycle — planning, sub-agents, and tool use all happen in one loop, chosen autonomously by the agent
- Self-verification: Ralph Loop verifies the agent's answer against the original task and re-enters if incomplete (
--verify) - Parallel execution: Concurrent readonly tool calls in a single turn, plus
multi_taskfor spawning parallel sub-agents with dependency ordering - Memory system: LLM-driven compression (sliding window / selective / deletion), git-aware long-term memory, and YAML session persistence resumable via
--resume - OAuth login:
--login//loginto authenticate with ChatGPT Codex subscription models; bundled OAuth catalog auto-synced - TUI: Dark/light themes, slash-command autocomplete, live status bar, token & cache tracking (
/stats) - Skills: Extensible skill registry — list, install, and manage via
/skills - Benchmarks: First-class Harbor integration for agent evaluation (see Evaluation)
Evaluation
Ouro can be evaluated on agent benchmarks using Harbor. A convenience script harbor-run.sh is provided at the repo root:
- Edit
harbor-run.shto set your model, dataset, and ouro version. - Run:
export OURO_API_KEY=<your-api-key>
./harbor-run.sh # run with defaults in the script
./harbor-run.sh -l 5 # limit to 5 tasks
./harbor-run.sh --n-concurrent 4 # 4 parallel workers
Extra flags are forwarded to harbor run, so any Harbor CLI option works. See ouro_harbor/README.md for full details.
Configuration
See Configuration Guide for all settings.
Documentation
- Configuration -- model setup, runtime settings, custom endpoints
- Examples -- usage patterns and programmatic API
- Memory Management -- compression, persistence, token tracking
- Extending -- adding tools, agents, LLM providers
- Packaging -- building, publishing, Docker
Contributing
Contributions are welcome! Please open an issue or submit a pull request.
For development setup, see the Installation section (install from source).
License
MIT License
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file ouro_ai-0.2.4.tar.gz.
File metadata
- Download URL: ouro_ai-0.2.4.tar.gz
- Upload date:
- Size: 184.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
423c53f3d47f64713937e2f2bb29d73143e41095c89c8e9fff3c2b83299dfe03
|
|
| MD5 |
ef413bc149834ffdd4177bad86828cd4
|
|
| BLAKE2b-256 |
8c6c35b3caada610e06f8c7d0e24feaf525061ccba22f6c8bff48a2bf8b7b274
|
Provenance
The following attestation bundles were made for ouro_ai-0.2.4.tar.gz:
Publisher:
release.yml on ouro-ai-labs/ouro
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
ouro_ai-0.2.4.tar.gz -
Subject digest:
423c53f3d47f64713937e2f2bb29d73143e41095c89c8e9fff3c2b83299dfe03 - Sigstore transparency entry: 975524912
- Sigstore integration time:
-
Permalink:
ouro-ai-labs/ouro@080908106d7f3e1ac824a51e4b8932904c318e27 -
Branch / Tag:
refs/tags/v0.2.4 - Owner: https://github.com/ouro-ai-labs
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@080908106d7f3e1ac824a51e4b8932904c318e27 -
Trigger Event:
push
-
Statement type:
File details
Details for the file ouro_ai-0.2.4-py3-none-any.whl.
File metadata
- Download URL: ouro_ai-0.2.4-py3-none-any.whl
- Upload date:
- Size: 168.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8e593a2562aaab986e15dfaa701fbacf0148bc405518beb2ca3633d607d66012
|
|
| MD5 |
b4ee17eb94bb95c7b5e315d236410845
|
|
| BLAKE2b-256 |
d3b08b4720629c3b6834ee16a574901b720469cd9ad525b36bad39555983f2e4
|
Provenance
The following attestation bundles were made for ouro_ai-0.2.4-py3-none-any.whl:
Publisher:
release.yml on ouro-ai-labs/ouro
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
ouro_ai-0.2.4-py3-none-any.whl -
Subject digest:
8e593a2562aaab986e15dfaa701fbacf0148bc405518beb2ca3633d607d66012 - Sigstore transparency entry: 975524914
- Sigstore integration time:
-
Permalink:
ouro-ai-labs/ouro@080908106d7f3e1ac824a51e4b8932904c318e27 -
Branch / Tag:
refs/tags/v0.2.4 - Owner: https://github.com/ouro-ai-labs
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@080908106d7f3e1ac824a51e4b8932904c318e27 -
Trigger Event:
push
-
Statement type: