@llumiverse/drivers 0.9.2 → 0.11.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/README.md +51 -7
- package/lib/cjs/bedrock/index.js +32 -8
- package/lib/cjs/bedrock/index.js.map +1 -1
- package/lib/cjs/bedrock/s3.js.map +1 -1
- package/lib/cjs/huggingface_ie.js +1 -7
- package/lib/cjs/huggingface_ie.js.map +1 -1
- package/lib/cjs/mistral/index.js +31 -29
- package/lib/cjs/mistral/index.js.map +1 -1
- package/lib/cjs/openai.js +4 -7
- package/lib/cjs/openai.js.map +1 -1
- package/lib/cjs/replicate.js +3 -5
- package/lib/cjs/replicate.js.map +1 -1
- package/lib/cjs/test/index.js.map +1 -1
- package/lib/cjs/togetherai/index.js +5 -12
- package/lib/cjs/togetherai/index.js.map +1 -1
- package/lib/cjs/vertexai/embeddings/embeddings-text.js +23 -0
- package/lib/cjs/vertexai/embeddings/embeddings-text.js.map +1 -0
- package/lib/cjs/vertexai/index.js +5 -8
- package/lib/cjs/vertexai/index.js.map +1 -1
- package/lib/cjs/vertexai/models/codey-chat.js +2 -2
- package/lib/cjs/vertexai/models/codey-chat.js.map +1 -1
- package/lib/cjs/vertexai/models/codey-text.js +2 -2
- package/lib/cjs/vertexai/models/codey-text.js.map +1 -1
- package/lib/cjs/vertexai/models/gemini.js +2 -2
- package/lib/cjs/vertexai/models/gemini.js.map +1 -1
- package/lib/cjs/vertexai/models/palm-model-base.js.map +1 -1
- package/lib/cjs/vertexai/models/palm2-chat.js +2 -2
- package/lib/cjs/vertexai/models/palm2-chat.js.map +1 -1
- package/lib/cjs/vertexai/models/palm2-text.js +2 -2
- package/lib/cjs/vertexai/models/palm2-text.js.map +1 -1
- package/lib/esm/bedrock/index.js +33 -9
- package/lib/esm/bedrock/index.js.map +1 -1
- package/lib/esm/bedrock/s3.js.map +1 -1
- package/lib/esm/huggingface_ie.js +2 -8
- package/lib/esm/huggingface_ie.js.map +1 -1
- package/lib/esm/mistral/index.js +32 -30
- package/lib/esm/mistral/index.js.map +1 -1
- package/lib/esm/openai.js +5 -8
- package/lib/esm/openai.js.map +1 -1
- package/lib/esm/replicate.js +4 -6
- package/lib/esm/replicate.js.map +1 -1
- package/lib/esm/src/bedrock/index.js +375 -0
- package/lib/esm/src/bedrock/index.js.map +1 -0
- package/lib/esm/src/bedrock/s3.js +53 -0
- package/lib/esm/src/bedrock/s3.js.map +1 -0
- package/lib/esm/src/huggingface_ie.js +173 -0
- package/lib/esm/src/huggingface_ie.js.map +1 -0
- package/lib/esm/src/index.js +9 -0
- package/lib/esm/src/index.js.map +1 -0
- package/lib/esm/src/mistral/index.js +145 -0
- package/lib/esm/src/mistral/index.js.map +1 -0
- package/lib/esm/src/mistral/types.js +80 -0
- package/lib/esm/src/mistral/types.js.map +1 -0
- package/lib/esm/src/openai.js +195 -0
- package/lib/esm/src/openai.js.map +1 -0
- package/lib/esm/src/replicate.js +281 -0
- package/lib/esm/src/replicate.js.map +1 -0
- package/lib/esm/src/test/TestErrorCompletionStream.js +16 -0
- package/lib/esm/src/test/TestErrorCompletionStream.js.map +1 -0
- package/lib/esm/src/test/TestValidationErrorCompletionStream.js +20 -0
- package/lib/esm/src/test/TestValidationErrorCompletionStream.js.map +1 -0
- package/lib/esm/src/test/index.js +91 -0
- package/lib/esm/src/test/index.js.map +1 -0
- package/lib/esm/src/test/utils.js +25 -0
- package/lib/esm/src/test/utils.js.map +1 -0
- package/lib/esm/src/togetherai/index.js +89 -0
- package/lib/esm/src/togetherai/index.js.map +1 -0
- package/lib/esm/src/togetherai/interfaces.js +2 -0
- package/lib/esm/src/togetherai/interfaces.js.map +1 -0
- package/lib/esm/src/vertexai/debug.js +6 -0
- package/lib/esm/src/vertexai/debug.js.map +1 -0
- package/lib/esm/src/vertexai/embeddings/embeddings-text.js +19 -0
- package/lib/esm/src/vertexai/embeddings/embeddings-text.js.map +1 -0
- package/lib/esm/src/vertexai/index.js +73 -0
- package/lib/esm/src/vertexai/index.js.map +1 -0
- package/lib/esm/src/vertexai/models/codey-chat.js +61 -0
- package/lib/esm/src/vertexai/models/codey-chat.js.map +1 -0
- package/lib/esm/src/vertexai/models/codey-text.js +31 -0
- package/lib/esm/src/vertexai/models/codey-text.js.map +1 -0
- package/lib/esm/src/vertexai/models/gemini.js +136 -0
- package/lib/esm/src/vertexai/models/gemini.js.map +1 -0
- package/lib/esm/src/vertexai/models/palm-model-base.js +53 -0
- package/lib/esm/src/vertexai/models/palm-model-base.js.map +1 -0
- package/lib/esm/src/vertexai/models/palm2-chat.js +61 -0
- package/lib/esm/src/vertexai/models/palm2-chat.js.map +1 -0
- package/lib/esm/src/vertexai/models/palm2-text.js +31 -0
- package/lib/esm/src/vertexai/models/palm2-text.js.map +1 -0
- package/lib/esm/src/vertexai/models.js +87 -0
- package/lib/esm/src/vertexai/models.js.map +1 -0
- package/{src/vertexai/utils/prompts.ts → lib/esm/src/vertexai/utils/prompts.js} +10 -29
- package/lib/esm/src/vertexai/utils/prompts.js.map +1 -0
- package/lib/esm/src/vertexai/utils/tensor.js +82 -0
- package/lib/esm/src/vertexai/utils/tensor.js.map +1 -0
- package/lib/esm/test/index.js.map +1 -1
- package/lib/esm/togetherai/index.js +6 -13
- package/lib/esm/togetherai/index.js.map +1 -1
- package/lib/esm/tsconfig.tsbuildinfo +1 -0
- package/lib/esm/vertexai/embeddings/embeddings-text.js +19 -0
- package/lib/esm/vertexai/embeddings/embeddings-text.js.map +1 -0
- package/lib/esm/vertexai/index.js +6 -9
- package/lib/esm/vertexai/index.js.map +1 -1
- package/lib/esm/vertexai/models/codey-chat.js +1 -1
- package/lib/esm/vertexai/models/codey-chat.js.map +1 -1
- package/lib/esm/vertexai/models/codey-text.js +2 -2
- package/lib/esm/vertexai/models/codey-text.js.map +1 -1
- package/lib/esm/vertexai/models/gemini.js +2 -2
- package/lib/esm/vertexai/models/gemini.js.map +1 -1
- package/lib/esm/vertexai/models/palm-model-base.js.map +1 -1
- package/lib/esm/vertexai/models/palm2-chat.js +1 -1
- package/lib/esm/vertexai/models/palm2-chat.js.map +1 -1
- package/lib/esm/vertexai/models/palm2-text.js +2 -2
- package/lib/esm/vertexai/models/palm2-text.js.map +1 -1
- package/lib/types/bedrock/index.d.ts +12 -9
- package/lib/types/bedrock/index.d.ts.map +1 -1
- package/lib/types/bedrock/s3.d.ts +2 -5
- package/lib/types/bedrock/s3.d.ts.map +1 -1
- package/lib/types/huggingface_ie.d.ts +5 -10
- package/lib/types/huggingface_ie.d.ts.map +1 -1
- package/lib/types/mistral/index.d.ts +7 -15
- package/lib/types/mistral/index.d.ts.map +1 -1
- package/lib/types/openai.d.ts +2 -7
- package/lib/types/openai.d.ts.map +1 -1
- package/lib/types/replicate.d.ts +2 -6
- package/lib/types/replicate.d.ts.map +1 -1
- package/lib/types/src/bedrock/index.d.ts +94 -0
- package/lib/types/src/bedrock/s3.d.ts +16 -0
- package/lib/types/src/huggingface_ie.d.ts +30 -0
- package/lib/types/src/index.d.ts +8 -0
- package/lib/types/src/mistral/index.d.ts +23 -0
- package/lib/types/src/mistral/types.d.ts +130 -0
- package/lib/types/src/openai.d.ts +30 -0
- package/lib/types/src/replicate.d.ts +47 -0
- package/lib/types/src/test/TestErrorCompletionStream.d.ts +8 -0
- package/lib/types/src/test/TestValidationErrorCompletionStream.d.ts +8 -0
- package/lib/types/src/test/index.d.ts +23 -0
- package/lib/types/src/test/utils.d.ts +4 -0
- package/lib/types/src/togetherai/index.d.ts +21 -0
- package/lib/types/src/togetherai/interfaces.d.ts +80 -0
- package/lib/types/src/vertexai/debug.d.ts +1 -0
- package/lib/types/src/vertexai/embeddings/embeddings-text.d.ts +9 -0
- package/lib/types/src/vertexai/index.d.ts +21 -0
- package/lib/types/src/vertexai/models/codey-chat.d.ts +50 -0
- package/lib/types/src/vertexai/models/codey-text.d.ts +38 -0
- package/lib/types/src/vertexai/models/gemini.d.ts +10 -0
- package/lib/types/src/vertexai/models/palm-model-base.d.ts +60 -0
- package/lib/types/src/vertexai/models/palm2-chat.d.ts +60 -0
- package/lib/types/src/vertexai/models/palm2-text.d.ts +38 -0
- package/lib/types/src/vertexai/models.d.ts +13 -0
- package/lib/types/src/vertexai/utils/prompts.d.ts +19 -0
- package/lib/types/src/vertexai/utils/tensor.d.ts +5 -0
- package/lib/types/test/index.d.ts +2 -5
- package/lib/types/test/index.d.ts.map +1 -1
- package/lib/types/togetherai/index.d.ts +2 -7
- package/lib/types/togetherai/index.d.ts.map +1 -1
- package/lib/types/vertexai/embeddings/embeddings-text.d.ts +10 -0
- package/lib/types/vertexai/embeddings/embeddings-text.d.ts.map +1 -0
- package/lib/types/vertexai/index.d.ts +3 -7
- package/lib/types/vertexai/index.d.ts.map +1 -1
- package/lib/types/vertexai/models/codey-chat.d.ts.map +1 -1
- package/lib/types/vertexai/models/codey-text.d.ts.map +1 -1
- package/lib/types/vertexai/models/gemini.d.ts.map +1 -1
- package/lib/types/vertexai/models/palm-model-base.d.ts +15 -1
- package/lib/types/vertexai/models/palm-model-base.d.ts.map +1 -1
- package/lib/types/vertexai/models/palm2-chat.d.ts.map +1 -1
- package/lib/types/vertexai/models/palm2-text.d.ts.map +1 -1
- package/package.json +15 -16
- package/src/bedrock/index.ts +37 -12
- package/src/bedrock/s3.ts +2 -3
- package/src/huggingface_ie.ts +3 -10
- package/src/mistral/index.ts +36 -43
- package/src/openai.ts +7 -11
- package/src/replicate.ts +4 -6
- package/src/test/index.ts +2 -2
- package/src/togetherai/index.ts +6 -13
- package/src/vertexai/embeddings/embeddings-text.ts +52 -0
- package/src/vertexai/index.ts +9 -10
- package/src/vertexai/models/codey-chat.ts +1 -1
- package/src/vertexai/models/codey-text.ts +2 -2
- package/src/vertexai/models/gemini.ts +4 -4
- package/src/vertexai/models/palm-model-base.ts +17 -1
- package/src/vertexai/models/palm2-chat.ts +1 -1
- package/src/vertexai/models/palm2-text.ts +2 -2
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
import { VertexAI } from "@google-cloud/vertexai";
|
|
2
|
+
import { AbstractDriver, BuiltinProviders } from "@llumiverse/core";
|
|
3
|
+
import { FetchClient } from "api-fetch-client";
|
|
4
|
+
import { getEmbeddingsForText } from "./embeddings/embeddings-text.js";
|
|
5
|
+
import { BuiltinModels, getModelDefinition } from "./models.js";
|
|
6
|
+
export class VertexAIDriver extends AbstractDriver {
|
|
7
|
+
provider = BuiltinProviders.vertexai;
|
|
8
|
+
//aiplatform: v1.ModelServiceClient;
|
|
9
|
+
vertexai;
|
|
10
|
+
fetchClient;
|
|
11
|
+
constructor(options) {
|
|
12
|
+
super(options);
|
|
13
|
+
//this.aiplatform = new v1.ModelServiceClient();
|
|
14
|
+
this.vertexai = new VertexAI({
|
|
15
|
+
project: this.options.project,
|
|
16
|
+
location: this.options.region,
|
|
17
|
+
});
|
|
18
|
+
this.fetchClient = createFetchClient({
|
|
19
|
+
region: this.options.region,
|
|
20
|
+
project: this.options.project,
|
|
21
|
+
}).withAuthCallback(async () => {
|
|
22
|
+
//@ts-ignore
|
|
23
|
+
const token = await this.vertexai.preview.googleAuth.getAccessToken();
|
|
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
|
+
validateConnection() {
|
|
59
|
+
throw new Error("Method not implemented.");
|
|
60
|
+
}
|
|
61
|
+
async generateEmbeddings(options) {
|
|
62
|
+
return getEmbeddingsForText(this, options);
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
//'us-central1-aiplatform.googleapis.com',
|
|
66
|
+
const API_BASE_PATH = 'aiplatform.googleapis.com';
|
|
67
|
+
function createFetchClient({ region, project, apiEndpoint, apiVersion = 'v1' }) {
|
|
68
|
+
const vertexBaseEndpoint = apiEndpoint ?? `${region}-${API_BASE_PATH}`;
|
|
69
|
+
return new FetchClient(`https://${vertexBaseEndpoint}/${apiVersion}/projects/${project}/locations/${region}`).withHeaders({
|
|
70
|
+
'Content-Type': 'application/json',
|
|
71
|
+
});
|
|
72
|
+
}
|
|
73
|
+
//# 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 "@llumiverse/core/formatters";
|
|
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;AAChG,OAAO,EAAE,mBAAmB,EAAE,MAAM,6BAA6B,CAAC;AAElE,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 { formatTextPrompt } from "@llumiverse/core/formatters";
|
|
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: formatTextPrompt(segments, opts.resultSchema)
|
|
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;AACpF,OAAO,EAAE,gBAAgB,EAAE,MAAM,6BAA6B,CAAC;AAE/D,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,gBAAgB,CAAC,QAAQ,EAAE,IAAI,CAAC,YAAY,CAAC;iBACxD,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?.promptTokenCount,
|
|
98
|
+
result: usage?.candidatesTokenCount,
|
|
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,53 @@
|
|
|
1
|
+
import { transformSSEStream } from "@llumiverse/core/async";
|
|
2
|
+
import { generateStreamingPrompt } from "../utils/tensor.js";
|
|
3
|
+
export class AbstractPalmModelDefinition {
|
|
4
|
+
createPrompt(driver, segments, options) {
|
|
5
|
+
return this.createNonStreamingPrompt(driver, segments, options);
|
|
6
|
+
}
|
|
7
|
+
async requestCompletion(driver, prompt, options) {
|
|
8
|
+
const nonStreamingPrompt = prompt;
|
|
9
|
+
Object.assign((nonStreamingPrompt).parameters, {
|
|
10
|
+
temperature: options.temperature,
|
|
11
|
+
maxOutputTokens: options.max_tokens,
|
|
12
|
+
});
|
|
13
|
+
const response = await driver.fetchClient.post(`/publishers/google/models/${this.model.id}:predict`, {
|
|
14
|
+
payload: nonStreamingPrompt
|
|
15
|
+
});
|
|
16
|
+
const metadata = response.metadata;
|
|
17
|
+
const inputTokens = metadata.tokenMetadata.inputTokenCount.totalTokens;
|
|
18
|
+
const outputTokens = metadata.tokenMetadata.outputTokenCount.totalTokens;
|
|
19
|
+
const result = this.extractContentFromResponse(response);
|
|
20
|
+
return {
|
|
21
|
+
result,
|
|
22
|
+
token_usage: {
|
|
23
|
+
prompt: inputTokens,
|
|
24
|
+
result: outputTokens,
|
|
25
|
+
total: inputTokens && outputTokens ? inputTokens + outputTokens : undefined,
|
|
26
|
+
}
|
|
27
|
+
};
|
|
28
|
+
}
|
|
29
|
+
async requestCompletionStream(driver, prompt, options) {
|
|
30
|
+
const inPrompt = prompt;
|
|
31
|
+
Object.assign(inPrompt.parameters, {
|
|
32
|
+
temperature: options.temperature,
|
|
33
|
+
maxOutputTokens: options.max_tokens,
|
|
34
|
+
});
|
|
35
|
+
const path = `/publishers/google/models/${this.model.id}:serverStreamingPredict?alt=sse`;
|
|
36
|
+
const newPrompt = generateStreamingPrompt(inPrompt);
|
|
37
|
+
// we need to modify the existing prompt since it is not the final one
|
|
38
|
+
const outPrompt = prompt;
|
|
39
|
+
delete outPrompt.instances;
|
|
40
|
+
outPrompt.inputs = newPrompt.inputs;
|
|
41
|
+
outPrompt.parameters = newPrompt.parameters;
|
|
42
|
+
const eventStrean = await driver.fetchClient.post(path, {
|
|
43
|
+
payload: newPrompt,
|
|
44
|
+
reader: 'sse'
|
|
45
|
+
});
|
|
46
|
+
return transformSSEStream(eventStrean, (data) => {
|
|
47
|
+
const json = JSON.parse(data);
|
|
48
|
+
const stringChunk = this.extractContentFromResponseChunk(json);
|
|
49
|
+
return Array.isArray(stringChunk) ? stringChunk.join('') : stringChunk;
|
|
50
|
+
});
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
//# 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":"AACA,OAAO,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAG5D,OAAO,EAAE,uBAAuB,EAAE,MAAM,oBAAoB,CAAC;AAkD7D,MAAM,OAAgB,2BAA2B;IAY7C,YAAY,CAAC,MAAsB,EAAE,QAAyB,EAAE,OAAsB;QAClF,OAAO,IAAI,CAAC,wBAAwB,CAAC,MAAM,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC;IACpE,CAAC;IAED,KAAK,CAAC,iBAAiB,CAAC,MAAsB,EAAE,MAA8C,EAAE,OAAyB;QACrH,MAAM,kBAAkB,GAAG,MAA6B,CAAC;QACzD,MAAM,CAAC,MAAM,CAAC,CAAC,kBAAkB,CAAC,CAAC,UAAU,EAAE;YAC3C,WAAW,EAAE,OAAO,CAAC,WAAW;YAChC,eAAe,EAAE,OAAO,CAAC,UAAU;SACtC,CAAC,CAAC;QAEH,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC,6BAA6B,IAAI,CAAC,KAAK,CAAC,EAAE,UAAU,EAAE;YACjG,OAAO,EAAE,kBAAkB;SAC9B,CAAC,CAAC;QAEH,MAAM,QAAQ,GAAG,QAAQ,CAAC,QAAgC,CAAC;QAC3D,MAAM,WAAW,GAAG,QAAQ,CAAC,aAAa,CAAC,eAAe,CAAC,WAAW,CAAC;QACvE,MAAM,YAAY,GAAG,QAAQ,CAAC,aAAa,CAAC,gBAAgB,CAAC,WAAW,CAAC;QACzE,MAAM,MAAM,GAAG,IAAI,CAAC,0BAA0B,CAAC,QAAQ,CAAC,CAAC;QACzD,OAAO;YACH,MAAM;YACN,WAAW,EAAE;gBACT,MAAM,EAAE,WAAW;gBACnB,MAAM,EAAE,YAAY;gBACpB,KAAK,EAAE,WAAW,IAAI,YAAY,CAAC,CAAC,CAAC,WAAW,GAAG,YAAY,CAAC,CAAC,CAAC,SAAS;aAC9E;SACU,CAAC;IAEpB,CAAC;IAED,KAAK,CAAC,uBAAuB,CAAC,MAAsB,EAAE,MAA8C,EAAE,OAAyB;QAC3H,MAAM,QAAQ,GAAG,MAA6B,CAAC;QAC/C,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,UAAU,EAAE;YAC/B,WAAW,EAAE,OAAO,CAAC,WAAW;YAChC,eAAe,EAAE,OAAO,CAAC,UAAU;SACtC,CAAC,CAAC;QAEH,MAAM,IAAI,GAAG,6BAA6B,IAAI,CAAC,KAAK,CAAC,EAAE,iCAAiC,CAAC;QAEzF,MAAM,SAAS,GAAG,uBAAuB,CAAC,QAAQ,CAAC,CAAC;QAEpD,sEAAsE;QACtE,MAAM,SAAS,GAAG,MAA0B,CAAC;QAC7C,OAAQ,SAAiB,CAAC,SAAS,CAAC;QACpC,SAAS,CAAC,MAAM,GAAG,SAAS,CAAC,MAAM,CAAC;QACpC,SAAS,CAAC,UAAU,GAAG,SAAS,CAAC,UAAU,CAAC;QAE5C,MAAM,WAAW,GAAG,MAAM,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,EAAE;YACpD,OAAO,EAAE,SAAS;YAClB,MAAM,EAAE,KAAK;SAChB,CAAC,CAAC;QAEH,OAAO,kBAAkB,CAAC,WAAW,EAAE,CAAC,IAAY,EAAE,EAAE;YACpD,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;YAC9B,MAAM,WAAW,GAAG,IAAI,CAAC,+BAA+B,CAAC,IAAI,CAAC,CAAC;YAC/D,OAAO,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC;QAC3E,CAAC,CAAC,CAAA;IACN,CAAC;CAEJ"}
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
import { ModelType, PromptRole } from "@llumiverse/core";
|
|
2
|
+
import { getJSONSafetyNotice } from "@llumiverse/core/formatters";
|
|
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;AAChG,OAAO,EAAE,mBAAmB,EAAE,MAAM,6BAA6B,CAAC;AAElE,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 { formatTextPrompt } from "@llumiverse/core/formatters";
|
|
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: formatTextPrompt(segments, opts.resultSchema)
|
|
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;AACpF,OAAO,EAAE,gBAAgB,EAAE,MAAM,6BAA6B,CAAC;AAE/D,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,gBAAgB,CAAC,QAAQ,EAAE,IAAI,CAAC,YAAY,CAAC;iBACxD,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,87 @@
|
|
|
1
|
+
import { ModelType } from "@llumiverse/core";
|
|
2
|
+
import { GeminiModelDefinition } from "./models/gemini.js";
|
|
3
|
+
import { Palm2TextDefinition } from "./models/palm2-text.js";
|
|
4
|
+
import { Palm2ChatDefinition } from "./models/palm2-chat.js";
|
|
5
|
+
import { CodeyChatDefinition } from "./models/codey-chat.js";
|
|
6
|
+
import { CodeyTextDefinition } from "./models/codey-text.js";
|
|
7
|
+
const Models = {
|
|
8
|
+
"gemini-pro": new GeminiModelDefinition(),
|
|
9
|
+
"text-bison": new Palm2TextDefinition(),
|
|
10
|
+
"chat-bison": new Palm2ChatDefinition(),
|
|
11
|
+
"code-bison": new CodeyTextDefinition(),
|
|
12
|
+
"codechat-bison": new CodeyChatDefinition(),
|
|
13
|
+
};
|
|
14
|
+
export function getModelName(model) {
|
|
15
|
+
const i = model.lastIndexOf('@');
|
|
16
|
+
return i > -1 ? model.substring(0, i) : model;
|
|
17
|
+
}
|
|
18
|
+
export function getModelDefinition(model) {
|
|
19
|
+
const def = Models[getModelName(model)];
|
|
20
|
+
if (!def) {
|
|
21
|
+
throw new Error(`Unknown model ${model}`);
|
|
22
|
+
}
|
|
23
|
+
return def;
|
|
24
|
+
}
|
|
25
|
+
export function getAIModels() {
|
|
26
|
+
return Object.values(Models).map(m => m.model);
|
|
27
|
+
}
|
|
28
|
+
// Builtin models. VertexAI doesn't provide an API to list models. so we have to hardcode them here.
|
|
29
|
+
export const BuiltinModels = [
|
|
30
|
+
{
|
|
31
|
+
id: "gemini-pro",
|
|
32
|
+
name: "Gemini Pro",
|
|
33
|
+
provider: "vertexai",
|
|
34
|
+
owner: "google",
|
|
35
|
+
type: ModelType.Text,
|
|
36
|
+
},
|
|
37
|
+
{
|
|
38
|
+
id: "chat-bison",
|
|
39
|
+
name: "PaLM 2 Chat Bison",
|
|
40
|
+
provider: "vertexai",
|
|
41
|
+
owner: "google",
|
|
42
|
+
type: ModelType.Chat,
|
|
43
|
+
},
|
|
44
|
+
{
|
|
45
|
+
id: "text-bison", // versions 001, 002
|
|
46
|
+
name: "PaLM 2 Text Bison",
|
|
47
|
+
provider: "vertexai",
|
|
48
|
+
owner: "google",
|
|
49
|
+
type: ModelType.Text,
|
|
50
|
+
},
|
|
51
|
+
{
|
|
52
|
+
id: "code-gecko",
|
|
53
|
+
name: "Codey for Code Completion",
|
|
54
|
+
provider: "vertexai",
|
|
55
|
+
owner: "google",
|
|
56
|
+
type: ModelType.Code,
|
|
57
|
+
},
|
|
58
|
+
{
|
|
59
|
+
id: "code-bison",
|
|
60
|
+
name: "Codey for Code Generation",
|
|
61
|
+
provider: "vertexai",
|
|
62
|
+
owner: "google",
|
|
63
|
+
type: ModelType.Code,
|
|
64
|
+
},
|
|
65
|
+
{
|
|
66
|
+
id: "codechat-bison",
|
|
67
|
+
name: "Codey for Code Chat",
|
|
68
|
+
provider: "vertexai",
|
|
69
|
+
owner: "google",
|
|
70
|
+
type: ModelType.Code,
|
|
71
|
+
},
|
|
72
|
+
{
|
|
73
|
+
id: "tablextembedding-gecko",
|
|
74
|
+
name: "Gecko Text Embeddings",
|
|
75
|
+
provider: "vertexai",
|
|
76
|
+
owner: "google",
|
|
77
|
+
type: ModelType.Embedding,
|
|
78
|
+
},
|
|
79
|
+
{
|
|
80
|
+
id: "textembedding-gecko-multilingual",
|
|
81
|
+
name: "Gecko Multilingual Text Embeddings",
|
|
82
|
+
provider: "vertexai",
|
|
83
|
+
owner: "google",
|
|
84
|
+
type: ModelType.Embedding,
|
|
85
|
+
},
|
|
86
|
+
];
|
|
87
|
+
//# sourceMappingURL=models.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"models.js","sourceRoot":"","sources":["../../../../src/vertexai/models.ts"],"names":[],"mappings":"AAAA,OAAO,EAAyC,SAAS,EAAgC,MAAM,kBAAkB,CAAC;AAClH,OAAO,EAAE,qBAAqB,EAAE,MAAM,oBAAoB,CAAC;AAE3D,OAAO,EAAE,mBAAmB,EAAE,MAAM,wBAAwB,CAAC;AAC7D,OAAO,EAAE,mBAAmB,EAAE,MAAM,wBAAwB,CAAC;AAC7D,OAAO,EAAE,mBAAmB,EAAE,MAAM,wBAAwB,CAAC;AAC7D,OAAO,EAAE,mBAAmB,EAAE,MAAM,wBAAwB,CAAC;AAG7D,MAAM,MAAM,GAAoC;IAC5C,YAAY,EAAE,IAAI,qBAAqB,EAAE;IACzC,YAAY,EAAE,IAAI,mBAAmB,EAAE;IACvC,YAAY,EAAE,IAAI,mBAAmB,EAAE;IACvC,YAAY,EAAE,IAAI,mBAAmB,EAAE;IACvC,gBAAgB,EAAE,IAAI,mBAAmB,EAAE;CAC9C,CAAA;AAUD,MAAM,UAAU,YAAY,CAAC,KAAa;IACtC,MAAM,CAAC,GAAG,KAAK,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;IACjC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;AAClD,CAAC;AAED,MAAM,UAAU,kBAAkB,CAAC,KAAa;IAC5C,MAAM,GAAG,GAAG,MAAM,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,CAAC;IACxC,IAAI,CAAC,GAAG,EAAE,CAAC;QACP,MAAM,IAAI,KAAK,CAAC,iBAAiB,KAAK,EAAE,CAAC,CAAC;IAC9C,CAAC;IACD,OAAO,GAAG,CAAC;AACf,CAAC;AAED,MAAM,UAAU,WAAW;IACvB,OAAO,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;AACnD,CAAC;AAED,oGAAoG;AACpG,MAAM,CAAC,MAAM,aAAa,GAAsB;IAC5C;QACI,EAAE,EAAE,YAAY;QAChB,IAAI,EAAE,YAAY;QAClB,QAAQ,EAAE,UAAU;QACpB,KAAK,EAAE,QAAQ;QACf,IAAI,EAAE,SAAS,CAAC,IAAI;KACvB;IACD;QACI,EAAE,EAAE,YAAY;QAChB,IAAI,EAAE,mBAAmB;QACzB,QAAQ,EAAE,UAAU;QACpB,KAAK,EAAE,QAAQ;QACf,IAAI,EAAE,SAAS,CAAC,IAAI;KACvB;IACD;QACI,EAAE,EAAE,YAAY,EAAE,oBAAoB;QACtC,IAAI,EAAE,mBAAmB;QACzB,QAAQ,EAAE,UAAU;QACpB,KAAK,EAAE,QAAQ;QACf,IAAI,EAAE,SAAS,CAAC,IAAI;KACvB;IACD;QACI,EAAE,EAAE,YAAY;QAChB,IAAI,EAAE,2BAA2B;QACjC,QAAQ,EAAE,UAAU;QACpB,KAAK,EAAE,QAAQ;QACf,IAAI,EAAE,SAAS,CAAC,IAAI;KACvB;IACD;QACI,EAAE,EAAE,YAAY;QAChB,IAAI,EAAE,2BAA2B;QACjC,QAAQ,EAAE,UAAU;QACpB,KAAK,EAAE,QAAQ;QACf,IAAI,EAAE,SAAS,CAAC,IAAI;KACvB;IACD;QACI,EAAE,EAAE,gBAAgB;QACpB,IAAI,EAAE,qBAAqB;QAC3B,QAAQ,EAAE,UAAU;QACpB,KAAK,EAAE,QAAQ;QACf,IAAI,EAAE,SAAS,CAAC,IAAI;KACvB;IACD;QACI,EAAE,EAAE,wBAAwB;QAC5B,IAAI,EAAE,uBAAuB;QAC7B,QAAQ,EAAE,UAAU;QACpB,KAAK,EAAE,QAAQ;QACf,IAAI,EAAE,SAAS,CAAC,SAAS;KAC5B;IACD;QACI,EAAE,EAAE,kCAAkC;QACtC,IAAI,EAAE,oCAAoC;QAC1C,QAAQ,EAAE,UAAU;QACpB,KAAK,EAAE,QAAQ;QACf,IAAI,EAAE,SAAS,CAAC,SAAS;KAC5B;CAIJ,CAAA"}
|
|
@@ -1,37 +1,19 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
export interface PromptParamatersBase {
|
|
5
|
-
temperature?: number,
|
|
6
|
-
maxOutputTokens?: number,
|
|
7
|
-
topK?: number,
|
|
8
|
-
topP?: number,
|
|
9
|
-
groundingConfig?: string,
|
|
10
|
-
stopSequences?: string[],
|
|
11
|
-
candidateCount?: number,
|
|
12
|
-
logprobs?: number,
|
|
13
|
-
presencePenalty?: number,
|
|
14
|
-
frequencyPenalty?: number,
|
|
15
|
-
logitBias?: Record<string, number>,
|
|
16
|
-
seed?: number,
|
|
17
|
-
echo?: boolean
|
|
1
|
+
import { PromptRole } from "@llumiverse/core";
|
|
2
|
+
export function getJSONSafetyNotice(schema) {
|
|
3
|
+
return "The answer must be a JSON object using the following JSON Schema:\n" + JSON.stringify(schema);
|
|
18
4
|
}
|
|
19
|
-
|
|
20
|
-
export function getJSONSafetyNotice(schema: JSONSchema4) {
|
|
21
|
-
return "The answer must be a JSON object using the following JSON Schema:\n" + JSON.stringify(schema)
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
export function getPromptAsText(segments: PromptSegment[], options: PromptOptions): string {
|
|
5
|
+
export function getPromptAsText(segments, options) {
|
|
25
6
|
const isChat = segments.find(m => m.role === PromptRole.assistant);
|
|
26
|
-
const context
|
|
27
|
-
const content
|
|
28
|
-
const safety
|
|
7
|
+
const context = [];
|
|
8
|
+
const content = [];
|
|
9
|
+
const safety = [];
|
|
29
10
|
for (const segment of segments) {
|
|
30
11
|
switch (segment.role) {
|
|
31
12
|
case PromptRole.user:
|
|
32
13
|
if (isChat) {
|
|
33
14
|
content.push('USER: ' + segment.content);
|
|
34
|
-
}
|
|
15
|
+
}
|
|
16
|
+
else {
|
|
35
17
|
content.push(segment.content);
|
|
36
18
|
}
|
|
37
19
|
break;
|
|
@@ -46,11 +28,9 @@ export function getPromptAsText(segments: PromptSegment[], options: PromptOption
|
|
|
46
28
|
break;
|
|
47
29
|
}
|
|
48
30
|
}
|
|
49
|
-
|
|
50
31
|
if (options.resultSchema) {
|
|
51
32
|
safety.push(getJSONSafetyNotice(options.resultSchema));
|
|
52
33
|
}
|
|
53
|
-
|
|
54
34
|
const out = [];
|
|
55
35
|
if (context.length > 0) {
|
|
56
36
|
out.push('CONTEXT: ' + context.join('\n'));
|
|
@@ -64,3 +44,4 @@ export function getPromptAsText(segments: PromptSegment[], options: PromptOption
|
|
|
64
44
|
}
|
|
65
45
|
return out.join('\n');
|
|
66
46
|
}
|
|
47
|
+
//# sourceMappingURL=prompts.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"prompts.js","sourceRoot":"","sources":["../../../../../src/vertexai/utils/prompts.ts"],"names":[],"mappings":"AAAA,OAAO,EAAiB,UAAU,EAAiB,MAAM,kBAAkB,CAAC;AAmB5E,MAAM,UAAU,mBAAmB,CAAC,MAAmB;IACnD,OAAO,qEAAqE,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAA;AACzG,CAAC;AAED,MAAM,UAAU,eAAe,CAAC,QAAyB,EAAE,OAAsB;IAC7E,MAAM,MAAM,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,UAAU,CAAC,SAAS,CAAC,CAAC;IACnE,MAAM,OAAO,GAAa,EAAE,CAAC;IAC7B,MAAM,OAAO,GAAa,EAAE,CAAC;IAC7B,MAAM,MAAM,GAAa,EAAE,CAAC;IAC5B,KAAK,MAAM,OAAO,IAAI,QAAQ,EAAE,CAAC;QAC7B,QAAQ,OAAO,CAAC,IAAI,EAAE,CAAC;YACnB,KAAK,UAAU,CAAC,IAAI;gBAChB,IAAI,MAAM,EAAE,CAAC;oBACT,OAAO,CAAC,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC;gBAC7C,CAAC;qBAAM,CAAC;oBACJ,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;gBAClC,CAAC;gBACD,MAAM;YACV,KAAK,UAAU,CAAC,SAAS;gBACrB,OAAO,CAAC,IAAI,CAAC,aAAa,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC;gBAC9C,MAAM;YACV,KAAK,UAAU,CAAC,MAAM;gBAClB,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;gBAC9B,MAAM;YACV,KAAK,UAAU,CAAC,MAAM;gBAClB,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;gBAC7B,MAAM;QACd,CAAC;IACL,CAAC;IAED,IAAI,OAAO,CAAC,YAAY,EAAE,CAAC;QACvB,MAAM,CAAC,IAAI,CAAC,mBAAmB,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC;IAC3D,CAAC;IAED,MAAM,GAAG,GAAG,EAAE,CAAC;IACf,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACrB,GAAG,CAAC,IAAI,CAAC,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;IAC/C,CAAC;IACD,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACrB,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,EAAE,CAAC;QACpE,GAAG,CAAC,IAAI,CAAC,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;IAC1C,CAAC;IACD,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACpB,GAAG,CAAC,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;IAChD,CAAC;IACD,OAAO,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AAC1B,CAAC"}
|