Skip to content

Commit f37cc5f

Browse files
Merge pull request #12542 from AUTOMATIC1111/res-sampler
Add RES sampler and reorder the sampler list
2 parents 3a4bee1 + aa26f8e commit f37cc5f

File tree

1 file changed

+10
-0
lines changed

1 file changed

+10
-0
lines changed

modules/sd_samplers_kdiffusion.py

+10
Original file line numberDiff line numberDiff line change
@@ -22,6 +22,9 @@
2222
('DPM++ 2M', 'sample_dpmpp_2m', ['k_dpmpp_2m'], {}),
2323
('DPM++ SDE', 'sample_dpmpp_sde', ['k_dpmpp_sde'], {"second_order": True, "brownian_noise": True}),
2424
('DPM++ 2M SDE', 'sample_dpmpp_2m_sde', ['k_dpmpp_2m_sde_ka'], {"brownian_noise": True}),
25+
('DPM++ 2M SDE Heun', 'sample_dpmpp_2m_sde', ['k_dpmpp_2m_sde_heun'], {"brownian_noise": True, "solver_type": "heun"}),
26+
('DPM++ 2M SDE Heun Karras', 'sample_dpmpp_2m_sde', ['k_dpmpp_2m_sde_heun_ka'], {'scheduler': 'karras', "brownian_noise": True, "solver_type": "heun"}),
27+
('DPM++ 2M SDE Heun Exponential', 'sample_dpmpp_2m_sde', ['k_dpmpp_2m_sde_heun_exp'], {'scheduler': 'exponential', "brownian_noise": True, "solver_type": "heun"}),
2528
('DPM++ 3M SDE', 'sample_dpmpp_3m_sde', ['k_dpmpp_3m_sde'], {'discard_next_to_last_sigma': True, "brownian_noise": True}),
2629
('DPM++ 3M SDE Karras', 'sample_dpmpp_3m_sde', ['k_dpmpp_3m_sde_ka'], {'scheduler': 'karras', 'discard_next_to_last_sigma': True, "brownian_noise": True}),
2730
('DPM++ 3M SDE Exponential', 'sample_dpmpp_3m_sde', ['k_dpmpp_3m_sde_exp'], {'scheduler': 'exponential', 'discard_next_to_last_sigma': True, "brownian_noise": True}),
@@ -161,6 +164,9 @@ def sample_img2img(self, p, x, noise, conditioning, unconditional_conditioning,
161164
noise_sampler = self.create_noise_sampler(x, sigmas, p)
162165
extra_params_kwargs['noise_sampler'] = noise_sampler
163166

167+
if self.config.options.get('solver_type', None) == 'heun':
168+
extra_params_kwargs['solver_type'] = 'heun'
169+
164170
self.model_wrap_cfg.init_latent = x
165171
self.last_latent = x
166172
self.sampler_extra_args = {
@@ -202,6 +208,9 @@ def sample(self, p, x, conditioning, unconditional_conditioning, steps=None, ima
202208
noise_sampler = self.create_noise_sampler(x, sigmas, p)
203209
extra_params_kwargs['noise_sampler'] = noise_sampler
204210

211+
if self.config.options.get('solver_type', None) == 'heun':
212+
extra_params_kwargs['solver_type'] = 'heun'
213+
205214
self.last_latent = x
206215
self.sampler_extra_args = {
207216
'cond': conditioning,
@@ -210,6 +219,7 @@ def sample(self, p, x, conditioning, unconditional_conditioning, steps=None, ima
210219
'cond_scale': p.cfg_scale,
211220
's_min_uncond': self.s_min_uncond
212221
}
222+
213223
samples = self.launch_sampling(steps, lambda: self.func(self.model_wrap_cfg, x, extra_args=self.sampler_extra_args, disable=False, callback=self.callback_state, **extra_params_kwargs))
214224

215225
if self.model_wrap_cfg.padded_cond_uncond:

0 commit comments

Comments
 (0)