modelfusion 0.48.0 → 0.49.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (108) hide show
  1. package/README.md +30 -45
  2. package/model-function/AsyncIterableResultPromise.cjs +5 -5
  3. package/model-function/AsyncIterableResultPromise.d.ts +3 -3
  4. package/model-function/AsyncIterableResultPromise.js +5 -5
  5. package/model-function/Model.d.ts +1 -1
  6. package/model-function/ModelCallEvent.d.ts +5 -7
  7. package/model-function/embed/embed.cjs +3 -3
  8. package/model-function/embed/embed.js +3 -3
  9. package/model-function/{executeCall.cjs → executeStandardCall.cjs} +3 -3
  10. package/model-function/{executeCall.d.ts → executeStandardCall.d.ts} +1 -1
  11. package/model-function/{executeCall.js → executeStandardCall.js} +1 -1
  12. package/model-function/executeStreamCall.cjs +132 -0
  13. package/model-function/executeStreamCall.d.ts +20 -0
  14. package/model-function/executeStreamCall.js +128 -0
  15. package/model-function/generate-image/generateImage.cjs +2 -2
  16. package/model-function/generate-image/generateImage.js +2 -2
  17. package/model-function/generate-speech/SpeechGenerationEvent.d.ts +27 -0
  18. package/model-function/generate-speech/SpeechGenerationModel.d.ts +15 -0
  19. package/model-function/generate-speech/generateSpeech.cjs +24 -0
  20. package/model-function/generate-speech/generateSpeech.d.ts +8 -0
  21. package/model-function/generate-speech/generateSpeech.js +20 -0
  22. package/model-function/generate-speech/index.cjs +20 -0
  23. package/model-function/generate-speech/index.d.ts +4 -0
  24. package/model-function/generate-speech/index.js +4 -0
  25. package/model-function/generate-speech/streamSpeech.cjs +34 -0
  26. package/model-function/generate-speech/streamSpeech.d.ts +8 -0
  27. package/model-function/generate-speech/streamSpeech.js +30 -0
  28. package/model-function/generate-structure/generateStructure.cjs +2 -2
  29. package/model-function/generate-structure/generateStructure.js +2 -2
  30. package/model-function/generate-structure/generateStructureOrText.cjs +2 -2
  31. package/model-function/generate-structure/generateStructureOrText.js +2 -2
  32. package/model-function/generate-structure/index.cjs +27 -0
  33. package/model-function/generate-structure/index.d.ts +11 -0
  34. package/model-function/generate-structure/index.js +11 -0
  35. package/model-function/generate-structure/streamStructure.cjs +28 -136
  36. package/model-function/generate-structure/streamStructure.js +27 -135
  37. package/model-function/generate-text/TextGenerationEvent.d.ts +6 -0
  38. package/model-function/generate-text/generateText.cjs +3 -3
  39. package/model-function/generate-text/generateText.d.ts +1 -1
  40. package/model-function/generate-text/generateText.js +3 -3
  41. package/model-function/generate-text/index.cjs +0 -1
  42. package/model-function/generate-text/index.d.ts +0 -1
  43. package/model-function/generate-text/index.js +0 -1
  44. package/model-function/generate-text/streamText.cjs +21 -128
  45. package/model-function/generate-text/streamText.js +20 -127
  46. package/model-function/generate-text/trimChatPrompt.cjs +1 -1
  47. package/model-function/generate-text/trimChatPrompt.d.ts +1 -1
  48. package/model-function/generate-text/trimChatPrompt.js +1 -1
  49. package/model-function/{transcribe-speech/transcribe.cjs → generate-transcription/generateTranscription.cjs} +6 -6
  50. package/model-function/{transcribe-speech/transcribe.d.ts → generate-transcription/generateTranscription.d.ts} +2 -2
  51. package/model-function/{transcribe-speech/transcribe.js → generate-transcription/generateTranscription.js} +4 -4
  52. package/model-function/index.cjs +5 -20
  53. package/model-function/index.d.ts +5 -20
  54. package/model-function/index.js +5 -20
  55. package/model-provider/elevenlabs/{ElevenLabsSpeechSynthesisModel.cjs → ElevenLabsSpeechModel.cjs} +6 -6
  56. package/model-provider/elevenlabs/{ElevenLabsSpeechSynthesisModel.d.ts → ElevenLabsSpeechModel.d.ts} +8 -8
  57. package/model-provider/elevenlabs/{ElevenLabsSpeechSynthesisModel.js → ElevenLabsSpeechModel.js} +4 -4
  58. package/model-provider/elevenlabs/index.cjs +1 -1
  59. package/model-provider/elevenlabs/index.d.ts +1 -1
  60. package/model-provider/elevenlabs/index.js +1 -1
  61. package/model-provider/huggingface/HuggingFaceImageDescriptionModel.cjs +21 -2
  62. package/model-provider/huggingface/HuggingFaceImageDescriptionModel.d.ts +11 -6
  63. package/model-provider/huggingface/HuggingFaceImageDescriptionModel.js +21 -2
  64. package/model-provider/lmnt/{LmntSpeechSynthesisModel.cjs → LmntSpeechModel.cjs} +5 -5
  65. package/model-provider/lmnt/LmntSpeechModel.d.ts +26 -0
  66. package/model-provider/lmnt/{LmntSpeechSynthesisModel.js → LmntSpeechModel.js} +3 -3
  67. package/model-provider/lmnt/index.cjs +1 -1
  68. package/model-provider/lmnt/index.d.ts +1 -1
  69. package/model-provider/lmnt/index.js +1 -1
  70. package/model-provider/openai/{OpenAITextGenerationModel.cjs → OpenAICompletionModel.cjs} +17 -17
  71. package/model-provider/openai/{OpenAITextGenerationModel.d.ts → OpenAICompletionModel.d.ts} +25 -25
  72. package/model-provider/openai/{OpenAITextGenerationModel.js → OpenAICompletionModel.js} +12 -12
  73. package/model-provider/openai/OpenAICostCalculator.cjs +3 -3
  74. package/model-provider/openai/OpenAICostCalculator.js +3 -3
  75. package/model-provider/openai/OpenAITranscriptionModel.d.ts +1 -1
  76. package/model-provider/openai/TikTokenTokenizer.d.ts +2 -2
  77. package/model-provider/openai/index.cjs +1 -1
  78. package/model-provider/openai/index.d.ts +1 -1
  79. package/model-provider/openai/index.js +1 -1
  80. package/package.json +1 -1
  81. package/model-function/describe-image/ImageDescriptionEvent.d.ts +0 -18
  82. package/model-function/describe-image/ImageDescriptionModel.d.ts +0 -10
  83. package/model-function/describe-image/describeImage.cjs +0 -26
  84. package/model-function/describe-image/describeImage.d.ts +0 -9
  85. package/model-function/describe-image/describeImage.js +0 -22
  86. package/model-function/generate-text/TextStreamingEvent.cjs +0 -2
  87. package/model-function/generate-text/TextStreamingEvent.d.ts +0 -7
  88. package/model-function/generate-text/TextStreamingEvent.js +0 -1
  89. package/model-function/synthesize-speech/SpeechSynthesisEvent.cjs +0 -2
  90. package/model-function/synthesize-speech/SpeechSynthesisEvent.d.ts +0 -21
  91. package/model-function/synthesize-speech/SpeechSynthesisEvent.js +0 -1
  92. package/model-function/synthesize-speech/SpeechSynthesisModel.cjs +0 -2
  93. package/model-function/synthesize-speech/SpeechSynthesisModel.d.ts +0 -15
  94. package/model-function/synthesize-speech/SpeechSynthesisModel.js +0 -1
  95. package/model-function/synthesize-speech/synthesizeSpeech.cjs +0 -67
  96. package/model-function/synthesize-speech/synthesizeSpeech.d.ts +0 -14
  97. package/model-function/synthesize-speech/synthesizeSpeech.js +0 -63
  98. package/model-provider/lmnt/LmntSpeechSynthesisModel.d.ts +0 -26
  99. /package/model-function/{describe-image/ImageDescriptionEvent.cjs → generate-speech/SpeechGenerationEvent.cjs} +0 -0
  100. /package/model-function/{describe-image/ImageDescriptionEvent.js → generate-speech/SpeechGenerationEvent.js} +0 -0
  101. /package/model-function/{describe-image/ImageDescriptionModel.cjs → generate-speech/SpeechGenerationModel.cjs} +0 -0
  102. /package/model-function/{describe-image/ImageDescriptionModel.js → generate-speech/SpeechGenerationModel.js} +0 -0
  103. /package/model-function/{transcribe-speech → generate-transcription}/TranscriptionEvent.cjs +0 -0
  104. /package/model-function/{transcribe-speech → generate-transcription}/TranscriptionEvent.d.ts +0 -0
  105. /package/model-function/{transcribe-speech → generate-transcription}/TranscriptionEvent.js +0 -0
  106. /package/model-function/{transcribe-speech → generate-transcription}/TranscriptionModel.cjs +0 -0
  107. /package/model-function/{transcribe-speech → generate-transcription}/TranscriptionModel.d.ts +0 -0
  108. /package/model-function/{transcribe-speech → generate-transcription}/TranscriptionModel.js +0 -0
