Buckets:
| import{s as Se,n as ye,o as Me}from"../chunks/scheduler.182ea377.js";import{S as Pe,i as Te,g as a,s as n,r as g,A as we,h as d,f as t,c as o,j as F,u as _,x as v,k as O,y as r,a as c,v as b,d as D,t as $,w as x}from"../chunks/index.abf12888.js";import{D as z}from"../chunks/Docstring.93f6f462.js";import{H as fe}from"../chunks/Heading.16916d63.js";function Ke(me){let u,B,N,j,S,G,y,he='The <code>KDPM2DiscreteScheduler</code> is inspired by the <a href="https://huggingface.co/papers/2206.00364" rel="nofollow">Elucidating the Design Space of Diffusion-Based Generative Models</a> paper, and the scheduler is ported from and created by <a href="https://github.com/crowsonkb/" rel="nofollow">Katherine Crowson</a>.',R,M,ge='The original codebase can be found at <a href="https://github.com/crowsonkb/k-diffusion" rel="nofollow">crowsonkb/k-diffusion</a>.',W,P,Y,i,T,ne,E,_e=`KDPM2DiscreteScheduler is inspired by the DPMSolver2 and Algorithm 2 from the <a href="https://huggingface.co/papers/2206.00364" rel="nofollow">Elucidating the Design Space of | |
| Diffusion-Based Generative Models</a> paper.`,oe,H,ve=`This model inherits from <a href="/docs/diffusers/v0.24.0/en/api/schedulers/overview#diffusers.SchedulerMixin">SchedulerMixin</a> and <a href="/docs/diffusers/v0.24.0/en/api/configuration#diffusers.ConfigMixin">ConfigMixin</a>. Check the superclass documentation for the generic | |
| methods the library implements for all schedulers such as loading and saving.`,ie,f,w,ae,I,be=`Ensures interchangeability with schedulers that need to scale the denoising model input depending on the | |
| current timestep.`,de,m,K,ce,q,De="Sets the discrete timesteps used for the diffusion chain (to be run before inference).",le,h,C,ue,U,$e=`Predict the sample from the previous timestep by reversing the SDE. This function propagates the diffusion | |
| process from the learned model outputs (most often the predicted noise).`,J,k,Q,p,L,pe,A,xe="Base class for the output of a scheduler’s <code>step</code> function.",X,V,Z;return S=new fe({props:{title:"KDPM2DiscreteScheduler",local:"kdpm2discretescheduler",headingTag:"h1"}}),P=new fe({props:{title:"KDPM2DiscreteScheduler",local:"diffusers.KDPM2DiscreteScheduler",headingTag:"h2"}}),T=new z({props:{name:"class diffusers.KDPM2DiscreteScheduler",anchor:"diffusers.KDPM2DiscreteScheduler",parameters:[{name:"num_train_timesteps",val:": int = 1000"},{name:"beta_start",val:": float = 0.00085"},{name:"beta_end",val:": float = 0.012"},{name:"beta_schedule",val:": str = 'linear'"},{name:"trained_betas",val:": typing.Union[numpy.ndarray, typing.List[float], NoneType] = None"},{name:"use_karras_sigmas",val:": typing.Optional[bool] = False"},{name:"prediction_type",val:": str = 'epsilon'"},{name:"timestep_spacing",val:": str = 'linspace'"},{name:"steps_offset",val:": int = 0"}],parametersDescription:[{anchor:"diffusers.KDPM2DiscreteScheduler.num_train_timesteps",description:`<strong>num_train_timesteps</strong> (<code>int</code>, defaults to 1000) — | |
| The number of diffusion steps to train the model.`,name:"num_train_timesteps"},{anchor:"diffusers.KDPM2DiscreteScheduler.beta_start",description:`<strong>beta_start</strong> (<code>float</code>, defaults to 0.00085) — | |
| The starting <code>beta</code> value of inference.`,name:"beta_start"},{anchor:"diffusers.KDPM2DiscreteScheduler.beta_end",description:`<strong>beta_end</strong> (<code>float</code>, defaults to 0.012) — | |
| The final <code>beta</code> value.`,name:"beta_end"},{anchor:"diffusers.KDPM2DiscreteScheduler.beta_schedule",description:`<strong>beta_schedule</strong> (<code>str</code>, defaults to <code>"linear"</code>) — | |
| The beta schedule, a mapping from a beta range to a sequence of betas for stepping the model. Choose from | |
| <code>linear</code> or <code>scaled_linear</code>.`,name:"beta_schedule"},{anchor:"diffusers.KDPM2DiscreteScheduler.trained_betas",description:`<strong>trained_betas</strong> (<code>np.ndarray</code>, <em>optional</em>) — | |
| Pass an array of betas directly to the constructor to bypass <code>beta_start</code> and <code>beta_end</code>.`,name:"trained_betas"},{anchor:"diffusers.KDPM2DiscreteScheduler.use_karras_sigmas",description:`<strong>use_karras_sigmas</strong> (<code>bool</code>, <em>optional</em>, defaults to <code>False</code>) — | |
| Whether to use Karras sigmas for step sizes in the noise schedule during the sampling process. If <code>True</code>, | |
| the sigmas are determined according to a sequence of noise levels {σi}.`,name:"use_karras_sigmas"},{anchor:"diffusers.KDPM2DiscreteScheduler.prediction_type",description:`<strong>prediction_type</strong> (<code>str</code>, defaults to <code>epsilon</code>, <em>optional</em>) — | |
| Prediction type of the scheduler function; can be <code>epsilon</code> (predicts the noise of the diffusion process), | |
| <code>sample</code> (directly predicts the noisy sample<code>) or </code>v_prediction\` (see section 2.4 of <a href="https://imagen.research.google/video/paper.pdf" rel="nofollow">Imagen | |
| Video</a> paper).`,name:"prediction_type"},{anchor:"diffusers.KDPM2DiscreteScheduler.timestep_spacing",description:`<strong>timestep_spacing</strong> (<code>str</code>, defaults to <code>"linspace"</code>) — | |
| The way the timesteps should be scaled. Refer to Table 2 of the <a href="https://huggingface.co/papers/2305.08891" rel="nofollow">Common Diffusion Noise Schedules and | |
| Sample Steps are Flawed</a> for more information.`,name:"timestep_spacing"},{anchor:"diffusers.KDPM2DiscreteScheduler.steps_offset",description:`<strong>steps_offset</strong> (<code>int</code>, defaults to 0) — | |
| An offset added to the inference steps. You can use a combination of <code>offset=1</code> and | |
| <code>set_alpha_to_one=False</code> to make the last step use step 0 for the previous alpha product like in Stable | |
| Diffusion.`,name:"steps_offset"}],source:"https://github.com/huggingface/diffusers/blob/v0.24.0/src/diffusers/schedulers/scheduling_k_dpm_2_discrete.py#L71"}}),w=new z({props:{name:"scale_model_input",anchor:"diffusers.KDPM2DiscreteScheduler.scale_model_input",parameters:[{name:"sample",val:": FloatTensor"},{name:"timestep",val:": typing.Union[float, torch.FloatTensor]"}],parametersDescription:[{anchor:"diffusers.KDPM2DiscreteScheduler.scale_model_input.sample",description:`<strong>sample</strong> (<code>torch.FloatTensor</code>) — | |
| The input sample.`,name:"sample"},{anchor:"diffusers.KDPM2DiscreteScheduler.scale_model_input.timestep",description:`<strong>timestep</strong> (<code>int</code>, <em>optional</em>) — | |
| The current timestep in the diffusion chain.`,name:"timestep"}],source:"https://github.com/huggingface/diffusers/blob/v0.24.0/src/diffusers/schedulers/scheduling_k_dpm_2_discrete.py#L178",returnDescription:`<script context="module">export const metadata = 'undefined';<\/script> | |
| <p>A scaled input sample.</p> | |
| `,returnType:`<script context="module">export const metadata = 'undefined';<\/script> | |
| <p><code>torch.FloatTensor</code></p> | |
| `}}),K=new z({props:{name:"set_timesteps",anchor:"diffusers.KDPM2DiscreteScheduler.set_timesteps",parameters:[{name:"num_inference_steps",val:": int"},{name:"device",val:": typing.Union[str, torch.device] = None"},{name:"num_train_timesteps",val:": typing.Optional[int] = None"}],parametersDescription:[{anchor:"diffusers.KDPM2DiscreteScheduler.set_timesteps.num_inference_steps",description:`<strong>num_inference_steps</strong> (<code>int</code>) — | |
| The number of diffusion steps used when generating samples with a pre-trained model.`,name:"num_inference_steps"},{anchor:"diffusers.KDPM2DiscreteScheduler.set_timesteps.device",description:`<strong>device</strong> (<code>str</code> or <code>torch.device</code>, <em>optional</em>) — | |
| The device to which the timesteps should be moved to. If <code>None</code>, the timesteps are not moved.`,name:"device"}],source:"https://github.com/huggingface/diffusers/blob/v0.24.0/src/diffusers/schedulers/scheduling_k_dpm_2_discrete.py#L208"}}),C=new z({props:{name:"step",anchor:"diffusers.KDPM2DiscreteScheduler.step",parameters:[{name:"model_output",val:": typing.Union[torch.FloatTensor, numpy.ndarray]"},{name:"timestep",val:": typing.Union[float, torch.FloatTensor]"},{name:"sample",val:": typing.Union[torch.FloatTensor, numpy.ndarray]"},{name:"return_dict",val:": bool = True"}],parametersDescription:[{anchor:"diffusers.KDPM2DiscreteScheduler.step.model_output",description:`<strong>model_output</strong> (<code>torch.FloatTensor</code>) — | |
| The direct output from learned diffusion model.`,name:"model_output"},{anchor:"diffusers.KDPM2DiscreteScheduler.step.timestep",description:`<strong>timestep</strong> (<code>float</code>) — | |
| The current discrete timestep in the diffusion chain.`,name:"timestep"},{anchor:"diffusers.KDPM2DiscreteScheduler.step.sample",description:`<strong>sample</strong> (<code>torch.FloatTensor</code>) — | |
| A current instance of a sample created by the diffusion process.`,name:"sample"},{anchor:"diffusers.KDPM2DiscreteScheduler.step.return_dict",description:`<strong>return_dict</strong> (<code>bool</code>) — | |
| Whether or not to return a <a href="/docs/diffusers/v0.24.0/en/api/schedulers/multistep_dpm_solver_inverse#diffusers.schedulers.scheduling_utils.SchedulerOutput">SchedulerOutput</a> or tuple.`,name:"return_dict"}],source:"https://github.com/huggingface/diffusers/blob/v0.24.0/src/diffusers/schedulers/scheduling_k_dpm_2_discrete.py#L360",returnDescription:`<script context="module">export const metadata = 'undefined';<\/script> | |
| <p>If return_dict is <code>True</code>, <a | |
| href="/docs/diffusers/v0.24.0/en/api/schedulers/multistep_dpm_solver_inverse#diffusers.schedulers.scheduling_utils.SchedulerOutput" | |
| >SchedulerOutput</a> is returned, otherwise a | |
| tuple is returned where the first element is the sample tensor.</p> | |
| `,returnType:`<script context="module">export const metadata = 'undefined';<\/script> | |
| <p><a | |
| href="/docs/diffusers/v0.24.0/en/api/schedulers/multistep_dpm_solver_inverse#diffusers.schedulers.scheduling_utils.SchedulerOutput" | |
| >SchedulerOutput</a> or <code>tuple</code></p> | |
| `}}),k=new fe({props:{title:"SchedulerOutput",local:"diffusers.schedulers.scheduling_utils.SchedulerOutput",headingTag:"h2"}}),L=new z({props:{name:"class diffusers.schedulers.scheduling_utils.SchedulerOutput",anchor:"diffusers.schedulers.scheduling_utils.SchedulerOutput",parameters:[{name:"prev_sample",val:": FloatTensor"}],parametersDescription:[{anchor:"diffusers.schedulers.scheduling_utils.SchedulerOutput.prev_sample",description:`<strong>prev_sample</strong> (<code>torch.FloatTensor</code> of shape <code>(batch_size, num_channels, height, width)</code> for images) — | |
| Computed sample <code>(x_{t-1})</code> of previous timestep. <code>prev_sample</code> should be used as next model input in the | |
| denoising loop.`,name:"prev_sample"}],source:"https://github.com/huggingface/diffusers/blob/v0.24.0/src/diffusers/schedulers/scheduling_utils.py#L50"}}),{c(){u=a("meta"),B=n(),N=a("p"),j=n(),g(S.$$.fragment),G=n(),y=a("p"),y.innerHTML=he,R=n(),M=a("p"),M.innerHTML=ge,W=n(),g(P.$$.fragment),Y=n(),i=a("div"),g(T.$$.fragment),ne=n(),E=a("p"),E.innerHTML=_e,oe=n(),H=a("p"),H.innerHTML=ve,ie=n(),f=a("div"),g(w.$$.fragment),ae=n(),I=a("p"),I.textContent=be,de=n(),m=a("div"),g(K.$$.fragment),ce=n(),q=a("p"),q.textContent=De,le=n(),h=a("div"),g(C.$$.fragment),ue=n(),U=a("p"),U.textContent=$e,J=n(),g(k.$$.fragment),Q=n(),p=a("div"),g(L.$$.fragment),pe=n(),A=a("p"),A.innerHTML=xe,X=n(),V=a("p"),this.h()},l(e){const s=we("svelte-u9bgzb",document.head);u=d(s,"META",{name:!0,content:!0}),s.forEach(t),B=o(e),N=d(e,"P",{}),F(N).forEach(t),j=o(e),_(S.$$.fragment,e),G=o(e),y=d(e,"P",{"data-svelte-h":!0}),v(y)!=="svelte-1r1y5wx"&&(y.innerHTML=he),R=o(e),M=d(e,"P",{"data-svelte-h":!0}),v(M)!=="svelte-loovl7"&&(M.innerHTML=ge),W=o(e),_(P.$$.fragment,e),Y=o(e),i=d(e,"DIV",{class:!0});var l=F(i);_(T.$$.fragment,l),ne=o(l),E=d(l,"P",{"data-svelte-h":!0}),v(E)!=="svelte-iytw69"&&(E.innerHTML=_e),oe=o(l),H=d(l,"P",{"data-svelte-h":!0}),v(H)!=="svelte-dyuhxt"&&(H.innerHTML=ve),ie=o(l),f=d(l,"DIV",{class:!0});var ee=F(f);_(w.$$.fragment,ee),ae=o(ee),I=d(ee,"P",{"data-svelte-h":!0}),v(I)!=="svelte-1rkfgpx"&&(I.textContent=be),ee.forEach(t),de=o(l),m=d(l,"DIV",{class:!0});var te=F(m);_(K.$$.fragment,te),ce=o(te),q=d(te,"P",{"data-svelte-h":!0}),v(q)!=="svelte-1vzm9q"&&(q.textContent=De),te.forEach(t),le=o(l),h=d(l,"DIV",{class:!0});var se=F(h);_(C.$$.fragment,se),ue=o(se),U=d(se,"P",{"data-svelte-h":!0}),v(U)!=="svelte-hi84tp"&&(U.textContent=$e),se.forEach(t),l.forEach(t),J=o(e),_(k.$$.fragment,e),Q=o(e),p=d(e,"DIV",{class:!0});var re=F(p);_(L.$$.fragment,re),pe=o(re),A=d(re,"P",{"data-svelte-h":!0}),v(A)!=="svelte-6ojmkw"&&(A.innerHTML=xe),re.forEach(t),X=o(e),V=d(e,"P",{}),F(V).forEach(t),this.h()},h(){O(u,"name","hf:doc:metadata"),O(u,"content",Ce),O(f,"class","docstring border-l-2 border-t-2 pl-4 pt-3.5 border-gray-100 rounded-tl-xl mb-6 mt-8"),O(m,"class","docstring border-l-2 border-t-2 pl-4 pt-3.5 border-gray-100 rounded-tl-xl mb-6 mt-8"),O(h,"class","docstring border-l-2 border-t-2 pl-4 pt-3.5 border-gray-100 rounded-tl-xl mb-6 mt-8"),O(i,"class","docstring border-l-2 border-t-2 pl-4 pt-3.5 border-gray-100 rounded-tl-xl mb-6 mt-8"),O(p,"class","docstring border-l-2 border-t-2 pl-4 pt-3.5 border-gray-100 rounded-tl-xl mb-6 mt-8")},m(e,s){r(document.head,u),c(e,B,s),c(e,N,s),c(e,j,s),b(S,e,s),c(e,G,s),c(e,y,s),c(e,R,s),c(e,M,s),c(e,W,s),b(P,e,s),c(e,Y,s),c(e,i,s),b(T,i,null),r(i,ne),r(i,E),r(i,oe),r(i,H),r(i,ie),r(i,f),b(w,f,null),r(f,ae),r(f,I),r(i,de),r(i,m),b(K,m,null),r(m,ce),r(m,q),r(i,le),r(i,h),b(C,h,null),r(h,ue),r(h,U),c(e,J,s),b(k,e,s),c(e,Q,s),c(e,p,s),b(L,p,null),r(p,pe),r(p,A),c(e,X,s),c(e,V,s),Z=!0},p:ye,i(e){Z||(D(S.$$.fragment,e),D(P.$$.fragment,e),D(T.$$.fragment,e),D(w.$$.fragment,e),D(K.$$.fragment,e),D(C.$$.fragment,e),D(k.$$.fragment,e),D(L.$$.fragment,e),Z=!0)},o(e){$(S.$$.fragment,e),$(P.$$.fragment,e),$(T.$$.fragment,e),$(w.$$.fragment,e),$(K.$$.fragment,e),$(C.$$.fragment,e),$(k.$$.fragment,e),$(L.$$.fragment,e),Z=!1},d(e){e&&(t(B),t(N),t(j),t(G),t(y),t(R),t(M),t(W),t(Y),t(i),t(J),t(Q),t(p),t(X),t(V)),t(u),x(S,e),x(P,e),x(T),x(w),x(K),x(C),x(k,e),x(L)}}}const Ce='{"title":"KDPM2DiscreteScheduler","local":"kdpm2discretescheduler","sections":[{"title":"KDPM2DiscreteScheduler","local":"diffusers.KDPM2DiscreteScheduler","sections":[],"depth":2},{"title":"SchedulerOutput","local":"diffusers.schedulers.scheduling_utils.SchedulerOutput","sections":[],"depth":2}],"depth":1}';function ke(me){return Me(()=>{new URLSearchParams(window.location.search).get("fw")}),[]}class He extends Pe{constructor(u){super(),Te(this,u,ke,Ke,Se,{})}}export{He as component}; | |
Xet Storage Details
- Size:
- 14.8 kB
- Xet hash:
- e051bd4163ba154282071f8253db1697796c643c14a3df35a52601ab67aea1c0
·
Xet efficiently stores files, intelligently splitting them into unique chunks and accelerating uploads and downloads. More info.