11 Likes
data:image/s3,"s3://crabby-images/fe078/fe078891ec72ce75fb9deeddb44bbe6c14350531" alt="Introducing Hyper Chat"
Introducing Hyper Chat
最近借着 AIGC 的潮流, 用 Tauri 做了个基于 OpenAI 和 Azure OpenAI Service 的聊天机器人, 目前正式版已经放出, 欢迎大家去 https://hyperchat.yancey.app/ 下载和使用. 代码放在了 https://github.com/orgs/HyperChatBot, 欢迎一起建设和优化.
Functions
Hyper Chat 的跨平台基于 tauri, 老实说比起 electron, 虽然 tauri 无需安装笨重的 chromium, 但 webkit 本身缺失了太多的功能, 如 `window.navigator.onLine`
, `onCompositionStart`
等等, 所以在实现上一些效果并不令人满意.‘
Hyper Chat 的初衷是绝不收集用户信息, 如 OpenAI Secret Key 和聊天记录. 因此我们使用 indexedDB 来存储数据. 在设置中, 我们支持导入和导出数据. 当然如果你有兴趣提供一个服务端, 前端代码也是很容易修改的, 你只需要将 `src/hooks/useDB.ts`
中的函数换成你的 API 接口即可.
data:image/s3,"s3://crabby-images/fe2f5/fe2f596a350c75cc3996cdbb74962ae3fa4c2b1e" alt="import-export-db"
data:image/s3,"s3://crabby-images/1721e/1721e278177ea68bd3c65a119fdf8a97d3912e73" alt="settings"
Customizable ChatBox
在聊天框区域, 对于每种模型 API, 我们都有和官方一致的配置参数可供用户选择.
data:image/s3,"s3://crabby-images/9e524/9e52404a2256e09bc7aa70300eedabb577c80ccb" alt="configuration"
data:image/s3,"s3://crabby-images/f60ea/f60ea6f5b8905ecc498928c88e4ce4bf04add222" alt="other-configuration"
Chat Completion
data:image/s3,"s3://crabby-images/3171a/3171a5af65dedea57d33a508878c5eaf5a931dcf" alt="chat-completions"
// 获取用户 prompt 的 token 数 const userMessageTokensCount = getTokensCount(prompt, model); // 总的 token 数等于用户 prompt 的 token 数 + 系统消息的 token 数 + 本次希望 Assistant 返回的最大 token 数 let tokensCount = userMessageTokensCount + systemMessageTokensCount + maxTokens; // 获取当前模型最大支持的 token 数, 如 GPT-3.5-turbo 最多支持 4097 个 token const tokensLimit = models.find((m) => m.name === model)?.tokensLimit || 0; // 如果用户输入的 prompt 的 token 数已经超过阈值, 就提示错误 if (tokensCount > tokensLimit) { toast.error( `This model's maximum context length is ${tokensLimit} tokens. However, you requested ${tokensCount} tokens (${ tokensCount - maxTokens } in the messages, ${maxTokens} in the completion). Please reduce the length of the prompt.` ); return; } // 从新到旧依次遍历过往的 message, 尽可能的多的将上下文交给模型处理 const context: CreateChatCompletionRequest["messages"] = []; currConversation.messages .slice() .reverse() .forEach(({ tokensCount: historyTokensCount, content, role }) => { tokensCount += historyTokensCount; if (tokensCount > tokensLimit) return; context.unshift({ role, content, }); });
Text Completion
data:image/s3,"s3://crabby-images/5f64b/5f64b63f1c4ed4fe606e43eafa6dbf4e4145eae9" alt="text-completion"
Audio Transparent and Translation
虽然 OpenAI 早已开源了 Whisper-1, 但我们还是接入了它的接口, 我们支持音频的转录和翻译. 在右下角先选择音频文件, 再敲击回车即可提交, 你也可以输入 prompt, 不过在 Audio 中, 它是可选的.
data:image/s3,"s3://crabby-images/e85b2/e85b28120f10092e7377971d99d2862acf8e5a2c" alt="audio-transparent-and-translation"
Image Generation
我们支持基于 DALL-E 的图片生成接口, 建议在配置中选择更小尺寸的图片, 这样生成起来会比较快. 此外, 图片有过期时间(约为 1 天), 请及时将生成的图片下载到本地.
data:image/s3,"s3://crabby-images/dbf35/dbf355ab8b5e89932724f4178d600863aa5e2d47" alt="image-generation"
最后
欢迎大家体验和使用, 有任何建议都可以通过 Official Discussion 一起讨论.
data:image/s3,"s3://crabby-images/c5a46/c5a465ddbd17e02c74a033d60b14a18d7e36616b" alt="教你在中国大陆足不出户开通境外汇丰银行卡"
PREVIOUS POST
教你在中国大陆足不出户开通境外汇丰银行卡
data:image/s3,"s3://crabby-images/0659b/0659b3d2bdc6ee4381b31132929ec9875de976ba" alt="How to deploy Nest.js microservices using Kubernetes"
NEXT POST
How to deploy Nest.js microservices using Kubernetes