@@ -1,133 +1,26 @@
1
- import { nanoid as createId } from "nanoid";
2
- import { FunctionEventSource } from "../../core/FunctionEventSource.js";
3
- import { getGlobalFunctionLogging } from "../../core/GlobalFunctionLogging.js";
4
- import { getGlobalFunctionObservers } from "../../core/GlobalFunctionObservers.js";
5
- import { AbortError } from "../../core/api/AbortError.js";
6
- import { getFunctionCallLogger } from "../../core/getFunctionCallLogger.js";
7
- import { getRun } from "../../core/getRun.js";
8
- import { startDurationMeasurement } from "../../util/DurationMeasurement.js";
9
- import { runSafe } from "../../util/runSafe.js";
10
1
  import { AsyncIterableResultPromise } from "../AsyncIterableResultPromise.js";
2
+ import { executeStreamCall } from "../executeStreamCall.js";
11
3
  export function streamText(model, prompt, options) {
12
- return new AsyncIterableResultPromise(doStreamText(model, prompt, options));
13
- }
14
- async function doStreamText(model, prompt, options) {
15
- const run = await getRun(options?.run);
16
- const eventSource = new FunctionEventSource({
17
- observers: [
18
- ...getFunctionCallLogger(options?.logging ?? getGlobalFunctionLogging()),
19
- ...getGlobalFunctionObservers(),
20
- ...(model.settings.observers ?? []),
21
- ...(run?.functionObserver != null ? [run.functionObserver] : []),
22
- ...(options?.observers ?? []),
23
- ],
24
- errorHandler: run?.errorHandler,
25
- });
26
- const durationMeasurement = startDurationMeasurement();
27
- const startMetadata = {
4
+ let accumulatedText = "";
5
+ let lastFullDelta;
6
+ return new AsyncIterableResultPromise(executeStreamCall({
28
7
  functionType: "text-streaming",
29
- callId: `call-${createId()}`,
30
- runId: run?.runId,
31
- sessionId: run?.sessionId,
32
- userId: run?.userId,
33
- functionId: options?.functionId,
34
- model: model.modelInformation,
35
- settings: model.settingsForEvent,
36
8
  input: prompt,
37
- timestamp: durationMeasurement.startDate,
38
- startTimestamp: durationMeasurement.startDate,
39
- };
40
- eventSource.notify({
41
- eventType: "started",
42
- ...startMetadata,
43
- });
44
- const result = await runSafe(async () => {
45
- const deltaIterable = await model.doStreamText(prompt, {
46
- functionId: options?.functionId,
47
- logging: options?.logging,
48
- observers: options?.observers,
49
- run,
50
- });
51
- return (async function* () {
52
- let accumulatedText = "";
53
- let lastFullDelta;
54
- for await (const event of deltaIterable) {
55
- if (event?.type === "error") {
56
- const error = event.error;
57
- const finishMetadata = {
58
- eventType: "finished",
59
- ...startMetadata,
60
- finishTimestamp: new Date(),
61
- durationInMs: durationMeasurement.durationInMs,
62
- };
63
- eventSource.notify(error instanceof AbortError
64
- ? {
65
- ...finishMetadata,
66
- result: {
67
- status: "abort",
68
- },
69
- }
70
- : {
71
- ...finishMetadata,
72
- result: {
73
- status: "error",
74
- error,
75
- },
76
- });
77
- throw error;
78
- }
79
- if (event?.type === "delta") {
80
- lastFullDelta = event.fullDelta;
81
- const textDelta = event.valueDelta;
82
- if (textDelta != null && textDelta.length > 0) {
83
- accumulatedText += textDelta;
84
- yield textDelta;
85
- }
86
- }
9
+ model,
10
+ options,
11
+ startStream: async (options) => model.doStreamText(prompt, options),
12
+ processDelta: (delta) => {
13
+ lastFullDelta = delta.fullDelta;
14
+ const textDelta = delta.valueDelta;
15
+ if (textDelta != null && textDelta.length > 0) {
16
+ accumulatedText += textDelta;
17
+ return textDelta;
87
18
  }
88
- const finishMetadata = {
89
- eventType: "finished",
90
- ...startMetadata,
91
- finishTimestamp: new Date(),
92
- durationInMs: durationMeasurement.durationInMs,
93
- };
94
- eventSource.notify({
95
- ...finishMetadata,
96
- result: {
97
- status: "success",
98
- response: lastFullDelta,
99
- value: accumulatedText,
100
- },
101
- });
102
- })();
103
- });
104
- if (!result.ok) {
105
- const finishMetadata = {
106
- eventType: "finished",
107
- ...startMetadata,
108
- finishTimestamp: new Date(),
109
- durationInMs: durationMeasurement.durationInMs,
110
- };
111
- if (result.isAborted) {
112
- eventSource.notify({
113
- ...finishMetadata,
114
- result: {
115
- status: "abort",
116
- },
117
- });
118
- throw new AbortError();
119
- }
120
- eventSource.notify({
121
- ...finishMetadata,
122
- result: {
123
- status: "error",
124
- error: result.error,
125
- },
126
- });
127
- throw result.error;
128
- }
129
- return {
130
- output: result.value,
131
- metadata: startMetadata,
132
- };
19
+ return undefined;
20
+ },
21
+ getResult: () => ({
22
+ response: lastFullDelta,
23
+ value: accumulatedText,
24
+ }),
25
+ }));
133
26
  }
@@ -10,7 +10,7 @@ const validateChatPrompt_js_1 = require("./validateChatPrompt.cjs");
10
10
  * When the minimal chat prompt (system message + last user message) is already too long, it will only
11
11
  * return this minimal chat prompt.
12
12
  *
13
- * @see https://modelfusion.dev/guide/function/generate-text/prompt-format#limiting-the-chat-length
13
+ * @see https://modelfusion.dev/guide/function/generate-text#limiting-the-chat-length
14
14
  */
15
15
  async function trimChatPrompt({ prompt, model, tokenLimit = model.contextWindowSize -
16
16
  (model.settings.maxCompletionTokens ?? model.contextWindowSize / 4), }) {
@@ -8,7 +8,7 @@ import { HasContextWindowSize, HasTokenizer, TextGenerationModel, TextGeneration
8
8
  * When the minimal chat prompt (system message + last user message) is already too long, it will only
9
9
  * return this minimal chat prompt.
10
10
  *
11
- * @see https://modelfusion.dev/guide/function/generate-text/prompt-format#limiting-the-chat-length
11
+ * @see https://modelfusion.dev/guide/function/generate-text#limiting-the-chat-length
12
12
  */
13
13
  export declare function trimChatPrompt({ prompt, model, tokenLimit, }: {
14
14
  prompt: ChatPrompt;
@@ -7,7 +7,7 @@ import { validateChatPrompt } from "./validateChatPrompt.js";
7
7
  * When the minimal chat prompt (system message + last user message) is already too long, it will only
8
8
  * return this minimal chat prompt.
9
9
  *
10
- * @see https://modelfusion.dev/guide/function/generate-text/prompt-format#limiting-the-chat-length
10
+ * @see https://modelfusion.dev/guide/function/generate-text#limiting-the-chat-length
11
11
  */
12
12
  export async function trimChatPrompt({ prompt, model, tokenLimit = model.contextWindowSize -
13
13
  (model.settings.maxCompletionTokens ?? model.contextWindowSize / 4), }) {
@@ -1,7 +1,7 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.transcribe = void 0;
4
- const executeCall_js_1 = require("../executeCall.cjs");
3
+ exports.generateTranscription = void 0;
4
+ const executeStandardCall_js_1 = require("../executeStandardCall.cjs");
5
5
  const ModelFunctionPromise_js_1 = require("../ModelFunctionPromise.cjs");
6
6
  /**
7
7
  * Transcribe audio data into text.
@@ -9,7 +9,7 @@ const ModelFunctionPromise_js_1 = require("../ModelFunctionPromise.cjs");
9
9
  * @example
10
10
  * const data = await fs.promises.readFile("data/test.mp3");
11
11
  *
12
- * const transcription = await transcribe(
12
+ * const transcription = await generateTranscription(
13
13
  * new OpenAITranscriptionModel({ model: "whisper-1" }),
14
14
  * {
15
15
  * type: "mp3",
@@ -17,8 +17,8 @@ const ModelFunctionPromise_js_1 = require("../ModelFunctionPromise.cjs");
17
17
  * }
18
18
  * );
19
19
  */
20
- function transcribe(model, data, options) {
21
- return new ModelFunctionPromise_js_1.ModelFunctionPromise((0, executeCall_js_1.executeCall)({
20
+ function generateTranscription(model, data, options) {
21
+ return new ModelFunctionPromise_js_1.ModelFunctionPromise((0, executeStandardCall_js_1.executeStandardCall)({
22
22
  functionType: "transcription",
23
23
  input: data,
24
24
  model,
@@ -32,4 +32,4 @@ function transcribe(model, data, options) {
32
32
  },
33
33
  }));
34
34
  }
35
- exports.transcribe = transcribe;
35
+ exports.generateTranscription = generateTranscription;
@@ -7,7 +7,7 @@ import { TranscriptionModel, TranscriptionModelSettings } from "./TranscriptionM
7
7
  * @example
8
8
  * const data = await fs.promises.readFile("data/test.mp3");
9
9
  *
10
- * const transcription = await transcribe(
10
+ * const transcription = await generateTranscription(
11
11
  * new OpenAITranscriptionModel({ model: "whisper-1" }),
12
12
  * {
13
13
  * type: "mp3",
@@ -15,4 +15,4 @@ import { TranscriptionModel, TranscriptionModelSettings } from "./TranscriptionM
15
15
  * }
16
16
  * );
17
17
  */
18
- export declare function transcribe<DATA>(model: TranscriptionModel<DATA, TranscriptionModelSettings>, data: DATA, options?: FunctionOptions): ModelFunctionPromise<string>;
18
+ export declare function generateTranscription<DATA>(model: TranscriptionModel<DATA, TranscriptionModelSettings>, data: DATA, options?: FunctionOptions): ModelFunctionPromise<string>;
@@ -1,4 +1,4 @@
1
- import { executeCall } from "../executeCall.js";
1
+ import { executeStandardCall } from "../executeStandardCall.js";
2
2
  import { ModelFunctionPromise } from "../ModelFunctionPromise.js";
3
3
  /**
4
4
  * Transcribe audio data into text.
@@ -6,7 +6,7 @@ import { ModelFunctionPromise } from "../ModelFunctionPromise.js";
6
6
  * @example
7
7
  * const data = await fs.promises.readFile("data/test.mp3");
8
8
  *
9
- * const transcription = await transcribe(
9
+ * const transcription = await generateTranscription(
10
10
  * new OpenAITranscriptionModel({ model: "whisper-1" }),
11
11
  * {
12
12
  * type: "mp3",
@@ -14,8 +14,8 @@ import { ModelFunctionPromise } from "../ModelFunctionPromise.js";
14
14
  * }
15
15
  * );
16
16
  */
17
- export function transcribe(model, data, options) {
18
- return new ModelFunctionPromise(executeCall({
17
+ export function generateTranscription(model, data, options) {
18
+ return new ModelFunctionPromise(executeStandardCall({
19
19
  functionType: "transcription",
20
20
  input: data,
21
21
  model,
@@ -21,9 +21,6 @@ __exportStar(require("./ModelCallMetadata.cjs"), exports);
21
21
  __exportStar(require("./ModelInformation.cjs"), exports);
22
22
  __exportStar(require("./PromptFormat.cjs"), exports);
23
23
  __exportStar(require("./SuccessfulModelCall.cjs"), exports);
24
- __exportStar(require("./describe-image/ImageDescriptionEvent.cjs"), exports);
25
- __exportStar(require("./describe-image/ImageDescriptionModel.cjs"), exports);
26
- __exportStar(require("./describe-image/describeImage.cjs"), exports);
27
24
  __exportStar(require("./embed/EmbeddingEvent.cjs"), exports);
28
25
  __exportStar(require("./embed/EmbeddingModel.cjs"), exports);
29
26
  __exportStar(require("./embed/embed.cjs"), exports);
@@ -31,23 +28,11 @@ __exportStar(require("./generate-image/ImageGenerationEvent.cjs"), exports);
31
28
  __exportStar(require("./generate-image/ImageGenerationModel.cjs"), exports);
32
29
  __exportStar(require("./generate-image/PromptFormatImageGenerationModel.cjs"), exports);
33
30
  __exportStar(require("./generate-image/generateImage.cjs"), exports);
34
- __exportStar(require("./generate-structure/NoSuchStructureError.cjs"), exports);
35
- __exportStar(require("./generate-structure/StructureFromTextGenerationModel.cjs"), exports);
36
- __exportStar(require("./generate-structure/StructureGenerationEvent.cjs"), exports);
37
- __exportStar(require("./generate-structure/StructureGenerationModel.cjs"), exports);
38
- __exportStar(require("./generate-structure/StructureOrTextGenerationModel.cjs"), exports);
39
- __exportStar(require("./generate-structure/StructureParseError.cjs"), exports);
40
- __exportStar(require("./generate-structure/StructureStreamingEvent.cjs"), exports);
41
- __exportStar(require("./generate-structure/StructureValidationError.cjs"), exports);
42
- __exportStar(require("./generate-structure/generateStructure.cjs"), exports);
43
- __exportStar(require("./generate-structure/generateStructureOrText.cjs"), exports);
44
- __exportStar(require("./generate-structure/streamStructure.cjs"), exports);
31
+ __exportStar(require("./generate-speech/index.cjs"), exports);
32
+ __exportStar(require("./generate-structure/index.cjs"), exports);
45
33
  __exportStar(require("./generate-text/index.cjs"), exports);
46
- __exportStar(require("./synthesize-speech/SpeechSynthesisEvent.cjs"), exports);
47
- __exportStar(require("./synthesize-speech/SpeechSynthesisModel.cjs"), exports);
48
- __exportStar(require("./synthesize-speech/synthesizeSpeech.cjs"), exports);
34
+ __exportStar(require("./generate-transcription/TranscriptionEvent.cjs"), exports);
35
+ __exportStar(require("./generate-transcription/TranscriptionModel.cjs"), exports);
36
+ __exportStar(require("./generate-transcription/generateTranscription.cjs"), exports);
49
37
  __exportStar(require("./tokenize-text/Tokenizer.cjs"), exports);
50
38
  __exportStar(require("./tokenize-text/countTokens.cjs"), exports);
51
- __exportStar(require("./transcribe-speech/TranscriptionEvent.cjs"), exports);
52
- __exportStar(require("./transcribe-speech/TranscriptionModel.cjs"), exports);
53
- __exportStar(require("./transcribe-speech/transcribe.cjs"), exports);
@@ -5,9 +5,6 @@ export * from "./ModelCallMetadata.js";
5
5
  export * from "./ModelInformation.js";
6
6
  export * from "./PromptFormat.js";
7
7
  export * from "./SuccessfulModelCall.js";
8
- export * from "./describe-image/ImageDescriptionEvent.js";
9
- export * from "./describe-image/ImageDescriptionModel.js";
10
- export * from "./describe-image/describeImage.js";
11
8
  export * from "./embed/EmbeddingEvent.js";
12
9
  export * from "./embed/EmbeddingModel.js";
13
10
  export * from "./embed/embed.js";
@@ -15,23 +12,11 @@ export * from "./generate-image/ImageGenerationEvent.js";
15
12
  export * from "./generate-image/ImageGenerationModel.js";
16
13
  export * from "./generate-image/PromptFormatImageGenerationModel.js";
17
14
  export * from "./generate-image/generateImage.js";
18
- export * from "./generate-structure/NoSuchStructureError.js";
19
- export * from "./generate-structure/StructureFromTextGenerationModel.js";
20
- export * from "./generate-structure/StructureGenerationEvent.js";
21
- export * from "./generate-structure/StructureGenerationModel.js";
22
- export * from "./generate-structure/StructureOrTextGenerationModel.js";
23
- export * from "./generate-structure/StructureParseError.js";
24
- export * from "./generate-structure/StructureStreamingEvent.js";
25
- export * from "./generate-structure/StructureValidationError.js";
26
- export * from "./generate-structure/generateStructure.js";
27
- export * from "./generate-structure/generateStructureOrText.js";
28
- export * from "./generate-structure/streamStructure.js";
15
+ export * from "./generate-speech/index.js";
16
+ export * from "./generate-structure/index.js";
29
17
  export * from "./generate-text/index.js";
30
- export * from "./synthesize-speech/SpeechSynthesisEvent.js";
31
- export * from "./synthesize-speech/SpeechSynthesisModel.js";
32
- export * from "./synthesize-speech/synthesizeSpeech.js";
18
+ export * from "./generate-transcription/TranscriptionEvent.js";
19
+ export * from "./generate-transcription/TranscriptionModel.js";
20
+ export * from "./generate-transcription/generateTranscription.js";
33
21
  export * from "./tokenize-text/Tokenizer.js";
34
22
  export * from "./tokenize-text/countTokens.js";
35
- export * from "./transcribe-speech/TranscriptionEvent.js";
36
- export * from "./transcribe-speech/TranscriptionModel.js";
37
- export * from "./transcribe-speech/transcribe.js";
@@ -5,9 +5,6 @@ export * from "./ModelCallMetadata.js";
5
5
  export * from "./ModelInformation.js";
6
6
  export * from "./PromptFormat.js";
7
7
  export * from "./SuccessfulModelCall.js";
8
- export * from "./describe-image/ImageDescriptionEvent.js";
9
- export * from "./describe-image/ImageDescriptionModel.js";
10
- export * from "./describe-image/describeImage.js";
11
8
  export * from "./embed/EmbeddingEvent.js";
12
9
  export * from "./embed/EmbeddingModel.js";
13
10
  export * from "./embed/embed.js";
@@ -15,23 +12,11 @@ export * from "./generate-image/ImageGenerationEvent.js";
15
12
  export * from "./generate-image/ImageGenerationModel.js";
16
13
  export * from "./generate-image/PromptFormatImageGenerationModel.js";
17
14
  export * from "./generate-image/generateImage.js";
18
- export * from "./generate-structure/NoSuchStructureError.js";
19
- export * from "./generate-structure/StructureFromTextGenerationModel.js";
20
- export * from "./generate-structure/StructureGenerationEvent.js";
21
- export * from "./generate-structure/StructureGenerationModel.js";
22
- export * from "./generate-structure/StructureOrTextGenerationModel.js";
23
- export * from "./generate-structure/StructureParseError.js";
24
- export * from "./generate-structure/StructureStreamingEvent.js";
25
- export * from "./generate-structure/StructureValidationError.js";
26
- export * from "./generate-structure/generateStructure.js";
27
- export * from "./generate-structure/generateStructureOrText.js";
28
- export * from "./generate-structure/streamStructure.js";
15
+ export * from "./generate-speech/index.js";
16
+ export * from "./generate-structure/index.js";
29
17
  export * from "./generate-text/index.js";
30
- export * from "./synthesize-speech/SpeechSynthesisEvent.js";
31
- export * from "./synthesize-speech/SpeechSynthesisModel.js";
32
- export * from "./synthesize-speech/synthesizeSpeech.js";
18
+ export * from "./generate-transcription/TranscriptionEvent.js";
19
+ export * from "./generate-transcription/TranscriptionModel.js";
20
+ export * from "./generate-transcription/generateTranscription.js";
33
21
  export * from "./tokenize-text/Tokenizer.js";
34
22
  export * from "./tokenize-text/countTokens.js";
35
- export * from "./transcribe-speech/TranscriptionEvent.js";
36
- export * from "./transcribe-speech/TranscriptionModel.js";
37
- export * from "./transcribe-speech/transcribe.js";
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.ElevenLabsSpeechSynthesisModel = void 0;
3
+ exports.ElevenLabsSpeechModel = void 0;
4
4
  const zod_1 = require("zod");
5
5
  const callWithRetryAndThrottle_js_1 = require("../../core/api/callWithRetryAndThrottle.cjs");
6
6
  const postToApi_js_1 = require("../../core/api/postToApi.cjs");
@@ -21,7 +21,7 @@ const defaultModel = "eleven_multilingual_v2";
21
21
  *
22
22
  * @see https://api.elevenlabs.io/docs#/text-to-speech/Text_to_speech_v1_text_to_speech__voice_id__post
23
23
  */
24
- class ElevenLabsSpeechSynthesisModel extends AbstractModel_js_1.AbstractModel {
24
+ class ElevenLabsSpeechModel extends AbstractModel_js_1.AbstractModel {
25
25
  constructor(settings) {
26
26
  super({ settings });
27
27
  Object.defineProperty(this, "provider", {
@@ -55,10 +55,10 @@ class ElevenLabsSpeechSynthesisModel extends AbstractModel_js_1.AbstractModel {
55
55
  voiceSettings: this.settings.voiceSettings,
56
56
  };
57
57
  }
58
- doSynthesizeSpeechStandard(text, options) {
58
+ doGenerateSpeechStandard(text, options) {
59
59
  return this.callAPI(text, options);
60
60
  }
61
- async doSynthesizeSpeechStreamDuplex(textStream
61
+ async doGenerateSpeechStreamDuplex(textStream
62
62
  // options?: FunctionOptions | undefined
63
63
  ) {
64
64
  const responseSchema = zod_1.z.union([
@@ -151,13 +151,13 @@ class ElevenLabsSpeechSynthesisModel extends AbstractModel_js_1.AbstractModel {
151
151
  return queue;
152
152
  }
153
153
  withSettings(additionalSettings) {
154
- return new ElevenLabsSpeechSynthesisModel({
154
+ return new ElevenLabsSpeechModel({
155
155
  ...this.settings,
156
156
  ...additionalSettings,
157
157
  });
158
158
  }
159
159
  }
160
- exports.ElevenLabsSpeechSynthesisModel = ElevenLabsSpeechSynthesisModel;
160
+ exports.ElevenLabsSpeechModel = ElevenLabsSpeechModel;
161
161
  async function callElevenLabsTextToSpeechAPI({ api = new ElevenLabsApiConfiguration_js_1.ElevenLabsApiConfiguration(), abortSignal, text, voiceId, modelId, voiceSettings, }) {
162
162
  return (0, postToApi_js_1.postJsonToApi)({
163
163
  url: api.assembleUrl(`/text-to-speech/${voiceId}`),
@@ -3,9 +3,9 @@ import { FunctionOptions } from "../../core/FunctionOptions.js";
3
3
  import { ApiConfiguration } from "../../core/api/ApiConfiguration.js";
4
4
  import { AbstractModel } from "../../model-function/AbstractModel.js";
5
5
  import { Delta } from "../../model-function/Delta.js";
6
- import { SpeechSynthesisModel, SpeechSynthesisModelSettings } from "../../model-function/synthesize-speech/SpeechSynthesisModel.js";
6
+ import { StreamingSpeechGenerationModel, SpeechGenerationModelSettings } from "../../model-function/generate-speech/SpeechGenerationModel.js";
7
7
  declare const elevenLabsModels: readonly ["eleven_multilingual_v2", "eleven_multilingual_v1", "eleven_monolingual_v1"];
8
- export interface ElevenLabsSpeechSynthesisModelSettings extends SpeechSynthesisModelSettings {
8
+ export interface ElevenLabsSpeechModelSettings extends SpeechGenerationModelSettings {
9
9
  api?: ApiConfiguration & {
10
10
  apiKey: string;
11
11
  };
@@ -26,14 +26,14 @@ export interface ElevenLabsSpeechSynthesisModelSettings extends SpeechSynthesisM
26
26
  *
27
27
  * @see https://api.elevenlabs.io/docs#/text-to-speech/Text_to_speech_v1_text_to_speech__voice_id__post
28
28
  */
29
- export declare class ElevenLabsSpeechSynthesisModel extends AbstractModel<ElevenLabsSpeechSynthesisModelSettings> implements SpeechSynthesisModel<ElevenLabsSpeechSynthesisModelSettings> {
30
- constructor(settings: ElevenLabsSpeechSynthesisModelSettings);
29
+ export declare class ElevenLabsSpeechModel extends AbstractModel<ElevenLabsSpeechModelSettings> implements StreamingSpeechGenerationModel<ElevenLabsSpeechModelSettings> {
30
+ constructor(settings: ElevenLabsSpeechModelSettings);
31
31
  readonly provider = "elevenlabs";
32
32
  get modelName(): string;
33
33
  private callAPI;
34
- get settingsForEvent(): Partial<ElevenLabsSpeechSynthesisModelSettings>;
35
- doSynthesizeSpeechStandard(text: string, options?: FunctionOptions): Promise<Buffer>;
36
- doSynthesizeSpeechStreamDuplex(textStream: AsyncIterable<string>): Promise<AsyncIterable<Delta<Buffer>>>;
37
- withSettings(additionalSettings: Partial<ElevenLabsSpeechSynthesisModelSettings>): this;
34
+ get settingsForEvent(): Partial<ElevenLabsSpeechModelSettings>;
35
+ doGenerateSpeechStandard(text: string, options?: FunctionOptions): Promise<Buffer>;
36
+ doGenerateSpeechStreamDuplex(textStream: AsyncIterable<string>): Promise<AsyncIterable<Delta<Buffer>>>;
37
+ withSettings(additionalSettings: Partial<ElevenLabsSpeechModelSettings>): this;
38
38
  }
39
39
  export {};
@@ -18,7 +18,7 @@ const defaultModel = "eleven_multilingual_v2";
18
18
  *
19
19
  * @see https://api.elevenlabs.io/docs#/text-to-speech/Text_to_speech_v1_text_to_speech__voice_id__post
20
20
  */
21
- export class ElevenLabsSpeechSynthesisModel extends AbstractModel {
21
+ export class ElevenLabsSpeechModel extends AbstractModel {
22
22
  constructor(settings) {
23
23
  super({ settings });
24
24
  Object.defineProperty(this, "provider", {
@@ -52,10 +52,10 @@ export class ElevenLabsSpeechSynthesisModel extends AbstractModel {
52
52
  voiceSettings: this.settings.voiceSettings,
53
53
  };
54
54
  }
55
- doSynthesizeSpeechStandard(text, options) {
55
+ doGenerateSpeechStandard(text, options) {
56
56
  return this.callAPI(text, options);
57
57
  }
58
- async doSynthesizeSpeechStreamDuplex(textStream
58
+ async doGenerateSpeechStreamDuplex(textStream
59
59
  // options?: FunctionOptions | undefined
60
60
  ) {
61
61
  const responseSchema = z.union([
@@ -148,7 +148,7 @@ export class ElevenLabsSpeechSynthesisModel extends AbstractModel {
148
148
  return queue;
149
149
  }
150
150
  withSettings(additionalSettings) {
151
- return new ElevenLabsSpeechSynthesisModel({
151
+ return new ElevenLabsSpeechModel({
152
152
  ...this.settings,
153
153
  ...additionalSettings,
154
154
  });
@@ -15,4 +15,4 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
15
15
  };
16
16
  Object.defineProperty(exports, "__esModule", { value: true });
17
17
  __exportStar(require("./ElevenLabsApiConfiguration.cjs"), exports);
18
- __exportStar(require("./ElevenLabsSpeechSynthesisModel.cjs"), exports);
18
+ __exportStar(require("./ElevenLabsSpeechModel.cjs"), exports);
@@ -1,2 +1,2 @@
1
1
  export * from "./ElevenLabsApiConfiguration.js";
2
- export * from "./ElevenLabsSpeechSynthesisModel.js";
2
+ export * from "./ElevenLabsSpeechModel.js";
@@ -1,2 +1,2 @@
1
1
  export * from "./ElevenLabsApiConfiguration.js";
2
- export * from "./ElevenLabsSpeechSynthesisModel.js";
2
+ export * from "./ElevenLabsSpeechModel.js";
@@ -5,6 +5,7 @@ const zod_1 = require("zod");
5
5
  const callWithRetryAndThrottle_js_1 = require("../../core/api/callWithRetryAndThrottle.cjs");
6
6
  const postToApi_js_1 = require("../../core/api/postToApi.cjs");
7
7
  const AbstractModel_js_1 = require("../../model-function/AbstractModel.cjs");
8
+ const PromptFormatTextGenerationModel_js_1 = require("../../model-function/generate-text/PromptFormatTextGenerationModel.cjs");
8
9
  const HuggingFaceApiConfiguration_js_1 = require("./HuggingFaceApiConfiguration.cjs");
9
10
  const HuggingFaceError_js_1 = require("./HuggingFaceError.cjs");
10
11
  /**
@@ -21,6 +22,18 @@ class HuggingFaceImageDescriptionModel extends AbstractModel_js_1.AbstractModel
21
22
  writable: true,
22
23
  value: "huggingface"
23
24
  });
25
+ Object.defineProperty(this, "contextWindowSize", {
26
+ enumerable: true,
27
+ configurable: true,
28
+ writable: true,
29
+ value: undefined
30
+ });
31
+ Object.defineProperty(this, "tokenizer", {
32
+ enumerable: true,
33
+ configurable: true,
34
+ writable: true,
35
+ value: undefined
36
+ });
24
37
  Object.defineProperty(this, "countPromptTokens", {
25
38
  enumerable: true,
26
39
  configurable: true,
@@ -45,13 +58,19 @@ class HuggingFaceImageDescriptionModel extends AbstractModel_js_1.AbstractModel
45
58
  get settingsForEvent() {
46
59
  return {};
47
60
  }
48
- async doDescribeImage(data, options) {
61
+ async doGenerateText(data, options) {
49
62
  const response = await this.callAPI(data, options);
50
63
  return {
51
64
  response,
52
- description: response[0].generated_text,
65
+ text: response[0].generated_text,
53
66
  };
54
67
  }
68
+ withPromptFormat(promptFormat) {
69
+ return new PromptFormatTextGenerationModel_js_1.PromptFormatTextGenerationModel({
70
+ model: this,
71
+ promptFormat,
72
+ });
73
+ }
55
74
  withSettings(additionalSettings) {
56
75
  return new HuggingFaceImageDescriptionModel(Object.assign({}, this.settings, additionalSettings));
57
76
  }
@@ -1,10 +1,12 @@
1
1
  /// <reference types="node" />
2
2
  import { z } from "zod";
3
+ import { FunctionOptions } from "../../core/FunctionOptions.js";
3
4
  import { ApiConfiguration } from "../../core/api/ApiConfiguration.js";
4
5
  import { AbstractModel } from "../../model-function/AbstractModel.js";
5
- import { FunctionOptions } from "../../core/FunctionOptions.js";
6
- import { ImageDescriptionModel, ImageDescriptionModelSettings } from "../../model-function/describe-image/ImageDescriptionModel.js";
7
- export interface HuggingFaceImageDescriptionModelSettings extends ImageDescriptionModelSettings {
6
+ import { PromptFormatTextGenerationModel } from "../../model-function/generate-text/PromptFormatTextGenerationModel.js";
7
+ import { TextGenerationModel, TextGenerationModelSettings } from "../../model-function/generate-text/TextGenerationModel.js";
8
+ import { TextGenerationPromptFormat } from "../../model-function/generate-text/TextGenerationPromptFormat.js";
9
+ export interface HuggingFaceImageDescriptionModelSettings extends TextGenerationModelSettings {
8
10
  api?: ApiConfiguration;
9
11
  model: string;
10
12
  }
@@ -13,19 +15,22 @@ export interface HuggingFaceImageDescriptionModelSettings extends ImageDescripti
13
15
  *
14
16
  * @see https://huggingface.co/tasks/image-to-text
15
17
  */
16
- export declare class HuggingFaceImageDescriptionModel extends AbstractModel<HuggingFaceImageDescriptionModelSettings> implements ImageDescriptionModel<Buffer, HuggingFaceImageDescriptionModelSettings> {
18
+ export declare class HuggingFaceImageDescriptionModel extends AbstractModel<HuggingFaceImageDescriptionModelSettings> implements TextGenerationModel<Buffer, HuggingFaceImageDescriptionModelSettings> {
17
19
  constructor(settings: HuggingFaceImageDescriptionModelSettings);
18
20
  readonly provider = "huggingface";
19
21
  get modelName(): string;
20
22
  callAPI(data: Buffer, options?: FunctionOptions): Promise<HuggingFaceImageDescriptionResponse>;
21
23
  get settingsForEvent(): Partial<HuggingFaceImageDescriptionModelSettings>;
24
+ readonly contextWindowSize: undefined;
25
+ readonly tokenizer: undefined;
22
26
  readonly countPromptTokens: undefined;
23
- doDescribeImage(data: Buffer, options?: FunctionOptions): Promise<{
27
+ doGenerateText(data: Buffer, options?: FunctionOptions): Promise<{
24
28
  response: {
25
29
  generated_text: string;
26
30
  }[];
27
- description: string;
31
+ text: string;
28
32
  }>;
33
+ withPromptFormat<INPUT_PROMPT>(promptFormat: TextGenerationPromptFormat<INPUT_PROMPT, Buffer>): PromptFormatTextGenerationModel<INPUT_PROMPT, Buffer, HuggingFaceImageDescriptionModelSettings, this>;
29
34
  withSettings(additionalSettings: Partial<HuggingFaceImageDescriptionModelSettings>): this;
30
35
  }
31
36
  declare const huggingFaceImageDescriptionResponseSchema: z.ZodArray<z.ZodObject<{