File size: 1,188 Bytes
3245107
d0db329
3245107
 
d0db329
3245107
 
 
 
 
 
 
d0db329
3245107
 
 
d0db329
 
 
 
3245107
 
 
d0db329
3245107
 
 
3fc700a
d0db329
3245107
d0db329
 
 
3245107
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
from abc import ABC
from openai import OpenAI
import os


class Base(ABC):
    def chat(self, system, history, gen_conf):
        raise NotImplementedError("Please implement encode method!")


class GptTurbo(Base):
    def __init__(self):
        self.client = OpenAI(api_key=os.environ["OPENAI_API_KEY"])

    def chat(self, system, history, gen_conf):
        history.insert(0, {"role": "system", "content": system})
        res = self.client.chat.completions.create(
            model="gpt-3.5-turbo",
            messages=history,
            **gen_conf)
        return res.choices[0].message.content.strip()


class QWenChat(Base):
    def chat(self, system, history, gen_conf):
        from http import HTTPStatus
        from dashscope import Generation
        # export DASHSCOPE_API_KEY=YOUR_DASHSCOPE_API_KEY
        history.insert(0, {"role": "system", "content": system})
        response = Generation.call(
            Generation.Models.qwen_turbo,
            messages=history,
            result_format='message'
        )
        if response.status_code == HTTPStatus.OK:
            return response.output.choices[0]['message']['content']
        return response.message