qingxu98 ysharma HF staff commited on
Commit
d112233
1 Parent(s): 2a6e50d

Added a Duplicate Badge (#4)

Browse files

- Added a Duplicate Badge (1e85bfadd8828378cac59663a0db1e5f2c7a512c)


Co-authored-by: yuvraj sharma <ysharma@users.noreply.huggingface.co>

Files changed (1) hide show
  1. app.py +111 -108
app.py CHANGED
@@ -1,108 +1,111 @@
1
- import os; os.environ['no_proxy'] = '*' # 避免代理网络产生意外污染
2
- import gradio as gr
3
- from predict import predict
4
- from toolbox import format_io, find_free_port
5
-
6
- # 建议您复制一个config_private.py放自己的秘密,如API和代理网址,避免不小心传github被别人看到
7
- try: from config_private import proxies, WEB_PORT
8
- except: from config import proxies, WEB_PORT
9
-
10
- # 如果WEB_PORT是-1,则随机选取WEB端口
11
- PORT = find_free_port() if WEB_PORT <= 0 else WEB_PORT
12
-
13
- initial_prompt = "Serve me as a writing and programming assistant."
14
- title_html = """<h1 align="center">ChatGPT 学术优化</h1>"""
15
-
16
- # 问询记录,python 版本建议3.9+(越新越好)
17
- import logging
18
- os.makedirs('gpt_log', exist_ok=True)
19
- try:logging.basicConfig(filename='gpt_log/chat_secrets.log', level=logging.INFO, encoding='utf-8')
20
- except:logging.basicConfig(filename='gpt_log/chat_secrets.log', level=logging.INFO)
21
- print('所有问询记录将自动保存在本地目录./gpt_log/chat_secrets.log,请注意自我隐私保护哦!')
22
-
23
- # 一些普通功能模块
24
- from functional import get_functionals
25
- functional = get_functionals()
26
-
27
- # 对一些丧心病狂的实验性功能模块进行测试
28
- from functional_crazy import get_crazy_functionals, on_file_uploaded, on_report_generated
29
- crazy_functional = get_crazy_functionals()
30
-
31
- # 处理markdown文本格式的转变
32
- gr.Chatbot.postprocess = format_io
33
-
34
- # 做一些样式上的调整
35
- try: set_theme = gr.themes.Default( primary_hue=gr.themes.utils.colors.orange,
36
- font=["ui-sans-serif", "system-ui", "sans-serif", gr.themes.utils.fonts.GoogleFont("Source Sans Pro")],
37
- font_mono=["ui-monospace", "Consolas", "monospace", gr.themes.utils.fonts.GoogleFont("IBM Plex Mono")])
38
- except:
39
- set_theme = None; print('gradio版本较旧,不能自定义字体和颜色')
40
-
41
- with gr.Blocks(theme=set_theme, analytics_enabled=False) as demo:
42
- gr.HTML(title_html)
43
- with gr.Row():
44
- with gr.Column(scale=2):
45
- chatbot = gr.Chatbot()
46
- chatbot.style(height=1000)
47
- chatbot.style()
48
- history = gr.State([])
49
- TRUE = gr.State(True)
50
- FALSE = gr.State(False)
51
- with gr.Column(scale=1):
52
- with gr.Row():
53
- with gr.Column(scale=12):
54
- api = gr.Textbox(show_label=False, placeholder="Input OpenAI Key.").style(container=False)
55
- with gr.Row():
56
- with gr.Column(scale=12):
57
- txt = gr.Textbox(show_label=False, placeholder="Input question here.").style(container=False)
58
- with gr.Column(scale=1):
59
- submitBtn = gr.Button("Ask", variant="primary")
60
- with gr.Row():
61
- for k in functional:
62
- variant = functional[k]["Color"] if "Color" in functional[k] else "secondary"
63
- functional[k]["Button"] = gr.Button(k, variant=variant)
64
- with gr.Row():
65
- gr.Markdown("以下部分实验性功能需从input框读取路径.")
66
- with gr.Row():
67
- for k in crazy_functional:
68
- variant = crazy_functional[k]["Color"] if "Color" in crazy_functional[k] else "secondary"
69
- crazy_functional[k]["Button"] = gr.Button(k, variant=variant)
70
- with gr.Row():
71
- gr.Markdown("上传本地文件供上面的实验性功能调用.")
72
- with gr.Row():
73
- file_upload = gr.Files(label='任何文件,但推荐上传压缩文件(zip, tar)', file_count="multiple")
74
-
75
- from check_proxy import check_proxy
76
- statusDisplay = gr.Markdown(f"{check_proxy(proxies)}")
77
- systemPromptTxt = gr.Textbox(show_label=True, placeholder=f"System Prompt", label="System prompt", value=initial_prompt).style(container=True)
78
- #inputs, top_p, temperature, top_k, repetition_penalty
79
- with gr.Accordion("arguments", open=False):
80
- top_p = gr.Slider(minimum=-0, maximum=1.0, value=1.0, step=0.01,interactive=True, label="Top-p (nucleus sampling)",)
81
- temperature = gr.Slider(minimum=-0, maximum=5.0, value=1.0, step=0.01, interactive=True, label="Temperature",)
82
-
83
- txt.submit(predict, [api, txt, top_p, temperature, chatbot, history, systemPromptTxt], [chatbot, history, statusDisplay])
84
- submitBtn.click(predict, [api, txt, top_p, temperature, chatbot, history, systemPromptTxt], [chatbot, history, statusDisplay], show_progress=True)
85
- for k in functional:
86
- functional[k]["Button"].click(predict,
87
- [api, txt, top_p, temperature, chatbot, history, systemPromptTxt, TRUE, gr.State(k)], [chatbot, history, statusDisplay], show_progress=True)
88
- file_upload.upload(on_file_uploaded, [file_upload, chatbot, txt], [chatbot, txt])
89
- for k in crazy_functional:
90
- click_handle = crazy_functional[k]["Button"].click(crazy_functional[k]["Function"],
91
- [api, txt, top_p, temperature, chatbot, history, systemPromptTxt, gr.State(PORT)], [chatbot, history, statusDisplay]
92
- )
93
- try: click_handle.then(on_report_generated, [file_upload, chatbot], [file_upload, chatbot])
94
- except: pass
95
-
96
-
97
- # 延迟函数,做一些准备工作,最后尝试打开浏览器
98
- def auto_opentab_delay():
99
- import threading, webbrowser, time
100
- print(f"URL http://localhost:{PORT}")
101
- def open(): time.sleep(2)
102
- webbrowser.open_new_tab(f'http://localhost:{PORT}')
103
- t = threading.Thread(target=open)
104
- t.daemon = True; t.start()
105
-
106
- auto_opentab_delay()
107
- demo.title = "ChatGPT 学术优化"
108
- demo.queue().launch()
 
 
 
 
1
+ import os; os.environ['no_proxy'] = '*' # 避免代理网络产生意外污染
2
+ import gradio as gr
3
+ from predict import predict
4
+ from toolbox import format_io, find_free_port
5
+
6
+ # 建议您复制一个config_private.py放自己的秘密,如API和代理网址,避免不小心传github被别人看到
7
+ try: from config_private import proxies, WEB_PORT
8
+ except: from config import proxies, WEB_PORT
9
+
10
+ # 如果WEB_PORT是-1,则随机选取WEB端口
11
+ PORT = find_free_port() if WEB_PORT <= 0 else WEB_PORT
12
+
13
+ initial_prompt = "Serve me as a writing and programming assistant."
14
+ title_html = """<h1 align="center">ChatGPT 学术优化</h1>"""
15
+
16
+ # 问询记录,python 版本建议3.9+(越新越好)
17
+ import logging
18
+ os.makedirs('gpt_log', exist_ok=True)
19
+ try:logging.basicConfig(filename='gpt_log/chat_secrets.log', level=logging.INFO, encoding='utf-8')
20
+ except:logging.basicConfig(filename='gpt_log/chat_secrets.log', level=logging.INFO)
21
+ print('所有问询记录将自动保存在本地目录./gpt_log/chat_secrets.log,请注意自我隐私保护哦!')
22
+
23
+ # 一些普通功能模块
24
+ from functional import get_functionals
25
+ functional = get_functionals()
26
+
27
+ # 对一些丧心病狂的实验性功能模块进行测试
28
+ from functional_crazy import get_crazy_functionals, on_file_uploaded, on_report_generated
29
+ crazy_functional = get_crazy_functionals()
30
+
31
+ # 处理markdown文本格式的转变
32
+ gr.Chatbot.postprocess = format_io
33
+
34
+ # 做一些样式上的调整
35
+ try: set_theme = gr.themes.Default( primary_hue=gr.themes.utils.colors.orange,
36
+ font=["ui-sans-serif", "system-ui", "sans-serif", gr.themes.utils.fonts.GoogleFont("Source Sans Pro")],
37
+ font_mono=["ui-monospace", "Consolas", "monospace", gr.themes.utils.fonts.GoogleFont("IBM Plex Mono")])
38
+ except:
39
+ set_theme = None; print('gradio版本较旧,不能自定义字体和颜色')
40
+
41
+ with gr.Blocks(theme=set_theme, analytics_enabled=False) as demo:
42
+ gr.HTML(title_html)
43
+ # To add a Duplicate Space badge
44
+ gr.HTML('''<center><a href="https://huggingface.co/spaces/qingxu98/gpt-academic?duplicate=true"><img src="https://bit.ly/3gLdBN6" alt="Duplicate Space"></a>复制空间以避免排队并使用您的 OpenAI API 密钥安全运行</center>''')
45
+
46
+ with gr.Row():
47
+ with gr.Column(scale=2):
48
+ chatbot = gr.Chatbot()
49
+ chatbot.style(height=1000)
50
+ chatbot.style()
51
+ history = gr.State([])
52
+ TRUE = gr.State(True)
53
+ FALSE = gr.State(False)
54
+ with gr.Column(scale=1):
55
+ with gr.Row():
56
+ with gr.Column(scale=12):
57
+ api = gr.Textbox(show_label=False, placeholder="Input OpenAI Key.").style(container=False)
58
+ with gr.Row():
59
+ with gr.Column(scale=12):
60
+ txt = gr.Textbox(show_label=False, placeholder="Input question here.").style(container=False)
61
+ with gr.Column(scale=1):
62
+ submitBtn = gr.Button("Ask", variant="primary")
63
+ with gr.Row():
64
+ for k in functional:
65
+ variant = functional[k]["Color"] if "Color" in functional[k] else "secondary"
66
+ functional[k]["Button"] = gr.Button(k, variant=variant)
67
+ with gr.Row():
68
+ gr.Markdown("以下部分实验性功能需从input框读取路径.")
69
+ with gr.Row():
70
+ for k in crazy_functional:
71
+ variant = crazy_functional[k]["Color"] if "Color" in crazy_functional[k] else "secondary"
72
+ crazy_functional[k]["Button"] = gr.Button(k, variant=variant)
73
+ with gr.Row():
74
+ gr.Markdown("上传本地文件供上面的实验性功能调用.")
75
+ with gr.Row():
76
+ file_upload = gr.Files(label='任何文件,但推荐上传压缩文件(zip, tar)', file_count="multiple")
77
+
78
+ from check_proxy import check_proxy
79
+ statusDisplay = gr.Markdown(f"{check_proxy(proxies)}")
80
+ systemPromptTxt = gr.Textbox(show_label=True, placeholder=f"System Prompt", label="System prompt", value=initial_prompt).style(container=True)
81
+ #inputs, top_p, temperature, top_k, repetition_penalty
82
+ with gr.Accordion("arguments", open=False):
83
+ top_p = gr.Slider(minimum=-0, maximum=1.0, value=1.0, step=0.01,interactive=True, label="Top-p (nucleus sampling)",)
84
+ temperature = gr.Slider(minimum=-0, maximum=5.0, value=1.0, step=0.01, interactive=True, label="Temperature",)
85
+
86
+ txt.submit(predict, [api, txt, top_p, temperature, chatbot, history, systemPromptTxt], [chatbot, history, statusDisplay])
87
+ submitBtn.click(predict, [api, txt, top_p, temperature, chatbot, history, systemPromptTxt], [chatbot, history, statusDisplay], show_progress=True)
88
+ for k in functional:
89
+ functional[k]["Button"].click(predict,
90
+ [api, txt, top_p, temperature, chatbot, history, systemPromptTxt, TRUE, gr.State(k)], [chatbot, history, statusDisplay], show_progress=True)
91
+ file_upload.upload(on_file_uploaded, [file_upload, chatbot, txt], [chatbot, txt])
92
+ for k in crazy_functional:
93
+ click_handle = crazy_functional[k]["Button"].click(crazy_functional[k]["Function"],
94
+ [api, txt, top_p, temperature, chatbot, history, systemPromptTxt, gr.State(PORT)], [chatbot, history, statusDisplay]
95
+ )
96
+ try: click_handle.then(on_report_generated, [file_upload, chatbot], [file_upload, chatbot])
97
+ except: pass
98
+
99
+
100
+ # 延迟函数,做一些准备工作,最后尝试打开浏览器
101
+ def auto_opentab_delay():
102
+ import threading, webbrowser, time
103
+ print(f"URL http://localhost:{PORT}")
104
+ def open(): time.sleep(2)
105
+ webbrowser.open_new_tab(f'http://localhost:{PORT}')
106
+ t = threading.Thread(target=open)
107
+ t.daemon = True; t.start()
108
+
109
+ auto_opentab_delay()
110
+ demo.title = "ChatGPT 学术优化"
111
+ demo.queue().launch()