inference-server 1.0.0-beta.19

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 (227) hide show
  1. package/README.md +216 -0
  2. package/dist/api/openai/enums.d.ts +4 -0
  3. package/dist/api/openai/enums.js +17 -0
  4. package/dist/api/openai/enums.js.map +1 -0
  5. package/dist/api/openai/handlers/chat.d.ts +3 -0
  6. package/dist/api/openai/handlers/chat.js +358 -0
  7. package/dist/api/openai/handlers/chat.js.map +1 -0
  8. package/dist/api/openai/handlers/completions.d.ts +3 -0
  9. package/dist/api/openai/handlers/completions.js +169 -0
  10. package/dist/api/openai/handlers/completions.js.map +1 -0
  11. package/dist/api/openai/handlers/embeddings.d.ts +3 -0
  12. package/dist/api/openai/handlers/embeddings.js +74 -0
  13. package/dist/api/openai/handlers/embeddings.js.map +1 -0
  14. package/dist/api/openai/handlers/images.d.ts +0 -0
  15. package/dist/api/openai/handlers/images.js +4 -0
  16. package/dist/api/openai/handlers/images.js.map +1 -0
  17. package/dist/api/openai/handlers/models.d.ts +3 -0
  18. package/dist/api/openai/handlers/models.js +23 -0
  19. package/dist/api/openai/handlers/models.js.map +1 -0
  20. package/dist/api/openai/handlers/transcription.d.ts +0 -0
  21. package/dist/api/openai/handlers/transcription.js +4 -0
  22. package/dist/api/openai/handlers/transcription.js.map +1 -0
  23. package/dist/api/openai/index.d.ts +7 -0
  24. package/dist/api/openai/index.js +14 -0
  25. package/dist/api/openai/index.js.map +1 -0
  26. package/dist/api/parseJSONRequestBody.d.ts +2 -0
  27. package/dist/api/parseJSONRequestBody.js +24 -0
  28. package/dist/api/parseJSONRequestBody.js.map +1 -0
  29. package/dist/api/v1/index.d.ts +2 -0
  30. package/dist/api/v1/index.js +29 -0
  31. package/dist/api/v1/index.js.map +1 -0
  32. package/dist/cli.d.ts +1 -0
  33. package/dist/cli.js +10 -0
  34. package/dist/cli.js.map +1 -0
  35. package/dist/engines/gpt4all/engine.d.ts +34 -0
  36. package/dist/engines/gpt4all/engine.js +357 -0
  37. package/dist/engines/gpt4all/engine.js.map +1 -0
  38. package/dist/engines/gpt4all/util.d.ts +3 -0
  39. package/dist/engines/gpt4all/util.js +29 -0
  40. package/dist/engines/gpt4all/util.js.map +1 -0
  41. package/dist/engines/index.d.ts +19 -0
  42. package/dist/engines/index.js +21 -0
  43. package/dist/engines/index.js.map +1 -0
  44. package/dist/engines/node-llama-cpp/engine.d.ts +49 -0
  45. package/dist/engines/node-llama-cpp/engine.js +666 -0
  46. package/dist/engines/node-llama-cpp/engine.js.map +1 -0
  47. package/dist/engines/node-llama-cpp/types.d.ts +13 -0
  48. package/dist/engines/node-llama-cpp/types.js +2 -0
  49. package/dist/engines/node-llama-cpp/types.js.map +1 -0
  50. package/dist/engines/node-llama-cpp/util.d.ts +15 -0
  51. package/dist/engines/node-llama-cpp/util.js +84 -0
  52. package/dist/engines/node-llama-cpp/util.js.map +1 -0
  53. package/dist/engines/node-llama-cpp/validateModelFile.d.ts +8 -0
  54. package/dist/engines/node-llama-cpp/validateModelFile.js +36 -0
  55. package/dist/engines/node-llama-cpp/validateModelFile.js.map +1 -0
  56. package/dist/engines/stable-diffusion-cpp/engine.d.ts +90 -0
  57. package/dist/engines/stable-diffusion-cpp/engine.js +294 -0
  58. package/dist/engines/stable-diffusion-cpp/engine.js.map +1 -0
  59. package/dist/engines/stable-diffusion-cpp/types.d.ts +3 -0
  60. package/dist/engines/stable-diffusion-cpp/types.js +2 -0
  61. package/dist/engines/stable-diffusion-cpp/types.js.map +1 -0
  62. package/dist/engines/stable-diffusion-cpp/util.d.ts +4 -0
  63. package/dist/engines/stable-diffusion-cpp/util.js +55 -0
  64. package/dist/engines/stable-diffusion-cpp/util.js.map +1 -0
  65. package/dist/engines/stable-diffusion-cpp/validateModelFiles.d.ts +19 -0
  66. package/dist/engines/stable-diffusion-cpp/validateModelFiles.js +91 -0
  67. package/dist/engines/stable-diffusion-cpp/validateModelFiles.js.map +1 -0
  68. package/dist/engines/transformers-js/engine.d.ts +37 -0
  69. package/dist/engines/transformers-js/engine.js +538 -0
  70. package/dist/engines/transformers-js/engine.js.map +1 -0
  71. package/dist/engines/transformers-js/types.d.ts +7 -0
  72. package/dist/engines/transformers-js/types.js +2 -0
  73. package/dist/engines/transformers-js/types.js.map +1 -0
  74. package/dist/engines/transformers-js/util.d.ts +7 -0
  75. package/dist/engines/transformers-js/util.js +36 -0
  76. package/dist/engines/transformers-js/util.js.map +1 -0
  77. package/dist/engines/transformers-js/validateModelFiles.d.ts +17 -0
  78. package/dist/engines/transformers-js/validateModelFiles.js +133 -0
  79. package/dist/engines/transformers-js/validateModelFiles.js.map +1 -0
  80. package/dist/experiments/ChatWithVision.d.ts +11 -0
  81. package/dist/experiments/ChatWithVision.js +91 -0
  82. package/dist/experiments/ChatWithVision.js.map +1 -0
  83. package/dist/experiments/StableDiffPromptGenerator.d.ts +0 -0
  84. package/dist/experiments/StableDiffPromptGenerator.js +4 -0
  85. package/dist/experiments/StableDiffPromptGenerator.js.map +1 -0
  86. package/dist/experiments/VoiceFunctionCall.d.ts +18 -0
  87. package/dist/experiments/VoiceFunctionCall.js +51 -0
  88. package/dist/experiments/VoiceFunctionCall.js.map +1 -0
  89. package/dist/http.d.ts +19 -0
  90. package/dist/http.js +54 -0
  91. package/dist/http.js.map +1 -0
  92. package/dist/index.d.ts +7 -0
  93. package/dist/index.js +8 -0
  94. package/dist/index.js.map +1 -0
  95. package/dist/instance.d.ts +88 -0
  96. package/dist/instance.js +594 -0
  97. package/dist/instance.js.map +1 -0
  98. package/dist/lib/acquireFileLock.d.ts +7 -0
  99. package/dist/lib/acquireFileLock.js +38 -0
  100. package/dist/lib/acquireFileLock.js.map +1 -0
  101. package/dist/lib/calculateContextIdentity.d.ts +7 -0
  102. package/dist/lib/calculateContextIdentity.js +39 -0
  103. package/dist/lib/calculateContextIdentity.js.map +1 -0
  104. package/dist/lib/calculateFileChecksum.d.ts +1 -0
  105. package/dist/lib/calculateFileChecksum.js +16 -0
  106. package/dist/lib/calculateFileChecksum.js.map +1 -0
  107. package/dist/lib/copyDirectory.d.ts +6 -0
  108. package/dist/lib/copyDirectory.js +27 -0
  109. package/dist/lib/copyDirectory.js.map +1 -0
  110. package/dist/lib/decodeAudio.d.ts +1 -0
  111. package/dist/lib/decodeAudio.js +26 -0
  112. package/dist/lib/decodeAudio.js.map +1 -0
  113. package/dist/lib/downloadModelFile.d.ts +10 -0
  114. package/dist/lib/downloadModelFile.js +58 -0
  115. package/dist/lib/downloadModelFile.js.map +1 -0
  116. package/dist/lib/flattenMessageTextContent.d.ts +2 -0
  117. package/dist/lib/flattenMessageTextContent.js +11 -0
  118. package/dist/lib/flattenMessageTextContent.js.map +1 -0
  119. package/dist/lib/getCacheDirPath.d.ts +12 -0
  120. package/dist/lib/getCacheDirPath.js +31 -0
  121. package/dist/lib/getCacheDirPath.js.map +1 -0
  122. package/dist/lib/loadImage.d.ts +12 -0
  123. package/dist/lib/loadImage.js +30 -0
  124. package/dist/lib/loadImage.js.map +1 -0
  125. package/dist/lib/logger.d.ts +12 -0
  126. package/dist/lib/logger.js +98 -0
  127. package/dist/lib/logger.js.map +1 -0
  128. package/dist/lib/math.d.ts +7 -0
  129. package/dist/lib/math.js +30 -0
  130. package/dist/lib/math.js.map +1 -0
  131. package/dist/lib/resolveModelFileLocation.d.ts +15 -0
  132. package/dist/lib/resolveModelFileLocation.js +41 -0
  133. package/dist/lib/resolveModelFileLocation.js.map +1 -0
  134. package/dist/lib/util.d.ts +7 -0
  135. package/dist/lib/util.js +61 -0
  136. package/dist/lib/util.js.map +1 -0
  137. package/dist/lib/validateModelFile.d.ts +9 -0
  138. package/dist/lib/validateModelFile.js +62 -0
  139. package/dist/lib/validateModelFile.js.map +1 -0
  140. package/dist/lib/validateModelOptions.d.ts +3 -0
  141. package/dist/lib/validateModelOptions.js +23 -0
  142. package/dist/lib/validateModelOptions.js.map +1 -0
  143. package/dist/pool.d.ts +61 -0
  144. package/dist/pool.js +512 -0
  145. package/dist/pool.js.map +1 -0
  146. package/dist/server.d.ts +59 -0
  147. package/dist/server.js +221 -0
  148. package/dist/server.js.map +1 -0
  149. package/dist/standalone.d.ts +1 -0
  150. package/dist/standalone.js +306 -0
  151. package/dist/standalone.js.map +1 -0
  152. package/dist/store.d.ts +60 -0
  153. package/dist/store.js +203 -0
  154. package/dist/store.js.map +1 -0
  155. package/dist/types/completions.d.ts +57 -0
  156. package/dist/types/completions.js +2 -0
  157. package/dist/types/completions.js.map +1 -0
  158. package/dist/types/index.d.ts +326 -0
  159. package/dist/types/index.js +2 -0
  160. package/dist/types/index.js.map +1 -0
  161. package/docs/engines.md +28 -0
  162. package/docs/gpu.md +72 -0
  163. package/docs/http-api.md +147 -0
  164. package/examples/all-options.js +108 -0
  165. package/examples/chat-cli.js +56 -0
  166. package/examples/chat-server.js +65 -0
  167. package/examples/concurrency.js +70 -0
  168. package/examples/express.js +70 -0
  169. package/examples/pool.js +91 -0
  170. package/package.json +113 -0
  171. package/src/api/openai/enums.ts +20 -0
  172. package/src/api/openai/handlers/chat.ts +408 -0
  173. package/src/api/openai/handlers/completions.ts +196 -0
  174. package/src/api/openai/handlers/embeddings.ts +92 -0
  175. package/src/api/openai/handlers/images.ts +3 -0
  176. package/src/api/openai/handlers/models.ts +33 -0
  177. package/src/api/openai/handlers/transcription.ts +2 -0
  178. package/src/api/openai/index.ts +16 -0
  179. package/src/api/parseJSONRequestBody.ts +26 -0
  180. package/src/api/v1/DRAFT.md +16 -0
  181. package/src/api/v1/index.ts +37 -0
  182. package/src/cli.ts +9 -0
  183. package/src/engines/gpt4all/engine.ts +441 -0
  184. package/src/engines/gpt4all/util.ts +31 -0
  185. package/src/engines/index.ts +28 -0
  186. package/src/engines/node-llama-cpp/engine.ts +811 -0
  187. package/src/engines/node-llama-cpp/types.ts +17 -0
  188. package/src/engines/node-llama-cpp/util.ts +126 -0
  189. package/src/engines/node-llama-cpp/validateModelFile.ts +46 -0
  190. package/src/engines/stable-diffusion-cpp/engine.ts +369 -0
  191. package/src/engines/stable-diffusion-cpp/types.ts +54 -0
  192. package/src/engines/stable-diffusion-cpp/util.ts +58 -0
  193. package/src/engines/stable-diffusion-cpp/validateModelFiles.ts +119 -0
  194. package/src/engines/transformers-js/engine.ts +659 -0
  195. package/src/engines/transformers-js/types.ts +25 -0
  196. package/src/engines/transformers-js/util.ts +40 -0
  197. package/src/engines/transformers-js/validateModelFiles.ts +168 -0
  198. package/src/experiments/ChatWithVision.ts +103 -0
  199. package/src/experiments/StableDiffPromptGenerator.ts +2 -0
  200. package/src/experiments/VoiceFunctionCall.ts +71 -0
  201. package/src/http.ts +72 -0
  202. package/src/index.ts +7 -0
  203. package/src/instance.ts +723 -0
  204. package/src/lib/acquireFileLock.ts +38 -0
  205. package/src/lib/calculateContextIdentity.ts +53 -0
  206. package/src/lib/calculateFileChecksum.ts +18 -0
  207. package/src/lib/copyDirectory.ts +29 -0
  208. package/src/lib/decodeAudio.ts +39 -0
  209. package/src/lib/downloadModelFile.ts +70 -0
  210. package/src/lib/flattenMessageTextContent.ts +19 -0
  211. package/src/lib/getCacheDirPath.ts +34 -0
  212. package/src/lib/loadImage.ts +46 -0
  213. package/src/lib/logger.ts +112 -0
  214. package/src/lib/math.ts +31 -0
  215. package/src/lib/resolveModelFileLocation.ts +49 -0
  216. package/src/lib/util.ts +75 -0
  217. package/src/lib/validateModelFile.ts +71 -0
  218. package/src/lib/validateModelOptions.ts +31 -0
  219. package/src/pool.ts +651 -0
  220. package/src/server.ts +270 -0
  221. package/src/standalone.ts +320 -0
  222. package/src/store.ts +278 -0
  223. package/src/types/completions.ts +86 -0
  224. package/src/types/index.ts +488 -0
  225. package/tsconfig.json +29 -0
  226. package/tsconfig.release.json +11 -0
  227. package/vitest.config.ts +18 -0
