Skip to main content

Minimalist Python framework for AI agents logic-only coding with streaming, tool calls, and multi-LLM provider support

Project description

open-taranis

Minimalist Python framework for AI agents logic-only coding with streaming, tool calls, and multi-LLM provider support.

Installation

pip install open-taranis --upgrade

Quick Start

import open_taranis as T

client = T.clients.openrouter("api_key")

messages = [
    T.create_user_prompt("Tell me about yourself")
]

stream = T.clients.openrouter_request(
    client=client,
    messages=messages,
    model="mistralai/mistral-7b-instruct:free", 
)

print("assistant : ",end="")
for token, tool, tool_bool in T.handle_streaming(stream) : 
    if token :
        print(token, end="")

To create a simple display using gradio as backend :

import open_taranis as T
import open_taranis.web_front as W

W.gr.ChatInterface(
    fn=W.chat_fn_gradio(
    client=T.clients.openrouter(api_key="api_key"),
    request=T.clients.openrouter_request,
    model="mistralai/mistral-7b-instruct:free",
    _system_prompt=""
).create_fn(),
    title="web front"
).launch()

Documentation :

Roadmap

  • v0.0.1: start
  • v0.0.x: Add and confirm other API providers (in the cloud, not locally)
  • v0.1.x: Functionality verifications in examples
  • > v0.2.0: Add features for logic-only coding approach
  • v0.6.x: Add llama.cpp as backend in addition to APIs
  • v0.7.x: Add reverse proxy + server to create a dedicated full relay/backend (like OpenRouter), framework usable as server and client
  • v0.8.x: Add PyTorch as backend with transformers to deploy a remote server
  • v0.9.x: Total reduction of dependencies for built-in functions (unless counter-optimizations)
  • v1.0.0: First complete version in Python without dependencies

Changelog

  • v0.0.4 : Add xai and groq provider
  • v0.0.6 : Add huggingface provider and args for clients.veniceai_request
  • v0.1.0 : Start the docs, add update-checker and preparing for the continuation of the project...
  • v0.1.1 : Code to deploy a frontend with gradio added (no complex logic at the moment, ex: tool_calls)
  • v0.1.2 : Fixed a display bug in the web_front and experimentally added ollama as a backend
  • v0.1.3 : Fixed the memory reset in the web_front and remove ollama module for openai front (work 100 times better)

Advanced Examples

Links

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

open_taranis-0.1.3.tar.gz (20.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

open_taranis-0.1.3-py3-none-any.whl (19.5 kB view details)

Uploaded Python 3

File details

Details for the file open_taranis-0.1.3.tar.gz.

File metadata

  • Download URL: open_taranis-0.1.3.tar.gz
  • Upload date:
  • Size: 20.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.12

File hashes

Hashes for open_taranis-0.1.3.tar.gz
Algorithm Hash digest
SHA256 1e3675e19c3522e06ff2f1bd27e5bfb5ad8b727b534cee591f1351fb93b6c2d9
MD5 668d11a819a86760a82f2a82e5a4a801
BLAKE2b-256 8474f243deeafbad81849b57addf83320ccc3ca076cc01588a7d0301d80059e4

See more details on using hashes here.

File details

Details for the file open_taranis-0.1.3-py3-none-any.whl.

File metadata

  • Download URL: open_taranis-0.1.3-py3-none-any.whl
  • Upload date:
  • Size: 19.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.12

File hashes

Hashes for open_taranis-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 a2b9ad2f695079d8c91ce2ea1950a2d25c70bc26d4cbee65670872d25b44a38b
MD5 7378c0b1f235eeda4901000b651fecce
BLAKE2b-256 7444050ad16e3bb3ccd9fa2138181c098f7f4a389bca72d2dac24667993fc3d9

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page