| from comfy.model_management import vram_state, VRAMState |
| import logging |
| import sys |
| from comfy.cli_args import args |
| from comfy import model_management |
| from . import devices |
|
|
| log = logging.getLogger("sd") |
| options_templates = {} |
| loaded_hypernetworks = [] |
| xformers_available = model_management.XFORMERS_IS_AVAILABLE |
| device = devices.device |
|
|
| class Options: |
| data = None |
| data_labels = options_templates |
| typemap = {int: float} |
|
|
| def __init__(self): |
| self.data = {k: v.default for k, v in self.data_labels.items()} |
|
|
| def __setattr__(self, key, value): |
| if self.data is not None: |
| if key in self.data or key in self.data_labels: |
| |
| |
| |
| |
| |
| |
| self.data[key] = value |
| return |
| return super(Options, self).__setattr__(key, value) |
|
|
| def __getattr__(self, item): |
| if self.data is not None: |
| if item in self.data: |
| return self.data[item] |
| if item in self.data_labels: |
| return self.data_labels[item].default |
| return super(Options, self).__getattribute__(item) |
|
|
|
|
| opts = Options() |
| opts.prompt_attention = 'A1111 parser' |
| opts.prompt_mean_norm = True |
| opts.comma_padding_backtrack = 20 |
| opts.CLIP_stop_at_last_layers = 1 |
| opts.enable_emphasis = True |
| opts.use_old_emphasis_implementation = False |
| opts.disable_nan_check = True |
| opts.pad_cond_uncond = False |
| opts.s_min_uncond = 0.0 |
| opts.upcast_sampling = True |
| opts.upcast_attn = not args.dont_upcast_attention |
| opts.textual_inversion_add_hashes_to_infotext = False |
| opts.encode_count = 0 |
| opts.max_chunk_count = 0 |
| opts.return_batch_chunks = False |
| opts.noise = None |
| opts.pad_with_repeats = True |
| opts.randn_source = "cpu" |
| opts.lora_functional = False |
| opts.use_old_scheduling = False |
| opts.eta_noise_seed_delta = 0 |
|
|
| opts.use_CFGDenoiser = False |
| opts.sgm_noise_multiplier = True |
| opts.debug= False |
|
|
|
|
| opts.sdxl_crop_top = 0 |
| opts.sdxl_crop_left = 0 |
| opts.sdxl_refiner_low_aesthetic_score = 2.5 |
| opts.sdxl_refiner_high_aesthetic_score = 6.0 |
|
|
| sd_model = Options() |
| sd_model.cond_stage_model = Options() |
|
|
| cmd_opts = Options() |
|
|
| opts.batch_cond_uncond = False |
| cmd_opts.lowvram = vram_state == VRAMState.LOW_VRAM |
| cmd_opts.medvram = vram_state == VRAMState.NORMAL_VRAM |
| should_batch_cond_uncond = lambda: opts.batch_cond_uncond or not (cmd_opts.lowvram or cmd_opts.medvram) |
| opts.batch_cond_uncond = should_batch_cond_uncond() |
|
|
| cmd_opts.xformers = xformers_available |
| cmd_opts.force_enable_xformers = xformers_available |
|
|
| opts.cross_attention_optimization = "None" |
| |
| |
| cmd_opts.sub_quad_q_chunk_size = 512 |
| cmd_opts.sub_quad_kv_chunk_size = 512 |
| cmd_opts.sub_quad_chunk_threshold = 80 |
| cmd_opts.token_merging_ratio = 0.0 |
| cmd_opts.token_merging_ratio_img2img = 0.0 |
| cmd_opts.token_merging_ratio_hr = 0.0 |
| cmd_opts.sd_vae_sliced_encode = False |
| cmd_opts.disable_opt_split_attention = False |