@@ -0,0 +1,55 @@
1
+ import StableDiffusion from '@lmagder/node-stable-diffusion-cpp';
2
+ export function parseQuantization(filename) {
3
+ // Regular expressions to match different quantization patterns
4
+ const regexPatterns = [
5
+ /q(\d+)_(\d+)/i, // q4_0
6
+ /[-_\.](f16|f32|int8|int4)/i, // f16, f32, int8, int4
7
+ /[-_\.](fp16|fp32)/i, // fp16, fp32
8
+ ];
9
+ for (const regex of regexPatterns) {
10
+ const match = filename.match(regex);
11
+ if (match) {
12
+ // If there's a match, return the full matched quantization string
13
+ // Remove leading dash if present, convert to uppercase
14
+ return match[0].replace(/^[-_]/, '').replace(/fp/i, 'f').toLowerCase();
15
+ }
16
+ }
17
+ return null;
18
+ }
19
+ export function getWeightType(key) {
20
+ const weightKey = key.toUpperCase();
21
+ if (weightKey in StableDiffusion.Type) {
22
+ return StableDiffusion.Type[weightKey];
23
+ }
24
+ console.warn('Unknown weight type', weightKey);
25
+ return undefined;
26
+ }
27
+ export function getSamplingMethod(method) {
28
+ switch (method) {
29
+ case 'euler':
30
+ return StableDiffusion.SampleMethod.Euler;
31
+ case 'euler_a':
32
+ return StableDiffusion.SampleMethod.EulerA;
33
+ case 'lcm':
34
+ return StableDiffusion.SampleMethod.LCM;
35
+ case 'heun':
36
+ return StableDiffusion.SampleMethod.Heun;
37
+ case 'dpm2':
38
+ return StableDiffusion.SampleMethod.DPM2;
39
+ case 'dpm++2s_a':
40
+ return StableDiffusion.SampleMethod.DPMPP2SA;
41
+ case 'dpm++2m':
42
+ return StableDiffusion.SampleMethod.DPMPP2M;
43
+ case 'dpm++2mv2':
44
+ return StableDiffusion.SampleMethod.DPMPP2Mv2;
45
+ case 'ipndm':
46
+ // @ts-ignore
47
+ return StableDiffusion.SampleMethod.IPNDM;
48
+ case 'ipndm_v':
49
+ // @ts-ignore
50
+ return StableDiffusion.SampleMethod.IPNDMV;
51
+ }
52
+ console.warn('Unknown sampling method', method);
53
+ return undefined;
54
+ }
55
+ //# sourceMappingURL=util.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"util.js","sourceRoot":"","sources":["../../../src/engines/stable-diffusion-cpp/util.ts"],"names":[],"mappings":"AAAA,OAAO,eAAe,MAAM,oCAAoC,CAAA;AAEhE,MAAM,UAAU,iBAAiB,CAAC,QAAgB;IACjD,+DAA+D;IAC/D,MAAM,aAAa,GAAG;QACrB,eAAe,EAAE,OAAO;QACxB,4BAA4B,EAAE,uBAAuB;QACrD,oBAAoB,EAAE,aAAa;KACnC,CAAA;IAED,KAAK,MAAM,KAAK,IAAI,aAAa,EAAE,CAAC;QACnC,MAAM,KAAK,GAAG,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,CAAA;QACnC,IAAI,KAAK,EAAE,CAAC;YACX,kEAAkE;YAClE,uDAAuD;YACvD,OAAO,KAAK,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC,WAAW,EAAE,CAAA;QACvE,CAAC;IACF,CAAC;IACD,OAAO,IAAI,CAAA;AACZ,CAAC;AAED,MAAM,UAAU,aAAa,CAAC,GAAW;IACxC,MAAM,SAAS,GAAG,GAAG,CAAC,WAAW,EAAuC,CAAA;IACxE,IAAI,SAAS,IAAI,eAAe,CAAC,IAAI,EAAE,CAAC;QACvC,OAAO,eAAe,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;IACvC,CAAC;IACD,OAAO,CAAC,IAAI,CAAC,qBAAqB,EAAE,SAAS,CAAC,CAAA;IAC9C,OAAO,SAAS,CAAA;AACjB,CAAC;AAED,MAAM,UAAU,iBAAiB,CAAC,MAAe;IAChD,QAAQ,MAAM,EAAE,CAAC;QAChB,KAAK,OAAO;YACX,OAAO,eAAe,CAAC,YAAY,CAAC,KAAK,CAAA;QAC1C,KAAK,SAAS;YACb,OAAO,eAAe,CAAC,YAAY,CAAC,MAAM,CAAA;QAC3C,KAAK,KAAK;YACT,OAAO,eAAe,CAAC,YAAY,CAAC,GAAG,CAAA;QACxC,KAAK,MAAM;YACV,OAAO,eAAe,CAAC,YAAY,CAAC,IAAI,CAAA;QACzC,KAAK,MAAM;YACV,OAAO,eAAe,CAAC,YAAY,CAAC,IAAI,CAAA;QACzC,KAAK,WAAW;YACf,OAAO,eAAe,CAAC,YAAY,CAAC,QAAQ,CAAA;QAC7C,KAAK,SAAS;YACb,OAAO,eAAe,CAAC,YAAY,CAAC,OAAO,CAAA;QAC5C,KAAK,WAAW;YACf,OAAO,eAAe,CAAC,YAAY,CAAC,SAAS,CAAA;QAC9C,KAAK,OAAO;YACX,aAAa;YACb,OAAO,eAAe,CAAC,YAAY,CAAC,KAAK,CAAA;QAC1C,KAAK,SAAS;YACb,aAAa;YACb,OAAO,eAAe,CAAC,YAAY,CAAC,MAAM,CAAA;IAC5C,CAAC;IACD,OAAO,CAAC,IAAI,CAAC,yBAAyB,EAAE,MAAM,CAAC,CAAA;IAC/C,OAAO,SAAS,CAAA;AACjB,CAAC"}
@@ -0,0 +1,19 @@
1
+ import { StableDiffusionModelConfig } from './engine.js';
2
+ interface ModelValidationErrors {
3
+ model?: string;
4
+ clipL?: string;
5
+ clipG?: string;
6
+ vae?: string;
7
+ t5xxl?: string;
8
+ controlNet?: string;
9
+ taesd?: string;
10
+ lora?: {
11
+ [index: number]: string;
12
+ };
13
+ }
14
+ export interface ModelValidationResult {
15
+ message: string;
16
+ errors: ModelValidationErrors;
17
+ }
18
+ export declare function validateModelFiles(config: StableDiffusionModelConfig): Promise<ModelValidationResult | undefined>;
19
+ export {};
@@ -0,0 +1,91 @@
1
+ import fs from 'node:fs';
2
+ import { calculateFileChecksum } from '../../lib/calculateFileChecksum.js';
3
+ import { resolveModelFileLocation } from '../../lib/resolveModelFileLocation.js';
4
+ export async function validateModelFiles(config) {
5
+ const validateFile = async (component, src) => {
6
+ const fileLocation = resolveModelFileLocation({
7
+ url: src.url,
8
+ filePath: src.file,
9
+ modelsCachePath: config.modelsCachePath,
10
+ });
11
+ if (!fs.existsSync(fileLocation)) {
12
+ return {
13
+ component,
14
+ message: `${component} file missing at ${fileLocation}`,
15
+ };
16
+ }
17
+ const ipullFile = fileLocation + '.ipull';
18
+ let validatedChecksum = false;
19
+ if (fs.existsSync(ipullFile)) {
20
+ // if we have a valid file at the download destination, we can remove the ipull file
21
+ if (src.sha256) {
22
+ const fileHash = await calculateFileChecksum(fileLocation, 'sha256');
23
+ if (fileHash === src.sha256) {
24
+ fs.unlinkSync(ipullFile);
25
+ validatedChecksum = true;
26
+ }
27
+ }
28
+ if (!validatedChecksum) {
29
+ return {
30
+ component,
31
+ message: `${component} with incomplete download`,
32
+ };
33
+ }
34
+ }
35
+ if (!validatedChecksum && src.sha256) {
36
+ const fileHash = await calculateFileChecksum(fileLocation, 'sha256');
37
+ if (fileHash !== src.sha256) {
38
+ return {
39
+ component,
40
+ message: `${component} file sha256 checksum mismatch: expected ${src.sha256} got ${fileHash} at ${fileLocation}`,
41
+ };
42
+ }
43
+ }
44
+ return undefined;
45
+ };
46
+ const validationPromises = [];
47
+ if (config.clipL) {
48
+ validationPromises.push(validateFile('clipL', config.clipL));
49
+ }
50
+ if (config.clipG) {
51
+ validationPromises.push(validateFile('clipG', config.clipG));
52
+ }
53
+ if (config.vae) {
54
+ validationPromises.push(validateFile('vae', config.vae));
55
+ }
56
+ if (config.t5xxl) {
57
+ validationPromises.push(validateFile('t5xxl', config.t5xxl));
58
+ }
59
+ if (config.controlNet) {
60
+ validationPromises.push(validateFile('controlNet', config.controlNet));
61
+ }
62
+ if (config.taesd) {
63
+ validationPromises.push(validateFile('taesd', config.taesd));
64
+ }
65
+ if (config.sha256) {
66
+ validationPromises.push(validateFile('model', { file: config.location, sha256: config.sha256 }));
67
+ }
68
+ // const loraDir = path.join(path.dirname(config.location), 'lora')
69
+ if (config.loras) {
70
+ for (const lora of config.loras) {
71
+ validationPromises.push(validateFile('lora', lora));
72
+ // const loraFile = path.join(loraDir, getModelFileName(lora))
73
+ // if (!fs.existsSync(loraFile)) {
74
+ // return `lora file missing: ${loraFile}`
75
+ // }
76
+ }
77
+ }
78
+ const res = await Promise.all(validationPromises);
79
+ const validationErrors = res.filter((e) => !!e);
80
+ if (validationErrors.length) {
81
+ return {
82
+ message: 'Invalid model files',
83
+ errors: validationErrors.reduce((acc, e) => {
84
+ acc[e.component] = e.message;
85
+ return acc;
86
+ }, {}),
87
+ };
88
+ }
89
+ return undefined;
90
+ }
91
+ //# sourceMappingURL=validateModelFiles.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"validateModelFiles.js","sourceRoot":"","sources":["../../../src/engines/stable-diffusion-cpp/validateModelFiles.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,37 @@
1
+ import { EngineContext, FileDownloadProgress, ModelConfig, EngineImageToTextArgs, EngineSpeechToTextArgs, EngineTextCompletionResult, EngineTextCompletionArgs, EngineEmbeddingArgs, EngineEmbeddingResult, TransformersJsModel } from '../../types/index.js';
2
+ import { Processor, PreTrainedModel, PreTrainedTokenizer } from '@huggingface/transformers';
3
+ interface TransformersJsModelComponents {
4
+ model?: PreTrainedModel;
5
+ processor?: Processor;
6
+ tokenizer?: PreTrainedTokenizer;
7
+ }
8
+ interface TransformersJsInstance {
9
+ textModel?: TransformersJsModelComponents;
10
+ visionModel?: TransformersJsModelComponents;
11
+ speechModel?: TransformersJsModelComponents;
12
+ }
13
+ export interface TransformersJsModelConfig extends ModelConfig {
14
+ location: string;
15
+ url: string;
16
+ textModel?: TransformersJsModel;
17
+ visionModel?: TransformersJsModel;
18
+ speechModel?: TransformersJsModel;
19
+ device?: {
20
+ gpu?: boolean | 'auto' | (string & {});
21
+ };
22
+ }
23
+ export declare const autoGpu = true;
24
+ export declare function prepareModel({ config, log }: EngineContext<TransformersJsModelConfig>, onProgress?: (progress: FileDownloadProgress) => void, signal?: AbortSignal): Promise<{
25
+ files: string[] | Buffer[];
26
+ } | undefined>;
27
+ export declare function createInstance({ config, log }: EngineContext<TransformersJsModelConfig>, signal?: AbortSignal): Promise<TransformersJsInstance>;
28
+ export declare function disposeInstance(instance: TransformersJsInstance): Promise<void>;
29
+ export declare function processTextCompletionTask({ request, config, log, onChunk }: EngineTextCompletionArgs<TransformersJsModelConfig>, instance: TransformersJsInstance, signal?: AbortSignal): Promise<EngineTextCompletionResult>;
30
+ export declare function processEmbeddingTask({ request, config }: EngineEmbeddingArgs<TransformersJsModelConfig>, instance: TransformersJsInstance, signal?: AbortSignal): Promise<EngineEmbeddingResult>;
31
+ export declare function processImageToTextTask({ request, config, log }: EngineImageToTextArgs, instance: TransformersJsInstance, signal?: AbortSignal): Promise<{
32
+ text: string;
33
+ } | undefined>;
34
+ export declare function processSpeechToTextTask({ request, onChunk }: EngineSpeechToTextArgs, instance: TransformersJsInstance, signal?: AbortSignal): Promise<{
35
+ text: string;
36
+ }>;
37
+ export {};