|
@@ -1,7 +1,7 @@
|
|
from __future__ import annotations
|
|
from __future__ import annotations
|
|
|
|
|
|
import datetime
|
|
import datetime
|
|
-
|
|
|
|
|
|
+import functools
|
|
import pytz
|
|
import pytz
|
|
import io
|
|
import io
|
|
import math
|
|
import math
|
|
@@ -349,6 +349,32 @@ def sanitize_filename_part(text, replace_spaces=True):
|
|
return text
|
|
return text
|
|
|
|
|
|
|
|
|
|
|
|
+@functools.cache
|
|
|
|
+def get_scheduler_str(sampler_name, scheduler_name):
|
|
|
|
+ """Returns {Scheduler} if the scheduler is applicable to the sampler"""
|
|
|
|
+ if scheduler_name == 'Automatic':
|
|
|
|
+ config = sd_samplers.find_sampler_config(sampler_name)
|
|
|
|
+ scheduler_name = config.options.get('scheduler', 'Automatic')
|
|
|
|
+ return scheduler_name.capitalize()
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+@functools.cache
|
|
|
|
+def get_sampler_scheduler_str(sampler_name, scheduler_name):
|
|
|
|
+ """Returns the '{Sampler} {Scheduler}' if the scheduler is applicable to the sampler"""
|
|
|
|
+ return f'{sampler_name} {get_scheduler_str(sampler_name, scheduler_name)}'
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+def get_sampler_scheduler(p, sampler):
|
|
|
|
+ """Returns '{Sampler} {Scheduler}' / '{Scheduler}' / 'NOTHING_AND_SKIP_PREVIOUS_TEXT'"""
|
|
|
|
+ if hasattr(p, 'scheduler') and hasattr(p, 'sampler_name'):
|
|
|
|
+ if sampler:
|
|
|
|
+ sampler_scheduler = get_sampler_scheduler_str(p.sampler_name, p.scheduler)
|
|
|
|
+ else:
|
|
|
|
+ sampler_scheduler = get_scheduler_str(p.sampler_name, p.scheduler)
|
|
|
|
+ return sanitize_filename_part(sampler_scheduler, replace_spaces=False)
|
|
|
|
+ return NOTHING_AND_SKIP_PREVIOUS_TEXT
|
|
|
|
+
|
|
|
|
+
|
|
class FilenameGenerator:
|
|
class FilenameGenerator:
|
|
replacements = {
|
|
replacements = {
|
|
'seed': lambda self: self.seed if self.seed is not None else '',
|
|
'seed': lambda self: self.seed if self.seed is not None else '',
|
|
@@ -360,6 +386,8 @@ class FilenameGenerator:
|
|
'height': lambda self: self.image.height,
|
|
'height': lambda self: self.image.height,
|
|
'styles': lambda self: self.p and sanitize_filename_part(", ".join([style for style in self.p.styles if not style == "None"]) or "None", replace_spaces=False),
|
|
'styles': lambda self: self.p and sanitize_filename_part(", ".join([style for style in self.p.styles if not style == "None"]) or "None", replace_spaces=False),
|
|
'sampler': lambda self: self.p and sanitize_filename_part(self.p.sampler_name, replace_spaces=False),
|
|
'sampler': lambda self: self.p and sanitize_filename_part(self.p.sampler_name, replace_spaces=False),
|
|
|
|
+ 'sampler_scheduler': lambda self: self.p and get_sampler_scheduler(self.p, True),
|
|
|
|
+ 'scheduler': lambda self: self.p and get_sampler_scheduler(self.p, False),
|
|
'model_hash': lambda self: getattr(self.p, "sd_model_hash", shared.sd_model.sd_model_hash),
|
|
'model_hash': lambda self: getattr(self.p, "sd_model_hash", shared.sd_model.sd_model_hash),
|
|
'model_name': lambda self: sanitize_filename_part(shared.sd_model.sd_checkpoint_info.name_for_extra, replace_spaces=False),
|
|
'model_name': lambda self: sanitize_filename_part(shared.sd_model.sd_checkpoint_info.name_for_extra, replace_spaces=False),
|
|
'date': lambda self: datetime.datetime.now().strftime('%Y-%m-%d'),
|
|
'date': lambda self: datetime.datetime.now().strftime('%Y-%m-%d'),
|