Skip to content

Universal-Code-Modules/universal-llm

Repository files navigation

Universal LLM

This module should manage interactions with AI language models. For starters: Openai, Huggingface, Ollama and Elevenlabs.

Requirements

Install ffmpeg for audio and video processing.

npm install

LLM

Openai - there is the connector class managing many kinds of interactions with the Openai API, mostly self explanatory. I will add image generations in the nearest future. You should have an openai account and the API key in .env file.

Huggingface - there is the connector class managing many kinds of interactions with the Huggingface API to multiple open-source LLMs, mostly self explanatory. You should obtain Hugginface token and place it in .env file. To compare manually performance and quality of open source models in parallel you can use lmsys.org.

Ollama - there is the connector class managing many kinds of interactions with multiple local LLMs. You should install Ollama on your local machine to use this module. Then run following commands (with your preferred model - in this case llama2):

ollama serve
ollama run llama2

Elevenlabs - one of the most popular speech-to-text services. There is the connector class managing many kinds of interactions with the Elevenlabs API, mostly self explanatory. You should obtain Elevenlabs API key and place it in .env file.

Testing

Running for all tests:

npm t

Running for single test file with environments file:

node --env-file=.env --test 'test/openai.js'

Running for single test in a test file:

node --env-file=.env --test --test-name-pattern="/Text completion/" 'test/openai.js'

Usage

OpenAi Example

'use strict';

const { openai } = require('./lib');

const { Chat } = openai;

const chat = new Chat({ apiKey: process.env.OPENAI_API_KEY });

(async () => {
  const msg = await chat.message({ text: 'Hello!' });
  console.log({ msg });
})();

Use common.callAPI universal method to call API endpoints in modules.

If LOG_API_CALL_TIME config variable is set to true, each method should measure and print the each API call time.

If LOG_API_CALL_RESULT config variable is set to true, each method should print the full api responce to pick required portion of data to return from a method.

Diagnostics

I would like to use Clinic.js for diagnostics, but we may set other systems in parrallel. To use it, you should install it globally with npm install -g clinic and then run it with clinic doctor command. Read more and check examples.

npm install -g clinic
npm install -g autocannon
clinic doctor -- node server.js

Deployment

A user peak a required module folder (the folder should contain all the necessary files, except utilities.js in the root). The functionality of a module should be tested on the local machine and then deployed to the cloud. A user should manually peak and install the module dependencies from the package.json.

Contributing

Anyone is welcome to contribute to the project. The project is open for the public and I would like to keep it that way. Peak a module you see a potential in and start working on it.

TODO list

  • Make LLM to be separate subrepository, with all dependencies and tests.
  • Write tests for openaAI assisitants
  • Finish Huggingface module and write tests
  • Add price calculation for all methods that return usage statistics
  • Add price estimation function for all methods, that do not return usage statistics
  • Add "my_" prefix to all generated dusting tests files, so git will ignore them
  • Make frontend allowing to interact with multiple LLMs in parralel and compare output
  • Connect the frontend to openai, huggingface and ollama modules
  • Make frontend to visualise dialogues and all other interactions with LLMs
  • Allow dynamic API_KEY definition (stored on frontend side)

To be continued...

About

Universal LLM connectors

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 3

  •  
  •  
  •