Spaces:
Runtime error
Runtime error
zjowowen
commited on
feature(zjow): add chatglm api support (#13)
Browse files- README.md +18 -0
- README_zh.md +18 -4
- app.py +4 -2
- llmriddles/llms/__init__.py +1 -0
- llmriddles/llms/chatglm.py +26 -0
- requirements-dev.txt +11 -0
- requirements.txt +1 -2
README.md
CHANGED
@@ -21,6 +21,16 @@ We provide an online version for players to directly access and try out.
|
|
21 |
- [ChatGPT + Chinese(w/ key)](http://llmriddles.opendilab.net/)
|
22 |
|
23 |
Local deployment can be done in the following ways:
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
24 |
### ChatGPT + Chinese
|
25 |
```shell
|
26 |
QUESTION_LANG=cn QUESTION_LLM='chatgpt' QUESTION_LLM_KEY=<your API key> python3 -u app.py
|
@@ -29,6 +39,14 @@ QUESTION_LANG=cn QUESTION_LLM='chatgpt' QUESTION_LLM_KEY=<your API key> python3
|
|
29 |
```shell
|
30 |
QUESTION_LANG=en QUESTION_LLM='chatgpt' QUESTION_LLM_KEY=<your API key> python3 -u app.py
|
31 |
```
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
32 |
### Mistral-7B-Instruct-v0.1 + English
|
33 |
```shell
|
34 |
QUESTION_LANG=en QUESTION_LLM='mistral-7b' python3 -u app.py
|
|
|
21 |
- [ChatGPT + Chinese(w/ key)](http://llmriddles.opendilab.net/)
|
22 |
|
23 |
Local deployment can be done in the following ways:
|
24 |
+
## Installation
|
25 |
+
### Use ChatGPT / ChatGLM API
|
26 |
+
```shell
|
27 |
+
pip3 install -r requirements.txt
|
28 |
+
```
|
29 |
+
### Do Mistral-7B-Instruct-v0.1 local inference
|
30 |
+
```shell
|
31 |
+
pip3 install -r requirements-dev.txt
|
32 |
+
```
|
33 |
+
## Launch
|
34 |
### ChatGPT + Chinese
|
35 |
```shell
|
36 |
QUESTION_LANG=cn QUESTION_LLM='chatgpt' QUESTION_LLM_KEY=<your API key> python3 -u app.py
|
|
|
39 |
```shell
|
40 |
QUESTION_LANG=en QUESTION_LLM='chatgpt' QUESTION_LLM_KEY=<your API key> python3 -u app.py
|
41 |
```
|
42 |
+
### ChatGLM + Chinese
|
43 |
+
```shell
|
44 |
+
QUESTION_LANG=cn QUESTION_LLM='chatglm' QUESTION_LLM_KEY=<your API key> python3 -u app.py
|
45 |
+
```
|
46 |
+
### ChatGLM + English
|
47 |
+
```shell
|
48 |
+
QUESTION_LANG=en QUESTION_LLM='chatglm' QUESTION_LLM_KEY=<your API key> python3 -u app.py
|
49 |
+
```
|
50 |
### Mistral-7B-Instruct-v0.1 + English
|
51 |
```shell
|
52 |
QUESTION_LANG=en QUESTION_LLM='mistral-7b' python3 -u app.py
|
README_zh.md
CHANGED
@@ -21,6 +21,16 @@
|
|
21 |
- [ChatGPT + 中文(已预设api key)](http://llmriddles.opendilab.net/)
|
22 |
|
23 |
本地部署可以通过以下方式:
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
24 |
### ChatGPT + 中文
|
25 |
```shell
|
26 |
QUESTION_LANG=cn QUESTION_LLM='chatgpt' QUESTION_LLM_KEY=<your API key> python3 -u app.py
|
@@ -29,13 +39,17 @@ QUESTION_LANG=cn QUESTION_LLM='chatgpt' QUESTION_LLM_KEY=<your API key> python3
|
|
29 |
```shell
|
30 |
QUESTION_LANG=en QUESTION_LLM='chatgpt' QUESTION_LLM_KEY=<your API key> python3 -u app.py
|
31 |
```
|
32 |
-
###
|
|
|
|
|
|
|
|
|
33 |
```shell
|
34 |
-
QUESTION_LANG=
|
35 |
```
|
36 |
-
###
|
37 |
```shell
|
38 |
-
QUESTION_LANG=en QUESTION_LLM='
|
39 |
```
|
40 |
## :technologist: 为什么制作这个游戏
|
41 |
|
|
|
21 |
- [ChatGPT + 中文(已预设api key)](http://llmriddles.opendilab.net/)
|
22 |
|
23 |
本地部署可以通过以下方式:
|
24 |
+
## 安装
|
25 |
+
### ChatGPT 或 ChatGLM API
|
26 |
+
```shell
|
27 |
+
pip3 install -r requirements.txt
|
28 |
+
```
|
29 |
+
### Mistral-7B-Instruct-v0.1 本地推理
|
30 |
+
```shell
|
31 |
+
pip3 install -r requirements-dev.txt
|
32 |
+
```
|
33 |
+
## 启动
|
34 |
### ChatGPT + 中文
|
35 |
```shell
|
36 |
QUESTION_LANG=cn QUESTION_LLM='chatgpt' QUESTION_LLM_KEY=<your API key> python3 -u app.py
|
|
|
39 |
```shell
|
40 |
QUESTION_LANG=en QUESTION_LLM='chatgpt' QUESTION_LLM_KEY=<your API key> python3 -u app.py
|
41 |
```
|
42 |
+
### ChatGLM + 中文
|
43 |
+
```shell
|
44 |
+
QUESTION_LANG=cn QUESTION_LLM='chatglm' QUESTION_LLM_KEY=<your API key> python3 -u app.py
|
45 |
+
```
|
46 |
+
### ChatGLM + 英文
|
47 |
```shell
|
48 |
+
QUESTION_LANG=en QUESTION_LLM='chatglm' QUESTION_LLM_KEY=<your API key> python3 -u app.py
|
49 |
```
|
50 |
+
### Mistral-7B-Instruct-v0.1 + 英文
|
51 |
```shell
|
52 |
+
QUESTION_LANG=en QUESTION_LLM='mistral-7b' python3 -u app.py
|
53 |
```
|
54 |
## :technologist: 为什么制作这个游戏
|
55 |
|
app.py
CHANGED
@@ -13,7 +13,7 @@ _QUESTIONS = list_ordered_questions()
|
|
13 |
_LANG = os.environ.get('QUESTION_LANG', 'cn')
|
14 |
assert _LANG in ['cn', 'en'], _LANG
|
15 |
_LLM = os.environ.get('QUESTION_LLM', 'chatgpt')
|
16 |
-
assert _LLM in ['chatgpt', 'mistral-7b'], _LLM
|
17 |
_LLM_KEY = os.environ.get('QUESTION_LLM_KEY', None)
|
18 |
_DEBUG = os.environ.get('DEBUG', 'false').lower() == 'true'
|
19 |
|
@@ -105,12 +105,14 @@ else:
|
|
105 |
|
106 |
|
107 |
def _need_api_key():
|
108 |
-
return _LLM == 'chatgpt' and _LLM_KEY is None
|
109 |
|
110 |
|
111 |
def _get_api_key_cfgs(api_key):
|
112 |
if _LLM == 'chatgpt':
|
113 |
return {'api_key': api_key}
|
|
|
|
|
114 |
else:
|
115 |
return {}
|
116 |
|
|
|
13 |
_LANG = os.environ.get('QUESTION_LANG', 'cn')
|
14 |
assert _LANG in ['cn', 'en'], _LANG
|
15 |
_LLM = os.environ.get('QUESTION_LLM', 'chatgpt')
|
16 |
+
assert _LLM in ['chatgpt', 'chatglm', 'mistral-7b'], _LLM
|
17 |
_LLM_KEY = os.environ.get('QUESTION_LLM_KEY', None)
|
18 |
_DEBUG = os.environ.get('DEBUG', 'false').lower() == 'true'
|
19 |
|
|
|
105 |
|
106 |
|
107 |
def _need_api_key():
|
108 |
+
return (_LLM == 'chatgpt' or _LLM == 'chatglm') and _LLM_KEY is None
|
109 |
|
110 |
|
111 |
def _get_api_key_cfgs(api_key):
|
112 |
if _LLM == 'chatgpt':
|
113 |
return {'api_key': api_key}
|
114 |
+
elif _LLM == 'chatglm':
|
115 |
+
return {'api_key': api_key}
|
116 |
else:
|
117 |
return {}
|
118 |
|
llmriddles/llms/__init__.py
CHANGED
@@ -1,3 +1,4 @@
|
|
1 |
from .base import register_llm, get_llm_fn
|
2 |
from .chatgpt import ask_chatgpt
|
|
|
3 |
from .mistral import ask_mistral_7b_instruct
|
|
|
1 |
from .base import register_llm, get_llm_fn
|
2 |
from .chatgpt import ask_chatgpt
|
3 |
+
from .chatglm import ask_chatglm
|
4 |
from .mistral import ask_mistral_7b_instruct
|
llmriddles/llms/chatglm.py
ADDED
@@ -0,0 +1,26 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
import zhipuai
|
2 |
+
from .base import register_llm
|
3 |
+
|
4 |
+
|
5 |
+
def ask_chatglm(message: str, api_key: str):
|
6 |
+
zhipuai.api_key = api_key
|
7 |
+
|
8 |
+
response = zhipuai.model_api.invoke(
|
9 |
+
model="chatglm_turbo",
|
10 |
+
prompt=[{
|
11 |
+
"role": "user",
|
12 |
+
"content": message
|
13 |
+
}],
|
14 |
+
top_p=0.7,
|
15 |
+
temperature=0.9,
|
16 |
+
)
|
17 |
+
|
18 |
+
response_msg = response['data']['choices'][0]['content']
|
19 |
+
# strip the front and end '"'
|
20 |
+
if len(response_msg) >= 2:
|
21 |
+
response_msg = response_msg[1:-1]
|
22 |
+
|
23 |
+
return response_msg
|
24 |
+
|
25 |
+
|
26 |
+
register_llm('chatglm', ask_chatglm)
|
requirements-dev.txt
ADDED
@@ -0,0 +1,11 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
hbutils>=0.9.1
|
2 |
+
tqdm
|
3 |
+
requests>=2.20
|
4 |
+
gradio==4.1.1
|
5 |
+
openai>=1
|
6 |
+
zhipuai
|
7 |
+
sympy
|
8 |
+
flask
|
9 |
+
transformers
|
10 |
+
torch
|
11 |
+
huggingface-hub
|
requirements.txt
CHANGED
@@ -3,6 +3,5 @@ tqdm
|
|
3 |
requests>=2.20
|
4 |
gradio==4.1.1
|
5 |
openai>=1
|
|
|
6 |
sympy
|
7 |
-
flask
|
8 |
-
transformers
|
|
|
3 |
requests>=2.20
|
4 |
gradio==4.1.1
|
5 |
openai>=1
|
6 |
+
zhipuai
|
7 |
sympy
|
|
|
|