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.
- package/README.md +216 -0
- package/dist/api/openai/enums.d.ts +4 -0
- package/dist/api/openai/enums.js +17 -0
- package/dist/api/openai/enums.js.map +1 -0
- package/dist/api/openai/handlers/chat.d.ts +3 -0
- package/dist/api/openai/handlers/chat.js +358 -0
- package/dist/api/openai/handlers/chat.js.map +1 -0
- package/dist/api/openai/handlers/completions.d.ts +3 -0
- package/dist/api/openai/handlers/completions.js +169 -0
- package/dist/api/openai/handlers/completions.js.map +1 -0
- package/dist/api/openai/handlers/embeddings.d.ts +3 -0
- package/dist/api/openai/handlers/embeddings.js +74 -0
- package/dist/api/openai/handlers/embeddings.js.map +1 -0
- package/dist/api/openai/handlers/images.d.ts +0 -0
- package/dist/api/openai/handlers/images.js +4 -0
- package/dist/api/openai/handlers/images.js.map +1 -0
- package/dist/api/openai/handlers/models.d.ts +3 -0
- package/dist/api/openai/handlers/models.js +23 -0
- package/dist/api/openai/handlers/models.js.map +1 -0
- package/dist/api/openai/handlers/transcription.d.ts +0 -0
- package/dist/api/openai/handlers/transcription.js +4 -0
- package/dist/api/openai/handlers/transcription.js.map +1 -0
- package/dist/api/openai/index.d.ts +7 -0
- package/dist/api/openai/index.js +14 -0
- package/dist/api/openai/index.js.map +1 -0
- package/dist/api/parseJSONRequestBody.d.ts +2 -0
- package/dist/api/parseJSONRequestBody.js +24 -0
- package/dist/api/parseJSONRequestBody.js.map +1 -0
- package/dist/api/v1/index.d.ts +2 -0
- package/dist/api/v1/index.js +29 -0
- package/dist/api/v1/index.js.map +1 -0
- package/dist/cli.d.ts +1 -0
- package/dist/cli.js +10 -0
- package/dist/cli.js.map +1 -0
- package/dist/engines/gpt4all/engine.d.ts +34 -0
- package/dist/engines/gpt4all/engine.js +357 -0
- package/dist/engines/gpt4all/engine.js.map +1 -0
- package/dist/engines/gpt4all/util.d.ts +3 -0
- package/dist/engines/gpt4all/util.js +29 -0
- package/dist/engines/gpt4all/util.js.map +1 -0
- package/dist/engines/index.d.ts +19 -0
- package/dist/engines/index.js +21 -0
- package/dist/engines/index.js.map +1 -0
- package/dist/engines/node-llama-cpp/engine.d.ts +49 -0
- package/dist/engines/node-llama-cpp/engine.js +666 -0
- package/dist/engines/node-llama-cpp/engine.js.map +1 -0
- package/dist/engines/node-llama-cpp/types.d.ts +13 -0
- package/dist/engines/node-llama-cpp/types.js +2 -0
- package/dist/engines/node-llama-cpp/types.js.map +1 -0
- package/dist/engines/node-llama-cpp/util.d.ts +15 -0
- package/dist/engines/node-llama-cpp/util.js +84 -0
- package/dist/engines/node-llama-cpp/util.js.map +1 -0
- package/dist/engines/node-llama-cpp/validateModelFile.d.ts +8 -0
- package/dist/engines/node-llama-cpp/validateModelFile.js +36 -0
- package/dist/engines/node-llama-cpp/validateModelFile.js.map +1 -0
- package/dist/engines/stable-diffusion-cpp/engine.d.ts +90 -0
- package/dist/engines/stable-diffusion-cpp/engine.js +294 -0
- package/dist/engines/stable-diffusion-cpp/engine.js.map +1 -0
- package/dist/engines/stable-diffusion-cpp/types.d.ts +3 -0
- package/dist/engines/stable-diffusion-cpp/types.js +2 -0
- package/dist/engines/stable-diffusion-cpp/types.js.map +1 -0
- package/dist/engines/stable-diffusion-cpp/util.d.ts +4 -0
- package/dist/engines/stable-diffusion-cpp/util.js +55 -0
- package/dist/engines/stable-diffusion-cpp/util.js.map +1 -0
- package/dist/engines/stable-diffusion-cpp/validateModelFiles.d.ts +19 -0
- package/dist/engines/stable-diffusion-cpp/validateModelFiles.js +91 -0
- package/dist/engines/stable-diffusion-cpp/validateModelFiles.js.map +1 -0
- package/dist/engines/transformers-js/engine.d.ts +37 -0
- package/dist/engines/transformers-js/engine.js +538 -0
- package/dist/engines/transformers-js/engine.js.map +1 -0
- package/dist/engines/transformers-js/types.d.ts +7 -0
- package/dist/engines/transformers-js/types.js +2 -0
- package/dist/engines/transformers-js/types.js.map +1 -0
- package/dist/engines/transformers-js/util.d.ts +7 -0
- package/dist/engines/transformers-js/util.js +36 -0
- package/dist/engines/transformers-js/util.js.map +1 -0
- package/dist/engines/transformers-js/validateModelFiles.d.ts +17 -0
- package/dist/engines/transformers-js/validateModelFiles.js +133 -0
- package/dist/engines/transformers-js/validateModelFiles.js.map +1 -0
- package/dist/experiments/ChatWithVision.d.ts +11 -0
- package/dist/experiments/ChatWithVision.js +91 -0
- package/dist/experiments/ChatWithVision.js.map +1 -0
- package/dist/experiments/StableDiffPromptGenerator.d.ts +0 -0
- package/dist/experiments/StableDiffPromptGenerator.js +4 -0
- package/dist/experiments/StableDiffPromptGenerator.js.map +1 -0
- package/dist/experiments/VoiceFunctionCall.d.ts +18 -0
- package/dist/experiments/VoiceFunctionCall.js +51 -0
- package/dist/experiments/VoiceFunctionCall.js.map +1 -0
- package/dist/http.d.ts +19 -0
- package/dist/http.js +54 -0
- package/dist/http.js.map +1 -0
- package/dist/index.d.ts +7 -0
- package/dist/index.js +8 -0
- package/dist/index.js.map +1 -0
- package/dist/instance.d.ts +88 -0
- package/dist/instance.js +594 -0
- package/dist/instance.js.map +1 -0
- package/dist/lib/acquireFileLock.d.ts +7 -0
- package/dist/lib/acquireFileLock.js +38 -0
- package/dist/lib/acquireFileLock.js.map +1 -0
- package/dist/lib/calculateContextIdentity.d.ts +7 -0
- package/dist/lib/calculateContextIdentity.js +39 -0
- package/dist/lib/calculateContextIdentity.js.map +1 -0
- package/dist/lib/calculateFileChecksum.d.ts +1 -0
- package/dist/lib/calculateFileChecksum.js +16 -0
- package/dist/lib/calculateFileChecksum.js.map +1 -0
- package/dist/lib/copyDirectory.d.ts +6 -0
- package/dist/lib/copyDirectory.js +27 -0
- package/dist/lib/copyDirectory.js.map +1 -0
- package/dist/lib/decodeAudio.d.ts +1 -0
- package/dist/lib/decodeAudio.js +26 -0
- package/dist/lib/decodeAudio.js.map +1 -0
- package/dist/lib/downloadModelFile.d.ts +10 -0
- package/dist/lib/downloadModelFile.js +58 -0
- package/dist/lib/downloadModelFile.js.map +1 -0
- package/dist/lib/flattenMessageTextContent.d.ts +2 -0
- package/dist/lib/flattenMessageTextContent.js +11 -0
- package/dist/lib/flattenMessageTextContent.js.map +1 -0
- package/dist/lib/getCacheDirPath.d.ts +12 -0
- package/dist/lib/getCacheDirPath.js +31 -0
- package/dist/lib/getCacheDirPath.js.map +1 -0
- package/dist/lib/loadImage.d.ts +12 -0
- package/dist/lib/loadImage.js +30 -0
- package/dist/lib/loadImage.js.map +1 -0
- package/dist/lib/logger.d.ts +12 -0
- package/dist/lib/logger.js +98 -0
- package/dist/lib/logger.js.map +1 -0
- package/dist/lib/math.d.ts +7 -0
- package/dist/lib/math.js +30 -0
- package/dist/lib/math.js.map +1 -0
- package/dist/lib/resolveModelFileLocation.d.ts +15 -0
- package/dist/lib/resolveModelFileLocation.js +41 -0
- package/dist/lib/resolveModelFileLocation.js.map +1 -0
- package/dist/lib/util.d.ts +7 -0
- package/dist/lib/util.js +61 -0
- package/dist/lib/util.js.map +1 -0
- package/dist/lib/validateModelFile.d.ts +9 -0
- package/dist/lib/validateModelFile.js +62 -0
- package/dist/lib/validateModelFile.js.map +1 -0
- package/dist/lib/validateModelOptions.d.ts +3 -0
- package/dist/lib/validateModelOptions.js +23 -0
- package/dist/lib/validateModelOptions.js.map +1 -0
- package/dist/pool.d.ts +61 -0
- package/dist/pool.js +512 -0
- package/dist/pool.js.map +1 -0
- package/dist/server.d.ts +59 -0
- package/dist/server.js +221 -0
- package/dist/server.js.map +1 -0
- package/dist/standalone.d.ts +1 -0
- package/dist/standalone.js +306 -0
- package/dist/standalone.js.map +1 -0
- package/dist/store.d.ts +60 -0
- package/dist/store.js +203 -0
- package/dist/store.js.map +1 -0
- package/dist/types/completions.d.ts +57 -0
- package/dist/types/completions.js +2 -0
- package/dist/types/completions.js.map +1 -0
- package/dist/types/index.d.ts +326 -0
- package/dist/types/index.js +2 -0
- package/dist/types/index.js.map +1 -0
- package/docs/engines.md +28 -0
- package/docs/gpu.md +72 -0
- package/docs/http-api.md +147 -0
- package/examples/all-options.js +108 -0
- package/examples/chat-cli.js +56 -0
- package/examples/chat-server.js +65 -0
- package/examples/concurrency.js +70 -0
- package/examples/express.js +70 -0
- package/examples/pool.js +91 -0
- package/package.json +113 -0
- package/src/api/openai/enums.ts +20 -0
- package/src/api/openai/handlers/chat.ts +408 -0
- package/src/api/openai/handlers/completions.ts +196 -0
- package/src/api/openai/handlers/embeddings.ts +92 -0
- package/src/api/openai/handlers/images.ts +3 -0
- package/src/api/openai/handlers/models.ts +33 -0
- package/src/api/openai/handlers/transcription.ts +2 -0
- package/src/api/openai/index.ts +16 -0
- package/src/api/parseJSONRequestBody.ts +26 -0
- package/src/api/v1/DRAFT.md +16 -0
- package/src/api/v1/index.ts +37 -0
- package/src/cli.ts +9 -0
- package/src/engines/gpt4all/engine.ts +441 -0
- package/src/engines/gpt4all/util.ts +31 -0
- package/src/engines/index.ts +28 -0
- package/src/engines/node-llama-cpp/engine.ts +811 -0
- package/src/engines/node-llama-cpp/types.ts +17 -0
- package/src/engines/node-llama-cpp/util.ts +126 -0
- package/src/engines/node-llama-cpp/validateModelFile.ts +46 -0
- package/src/engines/stable-diffusion-cpp/engine.ts +369 -0
- package/src/engines/stable-diffusion-cpp/types.ts +54 -0
- package/src/engines/stable-diffusion-cpp/util.ts +58 -0
- package/src/engines/stable-diffusion-cpp/validateModelFiles.ts +119 -0
- package/src/engines/transformers-js/engine.ts +659 -0
- package/src/engines/transformers-js/types.ts +25 -0
- package/src/engines/transformers-js/util.ts +40 -0
- package/src/engines/transformers-js/validateModelFiles.ts +168 -0
- package/src/experiments/ChatWithVision.ts +103 -0
- package/src/experiments/StableDiffPromptGenerator.ts +2 -0
- package/src/experiments/VoiceFunctionCall.ts +71 -0
- package/src/http.ts +72 -0
- package/src/index.ts +7 -0
- package/src/instance.ts +723 -0
- package/src/lib/acquireFileLock.ts +38 -0
- package/src/lib/calculateContextIdentity.ts +53 -0
- package/src/lib/calculateFileChecksum.ts +18 -0
- package/src/lib/copyDirectory.ts +29 -0
- package/src/lib/decodeAudio.ts +39 -0
- package/src/lib/downloadModelFile.ts +70 -0
- package/src/lib/flattenMessageTextContent.ts +19 -0
- package/src/lib/getCacheDirPath.ts +34 -0
- package/src/lib/loadImage.ts +46 -0
- package/src/lib/logger.ts +112 -0
- package/src/lib/math.ts +31 -0
- package/src/lib/resolveModelFileLocation.ts +49 -0
- package/src/lib/util.ts +75 -0
- package/src/lib/validateModelFile.ts +71 -0
- package/src/lib/validateModelOptions.ts +31 -0
- package/src/pool.ts +651 -0
- package/src/server.ts +270 -0
- package/src/standalone.ts +320 -0
- package/src/store.ts +278 -0
- package/src/types/completions.ts +86 -0
- package/src/types/index.ts +488 -0
- package/tsconfig.json +29 -0
- package/tsconfig.release.json +11 -0
- 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 {};
|