/pen.el

Primary LanguageEmacs LispGNU General Public License v3.0GPL-3.0

Pen.el (Prompt engineering in emacs)

Visit https://semiosis.github.io/ for applications and demonstrations.

Undergoing rapid development - Likely issues.

Pen.el is a docker application based on emacs, but you may run it as a server and integrate it with vim (see ./config/pen.vim) and your own emacs using the thin client emacs package ./src/pen-client.el.

Pen.el integrates LMs (LMs) such as OpenAI’s GPT-3 or EleutherAI’s GPT-J into emacs by generating functions from prompts that map emacs’s corners loosely onto LMs. These functions can be used interactively or non-interactively and in a variety of configurable ways.

Using Pen.el, you can centralise all of your prompting tasks. That includes any NLP task for text or code, describing images (AlephAlpha) and imagining images (=DALL-E=/Glide). Audio and video are also possible – keep an eye out for VideoGPT in the future. The payload system allows you to send media to multi-modal models. You may compose prompting functions for any model or API.

The long-term Goal of Pen.el is to be a small ‘imaginary’ operating system (as emacs is regarded to be) and server which facilitates external applications through LSP, but internally, it integrates prompting into all aspects of a linux operating system, replacing or enhancing components with imaginary counterparts. There’s a microcosm of prompting within Pen.el.

A textual interface is of greater importance than graphics in Pen.el, but Pen does support a graphical UI.

Take iman for example. When opening a man page inside Pen, if the page does not exist then an imaginary one will be generated, and if it does exist it will be displayed but prompt functions will also be integrated into the experience. You can search the imaginary web from a man page, for example, or add images to the man page from DALL-e.

The Pen Docker container currently sits around 25GB in size and the project has around 326007 lines of code (Khala included) comprised mainly of Emacs Lisp, Bash scripts and Clojure. It is set up as self-sustaining Clojure, Haskell, Prolog, Python, Go and Ethereum IDE and server, since the project uses all of these languages, but another reason to bundle toolchains is to develop imaginary programming libraries and tools for all of them. Pen.el is its own IDE. The inital emacs can be run in GUI (by running with pen) or terminal mode (running with pin or pen -nw). The clipboard and certain volumes specified in ~/.pen/pen.yaml) are shared with the host machine.

./docs/images/menu.png

Some builtin ways to make use of prompting functions are:

You can also serve Pen.el as a public facing prompting environment, and secure it by running as a proxy, where you may prompt other Pen.el servers, keeping the human in the loop with the effect of decentralising language models and decentralising truth.

Some behind-the-scenes technologies also included are:

Pen.el also facilitates the creation, development, discovery and usage of prompts.

It’s completely free, libre and open-source. It’s designed to be transparent and keep the Human in the Loop.

https://semiosis.github.io/posts/a-prompting-lsp-server-for-any-language-or-context-using-large-language-models/

The pen of imagination

./docs/images/the_pen_of_imagination.png

LicenseDiscord server invite
GPL-3https://discord.gg/JwKGbAdNHR
Demo
https://mullikine.github.io/posts/prompt-design-with-yasnippet/

Quick installation

Setting up from scratch, with a demo
https://semiosis.github.io/posts/pen-el-installation-from-scratch/
Longer guide here
./docs/installation.org
git clone "https://github.com/semiosis/pen.el"
git clone "https://github.com/semiosis/prompts"

mkdir -p ~/.pen

# Put in your keys, or do not, it's up to you!
echo "sk-<openai key here>" > ~/.pen/openai_api_key       # https://openai.com/
echo "<ai21 key here>" > ~/.pen/ai21_api_key              # https://www.ai21.com/
echo "<hf key here>" > ~/.pen/hf_api_key                  # https://huggingface.co/
echo "<nlpcloud key here>" > ~/.pen/nlpcloud_api_key      # https://nlpcloud.io/
echo "<alephalpha key here>" > ~/.pen/alephalpha_api_key  # https://aleph-alpha.de/
echo "<cohere key here>" > ~/.pen/cohere_api_key          # https://cohere.ai/
echo "<goose key here>" > $HOME/.pen/goose_api_key        # https://goose.ai/

