Buckets:
| import{s as je,o as $e,n as ae}from"../chunks/scheduler.8c3d61f6.js";import{S as We,i as Ce,g as u,s as i,r as g,A as Be,h as f,f as l,c as r,j as P,u as x,x as w,k as D,y as p,a as c,v,d as T,t as _,w as U}from"../chunks/index.da70eac4.js";import{T as Ge}from"../chunks/Tip.1d9b8c37.js";import{D as le}from"../chunks/Docstring.6b390b9a.js";import{C as xe}from"../chunks/CodeBlock.00a903b3.js";import{E as ge}from"../chunks/ExampleCodeBlock.db12be95.js";import{H as Ie,E as Xe}from"../chunks/EditOnGithub.1e64e623.js";function Re(Z){let n,h='To learn more about how to load Textual Inversion embeddings, see the <a href="../../using-diffusers/loading_adapters#textual-inversion">Textual Inversion</a> loading guide.';return{c(){n=u("p"),n.innerHTML=h},l(a){n=f(a,"P",{"data-svelte-h":!0}),w(n)!=="svelte-1n8qarv"&&(n.innerHTML=h)},m(a,o){c(a,n,o)},p:ae,d(a){a&&l(n)}}}function ze(Z){let n,h="To load a Textual Inversion embedding vector in 🤗 Diffusers format:",a,o,d;return o=new xe({props:{code:"ZnJvbSUyMGRpZmZ1c2VycyUyMGltcG9ydCUyMFN0YWJsZURpZmZ1c2lvblBpcGVsaW5lJTBBaW1wb3J0JTIwdG9yY2glMEElMEFtb2RlbF9pZCUyMCUzRCUyMCUyMnJ1bndheW1sJTJGc3RhYmxlLWRpZmZ1c2lvbi12MS01JTIyJTBBcGlwZSUyMCUzRCUyMFN0YWJsZURpZmZ1c2lvblBpcGVsaW5lLmZyb21fcHJldHJhaW5lZChtb2RlbF9pZCUyQyUyMHRvcmNoX2R0eXBlJTNEdG9yY2guZmxvYXQxNikudG8oJTIyY3VkYSUyMiklMEElMEFwaXBlLmxvYWRfdGV4dHVhbF9pbnZlcnNpb24oJTIyc2QtY29uY2VwdHMtbGlicmFyeSUyRmNhdC10b3klMjIpJTBBJTBBcHJvbXB0JTIwJTNEJTIwJTIyQSUyMCUzQ2NhdC10b3klM0UlMjBiYWNrcGFjayUyMiUwQSUwQWltYWdlJTIwJTNEJTIwcGlwZShwcm9tcHQlMkMlMjBudW1faW5mZXJlbmNlX3N0ZXBzJTNENTApLmltYWdlcyU1QjAlNUQlMEFpbWFnZS5zYXZlKCUyMmNhdC1iYWNrcGFjay5wbmclMjIp",highlighted:`<span class="hljs-keyword">from</span> diffusers <span class="hljs-keyword">import</span> StableDiffusionPipeline | |
| <span class="hljs-keyword">import</span> torch | |
| model_id = <span class="hljs-string">"runwayml/stable-diffusion-v1-5"</span> | |
| pipe = StableDiffusionPipeline.from_pretrained(model_id, torch_dtype=torch.float16).to(<span class="hljs-string">"cuda"</span>) | |
| pipe.load_textual_inversion(<span class="hljs-string">"sd-concepts-library/cat-toy"</span>) | |
| prompt = <span class="hljs-string">"A <cat-toy> backpack"</span> | |
| image = pipe(prompt, num_inference_steps=<span class="hljs-number">50</span>).images[<span class="hljs-number">0</span>] | |
| image.save(<span class="hljs-string">"cat-backpack.png"</span>)`,wrap:!1}}),{c(){n=u("p"),n.textContent=h,a=i(),g(o.$$.fragment)},l(t){n=f(t,"P",{"data-svelte-h":!0}),w(n)!=="svelte-1gc783q"&&(n.textContent=h),a=r(t),x(o.$$.fragment,t)},m(t,m){c(t,n,m),c(t,a,m),v(o,t,m),d=!0},p:ae,i(t){d||(T(o.$$.fragment,t),d=!0)},o(t){_(o.$$.fragment,t),d=!1},d(t){t&&(l(n),l(a)),U(o,t)}}}function Ee(Z){let n,h="locally:",a,o,d;return o=new xe({props:{code:"ZnJvbSUyMGRpZmZ1c2VycyUyMGltcG9ydCUyMFN0YWJsZURpZmZ1c2lvblBpcGVsaW5lJTBBaW1wb3J0JTIwdG9yY2glMEElMEFtb2RlbF9pZCUyMCUzRCUyMCUyMnJ1bndheW1sJTJGc3RhYmxlLWRpZmZ1c2lvbi12MS01JTIyJTBBcGlwZSUyMCUzRCUyMFN0YWJsZURpZmZ1c2lvblBpcGVsaW5lLmZyb21fcHJldHJhaW5lZChtb2RlbF9pZCUyQyUyMHRvcmNoX2R0eXBlJTNEdG9yY2guZmxvYXQxNikudG8oJTIyY3VkYSUyMiklMEElMEFwaXBlLmxvYWRfdGV4dHVhbF9pbnZlcnNpb24oJTIyLiUyRmNoYXJ0dXJuZXJ2Mi5wdCUyMiUyQyUyMHRva2VuJTNEJTIyY2hhcnR1cm5lcnYyJTIyKSUwQSUwQXByb21wdCUyMCUzRCUyMCUyMmNoYXJ0dXJuZXJ2MiUyQyUyMG11bHRpcGxlJTIwdmlld3MlMjBvZiUyMHRoZSUyMHNhbWUlMjBjaGFyYWN0ZXIlMjBpbiUyMHRoZSUyMHNhbWUlMjBvdXRmaXQlMkMlMjBhJTIwY2hhcmFjdGVyJTIwdHVybmFyb3VuZCUyMG9mJTIwYSUyMHdvbWFuJTIwd2VhcmluZyUyMGElMjBibGFjayUyMGphY2tldCUyMGFuZCUyMHJlZCUyMHNoaXJ0JTJDJTIwYmVzdCUyMHF1YWxpdHklMkMlMjBpbnRyaWNhdGUlMjBkZXRhaWxzLiUyMiUwQSUwQWltYWdlJTIwJTNEJTIwcGlwZShwcm9tcHQlMkMlMjBudW1faW5mZXJlbmNlX3N0ZXBzJTNENTApLmltYWdlcyU1QjAlNUQlMEFpbWFnZS5zYXZlKCUyMmNoYXJhY3Rlci5wbmclMjIp",highlighted:`<span class="hljs-keyword">from</span> diffusers <span class="hljs-keyword">import</span> StableDiffusionPipeline | |
| <span class="hljs-keyword">import</span> torch | |
| model_id = <span class="hljs-string">"runwayml/stable-diffusion-v1-5"</span> | |
| pipe = StableDiffusionPipeline.from_pretrained(model_id, torch_dtype=torch.float16).to(<span class="hljs-string">"cuda"</span>) | |
| pipe.load_textual_inversion(<span class="hljs-string">"./charturnerv2.pt"</span>, token=<span class="hljs-string">"charturnerv2"</span>) | |
| prompt = <span class="hljs-string">"charturnerv2, multiple views of the same character in the same outfit, a character turnaround of a woman wearing a black jacket and red shirt, best quality, intricate details."</span> | |
| image = pipe(prompt, num_inference_steps=<span class="hljs-number">50</span>).images[<span class="hljs-number">0</span>] | |
| image.save(<span class="hljs-string">"character.png"</span>)`,wrap:!1}}),{c(){n=u("p"),n.textContent=h,a=i(),g(o.$$.fragment)},l(t){n=f(t,"P",{"data-svelte-h":!0}),w(n)!=="svelte-4c75kq"&&(n.textContent=h),a=r(t),x(o.$$.fragment,t)},m(t,m){c(t,n,m),c(t,a,m),v(o,t,m),d=!0},p:ae,i(t){d||(T(o.$$.fragment,t),d=!0)},o(t){_(o.$$.fragment,t),d=!1},d(t){t&&(l(n),l(a)),U(o,t)}}}function Le(Z){let n,h="Example:",a,o,d;return o=new xe({props:{code:"ZnJvbSUyMGRpZmZ1c2VycyUyMGltcG9ydCUyMEF1dG9QaXBlbGluZUZvclRleHQySW1hZ2UlMEFpbXBvcnQlMjB0b3JjaCUwQSUwQXBpcGVsaW5lJTIwJTNEJTIwQXV0b1BpcGVsaW5lRm9yVGV4dDJJbWFnZS5mcm9tX3ByZXRyYWluZWQoJTIycnVud2F5bWwlMkZzdGFibGUtZGlmZnVzaW9uLXYxLTUlMjIpJTBBJTBBJTIzJTIwRXhhbXBsZSUyMDElMEFwaXBlbGluZS5sb2FkX3RleHR1YWxfaW52ZXJzaW9uKCUyMnNkLWNvbmNlcHRzLWxpYnJhcnklMkZndGE1LWFydHdvcmslMjIpJTBBcGlwZWxpbmUubG9hZF90ZXh0dWFsX2ludmVyc2lvbiglMjJzZC1jb25jZXB0cy1saWJyYXJ5JTJGbW9lYi1zdHlsZSUyMiklMEElMEElMjMlMjBSZW1vdmUlMjBhbGwlMjB0b2tlbiUyMGVtYmVkZGluZ3MlMEFwaXBlbGluZS51bmxvYWRfdGV4dHVhbF9pbnZlcnNpb24oKSUwQSUwQSUyMyUyMEV4YW1wbGUlMjAyJTBBcGlwZWxpbmUubG9hZF90ZXh0dWFsX2ludmVyc2lvbiglMjJzZC1jb25jZXB0cy1saWJyYXJ5JTJGbW9lYi1zdHlsZSUyMiklMEFwaXBlbGluZS5sb2FkX3RleHR1YWxfaW52ZXJzaW9uKCUyMnNkLWNvbmNlcHRzLWxpYnJhcnklMkZndGE1LWFydHdvcmslMjIpJTBBJTBBJTIzJTIwUmVtb3ZlJTIwanVzdCUyMG9uZSUyMHRva2VuJTBBcGlwZWxpbmUudW5sb2FkX3RleHR1YWxfaW52ZXJzaW9uKCUyMiUzQ21vZS1iaXVzJTNFJTIyKSUwQSUwQSUyMyUyMEV4YW1wbGUlMjAzJTNBJTIwdW5sb2FkJTIwZnJvbSUyMFNEWEwlMEFwaXBlbGluZSUyMCUzRCUyMEF1dG9QaXBlbGluZUZvclRleHQySW1hZ2UuZnJvbV9wcmV0cmFpbmVkKCUyMnN0YWJpbGl0eWFpJTJGc3RhYmxlLWRpZmZ1c2lvbi14bC1iYXNlLTEuMCUyMiklMEFlbWJlZGRpbmdfcGF0aCUyMCUzRCUyMGhmX2h1Yl9kb3dubG9hZCglMEElMjAlMjAlMjAlMjByZXBvX2lkJTNEJTIybGlub3l0cyUyRndlYl95MmslMjIlMkMlMjBmaWxlbmFtZSUzRCUyMndlYl95MmtfZW1iLnNhZmV0ZW5zb3JzJTIyJTJDJTIwcmVwb190eXBlJTNEJTIybW9kZWwlMjIlMEEpJTBBJTBBJTIzJTIwbG9hZCUyMGVtYmVkZGluZ3MlMjB0byUyMHRoZSUyMHRleHQlMjBlbmNvZGVycyUwQXN0YXRlX2RpY3QlMjAlM0QlMjBsb2FkX2ZpbGUoZW1iZWRkaW5nX3BhdGgpJTBBJTBBJTIzJTIwbG9hZCUyMGVtYmVkZGluZ3MlMjBvZiUyMHRleHRfZW5jb2RlciUyMDElMjAoQ0xJUCUyMFZpVC1MJTJGMTQpJTBBcGlwZWxpbmUubG9hZF90ZXh0dWFsX2ludmVyc2lvbiglMEElMjAlMjAlMjAlMjBzdGF0ZV9kaWN0JTVCJTIyY2xpcF9sJTIyJTVEJTJDJTBBJTIwJTIwJTIwJTIwdG9rZW5zJTNEJTVCJTIyJTNDczAlM0UlMjIlMkMlMjAlMjIlM0NzMSUzRSUyMiU1RCUyQyUwQSUyMCUyMCUyMCUyMHRleHRfZW5jb2RlciUzRHBpcGVsaW5lLnRleHRfZW5jb2RlciUyQyUwQSUyMCUyMCUyMCUyMHRva2VuaXplciUzRHBpcGVsaW5lLnRva2VuaXplciUyQyUwQSklMEElMjMlMjBsb2FkJTIwZW1iZWRkaW5ncyUyMG9mJTIwdGV4dF9lbmNvZGVyJTIwMiUyMChDTElQJTIwVmlULUclMkYxNCklMEFwaXBlbGluZS5sb2FkX3RleHR1YWxfaW52ZXJzaW9uKCUwQSUyMCUyMCUyMCUyMHN0YXRlX2RpY3QlNUIlMjJjbGlwX2clMjIlNUQlMkMlMEElMjAlMjAlMjAlMjB0b2tlbnMlM0QlNUIlMjIlM0NzMCUzRSUyMiUyQyUyMCUyMiUzQ3MxJTNFJTIyJTVEJTJDJTBBJTIwJTIwJTIwJTIwdGV4dF9lbmNvZGVyJTNEcGlwZWxpbmUudGV4dF9lbmNvZGVyXzIlMkMlMEElMjAlMjAlMjAlMjB0b2tlbml6ZXIlM0RwaXBlbGluZS50b2tlbml6ZXJfMiUyQyUwQSklMEElMEElMjMlMjBVbmxvYWQlMjBleHBsaWNpdGx5JTIwZnJvbSUyMGJvdGglMjB0ZXh0JTIwZW5jb2RlcnMlMjBhbmQlMjB0b2tlbml6ZXJzJTBBcGlwZWxpbmUudW5sb2FkX3RleHR1YWxfaW52ZXJzaW9uKCUwQSUyMCUyMCUyMCUyMHRva2VucyUzRCU1QiUyMiUzQ3MwJTNFJTIyJTJDJTIwJTIyJTNDczElM0UlMjIlNUQlMkMlMjB0ZXh0X2VuY29kZXIlM0RwaXBlbGluZS50ZXh0X2VuY29kZXIlMkMlMjB0b2tlbml6ZXIlM0RwaXBlbGluZS50b2tlbml6ZXIlMEEpJTBBcGlwZWxpbmUudW5sb2FkX3RleHR1YWxfaW52ZXJzaW9uKCUwQSUyMCUyMCUyMCUyMHRva2VucyUzRCU1QiUyMiUzQ3MwJTNFJTIyJTJDJTIwJTIyJTNDczElM0UlMjIlNUQlMkMlMjB0ZXh0X2VuY29kZXIlM0RwaXBlbGluZS50ZXh0X2VuY29kZXJfMiUyQyUyMHRva2VuaXplciUzRHBpcGVsaW5lLnRva2VuaXplcl8yJTBBKQ==",highlighted:`<span class="hljs-keyword">from</span> diffusers <span class="hljs-keyword">import</span> AutoPipelineForText2Image | |
| <span class="hljs-keyword">import</span> torch | |
| pipeline = AutoPipelineForText2Image.from_pretrained(<span class="hljs-string">"runwayml/stable-diffusion-v1-5"</span>) | |
| <span class="hljs-comment"># Example 1</span> | |
| pipeline.load_textual_inversion(<span class="hljs-string">"sd-concepts-library/gta5-artwork"</span>) | |
| pipeline.load_textual_inversion(<span class="hljs-string">"sd-concepts-library/moeb-style"</span>) | |
| <span class="hljs-comment"># Remove all token embeddings</span> | |
| pipeline.unload_textual_inversion() | |
| <span class="hljs-comment"># Example 2</span> | |
| pipeline.load_textual_inversion(<span class="hljs-string">"sd-concepts-library/moeb-style"</span>) | |
| pipeline.load_textual_inversion(<span class="hljs-string">"sd-concepts-library/gta5-artwork"</span>) | |
| <span class="hljs-comment"># Remove just one token</span> | |
| pipeline.unload_textual_inversion(<span class="hljs-string">"<moe-bius>"</span>) | |
| <span class="hljs-comment"># Example 3: unload from SDXL</span> | |
| pipeline = AutoPipelineForText2Image.from_pretrained(<span class="hljs-string">"stabilityai/stable-diffusion-xl-base-1.0"</span>) | |
| embedding_path = hf_hub_download( | |
| repo_id=<span class="hljs-string">"linoyts/web_y2k"</span>, filename=<span class="hljs-string">"web_y2k_emb.safetensors"</span>, repo_type=<span class="hljs-string">"model"</span> | |
| ) | |
| <span class="hljs-comment"># load embeddings to the text encoders</span> | |
| state_dict = load_file(embedding_path) | |
| <span class="hljs-comment"># load embeddings of text_encoder 1 (CLIP ViT-L/14)</span> | |
| pipeline.load_textual_inversion( | |
| state_dict[<span class="hljs-string">"clip_l"</span>], | |
| tokens=[<span class="hljs-string">"<s0>"</span>, <span class="hljs-string">"<s1>"</span>], | |
| text_encoder=pipeline.text_encoder, | |
| tokenizer=pipeline.tokenizer, | |
| ) | |
| <span class="hljs-comment"># load embeddings of text_encoder 2 (CLIP ViT-G/14)</span> | |
| pipeline.load_textual_inversion( | |
| state_dict[<span class="hljs-string">"clip_g"</span>], | |
| tokens=[<span class="hljs-string">"<s0>"</span>, <span class="hljs-string">"<s1>"</span>], | |
| text_encoder=pipeline.text_encoder_2, | |
| tokenizer=pipeline.tokenizer_2, | |
| ) | |
| <span class="hljs-comment"># Unload explicitly from both text encoders and tokenizers</span> | |
| pipeline.unload_textual_inversion( | |
| tokens=[<span class="hljs-string">"<s0>"</span>, <span class="hljs-string">"<s1>"</span>], text_encoder=pipeline.text_encoder, tokenizer=pipeline.tokenizer | |
| ) | |
| pipeline.unload_textual_inversion( | |
| tokens=[<span class="hljs-string">"<s0>"</span>, <span class="hljs-string">"<s1>"</span>], text_encoder=pipeline.text_encoder_2, tokenizer=pipeline.tokenizer_2 | |
| )`,wrap:!1}}),{c(){n=u("p"),n.textContent=h,a=i(),g(o.$$.fragment)},l(t){n=f(t,"P",{"data-svelte-h":!0}),w(n)!=="svelte-11lpom8"&&(n.textContent=h),a=r(t),x(o.$$.fragment,t)},m(t,m){c(t,n,m),c(t,a,m),v(o,t,m),d=!0},p:ae,i(t){d||(T(o.$$.fragment,t),d=!0)},o(t){_(o.$$.fragment,t),d=!1},d(t){t&&(l(n),l(a)),U(o,t)}}}function Ne(Z){let n,h,a,o,d,t,m,ve="Textual Inversion is a training method for personalizing models by learning new text embeddings from a few example images. The file produced from training is extremely small (a few KBs) and the new embeddings can be loaded into the text encoder.",K,G,Te="<code>TextualInversionLoaderMixin</code> provides a function for loading Textual Inversion embeddings from Diffusers and Automatic1111 into the text encoder and loading a special token to activate the embeddings.",O,j,ee,X,te,y,R,ie,V,_e="Load Textual Inversion tokens and embeddings to the tokenizer and text encoder.",re,M,z,de,Y,Ue=`Load Textual Inversion embeddings into the text encoder of <a href="/docs/diffusers/pr_10175/en/api/pipelines/stable_diffusion/text2img#diffusers.StableDiffusionPipeline">StableDiffusionPipeline</a> (both 🤗 Diffusers and | |
| Automatic1111 formats are supported).`,pe,q,Je="Example:",ce,$,me,H,we=`To load a Textual Inversion embedding vector in Automatic1111 format, make sure to download the vector first | |
| (for example from <a href="https://civitai.com/models/3036?modelVersionId=9857" rel="nofollow">civitAI</a>) and then load the vector`,ue,W,fe,C,E,he,S,Ze=`Processes prompts that include a special token corresponding to a multi-vector textual inversion embedding to | |
| be replaced with multiple special tokens each corresponding to one of the vectors. If the prompt has no textual | |
| inversion token or if the textual inversion token is a single vector, the input prompt is returned.`,Me,k,L,ye,Q,ke='Unload Textual Inversion embeddings from the text encoder of <a href="/docs/diffusers/pr_10175/en/api/pipelines/stable_diffusion/text2img#diffusers.StableDiffusionPipeline">StableDiffusionPipeline</a>',be,B,ne,N,oe,A,se;return d=new Ie({props:{title:"Textual Inversion",local:"textual-inversion",headingTag:"h1"}}),j=new Ge({props:{$$slots:{default:[Re]},$$scope:{ctx:Z}}}),X=new Ie({props:{title:"TextualInversionLoaderMixin",local:"diffusers.loaders.TextualInversionLoaderMixin",headingTag:"h2"}}),R=new le({props:{name:"class diffusers.loaders.TextualInversionLoaderMixin",anchor:"diffusers.loaders.TextualInversionLoaderMixin",parameters:[],source:"https://github.com/huggingface/diffusers/blob/vr_10175/src/diffusers/loaders/textual_inversion.py#L110"}}),z=new le({props:{name:"load_textual_inversion",anchor:"diffusers.loaders.TextualInversionLoaderMixin.load_textual_inversion",parameters:[{name:"pretrained_model_name_or_path",val:": typing.Union[str, typing.List[str], typing.Dict[str, torch.Tensor], typing.List[typing.Dict[str, torch.Tensor]]]"},{name:"token",val:": typing.Union[str, typing.List[str], NoneType] = None"},{name:"tokenizer",val:": typing.Optional[ForwardRef('PreTrainedTokenizer')] = None"},{name:"text_encoder",val:": typing.Optional[ForwardRef('PreTrainedModel')] = None"},{name:"**kwargs",val:""}],parametersDescription:[{anchor:"diffusers.loaders.TextualInversionLoaderMixin.load_textual_inversion.pretrained_model_name_or_path",description:`<strong>pretrained_model_name_or_path</strong> (<code>str</code> or <code>os.PathLike</code> or <code>List[str or os.PathLike]</code> or <code>Dict</code> or <code>List[Dict]</code>) — | |
| Can be either one of the following or a list of them:</p> | |
| <ul> | |
| <li>A string, the <em>model id</em> (for example <code>sd-concepts-library/low-poly-hd-logos-icons</code>) of a | |
| pretrained model hosted on the Hub.</li> | |
| <li>A path to a <em>directory</em> (for example <code>./my_text_inversion_directory/</code>) containing the textual | |
| inversion weights.</li> | |
| <li>A path to a <em>file</em> (for example <code>./my_text_inversions.pt</code>) containing textual inversion weights.</li> | |
| <li>A <a href="https://pytorch.org/tutorials/beginner/saving_loading_models.html#what-is-a-state-dict" rel="nofollow">torch state | |
| dict</a>.</li> | |
| </ul>`,name:"pretrained_model_name_or_path"},{anchor:"diffusers.loaders.TextualInversionLoaderMixin.load_textual_inversion.token",description:`<strong>token</strong> (<code>str</code> or <code>List[str]</code>, <em>optional</em>) — | |
| Override the token to use for the textual inversion weights. If <code>pretrained_model_name_or_path</code> is a | |
| list, then <code>token</code> must also be a list of equal length.`,name:"token"},{anchor:"diffusers.loaders.TextualInversionLoaderMixin.load_textual_inversion.text_encoder",description:`<strong>text_encoder</strong> (<a href="https://huggingface.co/docs/transformers/main/en/model_doc/clip#transformers.CLIPTextModel" rel="nofollow">CLIPTextModel</a>, <em>optional</em>) — | |
| Frozen text-encoder (<a href="https://huggingface.co/openai/clip-vit-large-patch14" rel="nofollow">clip-vit-large-patch14</a>). | |
| If not specified, function will take self.tokenizer.`,name:"text_encoder"},{anchor:"diffusers.loaders.TextualInversionLoaderMixin.load_textual_inversion.tokenizer",description:`<strong>tokenizer</strong> (<a href="https://huggingface.co/docs/transformers/main/en/model_doc/clip#transformers.CLIPTokenizer" rel="nofollow">CLIPTokenizer</a>, <em>optional</em>) — | |
| A <code>CLIPTokenizer</code> to tokenize text. If not specified, function will take self.tokenizer.`,name:"tokenizer"},{anchor:"diffusers.loaders.TextualInversionLoaderMixin.load_textual_inversion.weight_name",description:`<strong>weight_name</strong> (<code>str</code>, <em>optional</em>) — | |
| Name of a custom weight file. This should be used when:</p> | |
| <ul> | |
| <li>The saved textual inversion file is in 🤗 Diffusers format, but was saved under a specific weight | |
| name such as <code>text_inv.bin</code>.</li> | |
| <li>The saved textual inversion file is in the Automatic1111 format.</li> | |
| </ul>`,name:"weight_name"},{anchor:"diffusers.loaders.TextualInversionLoaderMixin.load_textual_inversion.cache_dir",description:`<strong>cache_dir</strong> (<code>Union[str, os.PathLike]</code>, <em>optional</em>) — | |
| Path to a directory where a downloaded pretrained model configuration is cached if the standard cache | |
| is not used.`,name:"cache_dir"},{anchor:"diffusers.loaders.TextualInversionLoaderMixin.load_textual_inversion.force_download",description:`<strong>force_download</strong> (<code>bool</code>, <em>optional</em>, defaults to <code>False</code>) — | |
| Whether or not to force the (re-)download of the model weights and configuration files, overriding the | |
| cached versions if they exist.`,name:"force_download"},{anchor:"diffusers.loaders.TextualInversionLoaderMixin.load_textual_inversion.proxies",description:`<strong>proxies</strong> (<code>Dict[str, str]</code>, <em>optional</em>) — | |
| A dictionary of proxy servers to use by protocol or endpoint, for example, <code>{'http': 'foo.bar:3128', 'http://hostname': 'foo.bar:4012'}</code>. The proxies are used on each request.`,name:"proxies"},{anchor:"diffusers.loaders.TextualInversionLoaderMixin.load_textual_inversion.local_files_only",description:`<strong>local_files_only</strong> (<code>bool</code>, <em>optional</em>, defaults to <code>False</code>) — | |
| Whether to only load local model weights and configuration files or not. If set to <code>True</code>, the model | |
| won’t be downloaded from the Hub.`,name:"local_files_only"},{anchor:"diffusers.loaders.TextualInversionLoaderMixin.load_textual_inversion.token",description:`<strong>token</strong> (<code>str</code> or <em>bool</em>, <em>optional</em>) — | |
| The token to use as HTTP bearer authorization for remote files. If <code>True</code>, the token generated from | |
| <code>diffusers-cli login</code> (stored in <code>~/.huggingface</code>) is used.`,name:"token"},{anchor:"diffusers.loaders.TextualInversionLoaderMixin.load_textual_inversion.revision",description:`<strong>revision</strong> (<code>str</code>, <em>optional</em>, defaults to <code>"main"</code>) — | |
| The specific model version to use. It can be a branch name, a tag name, a commit id, or any identifier | |
| allowed by Git.`,name:"revision"},{anchor:"diffusers.loaders.TextualInversionLoaderMixin.load_textual_inversion.subfolder",description:`<strong>subfolder</strong> (<code>str</code>, <em>optional</em>, defaults to <code>""</code>) — | |
| The subfolder location of a model file within a larger model repository on the Hub or locally.`,name:"subfolder"},{anchor:"diffusers.loaders.TextualInversionLoaderMixin.load_textual_inversion.mirror",description:`<strong>mirror</strong> (<code>str</code>, <em>optional</em>) — | |
| Mirror source to resolve accessibility issues if you’re downloading a model in China. We do not | |
| guarantee the timeliness or safety of the source, and you should refer to the mirror site for more | |
| information.`,name:"mirror"}],source:"https://github.com/huggingface/diffusers/blob/vr_10175/src/diffusers/loaders/textual_inversion.py#L263"}}),$=new ge({props:{anchor:"diffusers.loaders.TextualInversionLoaderMixin.load_textual_inversion.example",$$slots:{default:[ze]},$$scope:{ctx:Z}}}),W=new ge({props:{anchor:"diffusers.loaders.TextualInversionLoaderMixin.load_textual_inversion.example-2",$$slots:{default:[Ee]},$$scope:{ctx:Z}}}),E=new le({props:{name:"maybe_convert_prompt",anchor:"diffusers.loaders.TextualInversionLoaderMixin.maybe_convert_prompt",parameters:[{name:"prompt",val:": typing.Union[str, typing.List[str]]"},{name:"tokenizer",val:": PreTrainedTokenizer"}],parametersDescription:[{anchor:"diffusers.loaders.TextualInversionLoaderMixin.maybe_convert_prompt.prompt",description:`<strong>prompt</strong> (<code>str</code> or list of <code>str</code>) — | |
| The prompt or prompts to guide the image generation.`,name:"prompt"},{anchor:"diffusers.loaders.TextualInversionLoaderMixin.maybe_convert_prompt.tokenizer",description:`<strong>tokenizer</strong> (<code>PreTrainedTokenizer</code>) — | |
| The tokenizer responsible for encoding the prompt into input tokens.`,name:"tokenizer"}],source:"https://github.com/huggingface/diffusers/blob/vr_10175/src/diffusers/loaders/textual_inversion.py#L115",returnDescription:`<script context="module">export const metadata = 'undefined';<\/script> | |
| <p>The converted prompt</p> | |
| `,returnType:`<script context="module">export const metadata = 'undefined';<\/script> | |
| <p><code>str</code> or list of <code>str</code></p> | |
| `}}),L=new le({props:{name:"unload_textual_inversion",anchor:"diffusers.loaders.TextualInversionLoaderMixin.unload_textual_inversion",parameters:[{name:"tokens",val:": typing.Union[str, typing.List[str], NoneType] = None"},{name:"tokenizer",val:": typing.Optional[ForwardRef('PreTrainedTokenizer')] = None"},{name:"text_encoder",val:": typing.Optional[ForwardRef('PreTrainedModel')] = None"}],source:"https://github.com/huggingface/diffusers/blob/vr_10175/src/diffusers/loaders/textual_inversion.py#L458"}}),B=new ge({props:{anchor:"diffusers.loaders.TextualInversionLoaderMixin.unload_textual_inversion.example",$$slots:{default:[Le]},$$scope:{ctx:Z}}}),N=new Xe({props:{source:"https://github.com/huggingface/diffusers/blob/main/docs/source/en/api/loaders/textual_inversion.md"}}),{c(){n=u("meta"),h=i(),a=u("p"),o=i(),g(d.$$.fragment),t=i(),m=u("p"),m.textContent=ve,K=i(),G=u("p"),G.innerHTML=Te,O=i(),g(j.$$.fragment),ee=i(),g(X.$$.fragment),te=i(),y=u("div"),g(R.$$.fragment),ie=i(),V=u("p"),V.textContent=_e,re=i(),M=u("div"),g(z.$$.fragment),de=i(),Y=u("p"),Y.innerHTML=Ue,pe=i(),q=u("p"),q.textContent=Je,ce=i(),g($.$$.fragment),me=i(),H=u("p"),H.innerHTML=we,ue=i(),g(W.$$.fragment),fe=i(),C=u("div"),g(E.$$.fragment),he=i(),S=u("p"),S.textContent=Ze,Me=i(),k=u("div"),g(L.$$.fragment),ye=i(),Q=u("p"),Q.innerHTML=ke,be=i(),g(B.$$.fragment),ne=i(),g(N.$$.fragment),oe=i(),A=u("p"),this.h()},l(e){const s=Be("svelte-u9bgzb",document.head);n=f(s,"META",{name:!0,content:!0}),s.forEach(l),h=r(e),a=f(e,"P",{}),P(a).forEach(l),o=r(e),x(d.$$.fragment,e),t=r(e),m=f(e,"P",{"data-svelte-h":!0}),w(m)!=="svelte-17iorh0"&&(m.textContent=ve),K=r(e),G=f(e,"P",{"data-svelte-h":!0}),w(G)!=="svelte-16c4ckr"&&(G.innerHTML=Te),O=r(e),x(j.$$.fragment,e),ee=r(e),x(X.$$.fragment,e),te=r(e),y=f(e,"DIV",{class:!0});var J=P(y);x(R.$$.fragment,J),ie=r(J),V=f(J,"P",{"data-svelte-h":!0}),w(V)!=="svelte-7bntze"&&(V.textContent=_e),re=r(J),M=f(J,"DIV",{class:!0});var b=P(M);x(z.$$.fragment,b),de=r(b),Y=f(b,"P",{"data-svelte-h":!0}),w(Y)!=="svelte-15a127s"&&(Y.innerHTML=Ue),pe=r(b),q=f(b,"P",{"data-svelte-h":!0}),w(q)!=="svelte-11lpom8"&&(q.textContent=Je),ce=r(b),x($.$$.fragment,b),me=r(b),H=f(b,"P",{"data-svelte-h":!0}),w(H)!=="svelte-15d7mv5"&&(H.innerHTML=we),ue=r(b),x(W.$$.fragment,b),b.forEach(l),fe=r(J),C=f(J,"DIV",{class:!0});var F=P(C);x(E.$$.fragment,F),he=r(F),S=f(F,"P",{"data-svelte-h":!0}),w(S)!=="svelte-gjjmbb"&&(S.textContent=Ze),F.forEach(l),Me=r(J),k=f(J,"DIV",{class:!0});var I=P(k);x(L.$$.fragment,I),ye=r(I),Q=f(I,"P",{"data-svelte-h":!0}),w(Q)!=="svelte-u9mar"&&(Q.innerHTML=ke),be=r(I),x(B.$$.fragment,I),I.forEach(l),J.forEach(l),ne=r(e),x(N.$$.fragment,e),oe=r(e),A=f(e,"P",{}),P(A).forEach(l),this.h()},h(){D(n,"name","hf:doc:metadata"),D(n,"content",Fe),D(M,"class","docstring border-l-2 border-t-2 pl-4 pt-3.5 border-gray-100 rounded-tl-xl mb-6 mt-8"),D(C,"class","docstring border-l-2 border-t-2 pl-4 pt-3.5 border-gray-100 rounded-tl-xl mb-6 mt-8"),D(k,"class","docstring border-l-2 border-t-2 pl-4 pt-3.5 border-gray-100 rounded-tl-xl mb-6 mt-8"),D(y,"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){p(document.head,n),c(e,h,s),c(e,a,s),c(e,o,s),v(d,e,s),c(e,t,s),c(e,m,s),c(e,K,s),c(e,G,s),c(e,O,s),v(j,e,s),c(e,ee,s),v(X,e,s),c(e,te,s),c(e,y,s),v(R,y,null),p(y,ie),p(y,V),p(y,re),p(y,M),v(z,M,null),p(M,de),p(M,Y),p(M,pe),p(M,q),p(M,ce),v($,M,null),p(M,me),p(M,H),p(M,ue),v(W,M,null),p(y,fe),p(y,C),v(E,C,null),p(C,he),p(C,S),p(y,Me),p(y,k),v(L,k,null),p(k,ye),p(k,Q),p(k,be),v(B,k,null),c(e,ne,s),v(N,e,s),c(e,oe,s),c(e,A,s),se=!0},p(e,[s]){const J={};s&2&&(J.$$scope={dirty:s,ctx:e}),j.$set(J);const b={};s&2&&(b.$$scope={dirty:s,ctx:e}),$.$set(b);const F={};s&2&&(F.$$scope={dirty:s,ctx:e}),W.$set(F);const I={};s&2&&(I.$$scope={dirty:s,ctx:e}),B.$set(I)},i(e){se||(T(d.$$.fragment,e),T(j.$$.fragment,e),T(X.$$.fragment,e),T(R.$$.fragment,e),T(z.$$.fragment,e),T($.$$.fragment,e),T(W.$$.fragment,e),T(E.$$.fragment,e),T(L.$$.fragment,e),T(B.$$.fragment,e),T(N.$$.fragment,e),se=!0)},o(e){_(d.$$.fragment,e),_(j.$$.fragment,e),_(X.$$.fragment,e),_(R.$$.fragment,e),_(z.$$.fragment,e),_($.$$.fragment,e),_(W.$$.fragment,e),_(E.$$.fragment,e),_(L.$$.fragment,e),_(B.$$.fragment,e),_(N.$$.fragment,e),se=!1},d(e){e&&(l(h),l(a),l(o),l(t),l(m),l(K),l(G),l(O),l(ee),l(te),l(y),l(ne),l(oe),l(A)),l(n),U(d,e),U(j,e),U(X,e),U(R),U(z),U($),U(W),U(E),U(L),U(B),U(N,e)}}}const Fe='{"title":"Textual Inversion","local":"textual-inversion","sections":[{"title":"TextualInversionLoaderMixin","local":"diffusers.loaders.TextualInversionLoaderMixin","sections":[],"depth":2}],"depth":1}';function Ve(Z){return $e(()=>{new URLSearchParams(window.location.search).get("fw")}),[]}class Ae extends We{constructor(n){super(),Ce(this,n,Ve,Ne,je,{})}}export{Ae as component}; | |
Xet Storage Details
- Size:
- 26.5 kB
- Xet hash:
- 5d46ce5dcabf8218a49df51ed81aa415e376ced00b411202d4604d3c049d089d
·
Xet efficiently stores files, intelligently splitting them into unique chunks and accelerating uploads and downloads. More info.