File size: 7,581 Bytes
9dc1a52
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
44ec37f
 
 
9dc1a52
 
 
 
 
 
 
44ec37f
9dc1a52
44ec37f
9dc1a52
 
 
 
 
 
 
 
44ec37f
9dc1a52
44ec37f
9dc1a52
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
44ec37f
9dc1a52
 
 
 
 
44ec37f
 
9dc1a52
 
 
 
 
 
 
 
 
 
 
 
 
 
 
44ec37f
9dc1a52
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
import json

import gradio as gr
import pandas as pd
from llm import OpenAI3, OpenAI4
from mock_data import *

block_css = """
.importantButton {
    background: linear-gradient(45deg, #7e0570,#5d1c99, #6e00ff) !important;
    border: none !important;
}
.importantButton:hover {
    background: linear-gradient(45deg, #ff00e0,#8500ff, #6e00ff) !important;
    border: none !important;
}"""

webui_title = "📚📚📚📚📚📚📚📚📚📚📚📚* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *    ☘️ * * *学思案* * *    ☘️ * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *📚📚📚📚📚📚📚📚📚📚📚📚"

llm_name_dict = {'chatgpt-3.5': 'OpenAI3', 'chatgpt-4': 'OpenAI4', 'chatglm—6b': 'ChatGLM'}


def llm_change(name):
    llm = eval(eval('llm_name_dict[name]'))()
    return llm


def generate_comment_post_process(_summary):
    _summary = _summary.split('如下:')[-1]
    while _summary[0] == '\n':
        _summary = _summary[1:]
    return _summary


def show_config():
    return gr.update(visible=True)


def show_stand_file(stand_file_path, stand_file):
    df = pd.read_excel(stand_file_path)
    return gr.update(visible=True, value=df)


def hide_config():
    return gr.update(visible=False), gr.update(visible=False)


def clear_screen(chatbot):
    chatbot = [[None, None]]
    return chatbot


def generate_mock_data(_topic, _stand_file_path, _rewrite_prompt, _generate_num, _chatbot):

    try:

        scores_and_comments, stand_file = \
            generate_scores_and_comments(_stand_file_path, _rewrite_prompt, _topic, _generate_num)

        chat = ''
        for i in range(len(scores_and_comments)):
            chat = chat + 'Teacher' + str(i+1) + ':\n\n'
            for key, value in scores_and_comments[i]['scores'].items():
                chat = chat + key + ': ' + str(value) + '  - -  '
            chat = chat[:-5] + '\n\n'

            chat = chat + scores_and_comments[i]['comment'] + '\n\n'

        _chatbot = _chatbot + [[None, chat]]

        return _chatbot, scores_and_comments, stand_file, gr.update(visible=True), gr.update(visible=True)

    except Exception as e:
        message = '模拟测评生成失败,原因是:' + str(e) + '\n\n'
        _chatbot = _chatbot + [[None, message]]
        return _chatbot, dict(), pd.DataFrame(), gr.update(visible=False), \
               gr.update(visible=False)


def rewrite(standard_file, rewrite_prompt, topic, assessments, chatbot):
    try:
        rewrite_comment = medium_score_rewrite(standard_file, rewrite_prompt, topic, assessments)
        rewrite_comment = generate_comment_post_process(rewrite_comment)
        message = '上述评价按照中位法改写结果如下:\n\n' + rewrite_comment
    except Exception as e:
        message = '中位法改写失败,原因是:' + str(e) + '\n\n'
    chatbot = chatbot + [[None, message]]
    return chatbot


def summary(summary_prompt, assessments, chatbot):
    try:
        summary_comment = quantile_summary(summary_prompt, assessments)
        summary_comment = generate_comment_post_process(summary_comment)
        message = '上述评价按照四分位法摘要结果如下:\n\n' + summary_comment
    except Exception as e:
        message = '四分位法摘要生成失败,原因是:' + str(e) + '\n\n'
    chatbot = chatbot + [[None, message]]
    return chatbot


