Metadata-Version: 2.4
Name: just-agents-core
Version: 0.8.5
Summary: Just Agents - Base Package
License: MIT
Keywords: python,llm,science,review,agents,AI,longevity,biology,coding,web,tools,router
Author: Alex Karmazin
Author-email: karmazinalex@gmail.com
Maintainer: Anton Kulaga
Maintainer-email: antonkulaga@gmail.com
Requires-Python: >=3.10,<3.15
Classifier: Development Status :: 2 - Pre-Alpha
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: MacOS :: MacOS X
Classifier: Operating System :: Microsoft :: Windows
Classifier: Operating System :: Unix
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Programming Language :: Python :: 3.13
Classifier: Programming Language :: Python :: 3.14
Requires-Dist: docstring_parser (>=0.16)
Requires-Dist: litellm (>=1.72.1)
Requires-Dist: mcp (>=1.9.2)
Requires-Dist: pydantic (>=2.0.0,<3.0.0)
Requires-Dist: python-dotenv (>=1.1.0)
Requires-Dist: rich (>=14.0.0)
Project-URL: Bug Tracker, https://github.com/longevity-genie/just-agents/issues
Project-URL: Documentation, https://just-agents.readthedocs.io/
Project-URL: Homepage, https://github.com/longevity-genie/just-agents
Description-Content-Type: text/markdown

# just-agents-core

A lightweight, straightforward core library for LLM agents - no over-engineering, just simplicity!

## 🎯 Core Features
- 🪶 Lightweight and simple implementation
- 📝 Easy-to-understand agent interactions
- 🔧 Customizable prompts using YAML files
- 🤖 Support for various LLM models through litellm, including DeepSeek R1 and OpenAI o3-mini
- 🔄 Chain of Thought reasoning with function calls

## 🚀 Installation

```bash
pip install just-agents-core
```

## 🏗️ Core Components

### BaseAgent
A thin wrapper around litellm for basic LLM interactions. Provides:
- Simple prompt management
- Direct LLM communication
- Memory handling

### ChatAgent
The fundamental building block for agent interactions. Here's an example of using multiple chat agents:

```python
from just_agents.base_agent import ChatAgent
from just_agents.llm_options import LLAMA4_SCOUT

# Initialize agents with different roles
harris = ChatAgent(
    llm_options=LLAMA4_SCOUT, 
    role="You are Kamala Harris in a presidential debate",
    goal="Win the debate with clear, concise responses",
    task="Respond briefly and effectively to debate questions"
)

trump = ChatAgent(
    llm_options=LLAMA4_SCOUT,
    role="You are Donald Trump in a presidential debate",
    goal="Win the debate with your signature style",
    task="Respond briefly and effectively to debate questions"
)

moderator = ChatAgent(
    llm_options={
        "model": "groq/meta-llama/llama-4-maverick-17b-128e-instruct",
        "temperature": 0.0
    },
    role="You are a neutral debate moderator",
    goal="Ensure a fair and focused debate",
    task="Generate clear, specific questions about key political issues"
)
```

### ChainOfThoughtAgent
Extended agent with reasoning capabilities and function calling:

```python
from just_agents.patterns.chain_of_throught import ChainOfThoughtAgent
from just_agents import llm_options

def count_letters(character: str, word: str) -> str:
    """ Returns the number of character occurrences in the word. """
    count = word.count(character)
    return str(count)

# Initialize agent with tools and LLM options
agent = ChainOfThoughtAgent(
    tools=[count_letters],
    llm_options=llm_options.LLAMA4_SCOUT
)

# Get result and reasoning chain
result, chain = agent.think("Count the number of occurrences of the letter 'L' in 'HELLO'.")
```

## 📚 Motivation

Most existing agentic libraries are over-engineered, either directly or by using complex libraries under the hood. 
In reality, interactions with LLMs are mostly about strings, and you can create templates using f-strings and Python's 
native string templates.

It's easier to reason about code when you separate prompting from Python code into easily readable files (like YAML files).
This library was created to provide a controlled, simple approach to LLM agent development without unnecessary complexity.

## 📦 Structure
The just-agents-core package provides the fundamental building blocks for LLM agents. For additional functionality:

- `just_agents_coding`: For code execution in sandboxed environments
- `just_agents_tools`: Additional tools like web search capabilities
- `just_agents_web`: For serving agents as OpenAI-compatible REST API endpoints

For full usage examples and documentation, please refer to the [main repository](https://github.com/longevity-genie/just-agents).

