UNPKG

@wavequery/conductor

Version:
93 lines (91 loc) 3.56 kB
"use strict"; var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { if (k2 === undefined) k2 = k; var desc = Object.getOwnPropertyDescriptor(m, k); if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { desc = { enumerable: true, get: function() { return m[k]; } }; } Object.defineProperty(o, k2, desc); }) : (function(o, m, k, k2) { if (k2 === undefined) k2 = k; o[k2] = m[k]; })); var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { Object.defineProperty(o, "default", { enumerable: true, value: v }); }) : function(o, v) { o["default"] = v; }); var __importStar = (this && this.__importStar) || function (mod) { if (mod && mod.__esModule) return mod; var result = {}; if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); __setModuleDefault(result, mod); return result; }; Object.defineProperty(exports, "__esModule", { value: true }); exports.HuggingFaceProvider = void 0; class HuggingFaceProvider { constructor(config) { this.pipeline = null; this.model = config.model; } async ensurePipeline() { if (!this.pipeline) { const transformers = await Promise.resolve().then(() => __importStar(require("@xenova/transformers"))); this.pipeline = (await transformers.pipeline("text-generation", this.model)); } return this.pipeline; } async complete(prompt, options = {}) { try { const pipe = await this.ensurePipeline(); const response = await pipe(prompt, { max_new_tokens: options.maxTokens, temperature: options.temperature, }); return { content: response[0].generated_text, usage: { promptTokens: 0, completionTokens: 0, totalTokens: 0, }, raw: response, }; } catch (error) { throw new Error(`HuggingFace completion error: ${error.message}`); } } async completeWithFunctions(prompt, functions, options = {}) { // Similar to Anthropic, format functions as part of the prompt const functionsPrompt = ` You must respond using one of these functions: ${JSON.stringify(functions, null, 2)} Your response must be a JSON object with a "name" field indicating the function and an "arguments" object containing the function parameters. Original request: ${prompt} `; try { const response = await this.complete(functionsPrompt, options); try { const parsedResponse = JSON.parse(response.content); return { ...response, functionCall: { name: parsedResponse.name, arguments: parsedResponse.arguments, }, }; } catch (parseError) { throw new Error("Failed to parse function call response from HuggingFace model"); } } catch (error) { throw new Error(`HuggingFace function completion error: ${error.message}`); } } } exports.HuggingFaceProvider = HuggingFaceProvider; //# sourceMappingURL=huggingface.js.map