chore: auto concat messages

This commit is contained in:
Fred Liang 2023-12-25 04:33:47 +08:00
parent cad461b121
commit 199f29e63c
No known key found for this signature in database
GPG Key ID: 4DABDA85EF70EC71
2 changed files with 30 additions and 26 deletions

View File

@ -21,10 +21,24 @@ export class GeminiProApi implements LLMApi {
} }
async chat(options: ChatOptions): Promise<void> { async chat(options: ChatOptions): Promise<void> {
const messages = options.messages.map((v) => ({ const messages = options.messages.map((v) => ({
role: v.role.replace("assistant", "model").replace("system", "model"), role: v.role.replace("assistant", "model").replace("system", "user"),
parts: [{ text: v.content }], parts: [{ text: v.content }],
})); }));
// google requires that role in neighboring messages must not be the same
for (let i = 0; i < messages.length - 1; ) {
// Check if current and next item both have the role "model"
if (messages[i].role === messages[i + 1].role) {
// Concatenate the 'parts' of the current and next item
messages[i].parts = messages[i].parts.concat(messages[i + 1].parts);
// Remove the next item
messages.splice(i + 1, 1);
} else {
// Move to the next item
i++;
}
}
const modelConfig = { const modelConfig = {
...useAppConfig.getState().modelConfig, ...useAppConfig.getState().modelConfig,
...useChatStore.getState().currentSession().mask.modelConfig, ...useChatStore.getState().currentSession().mask.modelConfig,
@ -43,14 +57,6 @@ export class GeminiProApi implements LLMApi {
topP: modelConfig.top_p, topP: modelConfig.top_p,
// "topK": modelConfig.top_k, // "topK": modelConfig.top_k,
}, },
// stream: options.config.stream,
// model: modelConfig.model,
// temperature: modelConfig.temperature,
// presence_penalty: modelConfig.presence_penalty,
// frequency_penalty: modelConfig.frequency_penalty,
// top_p: modelConfig.top_p,
// max_tokens: Math.max(modelConfig.max_tokens, 1024),
// Please do not ask me why not send max_tokens, no reason, this param is just shit, I dont want to explain anymore.
}; };
console.log("[Request] google payload: ", requestPayload); console.log("[Request] google payload: ", requestPayload);

View File

@ -389,24 +389,22 @@ export const useChatStore = createPersistStore(
const shouldInjectSystemPrompts = modelConfig.enableInjectSystemPrompts; const shouldInjectSystemPrompts = modelConfig.enableInjectSystemPrompts;
var systemPrompts: ChatMessage[] = []; var systemPrompts: ChatMessage[] = [];
if (modelConfig.model !== "gemini-pro") { systemPrompts = shouldInjectSystemPrompts
systemPrompts = shouldInjectSystemPrompts ? [
? [ createMessage({
createMessage({ role: "system",
role: "system", content: fillTemplateWith("", {
content: fillTemplateWith("", { ...modelConfig,
...modelConfig, template: DEFAULT_SYSTEM_TEMPLATE,
template: DEFAULT_SYSTEM_TEMPLATE,
}),
}), }),
] }),
: []; ]
if (shouldInjectSystemPrompts) { : [];
console.log( if (shouldInjectSystemPrompts) {
"[Global System Prompt] ", console.log(
systemPrompts.at(0)?.content ?? "empty", "[Global System Prompt] ",
); systemPrompts.at(0)?.content ?? "empty",
} );
} }
// long term memory // long term memory