@llumiverse/drivers 0.8.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.
- package/lib/cjs/bedrock/index.js +338 -0
- package/lib/cjs/bedrock/index.js.map +1 -0
- package/lib/cjs/bedrock/s3.js +61 -0
- package/lib/cjs/bedrock/s3.js.map +1 -0
- package/lib/cjs/huggingface_ie.js +181 -0
- package/lib/cjs/huggingface_ie.js.map +1 -0
- package/lib/cjs/index.js +24 -0
- package/lib/cjs/index.js.map +1 -0
- package/lib/cjs/openai.js +205 -0
- package/lib/cjs/openai.js.map +1 -0
- package/lib/cjs/package.json +3 -0
- package/lib/cjs/replicate.js +290 -0
- package/lib/cjs/replicate.js.map +1 -0
- package/lib/cjs/test/TestErrorCompletionStream.js +20 -0
- package/lib/cjs/test/TestErrorCompletionStream.js.map +1 -0
- package/lib/cjs/test/TestValidationErrorCompletionStream.js +24 -0
- package/lib/cjs/test/TestValidationErrorCompletionStream.js.map +1 -0
- package/lib/cjs/test/index.js +109 -0
- package/lib/cjs/test/index.js.map +1 -0
- package/lib/cjs/test/utils.js +31 -0
- package/lib/cjs/test/utils.js.map +1 -0
- package/lib/cjs/togetherai/index.js +92 -0
- package/lib/cjs/togetherai/index.js.map +1 -0
- package/lib/cjs/togetherai/interfaces.js +3 -0
- package/lib/cjs/togetherai/interfaces.js.map +1 -0
- package/lib/cjs/vertexai/debug.js +13 -0
- package/lib/cjs/vertexai/debug.js.map +1 -0
- package/lib/cjs/vertexai/index.js +80 -0
- package/lib/cjs/vertexai/index.js.map +1 -0
- package/lib/cjs/vertexai/models/codey-chat.js +65 -0
- package/lib/cjs/vertexai/models/codey-chat.js.map +1 -0
- package/lib/cjs/vertexai/models/codey-text.js +35 -0
- package/lib/cjs/vertexai/models/codey-text.js.map +1 -0
- package/lib/cjs/vertexai/models/gemini.js +140 -0
- package/lib/cjs/vertexai/models/gemini.js.map +1 -0
- package/lib/cjs/vertexai/models/palm-model-base.js +65 -0
- package/lib/cjs/vertexai/models/palm-model-base.js.map +1 -0
- package/lib/cjs/vertexai/models/palm2-chat.js +65 -0
- package/lib/cjs/vertexai/models/palm2-chat.js.map +1 -0
- package/lib/cjs/vertexai/models/palm2-text.js +35 -0
- package/lib/cjs/vertexai/models/palm2-text.js.map +1 -0
- package/lib/cjs/vertexai/models.js +93 -0
- package/lib/cjs/vertexai/models.js.map +1 -0
- package/lib/cjs/vertexai/utils/prompts.js +52 -0
- package/lib/cjs/vertexai/utils/prompts.js.map +1 -0
- package/lib/cjs/vertexai/utils/tensor.js +87 -0
- package/lib/cjs/vertexai/utils/tensor.js.map +1 -0
- package/lib/esm/bedrock/index.js +331 -0
- package/lib/esm/bedrock/index.js.map +1 -0
- package/lib/esm/bedrock/s3.js +53 -0
- package/lib/esm/bedrock/s3.js.map +1 -0
- package/lib/esm/huggingface_ie.js +177 -0
- package/lib/esm/huggingface_ie.js.map +1 -0
- package/lib/esm/index.js +8 -0
- package/lib/esm/index.js.map +1 -0
- package/lib/esm/openai.js +198 -0
- package/lib/esm/openai.js.map +1 -0
- package/lib/esm/replicate.js +283 -0
- package/lib/esm/replicate.js.map +1 -0
- package/lib/esm/test/TestErrorCompletionStream.js +16 -0
- package/lib/esm/test/TestErrorCompletionStream.js.map +1 -0
- package/lib/esm/test/TestValidationErrorCompletionStream.js +20 -0
- package/lib/esm/test/TestValidationErrorCompletionStream.js.map +1 -0
- package/lib/esm/test/index.js +91 -0
- package/lib/esm/test/index.js.map +1 -0
- package/lib/esm/test/utils.js +25 -0
- package/lib/esm/test/utils.js.map +1 -0
- package/lib/esm/togetherai/index.js +88 -0
- package/lib/esm/togetherai/index.js.map +1 -0
- package/lib/esm/togetherai/interfaces.js +2 -0
- package/lib/esm/togetherai/interfaces.js.map +1 -0
- package/lib/esm/vertexai/debug.js +6 -0
- package/lib/esm/vertexai/debug.js.map +1 -0
- package/lib/esm/vertexai/index.js +76 -0
- package/lib/esm/vertexai/index.js.map +1 -0
- package/lib/esm/vertexai/models/codey-chat.js +61 -0
- package/lib/esm/vertexai/models/codey-chat.js.map +1 -0
- package/lib/esm/vertexai/models/codey-text.js +31 -0
- package/lib/esm/vertexai/models/codey-text.js.map +1 -0
- package/lib/esm/vertexai/models/gemini.js +136 -0
- package/lib/esm/vertexai/models/gemini.js.map +1 -0
- package/lib/esm/vertexai/models/palm-model-base.js +61 -0
- package/lib/esm/vertexai/models/palm-model-base.js.map +1 -0
- package/lib/esm/vertexai/models/palm2-chat.js +61 -0
- package/lib/esm/vertexai/models/palm2-chat.js.map +1 -0
- package/lib/esm/vertexai/models/palm2-text.js +31 -0
- package/lib/esm/vertexai/models/palm2-text.js.map +1 -0
- package/lib/esm/vertexai/models.js +87 -0
- package/lib/esm/vertexai/models.js.map +1 -0
- package/lib/esm/vertexai/utils/prompts.js +47 -0
- package/lib/esm/vertexai/utils/prompts.js.map +1 -0
- package/lib/esm/vertexai/utils/tensor.js +82 -0
- package/lib/esm/vertexai/utils/tensor.js.map +1 -0
- package/lib/types/bedrock/index.d.ts +88 -0
- package/lib/types/bedrock/index.d.ts.map +1 -0
- package/lib/types/bedrock/s3.d.ts +20 -0
- package/lib/types/bedrock/s3.d.ts.map +1 -0
- package/lib/types/huggingface_ie.d.ts +36 -0
- package/lib/types/huggingface_ie.d.ts.map +1 -0
- package/lib/types/index.d.ts +8 -0
- package/lib/types/index.d.ts.map +1 -0
- package/lib/types/openai.d.ts +36 -0
- package/lib/types/openai.d.ts.map +1 -0
- package/lib/types/replicate.d.ts +52 -0
- package/lib/types/replicate.d.ts.map +1 -0
- package/lib/types/test/TestErrorCompletionStream.d.ts +9 -0
- package/lib/types/test/TestErrorCompletionStream.d.ts.map +1 -0
- package/lib/types/test/TestValidationErrorCompletionStream.d.ts +9 -0
- package/lib/types/test/TestValidationErrorCompletionStream.d.ts.map +1 -0
- package/lib/types/test/index.d.ts +27 -0
- package/lib/types/test/index.d.ts.map +1 -0
- package/lib/types/test/utils.d.ts +5 -0
- package/lib/types/test/utils.d.ts.map +1 -0
- package/lib/types/togetherai/index.d.ts +23 -0
- package/lib/types/togetherai/index.d.ts.map +1 -0
- package/lib/types/togetherai/interfaces.d.ts +81 -0
- package/lib/types/togetherai/interfaces.d.ts.map +1 -0
- package/lib/types/vertexai/debug.d.ts +2 -0
- package/lib/types/vertexai/debug.d.ts.map +1 -0
- package/lib/types/vertexai/index.d.ts +26 -0
- package/lib/types/vertexai/index.d.ts.map +1 -0
- package/lib/types/vertexai/models/codey-chat.d.ts +51 -0
- package/lib/types/vertexai/models/codey-chat.d.ts.map +1 -0
- package/lib/types/vertexai/models/codey-text.d.ts +39 -0
- package/lib/types/vertexai/models/codey-text.d.ts.map +1 -0
- package/lib/types/vertexai/models/gemini.d.ts +11 -0
- package/lib/types/vertexai/models/gemini.d.ts.map +1 -0
- package/lib/types/vertexai/models/palm-model-base.d.ts +47 -0
- package/lib/types/vertexai/models/palm-model-base.d.ts.map +1 -0
- package/lib/types/vertexai/models/palm2-chat.d.ts +61 -0
- package/lib/types/vertexai/models/palm2-chat.d.ts.map +1 -0
- package/lib/types/vertexai/models/palm2-text.d.ts +39 -0
- package/lib/types/vertexai/models/palm2-text.d.ts.map +1 -0
- package/lib/types/vertexai/models.d.ts +14 -0
- package/lib/types/vertexai/models.d.ts.map +1 -0
- package/lib/types/vertexai/utils/prompts.d.ts +20 -0
- package/lib/types/vertexai/utils/prompts.d.ts.map +1 -0
- package/lib/types/vertexai/utils/tensor.d.ts +6 -0
- package/lib/types/vertexai/utils/tensor.d.ts.map +1 -0
- package/package.json +72 -0
- package/src/bedrock/index.ts +456 -0
- package/src/bedrock/s3.ts +62 -0
- package/src/huggingface_ie.ts +269 -0
- package/src/index.ts +7 -0
- package/src/openai.ts +254 -0
- package/src/replicate.ts +333 -0
- package/src/test/TestErrorCompletionStream.ts +17 -0
- package/src/test/TestValidationErrorCompletionStream.ts +21 -0
- package/src/test/index.ts +102 -0
- package/src/test/utils.ts +28 -0
- package/src/togetherai/index.ts +105 -0
- package/src/togetherai/interfaces.ts +88 -0
- package/src/vertexai/README.md +257 -0
- package/src/vertexai/debug.ts +6 -0
- package/src/vertexai/index.ts +99 -0
- package/src/vertexai/models/codey-chat.ts +115 -0
- package/src/vertexai/models/codey-text.ts +69 -0
- package/src/vertexai/models/gemini.ts +152 -0
- package/src/vertexai/models/palm-model-base.ts +122 -0
- package/src/vertexai/models/palm2-chat.ts +119 -0
- package/src/vertexai/models/palm2-text.ts +69 -0
- package/src/vertexai/models.ts +104 -0
- package/src/vertexai/utils/prompts.ts +66 -0
- package/src/vertexai/utils/tensor.ts +82 -0
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
export function throwError(message, prompt) {
|
|
2
|
+
const err = new Error(message);
|
|
3
|
+
err.prompt = prompt;
|
|
4
|
+
throw err;
|
|
5
|
+
}
|
|
6
|
+
export function createValidationErrorCompletion(segments) {
|
|
7
|
+
return {
|
|
8
|
+
result: "An invalid result",
|
|
9
|
+
prompt: segments,
|
|
10
|
+
execution_time: 3000,
|
|
11
|
+
error: {
|
|
12
|
+
code: "validation_error",
|
|
13
|
+
message: "Result cannot be validated!",
|
|
14
|
+
},
|
|
15
|
+
token_usage: {
|
|
16
|
+
result: 10,
|
|
17
|
+
prompt: 10,
|
|
18
|
+
total: 20,
|
|
19
|
+
},
|
|
20
|
+
};
|
|
21
|
+
}
|
|
22
|
+
export function sleep(ms) {
|
|
23
|
+
return new Promise(resolve => setTimeout(resolve, ms));
|
|
24
|
+
}
|
|
25
|
+
//# sourceMappingURL=utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/test/utils.ts"],"names":[],"mappings":"AAEA,MAAM,UAAU,UAAU,CAAC,OAAe,EAAE,MAAuB;IAC/D,MAAM,GAAG,GAAG,IAAI,KAAK,CAAC,OAAO,CAAC,CAAC;IAC9B,GAAW,CAAC,MAAM,GAAG,MAAM,CAAC;IAC7B,MAAM,GAAG,CAAC;AACd,CAAC;AAED,MAAM,UAAU,+BAA+B,CAAC,QAAyB;IACrE,OAAO;QACH,MAAM,EAAE,mBAAmB;QAC3B,MAAM,EAAE,QAAQ;QAChB,cAAc,EAAE,IAAI;QACpB,KAAK,EAAE;YACH,IAAI,EAAE,kBAAkB;YACxB,OAAO,EAAE,6BAA6B;SACzC;QACD,WAAW,EAAE;YACT,MAAM,EAAE,EAAE;YACV,MAAM,EAAE,EAAE;YACV,KAAK,EAAE,EAAE;SACZ;KACkC,CAAC;AAC5C,CAAC;AAED,MAAM,UAAU,KAAK,CAAC,EAAU;IAC5B,OAAO,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,CAAC;AAC3D,CAAC"}
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
import { AbstractDriver, PromptFormats } from "@llumiverse/core";
|
|
2
|
+
import { FetchClient } from "api-fetch-client";
|
|
3
|
+
export class TogetherAIDriver extends AbstractDriver {
|
|
4
|
+
provider;
|
|
5
|
+
apiKey;
|
|
6
|
+
defaultFormat;
|
|
7
|
+
fetchClient;
|
|
8
|
+
constructor(options) {
|
|
9
|
+
super(options);
|
|
10
|
+
this.provider = "togetherai";
|
|
11
|
+
this.defaultFormat = PromptFormats.genericTextLLM;
|
|
12
|
+
this.apiKey = options.apiKey;
|
|
13
|
+
this.fetchClient = new FetchClient('https://api.together.xyz').withHeaders({
|
|
14
|
+
authorization: `Bearer ${this.apiKey}`
|
|
15
|
+
});
|
|
16
|
+
}
|
|
17
|
+
async requestCompletion(prompt, options) {
|
|
18
|
+
const res = await this.fetchClient.post('/v1/completions', {
|
|
19
|
+
payload: {
|
|
20
|
+
model: options.model,
|
|
21
|
+
prompt: prompt,
|
|
22
|
+
max_tokens: options.max_tokens ?? 1024,
|
|
23
|
+
temperature: options.temperature ?? 0.7,
|
|
24
|
+
}
|
|
25
|
+
});
|
|
26
|
+
const text = res.choices[0]?.text ?? '';
|
|
27
|
+
const usage = res.usage || {};
|
|
28
|
+
return {
|
|
29
|
+
result: text,
|
|
30
|
+
token_usage: {
|
|
31
|
+
prompt: usage.prompt_tokens,
|
|
32
|
+
result: usage.completion_tokens,
|
|
33
|
+
total: usage.total_tokens,
|
|
34
|
+
},
|
|
35
|
+
};
|
|
36
|
+
}
|
|
37
|
+
async requestCompletionStream(prompt, options) {
|
|
38
|
+
const stream = await this.fetchClient.post('/v1/completions', {
|
|
39
|
+
payload: {
|
|
40
|
+
model: options.model,
|
|
41
|
+
prompt: prompt,
|
|
42
|
+
max_tokens: options.max_tokens ?? 1024,
|
|
43
|
+
temperature: options.temperature ?? 0.7,
|
|
44
|
+
stream: true,
|
|
45
|
+
},
|
|
46
|
+
reader: 'sse'
|
|
47
|
+
});
|
|
48
|
+
return stream.pipeThrough(new TransformStream({
|
|
49
|
+
transform(event, controller) {
|
|
50
|
+
if (event.type === 'event' && event.data && event.data !== '[DONE]') {
|
|
51
|
+
try {
|
|
52
|
+
const data = JSON.parse(event.data);
|
|
53
|
+
controller.enqueue(data.choices[0]?.text ?? '');
|
|
54
|
+
}
|
|
55
|
+
catch (err) {
|
|
56
|
+
// double check for the last event whicb is not a JSON - at this time togetherai returrns the string [DONE]
|
|
57
|
+
// do nothing - happens if data is not a JSON - the last event data is the [DONE] string
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
}));
|
|
62
|
+
}
|
|
63
|
+
async listModels() {
|
|
64
|
+
const models = await this.fetchClient.get("/models/info");
|
|
65
|
+
// logObject('#### LIST MODELS RESULT IS', models[0]);
|
|
66
|
+
const aimodels = models.map(m => {
|
|
67
|
+
return {
|
|
68
|
+
id: m.name,
|
|
69
|
+
name: m.display_name,
|
|
70
|
+
description: m.description,
|
|
71
|
+
provider: this.provider,
|
|
72
|
+
formats: [PromptFormats.genericTextLLM],
|
|
73
|
+
};
|
|
74
|
+
});
|
|
75
|
+
return aimodels;
|
|
76
|
+
}
|
|
77
|
+
listTrainableModels() {
|
|
78
|
+
throw new Error("Method not implemented.");
|
|
79
|
+
}
|
|
80
|
+
validateConnection() {
|
|
81
|
+
throw new Error("Method not implemented.");
|
|
82
|
+
}
|
|
83
|
+
//@ts-ignore
|
|
84
|
+
generateEmbeddings(content, model) {
|
|
85
|
+
throw new Error("Method not implemented.");
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/togetherai/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"interfaces.js","sourceRoot":"","sources":["../../../src/togetherai/interfaces.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"debug.js","sourceRoot":"","sources":["../../../src/vertexai/debug.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,MAAM,CAAC;AAExB,MAAM,UAAU,SAAS,CAAC,MAAc,EAAE,GAAQ;IAC9C,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,UAAU,EAAE,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC;IACpF,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;AAChC,CAAC"}
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
//import { v1 } from "@google-cloud/aiplatform";
|
|
2
|
+
import { VertexAI } from "@google-cloud/vertexai";
|
|
3
|
+
import { AbstractDriver, BuiltinProviders, PromptFormats } from "@llumiverse/core";
|
|
4
|
+
import { FetchClient } from "api-fetch-client";
|
|
5
|
+
import { BuiltinModels, getModelDefinition } from "./models.js";
|
|
6
|
+
export class VertexAIDriver extends AbstractDriver {
|
|
7
|
+
provider = BuiltinProviders.vertexai;
|
|
8
|
+
defaultFormat = PromptFormats.genericTextLLM;
|
|
9
|
+
//aiplatform: v1.ModelServiceClient;
|
|
10
|
+
vertexai;
|
|
11
|
+
fetchClient;
|
|
12
|
+
constructor(options) {
|
|
13
|
+
super(options);
|
|
14
|
+
//this.aiplatform = new v1.ModelServiceClient();
|
|
15
|
+
this.vertexai = new VertexAI({
|
|
16
|
+
project: this.options.project,
|
|
17
|
+
location: this.options.region,
|
|
18
|
+
});
|
|
19
|
+
this.fetchClient = createFetchClient({
|
|
20
|
+
region: this.options.region,
|
|
21
|
+
project: this.options.project,
|
|
22
|
+
}).withAuthCallback(async () => {
|
|
23
|
+
const token = await this.vertexai.preview.token;
|
|
24
|
+
return `Bearer ${token}`;
|
|
25
|
+
});
|
|
26
|
+
// this.aiplatform = new v1.ModelServiceClient({
|
|
27
|
+
// projectId: this.options.project,
|
|
28
|
+
// apiEndpoint: `${this.options.region}-${API_BASE_PATH}`,
|
|
29
|
+
// });
|
|
30
|
+
}
|
|
31
|
+
canStream(options) {
|
|
32
|
+
return Promise.resolve(getModelDefinition(options.model).model.canStream === true);
|
|
33
|
+
}
|
|
34
|
+
createPrompt(segments, options) {
|
|
35
|
+
return getModelDefinition(options.model).createPrompt(this, segments, options);
|
|
36
|
+
}
|
|
37
|
+
async requestCompletion(prompt, options) {
|
|
38
|
+
return getModelDefinition(options.model).requestCompletion(this, prompt, options);
|
|
39
|
+
}
|
|
40
|
+
async requestCompletionStream(prompt, options) {
|
|
41
|
+
return getModelDefinition(options.model).requestCompletionStream(this, prompt, options);
|
|
42
|
+
}
|
|
43
|
+
async listModels(_params) {
|
|
44
|
+
return BuiltinModels;
|
|
45
|
+
// try {
|
|
46
|
+
// const response = await this.fetchClient.get('/publishers/google/models/gemini-pro');
|
|
47
|
+
// console.log('>>>>>>>>', response);
|
|
48
|
+
// } catch (err: any) {
|
|
49
|
+
// console.error('+++++VETREX ERROR++++++', err);
|
|
50
|
+
// throw err;
|
|
51
|
+
// }
|
|
52
|
+
// TODO uncomment this to use apiplatform instead of the fetch client
|
|
53
|
+
// const response = await this.aiplatform.listModels({
|
|
54
|
+
// parent: `projects/${this.options.project}/locations/${this.options.region}`,
|
|
55
|
+
// });
|
|
56
|
+
return []; //TODO
|
|
57
|
+
}
|
|
58
|
+
listTrainableModels() {
|
|
59
|
+
throw new Error("Method not implemented.");
|
|
60
|
+
}
|
|
61
|
+
validateConnection() {
|
|
62
|
+
throw new Error("Method not implemented.");
|
|
63
|
+
}
|
|
64
|
+
generateEmbeddings(_content, _model) {
|
|
65
|
+
throw new Error("Method not implemented.");
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
//'us-central1-aiplatform.googleapis.com',
|
|
69
|
+
const API_BASE_PATH = 'aiplatform.googleapis.com';
|
|
70
|
+
function createFetchClient({ region, project, apiEndpoint, apiVersion = 'v1' }) {
|
|
71
|
+
const vertexBaseEndpoint = apiEndpoint ?? `${region}-${API_BASE_PATH}`;
|
|
72
|
+
return new FetchClient(`https://${vertexBaseEndpoint}/${apiVersion}/projects/${project}/locations/${region}`).withHeaders({
|
|
73
|
+
'Content-Type': 'application/json',
|
|
74
|
+
});
|
|
75
|
+
}
|
|
76
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/vertexai/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
import { ModelType, PromptRole } from "@llumiverse/core";
|
|
2
|
+
import { getJSONSafetyNotice } from "../utils/prompts.js";
|
|
3
|
+
import { AbstractPalmModelDefinition } from "./palm-model-base.js";
|
|
4
|
+
export class CodeyChatDefinition extends AbstractPalmModelDefinition {
|
|
5
|
+
versions = [];
|
|
6
|
+
model = {
|
|
7
|
+
id: "codechat-bison",
|
|
8
|
+
name: "Codey for Code Chat",
|
|
9
|
+
provider: "vertexai",
|
|
10
|
+
owner: "google",
|
|
11
|
+
type: ModelType.Chat,
|
|
12
|
+
canStream: true,
|
|
13
|
+
};
|
|
14
|
+
createNonStreamingPrompt(_driver, segments, opts) {
|
|
15
|
+
const system = [];
|
|
16
|
+
const messages = [];
|
|
17
|
+
const safety = [];
|
|
18
|
+
for (const segment of segments) {
|
|
19
|
+
switch (segment.role) {
|
|
20
|
+
case PromptRole.user:
|
|
21
|
+
messages.push({ author: 'user', content: segment.content });
|
|
22
|
+
break;
|
|
23
|
+
case PromptRole.assistant:
|
|
24
|
+
messages.push({ author: 'assistant', content: segment.content });
|
|
25
|
+
break;
|
|
26
|
+
case PromptRole.system:
|
|
27
|
+
system.push(segment.content);
|
|
28
|
+
break;
|
|
29
|
+
case PromptRole.safety:
|
|
30
|
+
safety.push(segment.content);
|
|
31
|
+
break;
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
if (opts.resultSchema) {
|
|
35
|
+
safety.push(getJSONSafetyNotice(opts.resultSchema));
|
|
36
|
+
}
|
|
37
|
+
const context = [];
|
|
38
|
+
if (system.length > 0) {
|
|
39
|
+
context.push(system.join('\n'));
|
|
40
|
+
}
|
|
41
|
+
if (safety.length > 0) {
|
|
42
|
+
context.push('IMPORTANT: ' + safety.join('\n'));
|
|
43
|
+
}
|
|
44
|
+
return {
|
|
45
|
+
instances: [{
|
|
46
|
+
context: context.length > 0 ? context.join('\n') : undefined,
|
|
47
|
+
messages
|
|
48
|
+
}],
|
|
49
|
+
parameters: {
|
|
50
|
+
// put defauilts here
|
|
51
|
+
}
|
|
52
|
+
};
|
|
53
|
+
}
|
|
54
|
+
extractContentFromResponse(response) {
|
|
55
|
+
return response.predictions[0].candidates[0].content ?? '';
|
|
56
|
+
}
|
|
57
|
+
extractContentFromResponseChunk(chunk) {
|
|
58
|
+
return chunk.outputs[0]?.structVal.candidates.listVal[0].structVal.content.stringVal || '';
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
//# sourceMappingURL=codey-chat.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"codey-chat.js","sourceRoot":"","sources":["../../../../src/vertexai/models/codey-chat.ts"],"names":[],"mappings":"AAAA,OAAO,EAAW,SAAS,EAAiB,UAAU,EAAiB,MAAM,kBAAkB,CAAC;AAEhG,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAC1D,OAAO,EAAE,2BAA2B,EAAqE,MAAM,sBAAsB,CAAC;AAgDtI,MAAM,OAAO,mBAAoB,SAAQ,2BAAsE;IAC3G,QAAQ,GAAa,EAAE,CAAC;IACxB,KAAK,GAAY;QACb,EAAE,EAAE,gBAAgB;QACpB,IAAI,EAAE,qBAAqB;QAC3B,QAAQ,EAAE,UAAU;QACpB,KAAK,EAAE,QAAQ;QACf,IAAI,EAAE,SAAS,CAAC,IAAI;QACpB,SAAS,EAAE,IAAI;KAClB,CAAA;IAED,wBAAwB,CAAC,OAAuB,EAAE,QAAyB,EAAE,IAAmB;QAC5F,MAAM,MAAM,GAAa,EAAE,CAAC;QAC5B,MAAM,QAAQ,GAAuB,EAAE,CAAC;QACxC,MAAM,MAAM,GAAa,EAAE,CAAC;QAC5B,KAAK,MAAM,OAAO,IAAI,QAAQ,EAAE,CAAC;YAC7B,QAAQ,OAAO,CAAC,IAAI,EAAE,CAAC;gBACnB,KAAK,UAAU,CAAC,IAAI;oBAChB,QAAQ,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC;oBAC5D,MAAM;gBACV,KAAK,UAAU,CAAC,SAAS;oBACrB,QAAQ,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,WAAW,EAAE,OAAO,EAAE,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC;oBACjE,MAAM;gBACV,KAAK,UAAU,CAAC,MAAM;oBAClB,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;oBAC7B,MAAM;gBACV,KAAK,UAAU,CAAC,MAAM;oBAClB,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;oBAC7B,MAAM;YACd,CAAC;QACL,CAAC;QAED,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACpB,MAAM,CAAC,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC;QACxD,CAAC;QAED,MAAM,OAAO,GAAG,EAAE,CAAA;QAClB,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACpB,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;QACpC,CAAC;QACD,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACpB,OAAO,CAAC,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;QACpD,CAAC;QAED,OAAO;YACH,SAAS,EAAE,CAAC;oBACR,OAAO,EAAE,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,SAAS;oBAC5D,QAAQ;iBACX,CAAC;YACF,UAAU,EAAE;YACR,qBAAqB;aACxB;SACe,CAAC;IACzB,CAAC;IAED,0BAA0B,CAAC,QAA2B;QAClD,OAAO,QAAQ,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,OAAO,IAAI,EAAE,CAAC;IAC/D,CAAC;IAED,+BAA+B,CAAC,KAAU;QACtC,OAAO,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,SAAS,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,OAAO,CAAC,SAAS,IAAI,EAAE,CAAC;IAC/F,CAAC;CAEJ"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { ModelType } from "@llumiverse/core";
|
|
2
|
+
import { getPromptAsText } from "../utils/prompts.js";
|
|
3
|
+
import { AbstractPalmModelDefinition } from "./palm-model-base.js";
|
|
4
|
+
export class CodeyTextDefinition extends AbstractPalmModelDefinition {
|
|
5
|
+
versions = [];
|
|
6
|
+
model = {
|
|
7
|
+
id: "code-bison",
|
|
8
|
+
name: "Codey for Code Generation",
|
|
9
|
+
provider: "vertexai",
|
|
10
|
+
owner: "google",
|
|
11
|
+
type: ModelType.Text,
|
|
12
|
+
canStream: true,
|
|
13
|
+
};
|
|
14
|
+
createNonStreamingPrompt(_driver, segments, opts) {
|
|
15
|
+
return {
|
|
16
|
+
instances: [{
|
|
17
|
+
prefix: getPromptAsText(segments, opts)
|
|
18
|
+
}],
|
|
19
|
+
parameters: {
|
|
20
|
+
// put defauilts here
|
|
21
|
+
}
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
extractContentFromResponse(response) {
|
|
25
|
+
return response.predictions[0].content ?? '';
|
|
26
|
+
}
|
|
27
|
+
extractContentFromResponseChunk(chunk) {
|
|
28
|
+
return chunk.outputs[0]?.structVal.content.stringVal || '';
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
//# sourceMappingURL=codey-text.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"codey-text.js","sourceRoot":"","sources":["../../../../src/vertexai/models/codey-text.ts"],"names":[],"mappings":"AAAA,OAAO,EAAW,SAAS,EAAgC,MAAM,kBAAkB,CAAC;AAEpF,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,EAAE,2BAA2B,EAAqE,MAAM,sBAAsB,CAAC;AAmCtI,MAAM,OAAO,mBAAoB,SAAQ,2BAAsE;IAC3G,QAAQ,GAAa,EAAE,CAAC;IACxB,KAAK,GAAY;QACb,EAAE,EAAE,YAAY;QAChB,IAAI,EAAE,2BAA2B;QACjC,QAAQ,EAAE,UAAU;QACpB,KAAK,EAAE,QAAQ;QACf,IAAI,EAAE,SAAS,CAAC,IAAI;QACpB,SAAS,EAAE,IAAI;KAClB,CAAA;IAED,wBAAwB,CAAC,OAAuB,EAAE,QAAyB,EAAE,IAAmB;QAC5F,OAAO;YACH,SAAS,EAAE,CAAC;oBACR,MAAM,EAAE,eAAe,CAAC,QAAQ,EAAE,IAAI,CAAC;iBAC1C,CAAC;YACF,UAAU,EAAE;YACR,qBAAqB;aACxB;SACe,CAAC;IACzB,CAAC;IAED,0BAA0B,CAAC,QAA2B;QAClD,OAAO,QAAQ,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,OAAO,IAAI,EAAE,CAAC;IACjD,CAAC;IAED,+BAA+B,CAAC,KAAU;QACtC,OAAO,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,SAAS,CAAC,OAAO,CAAC,SAAS,IAAI,EAAE,CAAC;IAC/D,CAAC;CAEJ"}
|
|
@@ -0,0 +1,136 @@
|
|
|
1
|
+
import { HarmBlockThreshold, HarmCategory } from "@google-cloud/vertexai";
|
|
2
|
+
import { ModelType, PromptRole } from "@llumiverse/core";
|
|
3
|
+
import { asyncMap } from "@llumiverse/core/async";
|
|
4
|
+
function getGenerativeModel(driver, options) {
|
|
5
|
+
return driver.vertexai.preview.getGenerativeModel({
|
|
6
|
+
model: options.model,
|
|
7
|
+
//TODO pass in the options
|
|
8
|
+
safety_settings: [{
|
|
9
|
+
category: HarmCategory.HARM_CATEGORY_DANGEROUS_CONTENT,
|
|
10
|
+
threshold: HarmBlockThreshold.BLOCK_MEDIUM_AND_ABOVE
|
|
11
|
+
}],
|
|
12
|
+
generation_config: {
|
|
13
|
+
temperature: options.temperature,
|
|
14
|
+
max_output_tokens: options.max_tokens
|
|
15
|
+
},
|
|
16
|
+
});
|
|
17
|
+
}
|
|
18
|
+
function collectTextParts(content) {
|
|
19
|
+
const out = [];
|
|
20
|
+
const parts = content.parts;
|
|
21
|
+
if (parts) {
|
|
22
|
+
for (const part of parts) {
|
|
23
|
+
if (part.text) {
|
|
24
|
+
out.push(part.text);
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
return out.join('\n');
|
|
29
|
+
}
|
|
30
|
+
export class GeminiModelDefinition {
|
|
31
|
+
model = {
|
|
32
|
+
id: "gemini-pro",
|
|
33
|
+
name: "Gemini Pro",
|
|
34
|
+
provider: "vertexai",
|
|
35
|
+
owner: "google",
|
|
36
|
+
type: ModelType.Text,
|
|
37
|
+
canStream: true,
|
|
38
|
+
};
|
|
39
|
+
createPrompt(_driver, segments, options) {
|
|
40
|
+
const schema = options.resultSchema;
|
|
41
|
+
const contents = [];
|
|
42
|
+
const safety = [];
|
|
43
|
+
let lastUserContent = undefined;
|
|
44
|
+
for (const msg of segments) {
|
|
45
|
+
if (msg.role === PromptRole.safety) {
|
|
46
|
+
safety.push(msg.content);
|
|
47
|
+
}
|
|
48
|
+
else {
|
|
49
|
+
const role = msg.role === PromptRole.assistant ? "model" : "user";
|
|
50
|
+
if (lastUserContent && lastUserContent.role === role) {
|
|
51
|
+
lastUserContent.parts.push({ text: msg.content });
|
|
52
|
+
}
|
|
53
|
+
else {
|
|
54
|
+
const content = {
|
|
55
|
+
role,
|
|
56
|
+
parts: [{ text: msg.content }],
|
|
57
|
+
};
|
|
58
|
+
if (role === 'user') {
|
|
59
|
+
lastUserContent = content;
|
|
60
|
+
}
|
|
61
|
+
contents.push(content);
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
let tools = undefined;
|
|
66
|
+
if (schema) {
|
|
67
|
+
// tools = [{
|
|
68
|
+
// function_declarations: [{
|
|
69
|
+
// name: "validate_json_response",
|
|
70
|
+
// description: "Validate the given JSON response",
|
|
71
|
+
// parameters: schema as any,
|
|
72
|
+
// }]
|
|
73
|
+
// } as Tool];
|
|
74
|
+
safety.push("The answer must be a JSON object using the following JSON Schema:\n" + JSON.stringify(schema));
|
|
75
|
+
}
|
|
76
|
+
if (safety.length > 0) {
|
|
77
|
+
const content = safety.join('\n');
|
|
78
|
+
if (lastUserContent) {
|
|
79
|
+
lastUserContent.parts.push({ text: content });
|
|
80
|
+
}
|
|
81
|
+
else {
|
|
82
|
+
contents.push({
|
|
83
|
+
role: 'user',
|
|
84
|
+
parts: [{ text: content }],
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
// put system mesages first and safety last
|
|
89
|
+
return { contents, tools };
|
|
90
|
+
}
|
|
91
|
+
async requestCompletion(driver, prompt, options) {
|
|
92
|
+
const model = getGenerativeModel(driver, options);
|
|
93
|
+
const r = await model.generateContent(prompt);
|
|
94
|
+
const response = await r.response;
|
|
95
|
+
const usage = response.usageMetadata;
|
|
96
|
+
const token_usage = {
|
|
97
|
+
prompt: usage?.prompt_token_count,
|
|
98
|
+
result: usage?.candidates_token_count,
|
|
99
|
+
total: usage?.totalTokenCount,
|
|
100
|
+
};
|
|
101
|
+
let result;
|
|
102
|
+
const candidate = response.candidates[0];
|
|
103
|
+
if (candidate) {
|
|
104
|
+
const content = candidate.content;
|
|
105
|
+
if (content) {
|
|
106
|
+
result = collectTextParts(content);
|
|
107
|
+
// if (options.resultSchema) {
|
|
108
|
+
// result = candidate.;
|
|
109
|
+
// } else {
|
|
110
|
+
// }
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
return {
|
|
114
|
+
result: result ?? '',
|
|
115
|
+
token_usage
|
|
116
|
+
};
|
|
117
|
+
}
|
|
118
|
+
async requestCompletionStream(driver, prompt, options) {
|
|
119
|
+
const model = getGenerativeModel(driver, options);
|
|
120
|
+
const streamingResp = await model.generateContentStream(prompt);
|
|
121
|
+
const stream = asyncMap(streamingResp.stream, async (item) => {
|
|
122
|
+
if (item.candidates.length > 0) {
|
|
123
|
+
for (const candidate of item.candidates) {
|
|
124
|
+
if (candidate.content?.role === 'model') {
|
|
125
|
+
const text = collectTextParts(candidate.content);
|
|
126
|
+
if (text)
|
|
127
|
+
return text;
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
return '';
|
|
132
|
+
});
|
|
133
|
+
return stream;
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
//# sourceMappingURL=gemini.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gemini.js","sourceRoot":"","sources":["../../../../src/vertexai/models/gemini.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
import { generateStreamingPrompt } from "../utils/tensor.js";
|
|
2
|
+
export class AbstractPalmModelDefinition {
|
|
3
|
+
createPrompt(driver, segments, options) {
|
|
4
|
+
return this.createNonStreamingPrompt(driver, segments, options);
|
|
5
|
+
}
|
|
6
|
+
async requestCompletion(driver, prompt, options) {
|
|
7
|
+
const nonStreamingPrompt = prompt;
|
|
8
|
+
Object.assign((nonStreamingPrompt).parameters, {
|
|
9
|
+
temperature: options.temperature,
|
|
10
|
+
maxOutputTokens: options.max_tokens,
|
|
11
|
+
});
|
|
12
|
+
const response = await driver.fetchClient.post(`/publishers/google/models/${this.model.id}:predict`, {
|
|
13
|
+
payload: nonStreamingPrompt
|
|
14
|
+
});
|
|
15
|
+
const metadata = response.metadata;
|
|
16
|
+
const inputTokens = metadata.tokenMetadata.inputTokenCount.totalTokens;
|
|
17
|
+
const outputTokens = metadata.tokenMetadata.outputTokenCount.totalTokens;
|
|
18
|
+
const result = this.extractContentFromResponse(response);
|
|
19
|
+
return {
|
|
20
|
+
result,
|
|
21
|
+
token_usage: {
|
|
22
|
+
prompt: inputTokens,
|
|
23
|
+
result: outputTokens,
|
|
24
|
+
total: inputTokens && outputTokens ? inputTokens + outputTokens : undefined,
|
|
25
|
+
}
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
async requestCompletionStream(driver, prompt, options) {
|
|
29
|
+
const inPrompt = prompt;
|
|
30
|
+
Object.assign(inPrompt.parameters, {
|
|
31
|
+
temperature: options.temperature,
|
|
32
|
+
maxOutputTokens: options.max_tokens,
|
|
33
|
+
});
|
|
34
|
+
const path = `/publishers/google/models/${this.model.id}:serverStreamingPredict?alt=sse`;
|
|
35
|
+
const newPrompt = generateStreamingPrompt(inPrompt);
|
|
36
|
+
// we need to modify the existing prompt since it is not the final one
|
|
37
|
+
const outPrompt = prompt;
|
|
38
|
+
delete outPrompt.instances;
|
|
39
|
+
outPrompt.inputs = newPrompt.inputs;
|
|
40
|
+
outPrompt.parameters = newPrompt.parameters;
|
|
41
|
+
const eventStrean = await driver.fetchClient.post(path, {
|
|
42
|
+
payload: newPrompt,
|
|
43
|
+
reader: 'sse'
|
|
44
|
+
});
|
|
45
|
+
return eventStrean.pipeThrough(new ChunkTransformStream(this));
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
class ChunkTransformStream extends TransformStream {
|
|
49
|
+
constructor(def) {
|
|
50
|
+
super({
|
|
51
|
+
transform(event, controller) {
|
|
52
|
+
if (event.type === 'event' && event.data) {
|
|
53
|
+
const data = JSON.parse(event.data);
|
|
54
|
+
const stringChunk = def.extractContentFromResponseChunk(data);
|
|
55
|
+
controller.enqueue(Array.isArray(stringChunk) ? stringChunk.join('') : stringChunk);
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
//# sourceMappingURL=palm-model-base.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"palm-model-base.js","sourceRoot":"","sources":["../../../../src/vertexai/models/palm-model-base.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
import { ModelType, PromptRole } from "@llumiverse/core";
|
|
2
|
+
import { getJSONSafetyNotice } from "../utils/prompts.js";
|
|
3
|
+
import { AbstractPalmModelDefinition } from "./palm-model-base.js";
|
|
4
|
+
export class Palm2ChatDefinition extends AbstractPalmModelDefinition {
|
|
5
|
+
versions = [];
|
|
6
|
+
model = {
|
|
7
|
+
id: "chat-bison",
|
|
8
|
+
name: "PaLM 2 for Chat",
|
|
9
|
+
provider: "vertexai",
|
|
10
|
+
owner: "google",
|
|
11
|
+
type: ModelType.Chat,
|
|
12
|
+
canStream: true,
|
|
13
|
+
};
|
|
14
|
+
createNonStreamingPrompt(_driver, segments, opts) {
|
|
15
|
+
const system = [];
|
|
16
|
+
const messages = [];
|
|
17
|
+
const safety = [];
|
|
18
|
+
for (const segment of segments) {
|
|
19
|
+
switch (segment.role) {
|
|
20
|
+
case PromptRole.user:
|
|
21
|
+
messages.push({ author: 'user', content: segment.content });
|
|
22
|
+
break;
|
|
23
|
+
case PromptRole.assistant:
|
|
24
|
+
messages.push({ author: 'assistant', content: segment.content });
|
|
25
|
+
break;
|
|
26
|
+
case PromptRole.system:
|
|
27
|
+
system.push(segment.content);
|
|
28
|
+
break;
|
|
29
|
+
case PromptRole.safety:
|
|
30
|
+
safety.push(segment.content);
|
|
31
|
+
break;
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
if (opts.resultSchema) {
|
|
35
|
+
safety.push(getJSONSafetyNotice(opts.resultSchema));
|
|
36
|
+
}
|
|
37
|
+
const context = [];
|
|
38
|
+
if (system.length > 0) {
|
|
39
|
+
context.push(system.join('\n'));
|
|
40
|
+
}
|
|
41
|
+
if (safety.length > 0) {
|
|
42
|
+
context.push('IMPORTANT: ' + safety.join('\n'));
|
|
43
|
+
}
|
|
44
|
+
return {
|
|
45
|
+
instances: [{
|
|
46
|
+
context: context.length > 0 ? context.join('\n') : undefined,
|
|
47
|
+
messages
|
|
48
|
+
}],
|
|
49
|
+
parameters: {
|
|
50
|
+
// put defauilts here
|
|
51
|
+
}
|
|
52
|
+
};
|
|
53
|
+
}
|
|
54
|
+
extractContentFromResponse(response) {
|
|
55
|
+
return response.predictions[0].candidates[0].content ?? '';
|
|
56
|
+
}
|
|
57
|
+
extractContentFromResponseChunk(chunk) {
|
|
58
|
+
return chunk.outputs[0]?.structVal.candidates.listVal[0].structVal.content.stringVal || '';
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
//# sourceMappingURL=palm2-chat.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"palm2-chat.js","sourceRoot":"","sources":["../../../../src/vertexai/models/palm2-chat.ts"],"names":[],"mappings":"AAAA,OAAO,EAAW,SAAS,EAAiB,UAAU,EAAiB,MAAM,kBAAkB,CAAC;AAEhG,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAC1D,OAAO,EAAE,2BAA2B,EAAqE,MAAM,sBAAsB,CAAC;AAqDtI,MAAM,OAAO,mBAAoB,SAAQ,2BAAsE;IAC3G,QAAQ,GAAa,EAAE,CAAC;IACxB,KAAK,GAAY;QACb,EAAE,EAAE,YAAY;QAChB,IAAI,EAAE,iBAAiB;QACvB,QAAQ,EAAE,UAAU;QACpB,KAAK,EAAE,QAAQ;QACf,IAAI,EAAE,SAAS,CAAC,IAAI;QACpB,SAAS,EAAE,IAAI;KAClB,CAAA;IAED,wBAAwB,CAAC,OAAuB,EAAE,QAAyB,EAAE,IAAmB;QAC5F,MAAM,MAAM,GAAa,EAAE,CAAC;QAC5B,MAAM,QAAQ,GAAuB,EAAE,CAAC;QACxC,MAAM,MAAM,GAAa,EAAE,CAAC;QAC5B,KAAK,MAAM,OAAO,IAAI,QAAQ,EAAE,CAAC;YAC7B,QAAQ,OAAO,CAAC,IAAI,EAAE,CAAC;gBACnB,KAAK,UAAU,CAAC,IAAI;oBAChB,QAAQ,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC;oBAC5D,MAAM;gBACV,KAAK,UAAU,CAAC,SAAS;oBACrB,QAAQ,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,WAAW,EAAE,OAAO,EAAE,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC;oBACjE,MAAM;gBACV,KAAK,UAAU,CAAC,MAAM;oBAClB,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;oBAC7B,MAAM;gBACV,KAAK,UAAU,CAAC,MAAM;oBAClB,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;oBAC7B,MAAM;YACd,CAAC;QACL,CAAC;QAED,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACpB,MAAM,CAAC,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC;QACxD,CAAC;QAED,MAAM,OAAO,GAAG,EAAE,CAAA;QAClB,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACpB,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;QACpC,CAAC;QACD,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACpB,OAAO,CAAC,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;QACpD,CAAC;QAED,OAAO;YACH,SAAS,EAAE,CAAC;oBACR,OAAO,EAAE,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,SAAS;oBAC5D,QAAQ;iBACX,CAAC;YACF,UAAU,EAAE;YACR,qBAAqB;aACxB;SACe,CAAC;IACzB,CAAC;IAED,0BAA0B,CAAC,QAA2B;QAClD,OAAO,QAAQ,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,OAAO,IAAI,EAAE,CAAC;IAC/D,CAAC;IAED,+BAA+B,CAAC,KAAU;QACtC,OAAO,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,SAAS,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,OAAO,CAAC,SAAS,IAAI,EAAE,CAAA;IAC9F,CAAC;CACJ"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { ModelType } from "@llumiverse/core";
|
|
2
|
+
import { getPromptAsText } from "../utils/prompts.js";
|
|
3
|
+
import { AbstractPalmModelDefinition } from "./palm-model-base.js";
|
|
4
|
+
export class Palm2TextDefinition extends AbstractPalmModelDefinition {
|
|
5
|
+
versions = [];
|
|
6
|
+
model = {
|
|
7
|
+
id: "text-bison",
|
|
8
|
+
name: "PaLM 2 for Text",
|
|
9
|
+
provider: "vertexai",
|
|
10
|
+
owner: "google",
|
|
11
|
+
type: ModelType.Text,
|
|
12
|
+
canStream: true,
|
|
13
|
+
};
|
|
14
|
+
createNonStreamingPrompt(_driver, segments, opts) {
|
|
15
|
+
return {
|
|
16
|
+
instances: [{
|
|
17
|
+
prompt: getPromptAsText(segments, opts)
|
|
18
|
+
}],
|
|
19
|
+
parameters: {
|
|
20
|
+
// put defauilts here
|
|
21
|
+
}
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
extractContentFromResponse(response) {
|
|
25
|
+
return response.predictions[0].content ?? '';
|
|
26
|
+
}
|
|
27
|
+
extractContentFromResponseChunk(chunk) {
|
|
28
|
+
return chunk.outputs[0]?.structVal.content.stringVal || '';
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
//# sourceMappingURL=palm2-text.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"palm2-text.js","sourceRoot":"","sources":["../../../../src/vertexai/models/palm2-text.ts"],"names":[],"mappings":"AAAA,OAAO,EAAW,SAAS,EAAgC,MAAM,kBAAkB,CAAC;AAEpF,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,EAAE,2BAA2B,EAAqE,MAAM,sBAAsB,CAAC;AAmCtI,MAAM,OAAO,mBAAoB,SAAQ,2BAAsE;IAC3G,QAAQ,GAAa,EAAE,CAAC;IACxB,KAAK,GAAY;QACb,EAAE,EAAE,YAAY;QAChB,IAAI,EAAE,iBAAiB;QACvB,QAAQ,EAAE,UAAU;QACpB,KAAK,EAAE,QAAQ;QACf,IAAI,EAAE,SAAS,CAAC,IAAI;QACpB,SAAS,EAAE,IAAI;KAClB,CAAA;IAED,wBAAwB,CAAC,OAAuB,EAAE,QAAyB,EAAE,IAAmB;QAC5F,OAAO;YACH,SAAS,EAAE,CAAC;oBACR,MAAM,EAAE,eAAe,CAAC,QAAQ,EAAE,IAAI,CAAC;iBAC1C,CAAC;YACF,UAAU,EAAE;YACR,qBAAqB;aACxB;SACe,CAAC;IACzB,CAAC;IAED,0BAA0B,CAAC,QAA2B;QAClD,OAAO,QAAQ,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,OAAO,IAAI,EAAE,CAAC;IACjD,CAAC;IAED,+BAA+B,CAAC,KAAU;QACtC,OAAO,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,SAAS,CAAC,OAAO,CAAC,SAAS,IAAI,EAAE,CAAC;IAC/D,CAAC;CAEJ"}
|