with gr.Blocks(css=block_css) as demo:
    gr.Markdown('\n\n\n\n')
    gr.Markdown(webui_title)
    gr.Markdown('\n\n\n\n')
    show_config_button = gr.Button('标准评价和prompt配置', visible=True)
    config = gr.Column(visible=False)
    show_config_button.click(show_config, outputs=[config])

    mock = gr.Column(visible=True)

    with config:
        # llm = gr.State('')
        # model_mode = gr.Radio(['chatgpt-3.5', "chatgpt-4", 'chatglm—6b'], label="请选择驱动模型")
        # model_name = gr.Radio(['chatgpt-3.5'], label="请选择驱动模型")
        # model_name.change(fn=llm_change, inputs=[model_name], outputs=[llm])
        stand_file_path = gr.Textbox('指标评价标准.xlsx', label='请输入评价标准文件路径')
        stand_comment = gr.DataFrame(visible=False)
        r_prompt = """The content within the angle brackets is an evaluation of the instructional design regarding the {topic} knowledge point. However, the evaluation does not incorporate the {topic} theme. Please modify the evaluation by incorporating the {topic} theme in each sentence while maintaining the same evaluative perspective and positive/negative nature. The modified evaluation should appear to be specifically targeted towards the {topic} theme.
        <{stand_comment}>
        """
        r_prompt = gr.Text(value=r_prompt, label='请配置改写prompt', lines=3)

        s_prompt = """尖括号里面的内容是多位老师对某堂课的教学评价,每位老师的评价用换行符进行了分隔,请对各位老师的评价进行摘要总结
        '<{comment}>'
         """
        s_prompt = gr.Text(value=s_prompt, label='请配置摘要prompt', lines=3)
        with gr.Row():
            with gr.Column(scale=2):
                set_config_button = gr.Button('确定', visible=True)
            with gr.Column(scale=2):
                show_stand_button = gr.Button('加载/更新标准评价', visible=True)
        set_config_button.click(hide_config, outputs=[stand_comment, config])
        show_stand_button.click(show_stand_file, inputs=[stand_file_path, stand_comment], outputs=stand_comment)

    with mock:
        with gr.Row():
            with gr.Column(scale=10):
                topic = gr.Textbox('升华和凝华', label='请输入讲课主题')

                # data_out_path = gr.Textbox('', label='请输入模拟数据导出路径')
                generate_num = gr.Slider(1, 20, value=3, step=1, label="评课人数量", interactive=True)
                mock_data = gr.Json(visible=False)

                with gr.Row():
                    with gr.Column(scale=2):
                        generate_button = gr.Button('生成模拟测评')
                    with gr.Column(scale=2):
                        clear_screen_button = gr.Button('清屏', visible=True)
                    with gr.Column(scale=2):
                        rewrite_button = gr.Button('中位值改写', visible=False)
                    with gr.Column(scale=2):
                        summary_button = gr.Button('四分位摘要', visible=False)

            with gr.Column(scale=10):

                chatbot = gr.Chatbot([[None, None]],
                                     elem_id="chat-box",
                                     show_label=False).style(height=1000)
                generate_button.click(generate_mock_data, inputs=[topic, stand_file_path, r_prompt, generate_num,
                            chatbot], outputs=[chatbot, mock_data, stand_comment, rewrite_button, summary_button])
                rewrite_button.click(rewrite, inputs=[stand_comment, r_prompt, topic, mock_data, chatbot],
                                     outputs=chatbot)
                summary_button.click(summary, inputs=[s_prompt, mock_data, chatbot],
                                     outputs=chatbot)
                clear_screen_button.click(clear_screen, inputs=[chatbot], outputs=chatbot)


# demo.queue(concurrency_count=5).launch(server_name='0.0.0.0', server_port=7858, share=True)

demo.queue(concurrency_count=5).launch()