| 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, chat_template.im_start_token) |
| 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'] |
| ) |
|
|