Buckets:
| import{s as Yn,o as Fn,n as qn}from"../chunks/scheduler.53228c21.js";import{S as Hn,i as zn,e as o,s,c,h as On,a as r,d as t,b as a,f as C,g as m,j as p,k as V,l,m as i,n as u,t as M,o as y,p as f}from"../chunks/index.100fac89.js";import{C as et}from"../chunks/CopyLLMTxtMenu.7aefc1a4.js";import{D as ce}from"../chunks/Docstring.d6cb35e8.js";import{C as Ce}from"../chunks/CodeBlock.d30a6509.js";import{E as nt}from"../chunks/ExampleCodeBlock.a12c1377.js";import{H as G,E as tt}from"../chunks/MermaidChart.svelte_svelte_type_style_lang.3722da43.js";function st(Ae){let _,I="Examples:",b,j,T;return j=new Ce({props:{code:"aW1wb3J0JTIwdG9yY2glMEFmcm9tJTIwZGlmZnVzZXJzJTIwaW1wb3J0JTIwS2FuZGluc2t5NVQyVlBpcGVsaW5lJTBBZnJvbSUyMGRpZmZ1c2Vycy51dGlscyUyMGltcG9ydCUyMGV4cG9ydF90b192aWRlbyUwQSUwQSUyMyUyMEF2YWlsYWJsZSUyMG1vZGVscyUzQSUwQSUyMyUyMGFpLWZvcmV2ZXIlMkZLYW5kaW5za3ktNS4wLVQyVi1MaXRlLXNmdC01cy1EaWZmdXNlcnMlMEElMjMlMjBhaS1mb3JldmVyJTJGS2FuZGluc2t5LTUuMC1UMlYtTGl0ZS1ub2NmZy01cy1EaWZmdXNlcnMlMEElMjMlMjBhaS1mb3JldmVyJTJGS2FuZGluc2t5LTUuMC1UMlYtTGl0ZS1kaXN0aWxsZWQxNnN0ZXBzLTVzLURpZmZ1c2VycyUwQSUyMyUyMGFpLWZvcmV2ZXIlMkZLYW5kaW5za3ktNS4wLVQyVi1MaXRlLXByZXRyYWluLTVzLURpZmZ1c2VycyUwQSUwQW1vZGVsX2lkJTIwJTNEJTIwJTIyYWktZm9yZXZlciUyRkthbmRpbnNreS01LjAtVDJWLUxpdGUtc2Z0LTVzLURpZmZ1c2VycyUyMiUwQXBpcGUlMjAlM0QlMjBLYW5kaW5za3k1VDJWUGlwZWxpbmUuZnJvbV9wcmV0cmFpbmVkKG1vZGVsX2lkJTJDJTIwdG9yY2hfZHR5cGUlM0R0b3JjaC5iZmxvYXQxNiklMEFwaXBlJTIwJTNEJTIwcGlwZS50byglMjJjdWRhJTIyKSUwQSUwQXByb21wdCUyMCUzRCUyMCUyMkElMjBjYXQlMjBhbmQlMjBhJTIwZG9nJTIwYmFraW5nJTIwYSUyMGNha2UlMjB0b2dldGhlciUyMGluJTIwYSUyMGtpdGNoZW4uJTIyJTBBbmVnYXRpdmVfcHJvbXB0JTIwJTNEJTIwJTIyU3RhdGljJTJDJTIwMkQlMjBjYXJ0b29uJTJDJTIwY2FydG9vbiUyQyUyMDJkJTIwYW5pbWF0aW9uJTJDJTIwcGFpbnRpbmdzJTJDJTIwaW1hZ2VzJTJDJTIwd29yc3QlMjBxdWFsaXR5JTJDJTIwbG93JTIwcXVhbGl0eSUyQyUyMHVnbHklMkMlMjBkZWZvcm1lZCUyQyUyMHdhbGtpbmclMjBiYWNrd2FyZHMlMjIlMEElMEFvdXRwdXQlMjAlM0QlMjBwaXBlKCUwQSUyMCUyMCUyMCUyMHByb21wdCUzRHByb21wdCUyQyUwQSUyMCUyMCUyMCUyMG5lZ2F0aXZlX3Byb21wdCUzRG5lZ2F0aXZlX3Byb21wdCUyQyUwQSUyMCUyMCUyMCUyMGhlaWdodCUzRDUxMiUyQyUwQSUyMCUyMCUyMCUyMHdpZHRoJTNENzY4JTJDJTBBJTIwJTIwJTIwJTIwbnVtX2ZyYW1lcyUzRDEyMSUyQyUwQSUyMCUyMCUyMCUyMG51bV9pbmZlcmVuY2Vfc3RlcHMlM0Q1MCUyQyUwQSUyMCUyMCUyMCUyMGd1aWRhbmNlX3NjYWxlJTNENS4wJTJDJTBBKS5mcmFtZXMlNUIwJTVEJTBBJTBBZXhwb3J0X3RvX3ZpZGVvKG91dHB1dCUyQyUyMCUyMm91dHB1dC5tcDQlMjIlMkMlMjBmcHMlM0QyNCUyQyUyMHF1YWxpdHklM0Q5KQ==",highlighted:`<span class="hljs-meta">>>> </span><span class="hljs-keyword">import</span> torch | |
| <span class="hljs-meta">>>> </span><span class="hljs-keyword">from</span> diffusers <span class="hljs-keyword">import</span> Kandinsky5T2VPipeline | |
| <span class="hljs-meta">>>> </span><span class="hljs-keyword">from</span> diffusers.utils <span class="hljs-keyword">import</span> export_to_video | |
| <span class="hljs-meta">>>> </span><span class="hljs-comment"># Available models:</span> | |
| <span class="hljs-meta">>>> </span><span class="hljs-comment"># ai-forever/Kandinsky-5.0-T2V-Lite-sft-5s-Diffusers</span> | |
| <span class="hljs-meta">>>> </span><span class="hljs-comment"># ai-forever/Kandinsky-5.0-T2V-Lite-nocfg-5s-Diffusers</span> | |
| <span class="hljs-meta">>>> </span><span class="hljs-comment"># ai-forever/Kandinsky-5.0-T2V-Lite-distilled16steps-5s-Diffusers</span> | |
| <span class="hljs-meta">>>> </span><span class="hljs-comment"># ai-forever/Kandinsky-5.0-T2V-Lite-pretrain-5s-Diffusers</span> | |
| <span class="hljs-meta">>>> </span>model_id = <span class="hljs-string">"ai-forever/Kandinsky-5.0-T2V-Lite-sft-5s-Diffusers"</span> | |
| <span class="hljs-meta">>>> </span>pipe = Kandinsky5T2VPipeline.from_pretrained(model_id, torch_dtype=torch.bfloat16) | |
| <span class="hljs-meta">>>> </span>pipe = pipe.to(<span class="hljs-string">"cuda"</span>) | |
| <span class="hljs-meta">>>> </span>prompt = <span class="hljs-string">"A cat and a dog baking a cake together in a kitchen."</span> | |
| <span class="hljs-meta">>>> </span>negative_prompt = <span class="hljs-string">"Static, 2D cartoon, cartoon, 2d animation, paintings, images, worst quality, low quality, ugly, deformed, walking backwards"</span> | |
| <span class="hljs-meta">>>> </span>output = pipe( | |
| <span class="hljs-meta">... </span> prompt=prompt, | |
| <span class="hljs-meta">... </span> negative_prompt=negative_prompt, | |
| <span class="hljs-meta">... </span> height=<span class="hljs-number">512</span>, | |
| <span class="hljs-meta">... </span> width=<span class="hljs-number">768</span>, | |
| <span class="hljs-meta">... </span> num_frames=<span class="hljs-number">121</span>, | |
| <span class="hljs-meta">... </span> num_inference_steps=<span class="hljs-number">50</span>, | |
| <span class="hljs-meta">... </span> guidance_scale=<span class="hljs-number">5.0</span>, | |
| <span class="hljs-meta">... </span>).frames[<span class="hljs-number">0</span>] | |
| <span class="hljs-meta">>>> </span>export_to_video(output, <span class="hljs-string">"output.mp4"</span>, fps=<span class="hljs-number">24</span>, quality=<span class="hljs-number">9</span>)`,wrap:!1}}),{c(){_=o("p"),_.textContent=I,b=s(),c(j.$$.fragment)},l(g){_=r(g,"P",{"data-svelte-h":!0}),p(_)!=="svelte-kvfsh7"&&(_.textContent=I),b=a(g),m(j.$$.fragment,g)},m(g,v){i(g,_,v),i(g,b,v),u(j,g,v),T=!0},p:qn,i(g){T||(M(j.$$.fragment,g),T=!0)},o(g){y(j.$$.fragment,g),T=!1},d(g){g&&(t(_),t(b)),f(j,g)}}}function at(Ae){let _,I,b,j,T,g,v,Ze,W,wn="Kandinsky 5.0 Video is created by the Kandinsky team: Alexey Letunovskiy, Maria Kovaleva, Ivan Kirillov, Lev Novitskiy, Denis Koposov, Dmitrii Mikhailov, Anna Averchenkova, Andrey Shutkin, Julia Agafonova, Olga Kim, Anastasiia Kargapoltseva, Nikita Kiselev, Anna Dmitrienko, Anastasia Maltseva, Kirill Chernyshev, Ilia Vasiliev, Viacheslav Vasilev, Vladimir Polovnikov, Yury Kolabushin, Alexander Belykh, Mikhail Mamaev, Anastasia Aliaskina, Tatiana Nikulina, Polina Gavrilova, Vladimir Arkhipkin, Vladimir Korviakov, Nikolai Gerasimenko, Denis Parkhomenko, Denis Dimitrov",Be,$,Un="Kandinsky 5.0 is a family of diffusion models for Video & Image generation. Kandinsky 5.0 T2V Lite is a lightweight video generation model (2B parameters) that ranks #1 among open-source models in its class. It outperforms larger models and offers the best understanding of Russian concepts in the open-source ecosystem.",Ge,Q,Jn="The model introduces several key innovations:",Ie,E,xn="<li><strong>Latent diffusion pipeline</strong> with <strong>Flow Matching</strong> for improved training stability</li> <li><strong>Diffusion Transformer (DiT)</strong> as the main generative backbone with cross-attention to text embeddings</li> <li>Dual text encoding using <strong>Qwen2.5-VL</strong> and <strong>CLIP</strong> for comprehensive text understanding</li> <li><strong>HunyuanVideo 3D VAE</strong> for efficient video encoding and decoding</li> <li><strong>Sparse attention mechanisms</strong> (NABLA) for efficient long-sequence processing</li>",We,K,Vn='The original codebase can be found at <a href="https://github.com/ai-forever/Kandinsky-5" rel="nofollow">ai-forever/Kandinsky-5</a>.',$e,A,Cn='<p>Check out the <a href="https://huggingface.co/ai-forever" rel="nofollow">AI Forever</a> organization on the Hub for the official model checkpoints for text-to-video generation, including pretrained, SFT, no-CFG, and distilled variants.</p>',Qe,P,Ee,L,An="Kandinsky 5.0 T2V Lite comes in several variants optimized for different use cases:",Ke,N,Zn="<thead><tr><th>model_id</th> <th>Description</th> <th>Use Cases</th></tr></thead> <tbody><tr><td><strong>ai-forever/Kandinsky-5.0-T2V-Lite-sft-5s-Diffusers</strong></td> <td>5 second Supervised Fine-Tuned model</td> <td>Highest generation quality</td></tr> <tr><td><strong>ai-forever/Kandinsky-5.0-T2V-Lite-sft-10s-Diffusers</strong></td> <td>10 second Supervised Fine-Tuned model</td> <td>Highest generation quality</td></tr> <tr><td><strong>ai-forever/Kandinsky-5.0-T2V-Lite-nocfg-5s-Diffusers</strong></td> <td>5 second Classifier-Free Guidance distilled</td> <td>2× faster inference</td></tr> <tr><td><strong>ai-forever/Kandinsky-5.0-T2V-Lite-nocfg-10s-Diffusers</strong></td> <td>10 second Classifier-Free Guidance distilled</td> <td>2× faster inference</td></tr> <tr><td><strong>ai-forever/Kandinsky-5.0-T2V-Lite-distilled16steps-5s-Diffusers</strong></td> <td>5 second Diffusion distilled to 16 steps</td> <td>6× faster inference, minimal quality loss</td></tr> <tr><td><strong>ai-forever/Kandinsky-5.0-T2V-Lite-distilled16steps-10s-Diffusers</strong></td> <td>10 second Diffusion distilled to 16 steps</td> <td>6× faster inference, minimal quality loss</td></tr> <tr><td><strong>ai-forever/Kandinsky-5.0-T2V-Lite-pretrain-5s-Diffusers</strong></td> <td>5 second Base pretrained model</td> <td>Research and fine-tuning</td></tr> <tr><td><strong>ai-forever/Kandinsky-5.0-T2V-Lite-pretrain-10s-Diffusers</strong></td> <td>10 second Base pretrained model</td> <td>Research and fine-tuning</td></tr></tbody>",Pe,X,Bn="All models are available in 5-second and 10-second video generation versions.",Le,S,Ne,d,D,ln,me,Gn="Pipeline for text-to-video generation using Kandinsky 5.0.",on,ue,In=`This model inherits from <a href="/docs/diffusers/pr_12595/en/api/pipelines/overview#diffusers.DiffusionPipeline">DiffusionPipeline</a>. Check the superclass documentation for the generic methods | |
| implemented for all pipelines (downloading, saving, running on a particular device, etc.).`,rn,k,R,pn,Me,Wn="The call function to the pipeline for generation.",dn,Z,cn,B,Y,mn,ye,$n="Validate input parameters for the pipeline.",un,w,F,Mn,fe,Qn="Encodes a single prompt (positive or negative) into text encoder hidden states.",yn,he,En=`This method combines embeddings from both Qwen2.5-VL and CLIP text encoders to create comprehensive text | |
| representations for video generation.`,fn,U,q,hn,ge,Kn="Create a sparse temporal attention (STA) mask for efficient video generation.",gn,_e,Pn=`This method generates a mask that limits attention to nearby frames and spatial positions, reducing | |
| computational complexity for video generation.`,_n,J,H,jn,je,Ln="Generate sparse attention parameters for the transformer based on sample dimensions.",Tn,Te,Nn=`This method computes the sparse attention configuration needed for efficient video processing in the | |
| transformer model.`,vn,x,z,bn,ve,Xn="Prepare initial latent variables for video generation.",kn,be,Sn="This method creates random noise latents or uses provided latents as starting point for the denoising process.",Xe,O,Se,ee,De,ne,Re,te,Ye,se,Dn="<strong>⚠️ Warning!</strong> all 10 second models should be used with Flex attention and max-autotune-no-cudagraphs compilation:",Fe,ae,qe,ie,He,le,Rn="<strong>⚠️ Warning!</strong> all nocfg and diffusion distilled models should be infered wothout CFG (<code>guidance_scale=1.0</code>):",ze,oe,Oe,re,en,pe,nn,de,tn,Ve,sn;return T=new et({props:{containerStyle:"float: right; margin-left: 10px; display: inline-flex; position: relative; z-index: 10;"}}),v=new G({props:{title:"Kandinsky 5.0 Video",local:"kandinsky-50-video",headingTag:"h1"}}),P=new G({props:{title:"Available Models",local:"available-models",headingTag:"h2"}}),S=new G({props:{title:"Kandinsky5T2VPipeline",local:"diffusers.Kandinsky5T2VPipeline",headingTag:"h2"}}),D=new ce({props:{name:"class diffusers.Kandinsky5T2VPipeline",anchor:"diffusers.Kandinsky5T2VPipeline",parameters:[{name:"transformer",val:": Kandinsky5Transformer3DModel"},{name:"vae",val:": AutoencoderKLHunyuanVideo"},{name:"text_encoder",val:": Qwen2_5_VLForConditionalGeneration"},{name:"tokenizer",val:": Qwen2VLProcessor"},{name:"text_encoder_2",val:": CLIPTextModel"},{name:"tokenizer_2",val:": CLIPTokenizer"},{name:"scheduler",val:": FlowMatchEulerDiscreteScheduler"}],parametersDescription:[{anchor:"diffusers.Kandinsky5T2VPipeline.transformer",description:`<strong>transformer</strong> (<code>Kandinsky5Transformer3DModel</code>) — | |
| Conditional Transformer to denoise the encoded video latents.`,name:"transformer"},{anchor:"diffusers.Kandinsky5T2VPipeline.vae",description:`<strong>vae</strong> (<a href="/docs/diffusers/pr_12595/en/api/models/autoencoder_kl_hunyuan_video#diffusers.AutoencoderKLHunyuanVideo">AutoencoderKLHunyuanVideo</a>) — | |
| Variational Auto-Encoder (VAE) Model to encode and decode videos to and from latent representations.`,name:"vae"},{anchor:"diffusers.Kandinsky5T2VPipeline.text_encoder",description:`<strong>text_encoder</strong> (<code>Qwen2_5_VLForConditionalGeneration</code>) — | |
| Frozen text-encoder (Qwen2.5-VL).`,name:"text_encoder"},{anchor:"diffusers.Kandinsky5T2VPipeline.tokenizer",description:`<strong>tokenizer</strong> (<code>AutoProcessor</code>) — | |
| Tokenizer for Qwen2.5-VL.`,name:"tokenizer"},{anchor:"diffusers.Kandinsky5T2VPipeline.text_encoder_2",description:`<strong>text_encoder_2</strong> (<code>CLIPTextModel</code>) — | |
| Frozen CLIP text encoder.`,name:"text_encoder_2"},{anchor:"diffusers.Kandinsky5T2VPipeline.tokenizer_2",description:`<strong>tokenizer_2</strong> (<code>CLIPTokenizer</code>) — | |
| Tokenizer for CLIP.`,name:"tokenizer_2"},{anchor:"diffusers.Kandinsky5T2VPipeline.scheduler",description:`<strong>scheduler</strong> (<a href="/docs/diffusers/pr_12595/en/api/schedulers/flow_match_euler_discrete#diffusers.FlowMatchEulerDiscreteScheduler">FlowMatchEulerDiscreteScheduler</a>) — | |
| A scheduler to be used in combination with <code>transformer</code> to denoise the encoded video latents.`,name:"scheduler"}],source:"https://github.com/huggingface/diffusers/blob/vr_12595/src/diffusers/pipelines/kandinsky5/pipeline_kandinsky.py#L107"}}),R=new ce({props:{name:"__call__",anchor:"diffusers.Kandinsky5T2VPipeline.__call__",parameters:[{name:"prompt",val:": typing.Union[str, typing.List[str]] = None"},{name:"negative_prompt",val:": typing.Union[str, typing.List[str], NoneType] = None"},{name:"height",val:": int = 512"},{name:"width",val:": int = 768"},{name:"num_frames",val:": int = 121"},{name:"num_inference_steps",val:": int = 50"},{name:"guidance_scale",val:": float = 5.0"},{name:"num_videos_per_prompt",val:": typing.Optional[int] = 1"},{name:"generator",val:": typing.Union[torch._C.Generator, typing.List[torch._C.Generator], NoneType] = None"},{name:"latents",val:": typing.Optional[torch.Tensor] = None"},{name:"prompt_embeds_qwen",val:": typing.Optional[torch.Tensor] = None"},{name:"prompt_embeds_clip",val:": typing.Optional[torch.Tensor] = None"},{name:"negative_prompt_embeds_qwen",val:": typing.Optional[torch.Tensor] = None"},{name:"negative_prompt_embeds_clip",val:": typing.Optional[torch.Tensor] = None"},{name:"prompt_cu_seqlens",val:": typing.Optional[torch.Tensor] = None"},{name:"negative_prompt_cu_seqlens",val:": typing.Optional[torch.Tensor] = None"},{name:"output_type",val:": typing.Optional[str] = 'pil'"},{name:"return_dict",val:": bool = True"},{name:"callback_on_step_end",val:": typing.Union[typing.Callable[[int, int, typing.Dict], NoneType], diffusers.callbacks.PipelineCallback, diffusers.callbacks.MultiPipelineCallbacks, NoneType] = None"},{name:"callback_on_step_end_tensor_inputs",val:": typing.List[str] = ['latents']"},{name:"max_sequence_length",val:": int = 512"},{name:"**kwargs",val:""}],parametersDescription:[{anchor:"diffusers.Kandinsky5T2VPipeline.__call__.prompt",description:`<strong>prompt</strong> (<code>str</code> or <code>List[str]</code>, <em>optional</em>) — | |
| The prompt or prompts to guide the video generation. If not defined, pass <code>prompt_embeds</code> instead.`,name:"prompt"},{anchor:"diffusers.Kandinsky5T2VPipeline.__call__.negative_prompt",description:`<strong>negative_prompt</strong> (<code>str</code> or <code>List[str]</code>, <em>optional</em>) — | |
| The prompt or prompts to avoid during video generation. If not defined, pass <code>negative_prompt_embeds</code> | |
| instead. Ignored when not using guidance (<code>guidance_scale</code> < <code>1</code>).`,name:"negative_prompt"},{anchor:"diffusers.Kandinsky5T2VPipeline.__call__.height",description:`<strong>height</strong> (<code>int</code>, defaults to <code>512</code>) — | |
| The height in pixels of the generated video.`,name:"height"},{anchor:"diffusers.Kandinsky5T2VPipeline.__call__.width",description:`<strong>width</strong> (<code>int</code>, defaults to <code>768</code>) — | |
| The width in pixels of the generated video.`,name:"width"},{anchor:"diffusers.Kandinsky5T2VPipeline.__call__.num_frames",description:`<strong>num_frames</strong> (<code>int</code>, defaults to <code>25</code>) — | |
| The number of frames in the generated video.`,name:"num_frames"},{anchor:"diffusers.Kandinsky5T2VPipeline.__call__.num_inference_steps",description:`<strong>num_inference_steps</strong> (<code>int</code>, defaults to <code>50</code>) — | |
| The number of denoising steps.`,name:"num_inference_steps"},{anchor:"diffusers.Kandinsky5T2VPipeline.__call__.guidance_scale",description:`<strong>guidance_scale</strong> (<code>float</code>, defaults to <code>5.0</code>) — | |
| Guidance scale as defined in classifier-free guidance.`,name:"guidance_scale"},{anchor:"diffusers.Kandinsky5T2VPipeline.__call__.num_videos_per_prompt",description:`<strong>num_videos_per_prompt</strong> (<code>int</code>, <em>optional</em>, defaults to 1) — | |
| The number of videos to generate per prompt.`,name:"num_videos_per_prompt"},{anchor:"diffusers.Kandinsky5T2VPipeline.__call__.generator",description:`<strong>generator</strong> (<code>torch.Generator</code> or <code>List[torch.Generator]</code>, <em>optional</em>) — | |
| A torch generator to make generation deterministic.`,name:"generator"},{anchor:"diffusers.Kandinsky5T2VPipeline.__call__.latents",description:`<strong>latents</strong> (<code>torch.Tensor</code>, <em>optional</em>) — | |
| Pre-generated noisy latents.`,name:"latents"},{anchor:"diffusers.Kandinsky5T2VPipeline.__call__.prompt_embeds",description:`<strong>prompt_embeds</strong> (<code>torch.Tensor</code>, <em>optional</em>) — | |
| Pre-generated text embeddings.`,name:"prompt_embeds"},{anchor:"diffusers.Kandinsky5T2VPipeline.__call__.negative_prompt_embeds",description:`<strong>negative_prompt_embeds</strong> (<code>torch.Tensor</code>, <em>optional</em>) — | |
| Pre-generated negative text embeddings.`,name:"negative_prompt_embeds"},{anchor:"diffusers.Kandinsky5T2VPipeline.__call__.output_type",description:`<strong>output_type</strong> (<code>str</code>, <em>optional</em>, defaults to <code>"pil"</code>) — | |
| The output format of the generated video.`,name:"output_type"},{anchor:"diffusers.Kandinsky5T2VPipeline.__call__.return_dict",description:`<strong>return_dict</strong> (<code>bool</code>, <em>optional</em>, defaults to <code>True</code>) — | |
| Whether or not to return a <code>KandinskyPipelineOutput</code>.`,name:"return_dict"},{anchor:"diffusers.Kandinsky5T2VPipeline.__call__.callback_on_step_end",description:`<strong>callback_on_step_end</strong> (<code>Callable</code>, <code>PipelineCallback</code>, <code>MultiPipelineCallbacks</code>, <em>optional</em>) — | |
| A function that is called at the end of each denoising step.`,name:"callback_on_step_end"},{anchor:"diffusers.Kandinsky5T2VPipeline.__call__.callback_on_step_end_tensor_inputs",description:`<strong>callback_on_step_end_tensor_inputs</strong> (<code>List</code>, <em>optional</em>) — | |
| The list of tensor inputs for the <code>callback_on_step_end</code> function.`,name:"callback_on_step_end_tensor_inputs"},{anchor:"diffusers.Kandinsky5T2VPipeline.__call__.max_sequence_length",description:`<strong>max_sequence_length</strong> (<code>int</code>, defaults to <code>512</code>) — | |
| The maximum sequence length for text encoding.`,name:"max_sequence_length"}],source:"https://github.com/huggingface/diffusers/blob/vr_12595/src/diffusers/pipelines/kandinsky5/pipeline_kandinsky.py#L615",returnDescription:`<script context="module">export const metadata = 'undefined';<\/script> | |
| <p>If <code>return_dict</code> is <code>True</code>, <code>KandinskyPipelineOutput</code> is returned, otherwise a <code>tuple</code> is returned | |
| where the first element is a list with the generated images.</p> | |
| `,returnType:`<script context="module">export const metadata = 'undefined';<\/script> | |
| <p><code>~KandinskyPipelineOutput</code> or <code>tuple</code></p> | |
| `}}),Z=new nt({props:{anchor:"diffusers.Kandinsky5T2VPipeline.__call__.example",$$slots:{default:[st]},$$scope:{ctx:Ae}}}),Y=new ce({props:{name:"check_inputs",anchor:"diffusers.Kandinsky5T2VPipeline.check_inputs",parameters:[{name:"prompt",val:""},{name:"negative_prompt",val:""},{name:"height",val:""},{name:"width",val:""},{name:"prompt_embeds_qwen",val:" = None"},{name:"prompt_embeds_clip",val:" = None"},{name:"negative_prompt_embeds_qwen",val:" = None"},{name:"negative_prompt_embeds_clip",val:" = None"},{name:"prompt_cu_seqlens",val:" = None"},{name:"negative_prompt_cu_seqlens",val:" = None"},{name:"callback_on_step_end_tensor_inputs",val:" = None"}],parametersDescription:[{anchor:"diffusers.Kandinsky5T2VPipeline.check_inputs.prompt",description:"<strong>prompt</strong> — Input prompt",name:"prompt"},{anchor:"diffusers.Kandinsky5T2VPipeline.check_inputs.negative_prompt",description:"<strong>negative_prompt</strong> — Negative prompt for guidance",name:"negative_prompt"},{anchor:"diffusers.Kandinsky5T2VPipeline.check_inputs.height",description:"<strong>height</strong> — Video height",name:"height"},{anchor:"diffusers.Kandinsky5T2VPipeline.check_inputs.width",description:"<strong>width</strong> — Video width",name:"width"},{anchor:"diffusers.Kandinsky5T2VPipeline.check_inputs.prompt_embeds_qwen",description:"<strong>prompt_embeds_qwen</strong> — Pre-computed Qwen prompt embeddings",name:"prompt_embeds_qwen"},{anchor:"diffusers.Kandinsky5T2VPipeline.check_inputs.prompt_embeds_clip",description:"<strong>prompt_embeds_clip</strong> — Pre-computed CLIP prompt embeddings",name:"prompt_embeds_clip"},{anchor:"diffusers.Kandinsky5T2VPipeline.check_inputs.negative_prompt_embeds_qwen",description:"<strong>negative_prompt_embeds_qwen</strong> — Pre-computed Qwen negative prompt embeddings",name:"negative_prompt_embeds_qwen"},{anchor:"diffusers.Kandinsky5T2VPipeline.check_inputs.negative_prompt_embeds_clip",description:"<strong>negative_prompt_embeds_clip</strong> — Pre-computed CLIP negative prompt embeddings",name:"negative_prompt_embeds_clip"},{anchor:"diffusers.Kandinsky5T2VPipeline.check_inputs.prompt_cu_seqlens",description:"<strong>prompt_cu_seqlens</strong> — Pre-computed cumulative sequence lengths for Qwen positive prompt",name:"prompt_cu_seqlens"},{anchor:"diffusers.Kandinsky5T2VPipeline.check_inputs.negative_prompt_cu_seqlens",description:"<strong>negative_prompt_cu_seqlens</strong> — Pre-computed cumulative sequence lengths for Qwen negative prompt",name:"negative_prompt_cu_seqlens"},{anchor:"diffusers.Kandinsky5T2VPipeline.check_inputs.callback_on_step_end_tensor_inputs",description:"<strong>callback_on_step_end_tensor_inputs</strong> — Callback tensor inputs",name:"callback_on_step_end_tensor_inputs"}],source:"https://github.com/huggingface/diffusers/blob/vr_12595/src/diffusers/pipelines/kandinsky5/pipeline_kandinsky.py#L446",raiseDescription:`<script context="module">export const metadata = 'undefined';<\/script> | |
| <ul> | |
| <li><code>ValueError</code> — If inputs are invalid</li> | |
| </ul> | |
| `,raiseType:`<script context="module">export const metadata = 'undefined';<\/script> | |
| <p><code>ValueError</code></p> | |
| `}}),F=new ce({props:{name:"encode_prompt",anchor:"diffusers.Kandinsky5T2VPipeline.encode_prompt",parameters:[{name:"prompt",val:": typing.Union[str, typing.List[str]]"},{name:"num_videos_per_prompt",val:": int = 1"},{name:"max_sequence_length",val:": int = 512"},{name:"device",val:": typing.Optional[torch.device] = None"},{name:"dtype",val:": typing.Optional[torch.dtype] = None"}],parametersDescription:[{anchor:"diffusers.Kandinsky5T2VPipeline.encode_prompt.prompt",description:`<strong>prompt</strong> (<code>str</code> or <code>List[str]</code>) — | |
| Prompt to be encoded.`,name:"prompt"},{anchor:"diffusers.Kandinsky5T2VPipeline.encode_prompt.num_videos_per_prompt",description:`<strong>num_videos_per_prompt</strong> (<code>int</code>, <em>optional</em>, defaults to 1) — | |
| Number of videos to generate per prompt.`,name:"num_videos_per_prompt"},{anchor:"diffusers.Kandinsky5T2VPipeline.encode_prompt.max_sequence_length",description:`<strong>max_sequence_length</strong> (<code>int</code>, <em>optional</em>, defaults to 512) — | |
| Maximum sequence length for text encoding.`,name:"max_sequence_length"},{anchor:"diffusers.Kandinsky5T2VPipeline.encode_prompt.device",description:`<strong>device</strong> (<code>torch.device</code>, <em>optional</em>) — | |
| Torch device.`,name:"device"},{anchor:"diffusers.Kandinsky5T2VPipeline.encode_prompt.dtype",description:`<strong>dtype</strong> (<code>torch.dtype</code>, <em>optional</em>) — | |
| Torch dtype.`,name:"dtype"}],source:"https://github.com/huggingface/diffusers/blob/vr_12595/src/diffusers/pipelines/kandinsky5/pipeline_kandinsky.py#L353",returnDescription:`<script context="module">export const metadata = 'undefined';<\/script> | |
| <ul> | |
| <li>Qwen text embeddings of shape (batch_size * num_videos_per_prompt, sequence_length, embedding_dim)</li> | |
| <li>CLIP pooled embeddings of shape (batch_size * num_videos_per_prompt, clip_embedding_dim)</li> | |
| <li>Cumulative sequence lengths (<code>cu_seqlens</code>) for Qwen embeddings of shape (batch_size * | |
| num_videos_per_prompt + 1,)</li> | |
| </ul> | |
| `,returnType:`<script context="module">export const metadata = 'undefined';<\/script> | |
| <p>Tuple[torch.Tensor, torch.Tensor, torch.Tensor]</p> | |
| `}}),q=new ce({props:{name:"fast_sta_nabla",anchor:"diffusers.Kandinsky5T2VPipeline.fast_sta_nabla",parameters:[{name:"T",val:": int"},{name:"H",val:": int"},{name:"W",val:": int"},{name:"wT",val:": int = 3"},{name:"wH",val:": int = 3"},{name:"wW",val:": int = 3"},{name:"device",val:" = 'cuda'"}],parametersDescription:[{anchor:"diffusers.Kandinsky5T2VPipeline.fast_sta_nabla.T",description:"<strong>T</strong> (int) — Number of temporal frames",name:"T"},{anchor:"diffusers.Kandinsky5T2VPipeline.fast_sta_nabla.H",description:"<strong>H</strong> (int) — Height in latent space",name:"H"},{anchor:"diffusers.Kandinsky5T2VPipeline.fast_sta_nabla.W",description:"<strong>W</strong> (int) — Width in latent space",name:"W"},{anchor:"diffusers.Kandinsky5T2VPipeline.fast_sta_nabla.wT",description:"<strong>wT</strong> (int) — Temporal attention window size",name:"wT"},{anchor:"diffusers.Kandinsky5T2VPipeline.fast_sta_nabla.wH",description:"<strong>wH</strong> (int) — Height attention window size",name:"wH"},{anchor:"diffusers.Kandinsky5T2VPipeline.fast_sta_nabla.wW",description:"<strong>wW</strong> (int) — Width attention window size",name:"wW"},{anchor:"diffusers.Kandinsky5T2VPipeline.fast_sta_nabla.device",description:"<strong>device</strong> (str) — Device to create tensor on",name:"device"}],source:"https://github.com/huggingface/diffusers/blob/vr_12595/src/diffusers/pipelines/kandinsky5/pipeline_kandinsky.py#L182",returnDescription:`<script context="module">export const metadata = 'undefined';<\/script> | |
| <p>Sparse attention mask of shape (T<em>H</em>W, T<em>H</em>W)</p> | |
| `,returnType:`<script context="module">export const metadata = 'undefined';<\/script> | |
| <p>torch.Tensor</p> | |
| `}}),H=new ce({props:{name:"get_sparse_params",anchor:"diffusers.Kandinsky5T2VPipeline.get_sparse_params",parameters:[{name:"sample",val:""},{name:"device",val:""}],parametersDescription:[{anchor:"diffusers.Kandinsky5T2VPipeline.get_sparse_params.sample",description:"<strong>sample</strong> (torch.Tensor) — Input sample tensor",name:"sample"},{anchor:"diffusers.Kandinsky5T2VPipeline.get_sparse_params.device",description:"<strong>device</strong> (torch.device) — Device to place tensors on",name:"device"}],source:"https://github.com/huggingface/diffusers/blob/vr_12595/src/diffusers/pipelines/kandinsky5/pipeline_kandinsky.py#L217",returnDescription:`<script context="module">export const metadata = 'undefined';<\/script> | |
| <p>Dictionary containing sparse attention parameters</p> | |
| `,returnType:`<script context="module">export const metadata = 'undefined';<\/script> | |
| <p>Dict</p> | |
| `}}),z=new ce({props:{name:"prepare_latents",anchor:"diffusers.Kandinsky5T2VPipeline.prepare_latents",parameters:[{name:"batch_size",val:": int"},{name:"num_channels_latents",val:": int = 16"},{name:"height",val:": int = 480"},{name:"width",val:": int = 832"},{name:"num_frames",val:": int = 81"},{name:"dtype",val:": typing.Optional[torch.dtype] = None"},{name:"device",val:": typing.Optional[torch.device] = None"},{name:"generator",val:": typing.Union[torch._C.Generator, typing.List[torch._C.Generator], NoneType] = None"},{name:"latents",val:": typing.Optional[torch.Tensor] = None"}],parametersDescription:[{anchor:"diffusers.Kandinsky5T2VPipeline.prepare_latents.batch_size",description:"<strong>batch_size</strong> (int) — Number of videos to generate",name:"batch_size"},{anchor:"diffusers.Kandinsky5T2VPipeline.prepare_latents.num_channels_latents",description:"<strong>num_channels_latents</strong> (int) — Number of channels in latent space",name:"num_channels_latents"},{anchor:"diffusers.Kandinsky5T2VPipeline.prepare_latents.height",description:"<strong>height</strong> (int) — Height of generated video",name:"height"},{anchor:"diffusers.Kandinsky5T2VPipeline.prepare_latents.width",description:"<strong>width</strong> (int) — Width of generated video",name:"width"},{anchor:"diffusers.Kandinsky5T2VPipeline.prepare_latents.num_frames",description:"<strong>num_frames</strong> (int) — Number of frames in video",name:"num_frames"},{anchor:"diffusers.Kandinsky5T2VPipeline.prepare_latents.dtype",description:"<strong>dtype</strong> (torch.dtype) — Data type for latents",name:"dtype"},{anchor:"diffusers.Kandinsky5T2VPipeline.prepare_latents.device",description:"<strong>device</strong> (torch.device) — Device to create latents on",name:"device"},{anchor:"diffusers.Kandinsky5T2VPipeline.prepare_latents.generator",description:"<strong>generator</strong> (torch.Generator) — Random number generator",name:"generator"},{anchor:"diffusers.Kandinsky5T2VPipeline.prepare_latents.latents",description:"<strong>latents</strong> (torch.Tensor) — Pre-existing latents to use",name:"latents"}],source:"https://github.com/huggingface/diffusers/blob/vr_12595/src/diffusers/pipelines/kandinsky5/pipeline_kandinsky.py#L527",returnDescription:`<script context="module">export const metadata = 'undefined';<\/script> | |
| <p>Prepared latent tensor</p> | |
| `,returnType:`<script context="module">export const metadata = 'undefined';<\/script> | |
| <p>torch.Tensor</p> | |
| `}}),O=new G({props:{title:"Usage Examples",local:"usage-examples",headingTag:"h2"}}),ee=new G({props:{title:"Basic Text-to-Video Generation",local:"basic-text-to-video-generation",headingTag:"h3"}}),ne=new Ce({props:{code:"aW1wb3J0JTIwdG9yY2glMEFmcm9tJTIwZGlmZnVzZXJzJTIwaW1wb3J0JTIwS2FuZGluc2t5NVQyVlBpcGVsaW5lJTBBZnJvbSUyMGRpZmZ1c2Vycy51dGlscyUyMGltcG9ydCUyMGV4cG9ydF90b192aWRlbyUwQSUwQSUyMyUyMExvYWQlMjB0aGUlMjBwaXBlbGluZSUwQW1vZGVsX2lkJTIwJTNEJTIwJTIyYWktZm9yZXZlciUyRkthbmRpbnNreS01LjAtVDJWLUxpdGUtc2Z0LTVzLURpZmZ1c2VycyUyMiUwQXBpcGUlMjAlM0QlMjBLYW5kaW5za3k1VDJWUGlwZWxpbmUuZnJvbV9wcmV0cmFpbmVkKG1vZGVsX2lkJTJDJTIwdG9yY2hfZHR5cGUlM0R0b3JjaC5iZmxvYXQxNiklMEFwaXBlJTIwJTNEJTIwcGlwZS50byglMjJjdWRhJTIyKSUwQSUwQSUyMyUyMEdlbmVyYXRlJTIwdmlkZW8lMEFwcm9tcHQlMjAlM0QlMjAlMjJBJTIwY2F0JTIwYW5kJTIwYSUyMGRvZyUyMGJha2luZyUyMGElMjBjYWtlJTIwdG9nZXRoZXIlMjBpbiUyMGElMjBraXRjaGVuLiUyMiUwQW5lZ2F0aXZlX3Byb21wdCUyMCUzRCUyMCUyMlN0YXRpYyUyQyUyMDJEJTIwY2FydG9vbiUyQyUyMGNhcnRvb24lMkMlMjAyZCUyMGFuaW1hdGlvbiUyQyUyMHBhaW50aW5ncyUyQyUyMGltYWdlcyUyQyUyMHdvcnN0JTIwcXVhbGl0eSUyQyUyMGxvdyUyMHF1YWxpdHklMkMlMjB1Z2x5JTJDJTIwZGVmb3JtZWQlMkMlMjB3YWxraW5nJTIwYmFja3dhcmRzJTIyJTBBJTBBb3V0cHV0JTIwJTNEJTIwcGlwZSglMEElMjAlMjAlMjAlMjBwcm9tcHQlM0Rwcm9tcHQlMkMlMEElMjAlMjAlMjAlMjBuZWdhdGl2ZV9wcm9tcHQlM0RuZWdhdGl2ZV9wcm9tcHQlMkMlMEElMjAlMjAlMjAlMjBoZWlnaHQlM0Q1MTIlMkMlMEElMjAlMjAlMjAlMjB3aWR0aCUzRDc2OCUyQyUwQSUyMCUyMCUyMCUyMG51bV9mcmFtZXMlM0QxMjElMkMlMjAlMjAlMjMlMjB+NSUyMHNlY29uZHMlMjBhdCUyMDI0ZnBzJTBBJTIwJTIwJTIwJTIwbnVtX2luZmVyZW5jZV9zdGVwcyUzRDUwJTJDJTBBJTIwJTIwJTIwJTIwZ3VpZGFuY2Vfc2NhbGUlM0Q1LjAlMkMlMEEpLmZyYW1lcyU1QjAlNUQlMEElMEFleHBvcnRfdG9fdmlkZW8ob3V0cHV0JTJDJTIwJTIyb3V0cHV0Lm1wNCUyMiUyQyUyMGZwcyUzRDI0JTJDJTIwcXVhbGl0eSUzRDkp",highlighted:`<span class="hljs-keyword">import</span> torch | |
| <span class="hljs-keyword">from</span> diffusers <span class="hljs-keyword">import</span> Kandinsky5T2VPipeline | |
| <span class="hljs-keyword">from</span> diffusers.utils <span class="hljs-keyword">import</span> export_to_video | |
| <span class="hljs-comment"># Load the pipeline</span> | |
| model_id = <span class="hljs-string">"ai-forever/Kandinsky-5.0-T2V-Lite-sft-5s-Diffusers"</span> | |
| pipe = Kandinsky5T2VPipeline.from_pretrained(model_id, torch_dtype=torch.bfloat16) | |
| pipe = pipe.to(<span class="hljs-string">"cuda"</span>) | |
| <span class="hljs-comment"># Generate video</span> | |
| prompt = <span class="hljs-string">"A cat and a dog baking a cake together in a kitchen."</span> | |
| negative_prompt = <span class="hljs-string">"Static, 2D cartoon, cartoon, 2d animation, paintings, images, worst quality, low quality, ugly, deformed, walking backwards"</span> | |
| output = pipe( | |
| prompt=prompt, | |
| negative_prompt=negative_prompt, | |
| height=<span class="hljs-number">512</span>, | |
| width=<span class="hljs-number">768</span>, | |
| num_frames=<span class="hljs-number">121</span>, <span class="hljs-comment"># ~5 seconds at 24fps</span> | |
| num_inference_steps=<span class="hljs-number">50</span>, | |
| guidance_scale=<span class="hljs-number">5.0</span>, | |
| ).frames[<span class="hljs-number">0</span>] | |
| export_to_video(output, <span class="hljs-string">"output.mp4"</span>, fps=<span class="hljs-number">24</span>, quality=<span class="hljs-number">9</span>)`,wrap:!1}}),te=new G({props:{title:"10 second Models",local:"10-second-models",headingTag:"h3"}}),ae=new Ce({props:{code:"cGlwZSUyMCUzRCUyMEthbmRpbnNreTVUMlZQaXBlbGluZS5mcm9tX3ByZXRyYWluZWQoJTBBJTIwJTIwJTIwJTIwJTIyYWktZm9yZXZlciUyRkthbmRpbnNreS01LjAtVDJWLUxpdGUtc2Z0LTEwcy1EaWZmdXNlcnMlMjIlMkMlMjAlMEElMjAlMjAlMjAlMjB0b3JjaF9kdHlwZSUzRHRvcmNoLmJmbG9hdDE2JTBBKSUwQXBpcGUlMjAlM0QlMjBwaXBlLnRvKCUyMmN1ZGElMjIpJTBBJTBBcGlwZS50cmFuc2Zvcm1lci5zZXRfYXR0ZW50aW9uX2JhY2tlbmQoJTBBJTIwJTIwJTIwJTIwJTIyZmxleCUyMiUwQSklMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjMlMjAlM0MtLS0lMjBTZXR0JTIwYXR0ZW50aW9uJTIwYmFrZW5kJTIwdG8lMjBGbGV4JTBBcGlwZS50cmFuc2Zvcm1lci5jb21waWxlKCUwQSUyMCUyMCUyMCUyMG1vZGUlM0QlMjJtYXgtYXV0b3R1bmUtbm8tY3VkYWdyYXBocyUyMiUyQyUyMCUwQSUyMCUyMCUyMCUyMGR5bmFtaWMlM0RUcnVlJTBBKSUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMyUyMCUzQy0tLSUyMENvbXBpbGUlMjB3aXRoJTIwbWF4LWF1dG90dW5lLW5vLWN1ZGFncmFwaHMlMEElMEFwcm9tcHQlMjAlM0QlMjAlMjJBJTIwY2F0JTIwYW5kJTIwYSUyMGRvZyUyMGJha2luZyUyMGElMjBjYWtlJTIwdG9nZXRoZXIlMjBpbiUyMGElMjBraXRjaGVuLiUyMiUwQW5lZ2F0aXZlX3Byb21wdCUyMCUzRCUyMCUyMlN0YXRpYyUyQyUyMDJEJTIwY2FydG9vbiUyQyUyMGNhcnRvb24lMkMlMjAyZCUyMGFuaW1hdGlvbiUyQyUyMHBhaW50aW5ncyUyQyUyMGltYWdlcyUyQyUyMHdvcnN0JTIwcXVhbGl0eSUyQyUyMGxvdyUyMHF1YWxpdHklMkMlMjB1Z2x5JTJDJTIwZGVmb3JtZWQlMkMlMjB3YWxraW5nJTIwYmFja3dhcmRzJTIyJTBBJTBBb3V0cHV0JTIwJTNEJTIwcGlwZSglMEElMjAlMjAlMjAlMjBwcm9tcHQlM0Rwcm9tcHQlMkMlMEElMjAlMjAlMjAlMjBuZWdhdGl2ZV9wcm9tcHQlM0RuZWdhdGl2ZV9wcm9tcHQlMkMlMEElMjAlMjAlMjAlMjBoZWlnaHQlM0Q1MTIlMkMlMEElMjAlMjAlMjAlMjB3aWR0aCUzRDc2OCUyQyUwQSUyMCUyMCUyMCUyMG51bV9mcmFtZXMlM0QyNDElMkMlMEElMjAlMjAlMjAlMjBudW1faW5mZXJlbmNlX3N0ZXBzJTNENTAlMkMlMEElMjAlMjAlMjAlMjBndWlkYW5jZV9zY2FsZSUzRDUuMCUyQyUwQSkuZnJhbWVzJTVCMCU1RCUwQSUwQWV4cG9ydF90b192aWRlbyhvdXRwdXQlMkMlMjAlMjJvdXRwdXQubXA0JTIyJTJDJTIwZnBzJTNEMjQlMkMlMjBxdWFsaXR5JTNEOSk=",highlighted:`pipe = Kandinsky5T2VPipeline.from_pretrained( | |
| <span class="hljs-string">"ai-forever/Kandinsky-5.0-T2V-Lite-sft-10s-Diffusers"</span>, | |
| torch_dtype=torch.bfloat16 | |
| ) | |
| pipe = pipe.to(<span class="hljs-string">"cuda"</span>) | |
| pipe.transformer.set_attention_backend( | |
| <span class="hljs-string">"flex"</span> | |
| ) <span class="hljs-comment"># <--- Sett attention bakend to Flex</span> | |
| pipe.transformer.<span class="hljs-built_in">compile</span>( | |
| mode=<span class="hljs-string">"max-autotune-no-cudagraphs"</span>, | |
| dynamic=<span class="hljs-literal">True</span> | |
| ) <span class="hljs-comment"># <--- Compile with max-autotune-no-cudagraphs</span> | |
| prompt = <span class="hljs-string">"A cat and a dog baking a cake together in a kitchen."</span> | |
| negative_prompt = <span class="hljs-string">"Static, 2D cartoon, cartoon, 2d animation, paintings, images, worst quality, low quality, ugly, deformed, walking backwards"</span> | |
| output = pipe( | |
| prompt=prompt, | |
| negative_prompt=negative_prompt, | |
| height=<span class="hljs-number">512</span>, | |
| width=<span class="hljs-number">768</span>, | |
| num_frames=<span class="hljs-number">241</span>, | |
| num_inference_steps=<span class="hljs-number">50</span>, | |
| guidance_scale=<span class="hljs-number">5.0</span>, | |
| ).frames[<span class="hljs-number">0</span>] | |
| export_to_video(output, <span class="hljs-string">"output.mp4"</span>, fps=<span class="hljs-number">24</span>, quality=<span class="hljs-number">9</span>)`,wrap:!1}}),ie=new G({props:{title:"Diffusion Distilled model",local:"diffusion-distilled-model",headingTag:"h3"}}),oe=new Ce({props:{code:"bW9kZWxfaWQlMjAlM0QlMjAlMjJhaS1mb3JldmVyJTJGS2FuZGluc2t5LTUuMC1UMlYtTGl0ZS1kaXN0aWxsZWQxNnN0ZXBzLTVzLURpZmZ1c2VycyUyMiUwQXBpcGUlMjAlM0QlMjBLYW5kaW5za3k1VDJWUGlwZWxpbmUuZnJvbV9wcmV0cmFpbmVkKG1vZGVsX2lkJTJDJTIwdG9yY2hfZHR5cGUlM0R0b3JjaC5iZmxvYXQxNiklMEFwaXBlJTIwJTNEJTIwcGlwZS50byglMjJjdWRhJTIyKSUwQSUwQW91dHB1dCUyMCUzRCUyMHBpcGUoJTBBJTIwJTIwJTIwJTIwcHJvbXB0JTNEJTIyQSUyMGJlYXV0aWZ1bCUyMHN1bnNldCUyMG92ZXIlMjBtb3VudGFpbnMlMjIlMkMlMEElMjAlMjAlMjAlMjBudW1faW5mZXJlbmNlX3N0ZXBzJTNEMTYlMkMlMjAlMjAlMjMlMjAlM0MtLS0lMjBNb2RlbCUyMGlzJTIwZGlzdGlsbGVkJTIwaW4lMjAxNiUyMHN0ZXBzJTBBJTIwJTIwJTIwJTIwZ3VpZGFuY2Vfc2NhbGUlM0QxLjAlMkMlMjAlMjAlMjAlMjAlMjAlMjAlMjMlMjAlM0MtLS0lMjBubyUyMENGRyUwQSkuZnJhbWVzJTVCMCU1RCUwQSUwQWV4cG9ydF90b192aWRlbyhvdXRwdXQlMkMlMjAlMjJvdXRwdXQubXA0JTIyJTJDJTIwZnBzJTNEMjQlMkMlMjBxdWFsaXR5JTNEOSk=",highlighted:`model_id = <span class="hljs-string">"ai-forever/Kandinsky-5.0-T2V-Lite-distilled16steps-5s-Diffusers"</span> | |
| pipe = Kandinsky5T2VPipeline.from_pretrained(model_id, torch_dtype=torch.bfloat16) | |
| pipe = pipe.to(<span class="hljs-string">"cuda"</span>) | |
| output = pipe( | |
| prompt=<span class="hljs-string">"A beautiful sunset over mountains"</span>, | |
| num_inference_steps=<span class="hljs-number">16</span>, <span class="hljs-comment"># <--- Model is distilled in 16 steps</span> | |
| guidance_scale=<span class="hljs-number">1.0</span>, <span class="hljs-comment"># <--- no CFG</span> | |
| ).frames[<span class="hljs-number">0</span>] | |
| export_to_video(output, <span class="hljs-string">"output.mp4"</span>, fps=<span class="hljs-number">24</span>, quality=<span class="hljs-number">9</span>)`,wrap:!1}}),re=new G({props:{title:"Citation",local:"citation",headingTag:"h2"}}),pe=new Ce({props:{code:"JTQwbWlzYyU3QmthbmRpbnNreTIwMjUlMkMlMEElMjAlMjAlMjAlMjBhdXRob3IlMjAlM0QlMjAlN0JBbGV4ZXklMjBMZXR1bm92c2tpeSUyMGFuZCUyME1hcmlhJTIwS292YWxldmElMjBhbmQlMjBJdmFuJTIwS2lyaWxsb3YlMjBhbmQlMjBMZXYlMjBOb3ZpdHNraXklMjBhbmQlMjBEZW5pcyUyMEtvcG9zb3YlMjBhbmQlMEElMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjBEbWl0cmlpJTIwTWlraGFpbG92JTIwYW5kJTIwQW5uYSUyMEF2ZXJjaGVua292YSUyMGFuZCUyMEFuZHJleSUyMFNodXRraW4lMjBhbmQlMjBKdWxpYSUyMEFnYWZvbm92YSUyMGFuZCUyME9sZ2ElMjBLaW0lMjBhbmQlMEElMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjBBbmFzdGFzaWlhJTIwS2FyZ2Fwb2x0c2V2YSUyMGFuZCUyME5pa2l0YSUyMEtpc2VsZXYlMjBhbmQlMjBWbGFkaW1pciUyMEFya2hpcGtpbiUyMGFuZCUyMFZsYWRpbWlyJTIwS29ydmlha292JTIwYW5kJTBBJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwTmlrb2xhaSUyMEdlcmFzaW1lbmtvJTIwYW5kJTIwRGVuaXMlMjBQYXJraG9tZW5rbyUyMGFuZCUyMEFubmElMjBEbWl0cmllbmtvJTIwYW5kJTIwQW5hc3Rhc2lhJTIwTWFsdHNldmElMjBhbmQlMEElMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjBLaXJpbGwlMjBDaGVybnlzaGV2JTIwYW5kJTIwSWxpYSUyMFZhc2lsaWV2JTIwYW5kJTIwVmlhY2hlc2xhdiUyMFZhc2lsZXYlMjBhbmQlMjBWbGFkaW1pciUyMFBvbG92bmlrb3YlMjBhbmQlMEElMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjBZdXJ5JTIwS29sYWJ1c2hpbiUyMGFuZCUyMEFsZXhhbmRlciUyMEJlbHlraCUyMGFuZCUyME1pa2hhaWwlMjBNYW1hZXYlMjBhbmQlMjBBbmFzdGFzaWElMjBBbGlhc2tpbmElMjBhbmQlMEElMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjBUYXRpYW5hJTIwTmlrdWxpbmElMjBhbmQlMjBQb2xpbmElMjBHYXZyaWxvdmElMjBhbmQlMjBEZW5pcyUyMERpbWl0cm92JTdEJTJDJTBBJTIwJTIwJTIwJTIwdGl0bGUlMjAlM0QlMjAlN0JLYW5kaW5za3klMjA1LjAlM0ElMjBBJTIwZmFtaWx5JTIwb2YlMjBkaWZmdXNpb24lMjBtb2RlbHMlMjBmb3IlMjBWaWRlbyUyMCUyNiUyMEltYWdlJTIwZ2VuZXJhdGlvbiU3RCUyQyUwQSUyMCUyMCUyMCUyMGhvd3B1Ymxpc2hlZCUyMCUzRCUyMCU3QiU1Q3VybCU3Qmh0dHBzJTNBJTJGJTJGZ2l0aHViLmNvbSUyRmFpLWZvcmV2ZXIlMkZLYW5kaW5za3ktNSU3RCU3RCUyQyUwQSUyMCUyMCUyMCUyMHllYXIlMjAlM0QlMjAyMDI1JTBBJTdE",highlighted:`<span class="hljs-comment">@misc{kandinsky2025,</span> | |
| author = {Alexey Letunovskiy <span class="hljs-keyword">and</span> Maria Kovaleva <span class="hljs-keyword">and</span> Ivan Kirillov <span class="hljs-keyword">and</span> Lev Novitskiy <span class="hljs-keyword">and</span> Denis Koposov <span class="hljs-keyword">and</span> | |
| Dmitrii Mikhailov <span class="hljs-keyword">and</span> Anna Averchenkova <span class="hljs-keyword">and</span> Andrey Shutkin <span class="hljs-keyword">and</span> Julia Agafonova <span class="hljs-keyword">and</span> Olga Kim <span class="hljs-keyword">and</span> | |
| Anastasiia Kargapoltseva <span class="hljs-keyword">and</span> Nikita Kiselev <span class="hljs-keyword">and</span> Vladimir Arkhipkin <span class="hljs-keyword">and</span> Vladimir Korviakov <span class="hljs-keyword">and</span> | |
| Nikolai Gerasimenko <span class="hljs-keyword">and</span> Denis Parkhomenko <span class="hljs-keyword">and</span> Anna Dmitrienko <span class="hljs-keyword">and</span> Anastasia Maltseva <span class="hljs-keyword">and</span> | |
| Kirill Chernyshev <span class="hljs-keyword">and</span> Ilia Vasiliev <span class="hljs-keyword">and</span> Viacheslav Vasilev <span class="hljs-keyword">and</span> Vladimir Polovnikov <span class="hljs-keyword">and</span> | |
| Yury Kolabushin <span class="hljs-keyword">and</span> Alexander Belykh <span class="hljs-keyword">and</span> Mikhail Mamaev <span class="hljs-keyword">and</span> Anastasia Aliaskina <span class="hljs-keyword">and</span> | |
| Tatiana Nikulina <span class="hljs-keyword">and</span> Polina Gavrilova <span class="hljs-keyword">and</span> Denis Dimitrov}, | |
| title = {Kandinsky <span class="hljs-number">5</span>.<span class="hljs-number">0</span>: A family of diffusion models for Video & Image generation}, | |
| howpublished = {\\url{https:<span class="hljs-comment">//github.com/ai-forever/Kandinsky-5}},</span> | |
| year = <span class="hljs-number">2025</span> | |
| }`,wrap:!1}}),de=new tt({props:{source:"https://github.com/huggingface/diffusers/blob/main/docs/source/en/api/pipelines/kandinsky5_video.md"}}),{c(){_=o("meta"),I=s(),b=o("p"),j=s(),c(T.$$.fragment),g=s(),c(v.$$.fragment),Ze=s(),W=o("p"),W.textContent=wn,Be=s(),$=o("p"),$.textContent=Un,Ge=s(),Q=o("p"),Q.textContent=Jn,Ie=s(),E=o("ul"),E.innerHTML=xn,We=s(),K=o("p"),K.innerHTML=Vn,$e=s(),A=o("blockquote"),A.innerHTML=Cn,Qe=s(),c(P.$$.fragment),Ee=s(),L=o("p"),L.textContent=An,Ke=s(),N=o("table"),N.innerHTML=Zn,Pe=s(),X=o("p"),X.textContent=Bn,Le=s(),c(S.$$.fragment),Ne=s(),d=o("div"),c(D.$$.fragment),ln=s(),me=o("p"),me.textContent=Gn,on=s(),ue=o("p"),ue.innerHTML=In,rn=s(),k=o("div"),c(R.$$.fragment),pn=s(),Me=o("p"),Me.textContent=Wn,dn=s(),c(Z.$$.fragment),cn=s(),B=o("div"),c(Y.$$.fragment),mn=s(),ye=o("p"),ye.textContent=$n,un=s(),w=o("div"),c(F.$$.fragment),Mn=s(),fe=o("p"),fe.textContent=Qn,yn=s(),he=o("p"),he.textContent=En,fn=s(),U=o("div"),c(q.$$.fragment),hn=s(),ge=o("p"),ge.textContent=Kn,gn=s(),_e=o("p"),_e.textContent=Pn,_n=s(),J=o("div"),c(H.$$.fragment),jn=s(),je=o("p"),je.textContent=Ln,Tn=s(),Te=o("p"),Te.textContent=Nn,vn=s(),x=o("div"),c(z.$$.fragment),bn=s(),ve=o("p"),ve.textContent=Xn,kn=s(),be=o("p"),be.textContent=Sn,Xe=s(),c(O.$$.fragment),Se=s(),c(ee.$$.fragment),De=s(),c(ne.$$.fragment),Re=s(),c(te.$$.fragment),Ye=s(),se=o("p"),se.innerHTML=Dn,Fe=s(),c(ae.$$.fragment),qe=s(),c(ie.$$.fragment),He=s(),le=o("p"),le.innerHTML=Rn,ze=s(),c(oe.$$.fragment),Oe=s(),c(re.$$.fragment),en=s(),c(pe.$$.fragment),nn=s(),c(de.$$.fragment),tn=s(),Ve=o("p"),this.h()},l(e){const n=On("svelte-u9bgzb",document.head);_=r(n,"META",{name:!0,content:!0}),n.forEach(t),I=a(e),b=r(e,"P",{}),C(b).forEach(t),j=a(e),m(T.$$.fragment,e),g=a(e),m(v.$$.fragment,e),Ze=a(e),W=r(e,"P",{"data-svelte-h":!0}),p(W)!=="svelte-j56sfq"&&(W.textContent=wn),Be=a(e),$=r(e,"P",{"data-svelte-h":!0}),p($)!=="svelte-14nqts1"&&($.textContent=Un),Ge=a(e),Q=r(e,"P",{"data-svelte-h":!0}),p(Q)!=="svelte-cwew0b"&&(Q.textContent=Jn),Ie=a(e),E=r(e,"UL",{"data-svelte-h":!0}),p(E)!=="svelte-1vr585w"&&(E.innerHTML=xn),We=a(e),K=r(e,"P",{"data-svelte-h":!0}),p(K)!=="svelte-1dpa49j"&&(K.innerHTML=Vn),$e=a(e),A=r(e,"BLOCKQUOTE",{class:!0,"data-svelte-h":!0}),p(A)!=="svelte-kuoqxc"&&(A.innerHTML=Cn),Qe=a(e),m(P.$$.fragment,e),Ee=a(e),L=r(e,"P",{"data-svelte-h":!0}),p(L)!=="svelte-11l0uzw"&&(L.textContent=An),Ke=a(e),N=r(e,"TABLE",{"data-svelte-h":!0}),p(N)!=="svelte-1a5dsot"&&(N.innerHTML=Zn),Pe=a(e),X=r(e,"P",{"data-svelte-h":!0}),p(X)!=="svelte-1v681ke"&&(X.textContent=Bn),Le=a(e),m(S.$$.fragment,e),Ne=a(e),d=r(e,"DIV",{class:!0});var h=C(d);m(D.$$.fragment,h),ln=a(h),me=r(h,"P",{"data-svelte-h":!0}),p(me)!=="svelte-1hnedav"&&(me.textContent=Gn),on=a(h),ue=r(h,"P",{"data-svelte-h":!0}),p(ue)!=="svelte-1nyzdis"&&(ue.innerHTML=In),rn=a(h),k=r(h,"DIV",{class:!0});var ke=C(k);m(R.$$.fragment,ke),pn=a(ke),Me=r(ke,"P",{"data-svelte-h":!0}),p(Me)!=="svelte-50j04k"&&(Me.textContent=Wn),dn=a(ke),m(Z.$$.fragment,ke),ke.forEach(t),cn=a(h),B=r(h,"DIV",{class:!0});var an=C(B);m(Y.$$.fragment,an),mn=a(an),ye=r(an,"P",{"data-svelte-h":!0}),p(ye)!=="svelte-11b6rmu"&&(ye.textContent=$n),an.forEach(t),un=a(h),w=r(h,"DIV",{class:!0});var we=C(w);m(F.$$.fragment,we),Mn=a(we),fe=r(we,"P",{"data-svelte-h":!0}),p(fe)!=="svelte-1vxta4j"&&(fe.textContent=Qn),yn=a(we),he=r(we,"P",{"data-svelte-h":!0}),p(he)!=="svelte-1jhtoxo"&&(he.textContent=En),we.forEach(t),fn=a(h),U=r(h,"DIV",{class:!0});var Ue=C(U);m(q.$$.fragment,Ue),hn=a(Ue),ge=r(Ue,"P",{"data-svelte-h":!0}),p(ge)!=="svelte-prp4gp"&&(ge.textContent=Kn),gn=a(Ue),_e=r(Ue,"P",{"data-svelte-h":!0}),p(_e)!=="svelte-1i366n7"&&(_e.textContent=Pn),Ue.forEach(t),_n=a(h),J=r(h,"DIV",{class:!0});var Je=C(J);m(H.$$.fragment,Je),jn=a(Je),je=r(Je,"P",{"data-svelte-h":!0}),p(je)!=="svelte-11b03ij"&&(je.textContent=Ln),Tn=a(Je),Te=r(Je,"P",{"data-svelte-h":!0}),p(Te)!=="svelte-1q4t3h1"&&(Te.textContent=Nn),Je.forEach(t),vn=a(h),x=r(h,"DIV",{class:!0});var xe=C(x);m(z.$$.fragment,xe),bn=a(xe),ve=r(xe,"P",{"data-svelte-h":!0}),p(ve)!=="svelte-1auko1i"&&(ve.textContent=Xn),kn=a(xe),be=r(xe,"P",{"data-svelte-h":!0}),p(be)!=="svelte-1bvour2"&&(be.textContent=Sn),xe.forEach(t),h.forEach(t),Xe=a(e),m(O.$$.fragment,e),Se=a(e),m(ee.$$.fragment,e),De=a(e),m(ne.$$.fragment,e),Re=a(e),m(te.$$.fragment,e),Ye=a(e),se=r(e,"P",{"data-svelte-h":!0}),p(se)!=="svelte-1kr0lxg"&&(se.innerHTML=Dn),Fe=a(e),m(ae.$$.fragment,e),qe=a(e),m(ie.$$.fragment,e),He=a(e),le=r(e,"P",{"data-svelte-h":!0}),p(le)!=="svelte-188xe6v"&&(le.innerHTML=Rn),ze=a(e),m(oe.$$.fragment,e),Oe=a(e),m(re.$$.fragment,e),en=a(e),m(pe.$$.fragment,e),nn=a(e),m(de.$$.fragment,e),tn=a(e),Ve=r(e,"P",{}),C(Ve).forEach(t),this.h()},h(){V(_,"name","hf:doc:metadata"),V(_,"content",it),V(A,"class","tip"),V(k,"class","docstring border-l-2 border-t-2 pl-4 pt-3.5 border-gray-100 rounded-tl-xl mb-6 mt-8"),V(B,"class","docstring border-l-2 border-t-2 pl-4 pt-3.5 border-gray-100 rounded-tl-xl mb-6 mt-8"),V(w,"class","docstring border-l-2 border-t-2 pl-4 pt-3.5 border-gray-100 rounded-tl-xl mb-6 mt-8"),V(U,"class","docstring border-l-2 border-t-2 pl-4 pt-3.5 border-gray-100 rounded-tl-xl mb-6 mt-8"),V(J,"class","docstring border-l-2 border-t-2 pl-4 pt-3.5 border-gray-100 rounded-tl-xl mb-6 mt-8"),V(x,"class","docstring border-l-2 border-t-2 pl-4 pt-3.5 border-gray-100 rounded-tl-xl mb-6 mt-8"),V(d,"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,n){l(document.head,_),i(e,I,n),i(e,b,n),i(e,j,n),u(T,e,n),i(e,g,n),u(v,e,n),i(e,Ze,n),i(e,W,n),i(e,Be,n),i(e,$,n),i(e,Ge,n),i(e,Q,n),i(e,Ie,n),i(e,E,n),i(e,We,n),i(e,K,n),i(e,$e,n),i(e,A,n),i(e,Qe,n),u(P,e,n),i(e,Ee,n),i(e,L,n),i(e,Ke,n),i(e,N,n),i(e,Pe,n),i(e,X,n),i(e,Le,n),u(S,e,n),i(e,Ne,n),i(e,d,n),u(D,d,null),l(d,ln),l(d,me),l(d,on),l(d,ue),l(d,rn),l(d,k),u(R,k,null),l(k,pn),l(k,Me),l(k,dn),u(Z,k,null),l(d,cn),l(d,B),u(Y,B,null),l(B,mn),l(B,ye),l(d,un),l(d,w),u(F,w,null),l(w,Mn),l(w,fe),l(w,yn),l(w,he),l(d,fn),l(d,U),u(q,U,null),l(U,hn),l(U,ge),l(U,gn),l(U,_e),l(d,_n),l(d,J),u(H,J,null),l(J,jn),l(J,je),l(J,Tn),l(J,Te),l(d,vn),l(d,x),u(z,x,null),l(x,bn),l(x,ve),l(x,kn),l(x,be),i(e,Xe,n),u(O,e,n),i(e,Se,n),u(ee,e,n),i(e,De,n),u(ne,e,n),i(e,Re,n),u(te,e,n),i(e,Ye,n),i(e,se,n),i(e,Fe,n),u(ae,e,n),i(e,qe,n),u(ie,e,n),i(e,He,n),i(e,le,n),i(e,ze,n),u(oe,e,n),i(e,Oe,n),u(re,e,n),i(e,en,n),u(pe,e,n),i(e,nn,n),u(de,e,n),i(e,tn,n),i(e,Ve,n),sn=!0},p(e,[n]){const h={};n&2&&(h.$$scope={dirty:n,ctx:e}),Z.$set(h)},i(e){sn||(M(T.$$.fragment,e),M(v.$$.fragment,e),M(P.$$.fragment,e),M(S.$$.fragment,e),M(D.$$.fragment,e),M(R.$$.fragment,e),M(Z.$$.fragment,e),M(Y.$$.fragment,e),M(F.$$.fragment,e),M(q.$$.fragment,e),M(H.$$.fragment,e),M(z.$$.fragment,e),M(O.$$.fragment,e),M(ee.$$.fragment,e),M(ne.$$.fragment,e),M(te.$$.fragment,e),M(ae.$$.fragment,e),M(ie.$$.fragment,e),M(oe.$$.fragment,e),M(re.$$.fragment,e),M(pe.$$.fragment,e),M(de.$$.fragment,e),sn=!0)},o(e){y(T.$$.fragment,e),y(v.$$.fragment,e),y(P.$$.fragment,e),y(S.$$.fragment,e),y(D.$$.fragment,e),y(R.$$.fragment,e),y(Z.$$.fragment,e),y(Y.$$.fragment,e),y(F.$$.fragment,e),y(q.$$.fragment,e),y(H.$$.fragment,e),y(z.$$.fragment,e),y(O.$$.fragment,e),y(ee.$$.fragment,e),y(ne.$$.fragment,e),y(te.$$.fragment,e),y(ae.$$.fragment,e),y(ie.$$.fragment,e),y(oe.$$.fragment,e),y(re.$$.fragment,e),y(pe.$$.fragment,e),y(de.$$.fragment,e),sn=!1},d(e){e&&(t(I),t(b),t(j),t(g),t(Ze),t(W),t(Be),t($),t(Ge),t(Q),t(Ie),t(E),t(We),t(K),t($e),t(A),t(Qe),t(Ee),t(L),t(Ke),t(N),t(Pe),t(X),t(Le),t(Ne),t(d),t(Xe),t(Se),t(De),t(Re),t(Ye),t(se),t(Fe),t(qe),t(He),t(le),t(ze),t(Oe),t(en),t(nn),t(tn),t(Ve)),t(_),f(T,e),f(v,e),f(P,e),f(S,e),f(D),f(R),f(Z),f(Y),f(F),f(q),f(H),f(z),f(O,e),f(ee,e),f(ne,e),f(te,e),f(ae,e),f(ie,e),f(oe,e),f(re,e),f(pe,e),f(de,e)}}}const it='{"title":"Kandinsky 5.0 Video","local":"kandinsky-50-video","sections":[{"title":"Available Models","local":"available-models","sections":[],"depth":2},{"title":"Kandinsky5T2VPipeline","local":"diffusers.Kandinsky5T2VPipeline","sections":[],"depth":2},{"title":"Usage Examples","local":"usage-examples","sections":[{"title":"Basic Text-to-Video Generation","local":"basic-text-to-video-generation","sections":[],"depth":3},{"title":"10 second Models","local":"10-second-models","sections":[],"depth":3},{"title":"Diffusion Distilled model","local":"diffusion-distilled-model","sections":[],"depth":3}],"depth":2},{"title":"Citation","local":"citation","sections":[],"depth":2}],"depth":1}';function lt(Ae){return Fn(()=>{new URLSearchParams(window.location.search).get("fw")}),[]}class Mt extends Hn{constructor(_){super(),zn(this,_,lt,at,Yn,{})}}export{Mt as component}; | |
Xet Storage Details
- Size:
- 52.4 kB
- Xet hash:
- d836f8ba471e0cb53544d43e0f9a27a695b8b50a29f69a96db21c4ebcdb8fc91
·
Xet efficiently stores files, intelligently splitting them into unique chunks and accelerating uploads and downloads. More info.