This library is a port of the Guidance library for Node.js. It allows you to generate text from templates using a Language Model (LLM) and an endpoint that can generate text from a prompt.
npm install @mikugg/guidance
You can use end OpenAI endpoint to generate text from templates. The template processor will generate text from the template and then use the generated text as a prompt to the OpenAI endpoint. The generated text will be appended to the template and the process will repeat until the stop condition is met.
For serving LLaMA or Mistral models, I recommend using Aphrodite Engine, since it has logit_bias
support.
import * as Guidance from '@mikugg/guidance';
const tokenizer = new Guidance.Tokenizer.LLaMATokenizer();
const generator = new Guidance.TokenGenerator.OpenAITokenGenerator({
apiKey: 'sk-EMPTY',
baseURL: 'http://localhost:2242/v1',
model: 'mistralai/Mistral-7B-v0.1',
});
const templateProcessor = new Guidance.Template.TemplateProcessor(tokenizer, generator);
let result = await templateProcessor.processTemplate(
`Common sense question and answer, with short answers
Question: What is your favorite food?
Answer: "Sushi."
Question: What is your favorite color?
Answer: "Blue."
Question: What is your favorite animal?
Answer: "{{GEN response stop=" }}"`,
new Map([])
).then((result) => {
console.log(result.entries()); // {"response": "Elephant."}
});
You can provide an array of options to select the next text. The TemplateProcessor will increase the probability of one of those options being selected by the LLM.
import * as Guidance from '@mikugg/guidance';
const tokenizer = new Guidance.Tokenizer.LLaMATokenizer();
const generator = new Guidance.TokenGenerator.OpenAITokenGenerator({
apiKey: 'sk-EMPTY',
baseURL: 'http://localhost:2242/v1',
model: 'mistralai/Mistral-7B-v0.1',
});
const templateProcessor = new Guidance.Template.TemplateProcessor(tokenizer, generator);
let result = await templateProcessor.processTemplate(
`RPG Game Character specification
{
"name": "{{name}}",
"job": "{{GEN job stop=",}}",
"armor": "{{SEL armor options=valid_armors}}",
"weapon": "{{SEL weapon options=valid_weapons}}",
"pants": "{{SEL pants options=valid_pants}}"
}`,
new Map<string, string[] | string>([
['name', 'Rudeus'],
['valid_armors', ['plate', 'leather']],
['valid_weapons', ["axe", "mace", "spear", "sword", "bow", "crossbow"]],
['valid_pants', ['leather_jacket', 'leather_shorts', 'hat']], // Should select leather_shorts
])
).then((result) => {
console.log(result.entries());
});
You can check more examples in the this file.