Skip to main content

OpenJarvis — modular AI assistant backend with composable intelligence primitives

Project description

OpenJarvis

Personal AI, On Personal Devices.

Project Docs Python License Discord X / Twitter


Documentation

Project Site

Leaderboard

Roadmap

Why OpenJarvis?

Personal AI agents are exploding in popularity, but nearly all of them still route intelligence through cloud APIs. Your "personal" AI continues to depend on someone else's server. At the same time, our Intelligence Per Watt research showed that local language models already handle 88.7% of single-turn chat and reasoning queries, with intelligence efficiency improving 5.3× from 2023 to 2025. The models and hardware are increasingly ready. What has been missing is the software stack to make local-first personal AI practical.

OpenJarvis is that stack. It is a framework for local-first personal AI, built around three core ideas: shared primitives for building on-device agents; evaluations that treat energy, FLOPs, latency, and dollar cost as first-class constraints alongside accuracy; and a learning loop that improves models using local trace data. The goal is simple: make it possible to build personal AI agents that run locally by default, calling the cloud only when truly necessary. OpenJarvis aims to be both a research platform and a production foundation for local AI, in the spirit of PyTorch.

Installation

curl -fsSL https://openjarvis.ai/install.sh | bash

That's it. The installer handles everything: uv, the Python venv, Ollama, and pulling a small starter model. About 3 minutes on a typical broadband connection. Then:

jarvis

The Rust extension and bigger models continue downloading in the background while you chat. Run jarvis doctor to see status.

Platforms: macOS (Intel + Apple Silicon), Linux, WSL2 on Windows.

Manual install / contributors: see docs/getting-started/install.md.

Quick Start

curl -fsSL https://openjarvis.ai/install.sh | bash
jarvis

jarvis init --preset <name> switches to a starter config. Available presets: morning-digest-mac, morning-digest-linux, morning-digest-minimal, deep-research, code-assistant, scheduled-monitor, chat-simple.

Starter Configs

Install any preset with one command:

uv run jarvis init --preset morning-digest-mac   # or any preset below

Prefix every jarvis ... invocation with uv run, or activate the venv first (source .venv/bin/activate) so plain jarvis ... works for the rest of your shell session.

Preset Use Case What it does
morning-digest-mac Daily Briefing (Mac) Spoken briefing from email, calendar, health, news with Jarvis voice
morning-digest-linux Daily Briefing (Linux) Same, with vLLM support for GPU servers
morning-digest-minimal Daily Briefing (minimal) Just Gmail + Calendar, runs on any machine
deep-research Research Assistant Multi-hop research across indexed docs with citations
code-assistant Code Companion Agent with code execution, file I/O, and shell access
scheduled-monitor Persistent Monitor Stateful agent that runs on a schedule with memory
chat-simple Simple Chat Lightweight conversation, no tools needed
# Example: Morning Digest on Mac
uv run jarvis init --preset morning-digest-mac
uv run jarvis connect gdrive          # one OAuth flow covers Gmail, Calendar, Tasks
uv run jarvis digest --fresh          # generate and play your first briefing

# Example: Deep Research
uv run jarvis init --preset deep-research
uv run jarvis memory index ./docs/    # requires the Rust extension — see Setup above
uv run jarvis ask "Summarize all emails about Project X"

Skills

Skills teach agents how to better use tools and improve their reasoning. Every skill is a tool — agents discover them from a catalog and invoke them on demand.

# Install skills from public sources
jarvis skill install hermes:arxiv
jarvis skill sync hermes --category research

# Use skills with any agent
jarvis ask "Use the code-explainer skill to explain this Python code: for i in range(5): print(i*2)"

# Optimize skills from your trace history
jarvis optimize skills --policy dspy

# Benchmark the impact
jarvis bench skills --max-samples 5 --seeds 42

Import from Hermes Agent (~150 skills), OpenClaw (~13,700 community skills), or any GitHub repo. Skills follow the agentskills.io open standard.

See the Skills User Guide and Skills Tutorial for details.

