A way to use npcsh
Project description
npcsh
Welcome to npcsh, the shell for interacting with NPCs (LLM-powered AI agents). npcsh is meant to be a drop-in replacement shell for any kind of bash/zsh/powershell and allows the user to directly operate their machine through the use of the LLM-powered shell.
Additionally, npcsh introduces a new paradigm of programming for LLMs: npcsh allows users to set up NPC profiles (a la npc_profile.npc) where a user sets the primary directive of the NPC, the tools they want the NPC to use, and other properties of the NPC. NPCs can interact with each other and their primary directives and properties make these relationships explicit through jinja references.
compilation
Each NPC can be compiled to accomplish their primary directive and then any issues faced will be recorded and associated with the NPC so that it can reference it later through vector search. In any of the modes where a user requests input from an NPC, the NPC will include RAG search results before carrying out the request.
Base npcsh
In the base npcsh shell, inputs are processed by an LLM. The LLM first determines what kind of a request the user is making and decides which of the available tools or modes will best enable it to accomplish the request.
spool mode
Spool mode allows the users to have threaded conversations in the shell, i.e. conversations where context is retained over the course of several turns.
Users can speak with specific NPCs in spool mode by doing /spool <npc_name>
and can exit spool mode by doing /exit
.
Built-in NPCs
Built-in NPCs are NPCs that should offer broad utility to the user and allow them to create more complicated NPCs. These built-in NPCs facilitate the carrying out of many common data processing tasks as well as the ability to run commands and to execute and test programs.
Bash NPC
The bash NPC is an NPC focused on running bash commands and scripts. The bash NPC can be used to run bash commands and the user can converse with the bash NPC by doing /spool bash
to interrogate it about the commands it has run and the output it has produced.
A user can enter bash mode by typing /bash
and can exit bash mode by typing /bq
.
Use the Bash NPC in the profiles of other NPCs by referencing it like {{bash}}
.
Command NPC
The LLM or specific NPC will take the user's request and try to write a command or a script to accomplish the task and then attempt to run it and to tweak it until it works or it's exceeded the number of retries (default=5).
Use the Command NPC by typing /cmd <command>
. Chat with the Command NPC in spool mode by typing /spool cmd
.
Use the Command NPC in the profiles of other NPCs by referencing it like {{cmd}}
.
observation mode
Users can create schemas for recording observations. The idea here is to more easily facilitate the recording of data for individuals in essentially any realm (e.g. recipe testing, one's own blood pressure or weight, books read, movies watched, daily mood, etc.) without needing to use a tangled web of applications to do so. Observations can be referenced by the generic npcsh LLM shell or by specific NPCs.
Use the Observation NPC by typing /obs <observation>
.
Chat with the Observation NPC in spool mode by typing /spool obs
.
Use the Observation NPC in the profiles of other NPCs by referencing it like {{obs}}
.
question mode
The user can submit a 1-shot question to a general LLM or to a specific NPC.
Use it like
/question <question> <npc_name>
or
/question <question>
You can also chat with the Question NPC in spool mode by typing /spool question
.
thought mode
This will be like a way to write out some general thoughts to get some 1-shot feedback from a general LLM or a specific NPC.
Use it like
/thought <thought> <npc_name>
or
/thought <thought>
You can also chat with the Thought NPC in spool mode by typing /spool thought
.
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
File details
Details for the file npcsh-0.1.0.tar.gz
.
File metadata
- Download URL: npcsh-0.1.0.tar.gz
- Upload date:
- Size: 12.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.9.20
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | eca64b21b387a8552cec01b1592ca8fc2ff734a01e821c523b577e80e91497e1 |
|
MD5 | 75b20d098c72ec4f801dbd8f03e8813a |
|
BLAKE2b-256 | 360e02a343675fcae6a287bf1fbc7a23c32b2c3f315d959575de0e779e7ec5c5 |
File details
Details for the file npcsh-0.1.0-py3-none-any.whl
.
File metadata
- Download URL: npcsh-0.1.0-py3-none-any.whl
- Upload date:
- Size: 12.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.9.20
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | f3cf0ba03a756da0a263c602f9e0cc4b061d48693973e7c545b85f03b715fdff |
|
MD5 | 44e7437391903cce3ceb2af532765c78 |
|
BLAKE2b-256 | 5cf52ddcbe11865c01883efe0b629539c8a91123eadd095b99a0ebea746cc7d8 |