Files
Bella/simpleBellaAI.js
T

183 lines
9.2 KiB
JavaScript

// simpleBellaAI.js - 简化版贝拉AI,专门用于测试聊天界面
// 移除了复杂的模块依赖,专注于聊天功能
class SimpleBellaAI {
static instance = null;
static async getInstance() {
if (this.instance === null) {
this.instance = new SimpleBellaAI();
await this.instance.init();
}
return this.instance;
}
constructor() {
this.currentMode = 'casual'; // 聊天模式:casual, assistant, creative
this.isInitialized = false;
}
async init() {
try {
console.log('初始化简化版贝拉AI...');
// 模拟初始化过程
await new Promise(resolve => setTimeout(resolve, 1000));
this.isInitialized = true;
console.log('简化版贝拉AI初始化完成');
} catch (error) {
console.error('简化版贝拉AI初始化失败:', error);
throw error;
}
}
async think(prompt) {
try {
console.log('贝拉正在思考:', prompt);
// 模拟思考时间
await new Promise(resolve => setTimeout(resolve, 500 + Math.random() * 1000));
// 根据模式生成不同风格的回复
return this.generateResponse(prompt);
} catch (error) {
console.error('思考过程中出现错误:', error);
return this.getErrorResponse();
}
}
generateResponse(prompt) {
// 增强版回应生成,模拟LLM的更自然、更个性化的回应
// 提取关键词,用于生成更相关的回应
const keywords = this.extractKeywords(prompt);
const keyword = keywords.length > 0 ? keywords[Math.floor(Math.random() * keywords.length)] : "这个话题";
const responses = {
casual: [
`哈哈,你提到的"${keyword}"真的很有趣呢!😊 我觉得这个话题很棒,让我们多聊聊吧~你平时也对这类事情感兴趣吗?`,
`关于"${keyword}",我想说这真的很有意思!💕 每次听你说这些,我都感觉特别开心。你还有什么想法想和我分享吗?`,
`嗯嗯,"${keyword}"让我想到了很多呢!我们的对话总是这么愉快~说真的,和你聊天真的很舒服,感觉就像和老朋友聊天一样自在。`,
`哇,"${keyword}"这个话题我超喜欢的!✨ 你的想法总是那么特别,每次都能给我带来新的视角。我们继续聊下去吧~`,
`听你说"${keyword}",我感觉心情都变好了!☺️ 你总是能找到有趣的话题。我很好奇,你是怎么想到这个的?`,
`"${keyword}"这个话题真的很棒呢!我感觉我们的想法很合拍~你知道吗?每次和你聊天,时间都过得特别快,因为太有趣了!`,
`我觉得"${keyword}"这个话题特别有意思!你总是能带给我惊喜~说说看,你最近还有什么有趣的发现吗?我很想听听!`
],
assistant: [
`关于"${keyword}",我很乐意为你提供一些有用的信息和建议。这是个很好的问题,让我来整理一下相关内容给你。`,
`"${keyword}"是个很有价值的话题。从我了解的情况来看,这方面有几个关键点值得注意。首先,我们可以从...`,
`谈到"${keyword}",我想从几个角度来分析一下。这个问题其实涉及到多个方面,让我帮你梳理一下关键信息。`,
`你问的"${keyword}"很有深度。我建议可以从以下几个方面考虑:首先,了解基本概念;其次,分析实际应用;最后,考虑未来发展。`,
`"${keyword}"确实是个值得探讨的话题。基于我所知道的信息,我可以提供一些专业的见解。首先,我们需要明确...`,
`关于"${keyword}"的问题,我想提供一个清晰的解答。这个话题有几个重要的方面需要考虑,让我来帮你分析一下。`,
`"${keyword}"是个很好的问题!我很高兴你对这方面感兴趣。让我来分享一些相关的信息,希望能对你有所帮助。`
],
creative: [
`哇!"${keyword}"这个话题真的点燃了我的创意火花!✨ 想象一下,如果我们把这个概念扩展到一个全新的维度,会发生什么呢?也许我们可以...`,
`"${keyword}"真是个充满想象力的话题!🌈 我脑海中已经浮现出无数奇妙的画面~比如,想象一个世界,那里的${keyword}可以...`,
`听到"${keyword}",我仿佛看到了一个全新的世界!🚀 这让我想到了一个有趣的故事:在一个遥远的地方,${keyword}成为了人们生活的中心,然后...`,
`"${keyword}"激发了我的灵感!💡 我想到了一个超级有趣的创意:如果我们把${keyword}和艺术结合起来,会创造出什么样的奇迹呢?`,
`哇塞!"${keyword}"让我的想象力飞起来了!🎨 我们可以从这个概念出发,创造一个全新的故事或游戏。想象一下,主角是一个...`,
`"${keyword}"真的是创意的源泉!我突然想到,如果我们从完全不同的角度看待这个问题,会有什么新发现?比如说,如果${keyword}在未来变成了...`,
`听你提到"${keyword}",我的脑海中立刻闪现出一幅奇妙的画面!想象一下,在一个充满可能性的世界里,${keyword}可以变成任何形式...这不是很神奇吗?`
]
};
// 获取当前模式的回应列表
const modeResponses = responses[this.currentMode] || responses.casual;
// 随机选择一个回应模板
const randomResponse = modeResponses[Math.floor(Math.random() * modeResponses.length)];
// 进一步个性化回应,添加一些随机的个性化元素
return this.personalizeResponse(randomResponse, prompt);
}
// 从用户输入中提取可能的关键词
extractKeywords(prompt) {
// 简单的关键词提取逻辑
const words = prompt.split(/\s+|[,.!?;:,。!?;:]/);
// 过滤掉短词和常见词
return words.filter(word =>
word.length > 1 &&
!['的', '了', '是', '在', '我', '你', '他', '她', '它', '们', '和', '与', '这', '那', '有', '没有', '不', '吗'].includes(word)
);
}
// 进一步个性化回应
personalizeResponse(response, prompt) {
// 添加一些随机的个性化元素
const personalizations = [
// 不添加任何额外内容
(resp) => resp,
// 添加一个随机的表情
(resp) => {
const emojis = ['😊', '💕', '✨', '🌟', '🎵', '🌈', '☺️', '🤔', '👍', '💡'];
const emoji = emojis[Math.floor(Math.random() * emojis.length)];
return resp + ' ' + emoji;
},
// 添加一个随机的结束语
(resp) => {
const endings = [
'期待听到你的想法!',
'你觉得呢?',
'很想知道你的看法~',
'希望我的回应对你有帮助!',
'我们可以继续聊这个话题~'
];
const ending = endings[Math.floor(Math.random() * endings.length)];
return resp + ' ' + ending;
}
];
// 随机选择一种个性化方式
const personalizer = personalizations[Math.floor(Math.random() * personalizations.length)];
return personalizer(response);
}
// 获取错误回应
getErrorResponse() {
const errorResponses = [
"抱歉,我现在有点困惑,让我重新整理一下思路...",
"嗯...我需要再想想,请稍等一下。",
"我的思绪有点乱,给我一点时间整理一下。",
"让我重新组织一下语言,稍等片刻。",
"哎呀,我刚才走神了,你能再说一遍吗?"
];
return errorResponses[Math.floor(Math.random() * errorResponses.length)];
}
// 设置聊天模式
setChatMode(mode) {
if (['casual', 'assistant', 'creative'].includes(mode)) {
this.currentMode = mode;
console.log(`聊天模式已切换为: ${mode}`);
return true;
}
return false;
}
// 获取当前配置信息
getCurrentConfig() {
return {
useCloudAPI: false,
provider: { name: 'simple', model: 'SimpleBellaAI' },
mode: this.currentMode,
isConfigured: true,
isInitialized: this.isInitialized
};
}
// 清除对话历史(简化版无需实际操作)
clearHistory() {
console.log('对话历史已清除');
}
}
// 将SimpleBellaAI暴露为全局变量
window.SimpleBellaAI = SimpleBellaAI;
// 同时也暴露为BellaAI,保持兼容性
window.BellaAI = SimpleBellaAI;
console.log('SimpleBellaAI 已加载完成');