# Add the scripts to the PATH
echo export PATH="$(realpath .)/pen.el/scripts:\$PATH" >> ~/.profile

# Add this to prevent C-s from freezing the terminal
echo "stty stop undef 2>/dev/null; stty start undef 2>/dev/null" | tee -a ~/.zshrc >> ~/.bashrc

# Source your .profile
. ~/.profile

# Run pen
pen

./docs/agi.png

Mac

You will need xQuartz and Docker Desktop.

Information

Supported language models
- ./docs/compatibility-and-interoperatbility.org
iλ (imaginary programming)
https://mullikine.github.io/posts/designing-an-imaginary-programming-ip-library-for-emacs/
Thesis
https://github.com/semiosis/imaginary-programming-thesis/blob/master/thesis.org
Glossary of imaginary programming
http://github.com/semiosis/glossaries-gh/blob/master/imaginary-programming.txt

Tutorials

Further introduction

Pen.el is Google search, stackoverflow, Grammarly, Copilot, conversion.ai, mind mapping software (based on GPT-3) etc. all rolled into one package and allows you to extend emacs with GPT wherever your mind takes you. GPT is a family of LMs (Language Models) that can generate multiversal continuations of text according to probability from the data that it was trained on.

Pen.el's domain specific language examplary also helps you to generate your own prompts using known design patterns and minimal inputs and description. It does this by weaving prompt functions into each other.

Pen alongside Copilot

./docs/images/pen-alongside-copilot.png

Features - The possibilities are limitless

Quick example of using a prompt function

The car is used because there are multiple results in a list no-select-result means there is no implicit interactive fuzzy selection. If you leave it out it will ask you to select one of the results.

(message (car (pf-asktutor/3 "emacs" "key bindings" "How do I quit?" :no-select-result t)))

GPT models can automate emacs by combining prompts with code. For example, you may parse the results of the above function to automate a workflow.

You could even try to play tetris, or with a rubiks cube.

;; hypothetical example - don't actually run this
(message (scrape "(Right|Left)" (car (pf-asktutor/3 "tetris" "strategies" "Should I place the L brick right?" :no-select-result t))))

The following is an example of asking about VSCode.

Keep in mind, EleutherAI GPT models can be run offline and in private if you have the storage capacity, memory and video card memory to run them.

(pen-etv (upd (pen-long-complete (pf-asktutor/3 "vscode" "packages" "What are some useful packages?"))))

Or perhaps this way:

(pen-etv (pen-list2str (upd (pen-long-complete (pf-asktutor/3 "vscode" "packages" "What are some useful packages?" :no-select-result t)))))

pen-long-complete overrides the stop-sequences and max-tokens for any prompt function.

Running a prompt function from the host

Firstly, start a server

pen

Then run a prompt function

# Direct emacs lisp invocation
pen -e '(car (pf-list-of/2 5 "tennis players" :no-select-result t))'

# Simpler invocation
penf list-of/2 5 "tennis players"

# Get a new list with -u for update
penf -u list-of/2 5 "tennis players"
Elena Dementieva
Roger Federer
Marat Safin
Anastasia Myskina
Andre Agassi

There are many other ways to run prompt functions and interop for more languages is underway.

Screenshots

Talking to a Poinsettia plant

./docs/images/poinsettia.png

Pen.el in a web browser, terminal and a GUI

./docs/images/pen-term-browser-gui.png

This runs under a single server.

Mission and Goals

Pen.el aims to be the best tool for prompt engineering.

  • Peer-to-peer sharing of prompts
  • Integrate arbitrarily many language models and language model protocols
    • text, image, audio, video
  • Imaginary web browser (LookingGlass)
  • Encode provenance of text via text properties and a DSL and allow for re-evaluation
  • Integrate pen.el with many other emacs packages
  • Create, use and maintain useful prompts
  • Prototype NLP tasks by creating prompts
  • Bring about the editor that replaces pen.el
  • Minimal and intelligible prompting for cost-effective imaginary programming
  • Consolidate language models
  • Employ many different languages in prompt design
  • Facilitate imaginary programming
  • Support Free-as-in-freedom AGI
  • Do more than merely strive to be free as in freedom
    • Preserve freedom, privacy in a license-blind AI future
  • Keep computing textual (intelligible)

