2023-06-17 00:00:37 +02:00
|
|
|
import functools
|
2023-08-11 19:41:33 +02:00
|
|
|
from collections import OrderedDict
|
2023-06-17 00:00:37 +02:00
|
|
|
|
|
|
|
import gradio as gr
|
|
|
|
|
|
|
|
from modules import shared
|
|
|
|
|
2023-08-11 19:41:33 +02:00
|
|
|
loaders_and_params = OrderedDict({
|
|
|
|
'Transformers': [
|
|
|
|
'cpu_memory',
|
|
|
|
'gpu_memory',
|
|
|
|
'load_in_8bit',
|
|
|
|
'bf16',
|
|
|
|
'cpu',
|
|
|
|
'disk',
|
|
|
|
'auto_devices',
|
|
|
|
'load_in_4bit',
|
|
|
|
'use_double_quant',
|
|
|
|
'quant_type',
|
|
|
|
'compute_dtype',
|
|
|
|
'trust_remote_code',
|
2023-11-17 04:45:05 +01:00
|
|
|
'no_use_fast',
|
2023-11-04 17:59:33 +01:00
|
|
|
'use_flash_attention_2',
|
2024-07-01 17:08:08 +02:00
|
|
|
'use_eager_attention',
|
2023-08-11 19:41:33 +02:00
|
|
|
'alpha_value',
|
|
|
|
'compress_pos_emb',
|
2023-09-25 05:03:11 +02:00
|
|
|
'disable_exllama',
|
2023-12-15 15:46:13 +01:00
|
|
|
'disable_exllamav2',
|
2023-08-11 19:41:33 +02:00
|
|
|
],
|
2023-11-30 00:13:03 +01:00
|
|
|
'llama.cpp': [
|
|
|
|
'n_ctx',
|
|
|
|
'n_gpu_layers',
|
2024-12-17 21:43:48 +01:00
|
|
|
'cache_type',
|
2023-11-30 00:13:03 +01:00
|
|
|
'tensor_split',
|
|
|
|
'n_batch',
|
|
|
|
'threads',
|
|
|
|
'threads_batch',
|
|
|
|
'no_mmap',
|
|
|
|
'mlock',
|
|
|
|
'no_mul_mat_q',
|
|
|
|
'rope_freq_base',
|
|
|
|
'compress_pos_emb',
|
2024-04-30 14:11:31 +02:00
|
|
|
'cpu',
|
2023-11-30 00:13:03 +01:00
|
|
|
'numa',
|
2023-12-19 21:30:53 +01:00
|
|
|
'no_offload_kqv',
|
2024-02-05 03:36:40 +01:00
|
|
|
'row_split',
|
2024-07-23 03:05:11 +02:00
|
|
|
'tensorcores',
|
2024-06-13 05:34:54 +02:00
|
|
|
'flash_attn',
|
2024-03-09 04:25:33 +01:00
|
|
|
'streaming_llm',
|
|
|
|
'attention_sink_size',
|
2023-11-30 00:13:03 +01:00
|
|
|
],
|
2023-11-29 03:41:11 +01:00
|
|
|
'llamacpp_HF': [
|
|
|
|
'n_ctx',
|
|
|
|
'n_gpu_layers',
|
2024-12-17 21:43:48 +01:00
|
|
|
'cache_type',
|
2023-11-29 03:41:11 +01:00
|
|
|
'tensor_split',
|
|
|
|
'n_batch',
|
|
|
|
'threads',
|
|
|
|
'threads_batch',
|
|
|
|
'no_mmap',
|
|
|
|
'mlock',
|
|
|
|
'no_mul_mat_q',
|
|
|
|
'rope_freq_base',
|
|
|
|
'compress_pos_emb',
|
2024-04-30 14:11:31 +02:00
|
|
|
'cpu',
|
2023-11-29 03:41:11 +01:00
|
|
|
'numa',
|
|
|
|
'cfg_cache',
|
2023-12-08 15:29:26 +01:00
|
|
|
'trust_remote_code',
|
2023-11-29 03:41:11 +01:00
|
|
|
'no_use_fast',
|
|
|
|
'logits_all',
|
2023-12-19 19:22:21 +01:00
|
|
|
'no_offload_kqv',
|
2024-02-05 03:36:40 +01:00
|
|
|
'row_split',
|
2024-07-23 03:05:11 +02:00
|
|
|
'tensorcores',
|
2024-06-13 05:34:54 +02:00
|
|
|
'flash_attn',
|
2024-03-09 04:25:33 +01:00
|
|
|
'streaming_llm',
|
|
|
|
'attention_sink_size',
|
2023-11-29 03:41:11 +01:00
|
|
|
'llamacpp_HF_info',
|
|
|
|
],
|
2023-12-17 16:08:33 +01:00
|
|
|
'ExLlamav2_HF': [
|
2023-08-11 19:41:33 +02:00
|
|
|
'gpu_split',
|
|
|
|
'max_seq_len',
|
2023-12-17 16:08:33 +01:00
|
|
|
'cfg_cache',
|
|
|
|
'no_flash_attn',
|
2024-07-12 00:47:37 +02:00
|
|
|
'no_xformers',
|
|
|
|
'no_sdpa',
|
2023-12-17 16:08:33 +01:00
|
|
|
'num_experts_per_token',
|
2024-12-17 21:43:48 +01:00
|
|
|
'cache_type',
|
2024-02-16 19:26:10 +01:00
|
|
|
'autosplit',
|
2024-10-01 20:16:15 +02:00
|
|
|
'enable_tp',
|
2023-08-11 19:41:33 +02:00
|
|
|
'alpha_value',
|
|
|
|
'compress_pos_emb',
|
2023-12-08 15:29:26 +01:00
|
|
|
'trust_remote_code',
|
2023-11-17 04:45:05 +01:00
|
|
|
'no_use_fast',
|
2023-08-11 19:41:33 +02:00
|
|
|
],
|
2024-02-06 15:21:17 +01:00
|
|
|
'ExLlamav2': [
|
|
|
|
'gpu_split',
|
|
|
|
'max_seq_len',
|
|
|
|
'no_flash_attn',
|
2024-07-12 00:47:37 +02:00
|
|
|
'no_xformers',
|
|
|
|
'no_sdpa',
|
2024-02-06 15:21:17 +01:00
|
|
|
'num_experts_per_token',
|
2024-12-17 21:43:48 +01:00
|
|
|
'cache_type',
|
2024-02-16 19:26:10 +01:00
|
|
|
'autosplit',
|
2024-10-01 20:16:15 +02:00
|
|
|
'enable_tp',
|
2024-02-06 15:21:17 +01:00
|
|
|
'alpha_value',
|
|
|
|
'compress_pos_emb',
|
|
|
|
'exllamav2_info',
|
|
|
|
],
|
2023-06-17 00:00:37 +02:00
|
|
|
'AutoGPTQ': [
|
|
|
|
'triton',
|
|
|
|
'no_inject_fused_mlp',
|
2023-06-23 17:22:56 +02:00
|
|
|
'no_use_cuda_fp16',
|
2023-06-17 00:00:37 +02:00
|
|
|
'wbits',
|
|
|
|
'groupsize',
|
|
|
|
'desc_act',
|
2023-08-12 08:26:58 +02:00
|
|
|
'disable_exllama',
|
2023-12-15 15:46:13 +01:00
|
|
|
'disable_exllamav2',
|
2023-06-17 00:00:37 +02:00
|
|
|
'gpu_memory',
|
|
|
|
'cpu_memory',
|
|
|
|
'cpu',
|
|
|
|
'disk',
|
|
|
|
'auto_devices',
|
|
|
|
'trust_remote_code',
|
2023-11-17 04:45:05 +01:00
|
|
|
'no_use_fast',
|
2023-06-17 00:00:37 +02:00
|
|
|
'autogptq_info',
|
|
|
|
],
|
2023-12-19 01:23:16 +01:00
|
|
|
'HQQ': [
|
|
|
|
'hqq_backend',
|
|
|
|
'trust_remote_code',
|
|
|
|
'no_use_fast',
|
2024-06-24 07:30:03 +02:00
|
|
|
],
|
|
|
|
'TensorRT-LLM': [
|
|
|
|
'max_seq_len',
|
|
|
|
'cpp_runner',
|
|
|
|
'tensorrt_llm_info',
|
2023-12-06 04:01:01 +01:00
|
|
|
]
|
2023-08-11 19:41:33 +02:00
|
|
|
})
|
2023-06-17 00:00:37 +02:00
|
|
|
|
2023-12-21 04:18:07 +01:00
|
|
|
|
|
|
|
def transformers_samplers():
|
|
|
|
return {
|
2023-08-01 03:44:00 +02:00
|
|
|
'temperature',
|
2023-11-04 17:09:07 +01:00
|
|
|
'temperature_last',
|
2024-01-07 21:03:47 +01:00
|
|
|
'dynamic_temperature',
|
2024-01-09 03:28:35 +01:00
|
|
|
'dynatemp_low',
|
|
|
|
'dynatemp_high',
|
|
|
|
'dynatemp_exponent',
|
2024-02-04 04:20:02 +01:00
|
|
|
'smoothing_factor',
|
2024-03-03 17:22:21 +01:00
|
|
|
'smoothing_curve',
|
2023-08-01 03:44:00 +02:00
|
|
|
'top_p',
|
2023-11-02 20:32:51 +01:00
|
|
|
'min_p',
|
2023-08-01 03:44:00 +02:00
|
|
|
'top_k',
|
|
|
|
'typical_p',
|
|
|
|
'epsilon_cutoff',
|
|
|
|
'eta_cutoff',
|
|
|
|
'tfs',
|
|
|
|
'top_a',
|
|
|
|
'repetition_penalty',
|
2023-10-25 17:10:28 +02:00
|
|
|
'presence_penalty',
|
|
|
|
'frequency_penalty',
|
2023-08-01 03:44:00 +02:00
|
|
|
'repetition_penalty_range',
|
|
|
|
'encoder_repetition_penalty',
|
|
|
|
'no_repeat_ngram_size',
|
2024-05-20 04:53:47 +02:00
|
|
|
'dry_multiplier',
|
|
|
|
'dry_base',
|
|
|
|
'dry_allowed_length',
|
|
|
|
'dry_sequence_breakers',
|
2024-09-28 03:50:12 +02:00
|
|
|
'xtc_threshold',
|
|
|
|
'xtc_probability',
|
2023-08-01 03:44:00 +02:00
|
|
|
'seed',
|
|
|
|
'do_sample',
|
|
|
|
'penalty_alpha',
|
|
|
|
'mirostat_mode',
|
|
|
|
'mirostat_tau',
|
|
|
|
'mirostat_eta',
|
2023-10-05 15:01:36 +02:00
|
|
|
'grammar_file_row',
|
|
|
|
'grammar_string',
|
2023-08-06 22:22:48 +02:00
|
|
|
'guidance_scale',
|
|
|
|
'negative_prompt',
|
2023-08-01 03:44:00 +02:00
|
|
|
'ban_eos_token',
|
2023-09-15 23:27:27 +02:00
|
|
|
'custom_token_bans',
|
2024-02-06 15:20:10 +01:00
|
|
|
'sampler_priority',
|
2023-08-01 03:44:00 +02:00
|
|
|
'add_bos_token',
|
|
|
|
'skip_special_tokens',
|
2023-08-02 19:52:20 +02:00
|
|
|
'auto_max_new_tokens',
|
2024-01-17 21:09:36 +01:00
|
|
|
'prompt_lookup_num_tokens'
|
2023-12-21 04:18:07 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
loaders_samplers = {
|
|
|
|
'Transformers': transformers_samplers(),
|
|
|
|
'AutoGPTQ': transformers_samplers(),
|
|
|
|
'HQQ': transformers_samplers(),
|
2024-02-06 15:21:17 +01:00
|
|
|
'ExLlamav2': {
|
|
|
|
'temperature',
|
|
|
|
'temperature_last',
|
|
|
|
'top_p',
|
|
|
|
'min_p',
|
|
|
|
'top_k',
|
|
|
|
'typical_p',
|
|
|
|
'tfs',
|
|
|
|
'top_a',
|
|
|
|
'repetition_penalty',
|
|
|
|
'presence_penalty',
|
|
|
|
'frequency_penalty',
|
|
|
|
'repetition_penalty_range',
|
|
|
|
'seed',
|
|
|
|
'mirostat_mode',
|
|
|
|
'mirostat_tau',
|
|
|
|
'mirostat_eta',
|
|
|
|
'ban_eos_token',
|
|
|
|
'add_bos_token',
|
|
|
|
'custom_token_bans',
|
|
|
|
'skip_special_tokens',
|
|
|
|
'auto_max_new_tokens',
|
|
|
|
},
|
2023-09-12 19:33:07 +02:00
|
|
|
'ExLlamav2_HF': {
|
|
|
|
'temperature',
|
2023-11-04 17:09:07 +01:00
|
|
|
'temperature_last',
|
2024-01-07 21:03:47 +01:00
|
|
|
'dynamic_temperature',
|
2024-01-09 03:28:35 +01:00
|
|
|
'dynatemp_low',
|
|
|
|
'dynatemp_high',
|
|
|
|
'dynatemp_exponent',
|
2024-02-04 04:20:02 +01:00
|
|
|
'smoothing_factor',
|
2024-03-03 17:22:21 +01:00
|
|
|
'smoothing_curve',
|
2023-09-12 19:33:07 +02:00
|
|
|
'top_p',
|
2023-11-02 20:32:51 +01:00
|
|
|
'min_p',
|
2023-09-12 19:33:07 +02:00
|
|
|
'top_k',
|
|
|
|
'typical_p',
|
|
|
|
'epsilon_cutoff',
|
|
|
|
'eta_cutoff',
|
|
|
|
'tfs',
|
|
|
|
'top_a',
|
|
|
|
'repetition_penalty',
|
2023-10-25 17:10:28 +02:00
|
|
|
'presence_penalty',
|
|
|
|
'frequency_penalty',
|
2023-09-12 19:33:07 +02:00
|
|
|
'repetition_penalty_range',
|
|
|
|
'encoder_repetition_penalty',
|
|
|
|
'no_repeat_ngram_size',
|
2024-05-20 04:53:47 +02:00
|
|
|
'dry_multiplier',
|
|
|
|
'dry_base',
|
|
|
|
'dry_allowed_length',
|
|
|
|
'dry_sequence_breakers',
|
2024-09-28 03:50:12 +02:00
|
|
|
'xtc_threshold',
|
|
|
|
'xtc_probability',
|
2023-09-12 19:33:07 +02:00
|
|
|
'seed',
|
|
|
|
'do_sample',
|
|
|
|
'mirostat_mode',
|
|
|
|
'mirostat_tau',
|
|
|
|
'mirostat_eta',
|
2023-10-05 15:01:36 +02:00
|
|
|
'grammar_file_row',
|
|
|
|
'grammar_string',
|
2023-09-12 19:33:07 +02:00
|
|
|
'guidance_scale',
|
|
|
|
'negative_prompt',
|
|
|
|
'ban_eos_token',
|
2023-09-15 23:27:27 +02:00
|
|
|
'custom_token_bans',
|
2024-02-06 15:20:10 +01:00
|
|
|
'sampler_priority',
|
2023-09-12 19:33:07 +02:00
|
|
|
'add_bos_token',
|
|
|
|
'skip_special_tokens',
|
|
|
|
'auto_max_new_tokens',
|
|
|
|
},
|
2023-08-01 03:44:00 +02:00
|
|
|
'llama.cpp': {
|
|
|
|
'temperature',
|
|
|
|
'top_p',
|
2023-11-22 00:59:39 +01:00
|
|
|
'min_p',
|
2023-08-01 03:44:00 +02:00
|
|
|
'top_k',
|
2023-11-22 00:59:39 +01:00
|
|
|
'typical_p',
|
2023-08-01 03:44:00 +02:00
|
|
|
'tfs',
|
|
|
|
'repetition_penalty',
|
2023-10-25 17:10:28 +02:00
|
|
|
'presence_penalty',
|
|
|
|
'frequency_penalty',
|
2023-11-18 04:31:27 +01:00
|
|
|
'seed',
|
2023-08-01 03:44:00 +02:00
|
|
|
'mirostat_mode',
|
|
|
|
'mirostat_tau',
|
|
|
|
'mirostat_eta',
|
2023-09-24 16:17:33 +02:00
|
|
|
'grammar_file_row',
|
2023-09-24 23:05:24 +02:00
|
|
|
'grammar_string',
|
2023-08-01 03:44:00 +02:00
|
|
|
'ban_eos_token',
|
2023-09-15 23:27:27 +02:00
|
|
|
'custom_token_bans',
|
2023-08-01 03:44:00 +02:00
|
|
|
},
|
|
|
|
'llamacpp_HF': {
|
|
|
|
'temperature',
|
2023-11-04 17:09:07 +01:00
|
|
|
'temperature_last',
|
2024-01-07 21:03:47 +01:00
|
|
|
'dynamic_temperature',
|
2024-01-09 03:28:35 +01:00
|
|
|
'dynatemp_low',
|
|
|
|
'dynatemp_high',
|
|
|
|
'dynatemp_exponent',
|
2024-02-04 04:20:02 +01:00
|
|
|
'smoothing_factor',
|
2024-03-03 17:22:21 +01:00
|
|
|
'smoothing_curve',
|
2023-08-01 03:44:00 +02:00
|
|
|
'top_p',
|
2023-11-02 20:32:51 +01:00
|
|
|
'min_p',
|
2023-08-01 03:44:00 +02:00
|
|
|
'top_k',
|
|
|
|
'typical_p',
|
|
|
|
'epsilon_cutoff',
|
|
|
|
'eta_cutoff',
|
|
|
|
'tfs',
|
|
|
|
'top_a',
|
|
|
|
'repetition_penalty',
|
2023-10-25 17:10:28 +02:00
|
|
|
'presence_penalty',
|
|
|
|
'frequency_penalty',
|
2023-08-01 03:44:00 +02:00
|
|
|
'repetition_penalty_range',
|
|
|
|
'encoder_repetition_penalty',
|
|
|
|
'no_repeat_ngram_size',
|
2024-05-20 04:53:47 +02:00
|
|
|
'dry_multiplier',
|
|
|
|
'dry_base',
|
|
|
|
'dry_allowed_length',
|
|
|
|
'dry_sequence_breakers',
|
2024-09-28 03:50:12 +02:00
|
|
|
'xtc_threshold',
|
|
|
|
'xtc_probability',
|
2023-08-01 03:44:00 +02:00
|
|
|
'seed',
|
|
|
|
'do_sample',
|
|
|
|
'mirostat_mode',
|
|
|
|
'mirostat_tau',
|
|
|
|
'mirostat_eta',
|
2023-10-05 15:01:36 +02:00
|
|
|
'grammar_file_row',
|
|
|
|
'grammar_string',
|
2023-08-25 01:32:21 +02:00
|
|
|
'guidance_scale',
|
|
|
|
'negative_prompt',
|
2023-08-01 03:44:00 +02:00
|
|
|
'ban_eos_token',
|
2023-09-15 23:27:27 +02:00
|
|
|
'custom_token_bans',
|
2024-02-06 15:20:10 +01:00
|
|
|
'sampler_priority',
|
2023-08-01 03:44:00 +02:00
|
|
|
'add_bos_token',
|
|
|
|
'skip_special_tokens',
|
2023-08-02 19:52:20 +02:00
|
|
|
'auto_max_new_tokens',
|
2023-08-01 03:44:00 +02:00
|
|
|
},
|
2024-06-24 07:30:03 +02:00
|
|
|
'TensorRT-LLM': {
|
|
|
|
'temperature',
|
|
|
|
'top_p',
|
|
|
|
'top_k',
|
|
|
|
'repetition_penalty',
|
|
|
|
'presence_penalty',
|
|
|
|
'frequency_penalty',
|
|
|
|
'ban_eos_token',
|
|
|
|
'auto_max_new_tokens',
|
|
|
|
}
|
2023-08-11 19:41:33 +02:00
|
|
|
}
|
|
|
|
|
2023-08-01 03:44:00 +02:00
|
|
|
|
|
|
|
@functools.cache
|
|
|
|
def list_all_samplers():
|
|
|
|
all_samplers = set()
|
|
|
|
for k in loaders_samplers:
|
|
|
|
for sampler in loaders_samplers[k]:
|
|
|
|
all_samplers.add(sampler)
|
|
|
|
|
|
|
|
return sorted(all_samplers)
|
|
|
|
|
|
|
|
|
2024-01-09 04:42:31 +01:00
|
|
|
def blacklist_samplers(loader, dynamic_temperature):
|
2023-08-01 03:44:00 +02:00
|
|
|
all_samplers = list_all_samplers()
|
2024-01-09 04:42:31 +01:00
|
|
|
output = []
|
|
|
|
|
|
|
|
for sampler in all_samplers:
|
|
|
|
if loader == 'All' or sampler in loaders_samplers[loader]:
|
|
|
|
if sampler.startswith('dynatemp'):
|
|
|
|
output.append(gr.update(visible=dynamic_temperature))
|
|
|
|
else:
|
|
|
|
output.append(gr.update(visible=True))
|
|
|
|
else:
|
|
|
|
output.append(gr.update(visible=False))
|
|
|
|
|
|
|
|
return output
|
2023-08-01 03:44:00 +02:00
|
|
|
|
2023-06-17 00:00:37 +02:00
|
|
|
|
|
|
|
def get_gpu_memory_keys():
|
|
|
|
return [k for k in shared.gradio if k.startswith('gpu_memory')]
|
|
|
|
|
|
|
|
|
|
|
|
@functools.cache
|
|
|
|
def get_all_params():
|
|
|
|
all_params = set()
|
|
|
|
for k in loaders_and_params:
|
|
|
|
for el in loaders_and_params[k]:
|
|
|
|
all_params.add(el)
|
|
|
|
|
|
|
|
if 'gpu_memory' in all_params:
|
|
|
|
all_params.remove('gpu_memory')
|
|
|
|
for k in get_gpu_memory_keys():
|
|
|
|
all_params.add(k)
|
|
|
|
|
|
|
|
return sorted(all_params)
|
|
|
|
|
|
|
|
|
|
|
|
def make_loader_params_visible(loader):
|
|
|
|
params = []
|
|
|
|
all_params = get_all_params()
|
|
|
|
if loader in loaders_and_params:
|
|
|
|
params = loaders_and_params[loader]
|
|
|
|
|
|
|
|
if 'gpu_memory' in params:
|
|
|
|
params.remove('gpu_memory')
|
|
|
|
params += get_gpu_memory_keys()
|
|
|
|
|
|
|
|
return [gr.update(visible=True) if k in params else gr.update(visible=False) for k in all_params]
|