使用discord.js在Discord中让GPT-3的”davinci”通过机器人与用户对话的方法?

var collector = new MessageCollector(message.channel, filter, {    max: 10,    time: 60000,})
    start_sequence = "\nAI: "
        retart_sequence = "\nHuman: "
        collector.on("collect", (msg) => {
            console.log(msg.content)

                    openai.Completion.create({
                        engine: "davinci",
            prompt: msg.content,
            temperature: 0.9,
            max_tokens: 150,
            top_p: 1,
            frequency_penalty: 0.35,
            presence_penalty: 0.6,
             stop: ["\n", " Human:", " AI:"]
                  }).then((response) => {
                        message.channel.send(response.choices[0].text)
        })
    })}

我尝试过这种方法,但它只返回完成内容,就像默认预设而不是GPT-3的”playground”中的聊天预设。我使用openai-node在javascript中编程,而不是使用python来调用OpenAI API。


回答:

你的prompt需要提供更多信息,让GPT-3理解你想要什么。你提供的消息提示,例如

My message!

但你真正应该提供的是类似于这样的内容:

以下是与AI助手的对话。助手乐于助人,富有创造力,聪明且非常友好。Human: 你好,你是谁?AI: 我是由OpenAI创建的AI。今天我能帮你什么?Human: My message!AI:

此外,如果你希望它具有上下文感知能力,你需要继续向提示中添加信息,例如:

以下是与AI助手的对话。助手乐于助人,富有创造力,聪明且非常友好。Human: 你好,你是谁?AI: 我是由OpenAI创建的AI。今天我能帮你什么?Human: My message!AI: 这里的回应Human: 这里的另一条消息AI:

请注意令牌限制和成本。你可能需要选择让它具有上下文,或者在某个时候开始删除之前的消息。

Related Posts

L1-L2正则化的不同系数

我想对网络的权重同时应用L1和L2正则化。然而,我找不…

使用scikit-learn的无监督方法将列表分类成不同组别,有没有办法?

我有一系列实例,每个实例都有一份列表,代表它所遵循的不…

f1_score metric in lightgbm

我想使用自定义指标f1_score来训练一个lgb模型…

通过相关系数矩阵进行特征选择

我在测试不同的算法时,如逻辑回归、高斯朴素贝叶斯、随机…

可以将机器学习库用于流式输入和输出吗?

已关闭。此问题需要更加聚焦。目前不接受回答。 想要改进…

在TensorFlow中,queue.dequeue_up_to()方法的用途是什么?

我对这个方法感到非常困惑,特别是当我发现这个令人费解的…

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注