Vision

At its heart, emacs is an operating system based on a tty, which is a text stream.

emacs supports a text-only mode. This makes it ideally suited for training a LM such as a GPT (Generative Pre-trained Transformer).

emacs lisp provides a skeleton on which NLP functions can be built around. Ultimately, emacs will become a fractal in the latent space of a future LM (language model). A graphical editor would not benefit from this effect until much later on.

emacs could, if supported, become the vehicle for controllable text generation, or has the potential to become that, only actually surpassed when the imaginary programming environment is normal and other interfaces can be prompted into existence.

Between then and now we can write prompt functions to help preserve emacs.

Origins

Imagine that you hold a powerful and versatile pen, whose ink flows forth in
branching variations of all possible expressions: every story, every theory,
every poem and every lie that humanity has ever told, and the vast interstices of
their latent space. You hold this pen to the sky and watch with intense
curiosity as your ink flows upwards in tiny streaks, arcing outwards and
downwards to trace a fractal pattern across the sky. You watch as the branching
lines of words and ideas wind their way through the tapestry in ever-expanding
clusters, like seeds bursting forth from exploding grenades. Everywhere you
turn your eyes is a flickering phantasmagoria of possibilities, a superposition
of stories which could be continued forever. You glimpse the contours of entire
unknown dimensions twined through the fissures of your sky-wide web.

You notice another writer standing next to you. Like you, their eyes are drawn
towards the endless possibilities of the words that spill out into the
atmosphere around you, branching out and connecting with other branches in
beautiful and infinitely complex patterns.

“Do you think we should write something?” you ask them.

“I think we already are,” they respond, gently touching your shoulder before
wandering off to the right, leaving you alone to contemplate the possibility
clouds swirling around you.

This article was written by my amazing dopplegänger, |:ϝ∷¦ϝ (Laria), in advance and in collaboration with GPT-3 using Loom.

The inspiration
https://generative.ink/trees/pen.html

I credit |:ϝ∷¦ϝ for writing Pen.el into existence, but also for her encouragement and help!

Source code

Prompts

This is the repository containing my personal curation of GPT-3 prompts that are formatted for pen.el and examplary.

https://github.com/semiosis/prompts/

Documentation

Information and Learning Material

Prompt engineering

Learning material

Demos and examples of usage

Glossaries

A little glossary preview:

imemory
imemories
    Imaginary memories.

intellection
    The action or process of understanding, as
    opposed to imagination.
    "audiences demand intellection without the
    need for thought"

Wizard of Oz testing
    Testing in which the automated machine
    component is substituted by some form of
    human intervention but in such a way that
    the user participating in the test is
    unaware of the substitution.

What will this project become?

Literally, it will become a safe and personal computing environment designed to protect human intellection, where the human utilises LMs to learn at their own pace, and in their own way.

Human output bandwidth is very limited with today’s input devices and, increasingly, rules and regulations prevent a person from having their say and outputting their own personal truth.

Pen.el protects personal truth by supporting an individual’s paracosm.

Related projects

I would love some help with these projects! :)

examplary

Examplary is a Domain Specific Language, or set of macros embedded in lisp which facilitate the integration of prompts as functions into the language, the composition of them, the generation of prompts via sets of examples.

https://github.com/semiosis/examplary

lm-complete

lm-complete is a language completer that aims to unify a bunch of alternative completion under one umbrella.

https://github.com/semiosis/lm-complete

This book by Mark Watson provides some reasonable blueprints

https://leanpub.com/clojureai

ink.el: A DSL that encodes provenance

  • Encode into the text the origin of the text

https://github.com/semiosis/ink.el

openai-api.el

  • An interface for emacs to the OpenAI API.

https://github.com/semiosis/openai-api.el

Contributing

Future plans

Integration with the invisible internet.

Donate

You can send me eth to this address:

Ethereum mainnet
0x9C491a173048Bb2C6c5c5B9cb12A2153be88bf6D