Built-in Agents

OpenJarvis ships with eight built-in agents across three execution modes (on-demand, scheduled, continuous):

Agent Type What it does
morning_digest Scheduled Daily briefing from email, calendar, health, news — with TTS audio
deep_research On-demand Multi-hop research with citations across web and local docs
monitor_operative Continuous Long-horizon monitoring with memory, compression, and retrieval
orchestrator On-demand Multi-turn reasoning with automatic tool selection
native_react On-demand ReAct (Thought-Action-Observation) loop agent
operative Continuous Persistent autonomous agent with state management
native_openhands On-demand CodeAct — generates and executes Python code
simple On-demand Single-turn chat, no tools

See the User Guide and Tutorials for detailed setup instructions.

Full documentation — including Docker deployment, cloud engines, development setup, and tutorials — at open-jarvis.github.io/OpenJarvis.

Community

Contributing

We welcome contributions! See the Contributing Guide for incentives, contribution types, and the PR process.

Quick start for contributors:

git clone https://github.com/open-jarvis/OpenJarvis.git
cd OpenJarvis
uv sync --extra dev
uv run pre-commit install
uv run pytest tests/ -v

Browse the Roadmap for areas where help is needed. Comment "take" on any issue to get auto-assigned.

About

OpenJarvis is part of Intelligence Per Watt, a research initiative studying the intelligence efficiency of AI systems. The project is developed at Hazy Research and the Scaling Intelligence Lab at Stanford SAIL.

Sponsors

Laude InstituteStanford MarloweGoogle Cloud PlatformLambda LabsOllamaIBM ResearchStanford HAI

Citation

@misc{saadfalcon2026openjarvispersonalaipersonal,
      title={OpenJarvis: Personal AI, On Personal Devices}, 
      author={Jon Saad-Falcon and Avanika Narayan and Robby Manihani and Tanvir Bhathal and Herumb Shandilya and Hakki Orhun Akengin and Gabriel Bo and Andrew Park and Matthew Hart and Caia Costello and Chuan Li and Christopher Ré and Azalia Mirhoseini},
      year={2026},
      eprint={2605.17172},
      archivePrefix={arXiv},
      primaryClass={cs.LG},
      url={https://arxiv.org/abs/2605.17172}, 
}

License

Apache 2.0

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

openjarvis-1.0.2.dev698.tar.gz (37.6 MB view details)

Uploaded Source

Built Distribution

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

openjarvis-1.0.2.dev698-py3-none-any.whl (1.8 MB view details)

Uploaded Python 3

File details

Details for the file openjarvis-1.0.2.dev698.tar.gz.

File metadata

  • Download URL: openjarvis-1.0.2.dev698.tar.gz
  • Upload date:
  • Size: 37.6 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.16 {"installer":{"name":"uv","version":"0.11.16","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for openjarvis-1.0.2.dev698.tar.gz
Algorithm Hash digest
SHA256 7fe8d25e604b45f28a8168b3afb842e3e63bb9c4a64a182eed9616a308831c26
MD5 2f7d087eb310562dd1500636c5a144cb
BLAKE2b-256 9451879276c11c6cb88cf7d36a32968eb563158e16f15c1f7cd576527508ec5c

See more details on using hashes here.

File details

Details for the file openjarvis-1.0.2.dev698-py3-none-any.whl.

File metadata

  • Download URL: openjarvis-1.0.2.dev698-py3-none-any.whl
  • Upload date:
  • Size: 1.8 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.16 {"installer":{"name":"uv","version":"0.11.16","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for openjarvis-1.0.2.dev698-py3-none-any.whl
Algorithm Hash digest
SHA256 9cd6fb52c3e871d98fc3a4856870c79d76385a5f0bd9c06d92252dbd8cc94d9f
MD5 94a00bbb3ab023c8f2117e5bb66ca3e8
BLAKE2b-256 7b2cd7155681873dd2f4cd814be93103fc9b122fb03d08970d5c5eb758d7ea7c

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