Spaces:
Runtime error
Runtime error
| def init(cfg): | |
| # ========== 共同 ========== | |
| model = cfg['model'] | |
| s_info = cfg['s_info'] | |
| lock = cfg['session_lock'] | |
| # ========== 特殊 ========== | |
| chat_template = cfg['chat_template'] | |
| # ========== 注入内容 ========== | |
| def btn_rag(_n_keep, _n_discard, | |
| _temperature, _repeat_penalty, _frequency_penalty, | |
| _presence_penalty, _repeat_last_n, _top_k, | |
| _top_p, _min_p, _typical_p, | |
| _tfs_z, _mirostat_mode, _mirostat_eta, | |
| _mirostat_tau, _usr, _char, | |
| _rag, _max_tokens): | |
| with lock: | |
| if not cfg['session_active']: | |
| raise RuntimeError | |
| if cfg['btn_stop_status']: | |
| yield model.venv_info | |
| return | |
| # ========== 清除之前注入的内容 ========== | |
| model.venv_remove('rag') | |
| # ========== 没有需要注入的内容 ========== | |
| if not _rag: | |
| yield model.venv_info | |
| return | |
| # ========== 需要临时注入的内容 ========== | |
| model.venv_create('rag') | |
| t_rag = chat_template('system', _rag) | |
| model.eval_t(t_rag, _n_keep, _n_discard) | |
| yield model.venv_info | |
| cfg['btn_rag_fn'] = { | |
| 'fn': btn_rag, | |
| 'inputs': cfg['setting'], | |
| 'outputs': s_info | |
| } | |
| cfg['btn_rag_fn'].update(cfg['btn_concurrency']) | |
| cfg['btn_rag'].click( | |
| **cfg['btn_start'] | |
| ).success( | |
| **cfg['btn_rag_fn'] | |
| ).success( | |
| **cfg['btn_finish'] | |
| ) | |