Buckets:
| import{s as st,o as rt,n as N}from"../chunks/scheduler.25b97de1.js";import{S as at,i as it,g as f,s as a,r as h,A as lt,h as g,f as r,c as i,j as L,u as _,x as G,k as P,y as u,a as c,v as T,d as M,t as y,w as b}from"../chunks/index.d9030fc9.js";import{T as et}from"../chunks/Tip.baa67368.js";import{D as pe}from"../chunks/Docstring.e257edda.js";import{C as Se}from"../chunks/CodeBlock.e6cd0d95.js";import{F as dt,M as nt}from"../chunks/Markdown.7217f838.js";import{E as Xe}from"../chunks/ExampleCodeBlock.20db4b6e.js";import{H as Le,E as pt}from"../chunks/EditOnGithub.91d95064.js";function ct(w){let e,p="Example:",o,n,m;return n=new Se({props:{code:"ZnJvbSUyMHRyYW5zZm9ybWVycyUyMGltcG9ydCUyMEdyb3VwVmlUVGV4dENvbmZpZyUyQyUyMEdyb3VwVmlUVGV4dE1vZGVsJTBBJTBBJTIzJTIwSW5pdGlhbGl6aW5nJTIwYSUyMEdyb3VwVmlUVGV4dE1vZGVsJTIwd2l0aCUyMG52aWRpYSUyRmdyb3Vwdml0LWdjYy15ZmNjJTIwc3R5bGUlMjBjb25maWd1cmF0aW9uJTBBY29uZmlndXJhdGlvbiUyMCUzRCUyMEdyb3VwVmlUVGV4dENvbmZpZygpJTBBJTBBbW9kZWwlMjAlM0QlMjBHcm91cFZpVFRleHRNb2RlbChjb25maWd1cmF0aW9uKSUwQSUwQSUyMyUyMEFjY2Vzc2luZyUyMHRoZSUyMG1vZGVsJTIwY29uZmlndXJhdGlvbiUwQWNvbmZpZ3VyYXRpb24lMjAlM0QlMjBtb2RlbC5jb25maWc=",highlighted:`<span class="hljs-meta">>>> </span><span class="hljs-keyword">from</span> transformers <span class="hljs-keyword">import</span> GroupViTTextConfig, GroupViTTextModel | |
| <span class="hljs-meta">>>> </span><span class="hljs-comment"># Initializing a GroupViTTextModel with nvidia/groupvit-gcc-yfcc style configuration</span> | |
| <span class="hljs-meta">>>> </span>configuration = GroupViTTextConfig() | |
| <span class="hljs-meta">>>> </span>model = GroupViTTextModel(configuration) | |
| <span class="hljs-meta">>>> </span><span class="hljs-comment"># Accessing the model configuration</span> | |
| <span class="hljs-meta">>>> </span>configuration = model.config`,wrap:!1}}),{c(){e=f("p"),e.textContent=p,o=a(),h(n.$$.fragment)},l(t){e=g(t,"P",{"data-svelte-h":!0}),G(e)!=="svelte-11lpom8"&&(e.textContent=p),o=i(t),_(n.$$.fragment,t)},m(t,$){c(t,e,$),c(t,o,$),T(n,t,$),m=!0},p:N,i(t){m||(M(n.$$.fragment,t),m=!0)},o(t){y(n.$$.fragment,t),m=!1},d(t){t&&(r(e),r(o)),b(n,t)}}}function ut(w){let e,p="Example:",o,n,m;return n=new Se({props:{code:"ZnJvbSUyMHRyYW5zZm9ybWVycyUyMGltcG9ydCUyMEdyb3VwVmlUVmlzaW9uQ29uZmlnJTJDJTIwR3JvdXBWaVRWaXNpb25Nb2RlbCUwQSUwQSUyMyUyMEluaXRpYWxpemluZyUyMGElMjBHcm91cFZpVFZpc2lvbk1vZGVsJTIwd2l0aCUyMG52aWRpYSUyRmdyb3Vwdml0LWdjYy15ZmNjJTIwc3R5bGUlMjBjb25maWd1cmF0aW9uJTBBY29uZmlndXJhdGlvbiUyMCUzRCUyMEdyb3VwVmlUVmlzaW9uQ29uZmlnKCklMEElMEFtb2RlbCUyMCUzRCUyMEdyb3VwVmlUVmlzaW9uTW9kZWwoY29uZmlndXJhdGlvbiklMEElMEElMjMlMjBBY2Nlc3NpbmclMjB0aGUlMjBtb2RlbCUyMGNvbmZpZ3VyYXRpb24lMEFjb25maWd1cmF0aW9uJTIwJTNEJTIwbW9kZWwuY29uZmln",highlighted:`<span class="hljs-meta">>>> </span><span class="hljs-keyword">from</span> transformers <span class="hljs-keyword">import</span> GroupViTVisionConfig, GroupViTVisionModel | |
| <span class="hljs-meta">>>> </span><span class="hljs-comment"># Initializing a GroupViTVisionModel with nvidia/groupvit-gcc-yfcc style configuration</span> | |
| <span class="hljs-meta">>>> </span>configuration = GroupViTVisionConfig() | |
| <span class="hljs-meta">>>> </span>model = GroupViTVisionModel(configuration) | |
| <span class="hljs-meta">>>> </span><span class="hljs-comment"># Accessing the model configuration</span> | |
| <span class="hljs-meta">>>> </span>configuration = model.config`,wrap:!1}}),{c(){e=f("p"),e.textContent=p,o=a(),h(n.$$.fragment)},l(t){e=g(t,"P",{"data-svelte-h":!0}),G(e)!=="svelte-11lpom8"&&(e.textContent=p),o=i(t),_(n.$$.fragment,t)},m(t,$){c(t,e,$),c(t,o,$),T(n,t,$),m=!0},p:N,i(t){m||(M(n.$$.fragment,t),m=!0)},o(t){y(n.$$.fragment,t),m=!1},d(t){t&&(r(e),r(o)),b(n,t)}}}function mt(w){let e,p=`Although the recipe for forward pass needs to be defined within this function, one should call the <code>Module</code> | |
| instance afterwards instead of this since the former takes care of running the pre and post processing steps while | |
| the latter silently ignores them.`;return{c(){e=f("p"),e.innerHTML=p},l(o){e=g(o,"P",{"data-svelte-h":!0}),G(e)!=="svelte-fincs2"&&(e.innerHTML=p)},m(o,n){c(o,e,n)},p:N,d(o){o&&r(e)}}}function ft(w){let e,p="Examples:",o,n,m;return n=new Se({props:{code:"ZnJvbSUyMFBJTCUyMGltcG9ydCUyMEltYWdlJTBBaW1wb3J0JTIwcmVxdWVzdHMlMEFmcm9tJTIwdHJhbnNmb3JtZXJzJTIwaW1wb3J0JTIwQXV0b1Byb2Nlc3NvciUyQyUyMEdyb3VwVmlUTW9kZWwlMEElMEFtb2RlbCUyMCUzRCUyMEdyb3VwVmlUTW9kZWwuZnJvbV9wcmV0cmFpbmVkKCUyMm52aWRpYSUyRmdyb3Vwdml0LWdjYy15ZmNjJTIyKSUwQXByb2Nlc3NvciUyMCUzRCUyMEF1dG9Qcm9jZXNzb3IuZnJvbV9wcmV0cmFpbmVkKCUyMm52aWRpYSUyRmdyb3Vwdml0LWdjYy15ZmNjJTIyKSUwQSUwQXVybCUyMCUzRCUyMCUyMmh0dHAlM0ElMkYlMkZpbWFnZXMuY29jb2RhdGFzZXQub3JnJTJGdmFsMjAxNyUyRjAwMDAwMDAzOTc2OS5qcGclMjIlMEFpbWFnZSUyMCUzRCUyMEltYWdlLm9wZW4ocmVxdWVzdHMuZ2V0KHVybCUyQyUyMHN0cmVhbSUzRFRydWUpLnJhdyklMEElMEFpbnB1dHMlMjAlM0QlMjBwcm9jZXNzb3IoJTBBJTIwJTIwJTIwJTIwdGV4dCUzRCU1QiUyMmElMjBwaG90byUyMG9mJTIwYSUyMGNhdCUyMiUyQyUyMCUyMmElMjBwaG90byUyMG9mJTIwYSUyMGRvZyUyMiU1RCUyQyUyMGltYWdlcyUzRGltYWdlJTJDJTIwcmV0dXJuX3RlbnNvcnMlM0QlMjJwdCUyMiUyQyUyMHBhZGRpbmclM0RUcnVlJTBBKSUwQSUwQW91dHB1dHMlMjAlM0QlMjBtb2RlbCgqKmlucHV0cyklMEFsb2dpdHNfcGVyX2ltYWdlJTIwJTNEJTIwb3V0cHV0cy5sb2dpdHNfcGVyX2ltYWdlJTIwJTIwJTIzJTIwdGhpcyUyMGlzJTIwdGhlJTIwaW1hZ2UtdGV4dCUyMHNpbWlsYXJpdHklMjBzY29yZSUwQXByb2JzJTIwJTNEJTIwbG9naXRzX3Blcl9pbWFnZS5zb2Z0bWF4KGRpbSUzRDEpJTIwJTIwJTIzJTIwd2UlMjBjYW4lMjB0YWtlJTIwdGhlJTIwc29mdG1heCUyMHRvJTIwZ2V0JTIwdGhlJTIwbGFiZWwlMjBwcm9iYWJpbGl0aWVz",highlighted:`<span class="hljs-meta">>>> </span><span class="hljs-keyword">from</span> PIL <span class="hljs-keyword">import</span> Image | |
| <span class="hljs-meta">>>> </span><span class="hljs-keyword">import</span> requests | |
| <span class="hljs-meta">>>> </span><span class="hljs-keyword">from</span> transformers <span class="hljs-keyword">import</span> AutoProcessor, GroupViTModel | |
| <span class="hljs-meta">>>> </span>model = GroupViTModel.from_pretrained(<span class="hljs-string">"nvidia/groupvit-gcc-yfcc"</span>) | |
| <span class="hljs-meta">>>> </span>processor = AutoProcessor.from_pretrained(<span class="hljs-string">"nvidia/groupvit-gcc-yfcc"</span>) | |
| <span class="hljs-meta">>>> </span>url = <span class="hljs-string">"http://images.cocodataset.org/val2017/000000039769.jpg"</span> | |
| <span class="hljs-meta">>>> </span>image = Image.<span class="hljs-built_in">open</span>(requests.get(url, stream=<span class="hljs-literal">True</span>).raw) | |
| <span class="hljs-meta">>>> </span>inputs = processor( | |
| <span class="hljs-meta">... </span> text=[<span class="hljs-string">"a photo of a cat"</span>, <span class="hljs-string">"a photo of a dog"</span>], images=image, return_tensors=<span class="hljs-string">"pt"</span>, padding=<span class="hljs-literal">True</span> | |
| <span class="hljs-meta">... </span>) | |
| <span class="hljs-meta">>>> </span>outputs = model(**inputs) | |
| <span class="hljs-meta">>>> </span>logits_per_image = outputs.logits_per_image <span class="hljs-comment"># this is the image-text similarity score</span> | |
| <span class="hljs-meta">>>> </span>probs = logits_per_image.softmax(dim=<span class="hljs-number">1</span>) <span class="hljs-comment"># we can take the softmax to get the label probabilities</span>`,wrap:!1}}),{c(){e=f("p"),e.textContent=p,o=a(),h(n.$$.fragment)},l(t){e=g(t,"P",{"data-svelte-h":!0}),G(e)!=="svelte-kvfsh7"&&(e.textContent=p),o=i(t),_(n.$$.fragment,t)},m(t,$){c(t,e,$),c(t,o,$),T(n,t,$),m=!0},p:N,i(t){m||(M(n.$$.fragment,t),m=!0)},o(t){y(n.$$.fragment,t),m=!1},d(t){t&&(r(e),r(o)),b(n,t)}}}function gt(w){let e,p=`Although the recipe for forward pass needs to be defined within this function, one should call the <code>Module</code> | |
| instance afterwards instead of this since the former takes care of running the pre and post processing steps while | |
| the latter silently ignores them.`;return{c(){e=f("p"),e.innerHTML=p},l(o){e=g(o,"P",{"data-svelte-h":!0}),G(e)!=="svelte-fincs2"&&(e.innerHTML=p)},m(o,n){c(o,e,n)},p:N,d(o){o&&r(e)}}}function ht(w){let e,p="Examples:",o,n,m;return n=new Se({props:{code:"ZnJvbSUyMHRyYW5zZm9ybWVycyUyMGltcG9ydCUyMENMSVBUb2tlbml6ZXIlMkMlMjBHcm91cFZpVE1vZGVsJTBBJTBBbW9kZWwlMjAlM0QlMjBHcm91cFZpVE1vZGVsLmZyb21fcHJldHJhaW5lZCglMjJudmlkaWElMkZncm91cHZpdC1nY2MteWZjYyUyMiklMEF0b2tlbml6ZXIlMjAlM0QlMjBDTElQVG9rZW5pemVyLmZyb21fcHJldHJhaW5lZCglMjJudmlkaWElMkZncm91cHZpdC1nY2MteWZjYyUyMiklMEElMEFpbnB1dHMlMjAlM0QlMjB0b2tlbml6ZXIoJTVCJTIyYSUyMHBob3RvJTIwb2YlMjBhJTIwY2F0JTIyJTJDJTIwJTIyYSUyMHBob3RvJTIwb2YlMjBhJTIwZG9nJTIyJTVEJTJDJTIwcGFkZGluZyUzRFRydWUlMkMlMjByZXR1cm5fdGVuc29ycyUzRCUyMnB0JTIyKSUwQXRleHRfZmVhdHVyZXMlMjAlM0QlMjBtb2RlbC5nZXRfdGV4dF9mZWF0dXJlcygqKmlucHV0cyk=",highlighted:`<span class="hljs-meta">>>> </span><span class="hljs-keyword">from</span> transformers <span class="hljs-keyword">import</span> CLIPTokenizer, GroupViTModel | |
| <span class="hljs-meta">>>> </span>model = GroupViTModel.from_pretrained(<span class="hljs-string">"nvidia/groupvit-gcc-yfcc"</span>) | |
| <span class="hljs-meta">>>> </span>tokenizer = CLIPTokenizer.from_pretrained(<span class="hljs-string">"nvidia/groupvit-gcc-yfcc"</span>) | |
| <span class="hljs-meta">>>> </span>inputs = tokenizer([<span class="hljs-string">"a photo of a cat"</span>, <span class="hljs-string">"a photo of a dog"</span>], padding=<span class="hljs-literal">True</span>, return_tensors=<span class="hljs-string">"pt"</span>) | |
| <span class="hljs-meta">>>> </span>text_features = model.get_text_features(**inputs)`,wrap:!1}}),{c(){e=f("p"),e.textContent=p,o=a(),h(n.$$.fragment)},l(t){e=g(t,"P",{"data-svelte-h":!0}),G(e)!=="svelte-kvfsh7"&&(e.textContent=p),o=i(t),_(n.$$.fragment,t)},m(t,$){c(t,e,$),c(t,o,$),T(n,t,$),m=!0},p:N,i(t){m||(M(n.$$.fragment,t),m=!0)},o(t){y(n.$$.fragment,t),m=!1},d(t){t&&(r(e),r(o)),b(n,t)}}}function _t(w){let e,p=`Although the recipe for forward pass needs to be defined within this function, one should call the <code>Module</code> | |
| instance afterwards instead of this since the former takes care of running the pre and post processing steps while | |
| the latter silently ignores them.`;return{c(){e=f("p"),e.innerHTML=p},l(o){e=g(o,"P",{"data-svelte-h":!0}),G(e)!=="svelte-fincs2"&&(e.innerHTML=p)},m(o,n){c(o,e,n)},p:N,d(o){o&&r(e)}}}function Tt(w){let e,p="Examples:",o,n,m;return n=new Se({props:{code:"ZnJvbSUyMFBJTCUyMGltcG9ydCUyMEltYWdlJTBBaW1wb3J0JTIwcmVxdWVzdHMlMEFmcm9tJTIwdHJhbnNmb3JtZXJzJTIwaW1wb3J0JTIwQXV0b1Byb2Nlc3NvciUyQyUyMEdyb3VwVmlUTW9kZWwlMEElMEFtb2RlbCUyMCUzRCUyMEdyb3VwVmlUTW9kZWwuZnJvbV9wcmV0cmFpbmVkKCUyMm52aWRpYSUyRmdyb3Vwdml0LWdjYy15ZmNjJTIyKSUwQXByb2Nlc3NvciUyMCUzRCUyMEF1dG9Qcm9jZXNzb3IuZnJvbV9wcmV0cmFpbmVkKCUyMm52aWRpYSUyRmdyb3Vwdml0LWdjYy15ZmNjJTIyKSUwQSUwQXVybCUyMCUzRCUyMCUyMmh0dHAlM0ElMkYlMkZpbWFnZXMuY29jb2RhdGFzZXQub3JnJTJGdmFsMjAxNyUyRjAwMDAwMDAzOTc2OS5qcGclMjIlMEFpbWFnZSUyMCUzRCUyMEltYWdlLm9wZW4ocmVxdWVzdHMuZ2V0KHVybCUyQyUyMHN0cmVhbSUzRFRydWUpLnJhdyklMEElMEFpbnB1dHMlMjAlM0QlMjBwcm9jZXNzb3IoaW1hZ2VzJTNEaW1hZ2UlMkMlMjByZXR1cm5fdGVuc29ycyUzRCUyMnB0JTIyKSUwQSUwQWltYWdlX2ZlYXR1cmVzJTIwJTNEJTIwbW9kZWwuZ2V0X2ltYWdlX2ZlYXR1cmVzKCoqaW5wdXRzKQ==",highlighted:`<span class="hljs-meta">>>> </span><span class="hljs-keyword">from</span> PIL <span class="hljs-keyword">import</span> Image | |
| <span class="hljs-meta">>>> </span><span class="hljs-keyword">import</span> requests | |
| <span class="hljs-meta">>>> </span><span class="hljs-keyword">from</span> transformers <span class="hljs-keyword">import</span> AutoProcessor, GroupViTModel | |
| <span class="hljs-meta">>>> </span>model = GroupViTModel.from_pretrained(<span class="hljs-string">"nvidia/groupvit-gcc-yfcc"</span>) | |
| <span class="hljs-meta">>>> </span>processor = AutoProcessor.from_pretrained(<span class="hljs-string">"nvidia/groupvit-gcc-yfcc"</span>) | |
| <span class="hljs-meta">>>> </span>url = <span class="hljs-string">"http://images.cocodataset.org/val2017/000000039769.jpg"</span> | |
| <span class="hljs-meta">>>> </span>image = Image.<span class="hljs-built_in">open</span>(requests.get(url, stream=<span class="hljs-literal">True</span>).raw) | |
| <span class="hljs-meta">>>> </span>inputs = processor(images=image, return_tensors=<span class="hljs-string">"pt"</span>) | |
| <span class="hljs-meta">>>> </span>image_features = model.get_image_features(**inputs)`,wrap:!1}}),{c(){e=f("p"),e.textContent=p,o=a(),h(n.$$.fragment)},l(t){e=g(t,"P",{"data-svelte-h":!0}),G(e)!=="svelte-kvfsh7"&&(e.textContent=p),o=i(t),_(n.$$.fragment,t)},m(t,$){c(t,e,$),c(t,o,$),T(n,t,$),m=!0},p:N,i(t){m||(M(n.$$.fragment,t),m=!0)},o(t){y(n.$$.fragment,t),m=!1},d(t){t&&(r(e),r(o)),b(n,t)}}}function Mt(w){let e,p=`Although the recipe for forward pass needs to be defined within this function, one should call the <code>Module</code> | |
| instance afterwards instead of this since the former takes care of running the pre and post processing steps while | |
| the latter silently ignores them.`;return{c(){e=f("p"),e.innerHTML=p},l(o){e=g(o,"P",{"data-svelte-h":!0}),G(e)!=="svelte-fincs2"&&(e.innerHTML=p)},m(o,n){c(o,e,n)},p:N,d(o){o&&r(e)}}}function yt(w){let e,p="Examples:",o,n,m;return n=new Se({props:{code:"ZnJvbSUyMHRyYW5zZm9ybWVycyUyMGltcG9ydCUyMENMSVBUb2tlbml6ZXIlMkMlMjBHcm91cFZpVFRleHRNb2RlbCUwQSUwQXRva2VuaXplciUyMCUzRCUyMENMSVBUb2tlbml6ZXIuZnJvbV9wcmV0cmFpbmVkKCUyMm52aWRpYSUyRmdyb3Vwdml0LWdjYy15ZmNjJTIyKSUwQW1vZGVsJTIwJTNEJTIwR3JvdXBWaVRUZXh0TW9kZWwuZnJvbV9wcmV0cmFpbmVkKCUyMm52aWRpYSUyRmdyb3Vwdml0LWdjYy15ZmNjJTIyKSUwQSUwQWlucHV0cyUyMCUzRCUyMHRva2VuaXplciglNUIlMjJhJTIwcGhvdG8lMjBvZiUyMGElMjBjYXQlMjIlMkMlMjAlMjJhJTIwcGhvdG8lMjBvZiUyMGElMjBkb2clMjIlNUQlMkMlMjBwYWRkaW5nJTNEVHJ1ZSUyQyUyMHJldHVybl90ZW5zb3JzJTNEJTIycHQlMjIpJTBBJTBBb3V0cHV0cyUyMCUzRCUyMG1vZGVsKCoqaW5wdXRzKSUwQWxhc3RfaGlkZGVuX3N0YXRlJTIwJTNEJTIwb3V0cHV0cy5sYXN0X2hpZGRlbl9zdGF0ZSUwQXBvb2xlZF9vdXRwdXQlMjAlM0QlMjBvdXRwdXRzLnBvb2xlcl9vdXRwdXQlMjAlMjAlMjMlMjBwb29sZWQlMjAoRU9TJTIwdG9rZW4pJTIwc3RhdGVz",highlighted:`<span class="hljs-meta">>>> </span><span class="hljs-keyword">from</span> transformers <span class="hljs-keyword">import</span> CLIPTokenizer, GroupViTTextModel | |
| <span class="hljs-meta">>>> </span>tokenizer = CLIPTokenizer.from_pretrained(<span class="hljs-string">"nvidia/groupvit-gcc-yfcc"</span>) | |
| <span class="hljs-meta">>>> </span>model = GroupViTTextModel.from_pretrained(<span class="hljs-string">"nvidia/groupvit-gcc-yfcc"</span>) | |
| <span class="hljs-meta">>>> </span>inputs = tokenizer([<span class="hljs-string">"a photo of a cat"</span>, <span class="hljs-string">"a photo of a dog"</span>], padding=<span class="hljs-literal">True</span>, return_tensors=<span class="hljs-string">"pt"</span>) | |
| <span class="hljs-meta">>>> </span>outputs = model(**inputs) | |
| <span class="hljs-meta">>>> </span>last_hidden_state = outputs.last_hidden_state | |
| <span class="hljs-meta">>>> </span>pooled_output = outputs.pooler_output <span class="hljs-comment"># pooled (EOS token) states</span>`,wrap:!1}}),{c(){e=f("p"),e.textContent=p,o=a(),h(n.$$.fragment)},l(t){e=g(t,"P",{"data-svelte-h":!0}),G(e)!=="svelte-kvfsh7"&&(e.textContent=p),o=i(t),_(n.$$.fragment,t)},m(t,$){c(t,e,$),c(t,o,$),T(n,t,$),m=!0},p:N,i(t){m||(M(n.$$.fragment,t),m=!0)},o(t){y(n.$$.fragment,t),m=!1},d(t){t&&(r(e),r(o)),b(n,t)}}}function bt(w){let e,p=`Although the recipe for forward pass needs to be defined within this function, one should call the <code>Module</code> | |
| instance afterwards instead of this since the former takes care of running the pre and post processing steps while | |
| the latter silently ignores them.`;return{c(){e=f("p"),e.innerHTML=p},l(o){e=g(o,"P",{"data-svelte-h":!0}),G(e)!=="svelte-fincs2"&&(e.innerHTML=p)},m(o,n){c(o,e,n)},p:N,d(o){o&&r(e)}}}function vt(w){let e,p="Examples:",o,n,m;return n=new Se({props:{code:"ZnJvbSUyMFBJTCUyMGltcG9ydCUyMEltYWdlJTBBaW1wb3J0JTIwcmVxdWVzdHMlMEFmcm9tJTIwdHJhbnNmb3JtZXJzJTIwaW1wb3J0JTIwQXV0b1Byb2Nlc3NvciUyQyUyMEdyb3VwVmlUVmlzaW9uTW9kZWwlMEElMEFwcm9jZXNzb3IlMjAlM0QlMjBBdXRvUHJvY2Vzc29yLmZyb21fcHJldHJhaW5lZCglMjJudmlkaWElMkZncm91cHZpdC1nY2MteWZjYyUyMiklMEFtb2RlbCUyMCUzRCUyMEdyb3VwVmlUVmlzaW9uTW9kZWwuZnJvbV9wcmV0cmFpbmVkKCUyMm52aWRpYSUyRmdyb3Vwdml0LWdjYy15ZmNjJTIyKSUwQSUwQXVybCUyMCUzRCUyMCUyMmh0dHAlM0ElMkYlMkZpbWFnZXMuY29jb2RhdGFzZXQub3JnJTJGdmFsMjAxNyUyRjAwMDAwMDAzOTc2OS5qcGclMjIlMEFpbWFnZSUyMCUzRCUyMEltYWdlLm9wZW4ocmVxdWVzdHMuZ2V0KHVybCUyQyUyMHN0cmVhbSUzRFRydWUpLnJhdyklMEElMEFpbnB1dHMlMjAlM0QlMjBwcm9jZXNzb3IoaW1hZ2VzJTNEaW1hZ2UlMkMlMjByZXR1cm5fdGVuc29ycyUzRCUyMnB0JTIyKSUwQSUwQW91dHB1dHMlMjAlM0QlMjBtb2RlbCgqKmlucHV0cyklMEFsYXN0X2hpZGRlbl9zdGF0ZSUyMCUzRCUyMG91dHB1dHMubGFzdF9oaWRkZW5fc3RhdGUlMEFwb29sZWRfb3V0cHV0JTIwJTNEJTIwb3V0cHV0cy5wb29sZXJfb3V0cHV0JTIwJTIwJTIzJTIwcG9vbGVkJTIwQ0xTJTIwc3RhdGVz",highlighted:`<span class="hljs-meta">>>> </span><span class="hljs-keyword">from</span> PIL <span class="hljs-keyword">import</span> Image | |
| <span class="hljs-meta">>>> </span><span class="hljs-keyword">import</span> requests | |
| <span class="hljs-meta">>>> </span><span class="hljs-keyword">from</span> transformers <span class="hljs-keyword">import</span> AutoProcessor, GroupViTVisionModel | |
| <span class="hljs-meta">>>> </span>processor = AutoProcessor.from_pretrained(<span class="hljs-string">"nvidia/groupvit-gcc-yfcc"</span>) | |
| <span class="hljs-meta">>>> </span>model = GroupViTVisionModel.from_pretrained(<span class="hljs-string">"nvidia/groupvit-gcc-yfcc"</span>) | |
| <span class="hljs-meta">>>> </span>url = <span class="hljs-string">"http://images.cocodataset.org/val2017/000000039769.jpg"</span> | |
| <span class="hljs-meta">>>> </span>image = Image.<span class="hljs-built_in">open</span>(requests.get(url, stream=<span class="hljs-literal">True</span>).raw) | |
| <span class="hljs-meta">>>> </span>inputs = processor(images=image, return_tensors=<span class="hljs-string">"pt"</span>) | |
| <span class="hljs-meta">>>> </span>outputs = model(**inputs) | |
| <span class="hljs-meta">>>> </span>last_hidden_state = outputs.last_hidden_state | |
| <span class="hljs-meta">>>> </span>pooled_output = outputs.pooler_output <span class="hljs-comment"># pooled CLS states</span>`,wrap:!1}}),{c(){e=f("p"),e.textContent=p,o=a(),h(n.$$.fragment)},l(t){e=g(t,"P",{"data-svelte-h":!0}),G(e)!=="svelte-kvfsh7"&&(e.textContent=p),o=i(t),_(n.$$.fragment,t)},m(t,$){c(t,e,$),c(t,o,$),T(n,t,$),m=!0},p:N,i(t){m||(M(n.$$.fragment,t),m=!0)},o(t){y(n.$$.fragment,t),m=!1},d(t){t&&(r(e),r(o)),b(n,t)}}}function $t(w){let e,p,o,n,m,t,$=`This model is a PyTorch <a href="https://pytorch.org/docs/stable/nn.html#torch.nn.Module" rel="nofollow">torch.nn.Module</a> subclass. Use it | |
| as a regular PyTorch Module and refer to the PyTorch documentation for all matter related to general usage and | |
| behavior.`,Ue,k,X,Ce,U,Ve='The <a href="/docs/transformers/pr_33174/en/model_doc/groupvit#transformers.GroupViTModel">GroupViTModel</a> forward method, overrides the <code>__call__</code> special method.',W,j,se,re,Be,ce,S,ze,ae,Re='The <a href="/docs/transformers/pr_33174/en/model_doc/groupvit#transformers.GroupViTModel">GroupViTModel</a> forward method, overrides the <code>__call__</code> special method.',ue,Y,We,ie,He,me,Q,Ie,be,Ye='The <a href="/docs/transformers/pr_33174/en/model_doc/groupvit#transformers.GroupViTModel">GroupViTModel</a> forward method, overrides the <code>__call__</code> special method.',I,A,D,R,Qe,ve,ke,xe,H,Ae,F,O,K,$e,qe='The <a href="/docs/transformers/pr_33174/en/model_doc/groupvit#transformers.GroupViTTextModel">GroupViTTextModel</a> forward method, overrides the <code>__call__</code> special method.',fe,ee,Fe,le,te,ge,Ge,de,he,Pe,C,Ze,je,E,De='The <a href="/docs/transformers/pr_33174/en/model_doc/groupvit#transformers.GroupViTVisionModel">GroupViTVisionModel</a> forward method, overrides the <code>__call__</code> special method.',Z,oe,ne,q,Oe;return e=new Le({props:{title:"GroupViTModel",local:"transformers.GroupViTModel",headingTag:"h2"}}),n=new pe({props:{name:"class transformers.GroupViTModel",anchor:"transformers.GroupViTModel",parameters:[{name:"config",val:": GroupViTConfig"}],parametersDescription:[{anchor:"transformers.GroupViTModel.config",description:`<strong>config</strong> (<a href="/docs/transformers/pr_33174/en/model_doc/groupvit#transformers.GroupViTConfig">GroupViTConfig</a>) — Model configuration class with all the parameters of the model. | |
| Initializing with a config file does not load the weights associated with the model, only the | |
| configuration. Check out the <a href="/docs/transformers/pr_33174/en/main_classes/model#transformers.PreTrainedModel.from_pretrained">from_pretrained()</a> method to load the model weights.`,name:"config"}],source:"https://github.com/huggingface/transformers/blob/vr_33174/src/transformers/models/groupvit/modeling_groupvit.py#L1297"}}),X=new pe({props:{name:"forward",anchor:"transformers.GroupViTModel.forward",parameters:[{name:"input_ids",val:": Optional = None"},{name:"pixel_values",val:": Optional = None"},{name:"attention_mask",val:": Optional = None"},{name:"position_ids",val:": Optional = None"},{name:"return_loss",val:": Optional = None"},{name:"output_attentions",val:": Optional = None"},{name:"output_hidden_states",val:": Optional = None"},{name:"output_segmentation",val:": Optional = None"},{name:"return_dict",val:": Optional = None"}],parametersDescription:[{anchor:"transformers.GroupViTModel.forward.input_ids",description:`<strong>input_ids</strong> (<code>torch.LongTensor</code> of shape <code>(batch_size, sequence_length)</code>) — | |
| Indices of input sequence tokens in the vocabulary. Padding will be ignored by default should you provide | |
| it.</p> | |
| <p>Indices can be obtained using <a href="/docs/transformers/pr_33174/en/model_doc/clip#transformers.CLIPTokenizer">CLIPTokenizer</a>. See <a href="/docs/transformers/pr_33174/en/internal/tokenization_utils#transformers.PreTrainedTokenizerBase.encode">PreTrainedTokenizer.encode()</a> and | |
| <a href="/docs/transformers/pr_33174/en/internal/tokenization_utils#transformers.PreTrainedTokenizerBase.__call__">PreTrainedTokenizer.<strong>call</strong>()</a> for details.</p> | |
| <p><a href="../glossary#input-ids">What are input IDs?</a>`,name:"input_ids"},{anchor:"transformers.GroupViTModel.forward.attention_mask",description:`<strong>attention_mask</strong> (<code>torch.Tensor</code> of shape <code>(batch_size, sequence_length)</code>, <em>optional</em>) — | |
| Mask to avoid performing attention on padding token indices. Mask values selected in <code>[0, 1]</code>:</p> | |
| <ul> | |
| <li>1 for tokens that are <strong>not masked</strong>,</li> | |
| <li>0 for tokens that are <strong>masked</strong>.</li> | |
| </ul> | |
| <p><a href="../glossary#attention-mask">What are attention masks?</a>`,name:"attention_mask"},{anchor:"transformers.GroupViTModel.forward.position_ids",description:`<strong>position_ids</strong> (<code>torch.LongTensor</code> of shape <code>(batch_size, sequence_length)</code>, <em>optional</em>) — | |
| Indices of positions of each input sequence tokens in the position embeddings. Selected in the range <code>[0, config.max_position_embeddings - 1]</code>.</p> | |
| <p><a href="../glossary#position-ids">What are position IDs?</a>`,name:"position_ids"},{anchor:"transformers.GroupViTModel.forward.pixel_values",description:`<strong>pixel_values</strong> (<code>torch.FloatTensor</code> of shape <code>(batch_size, num_channels, height, width)</code>) — | |
| Pixel values. Pixel values can be obtained using <a href="/docs/transformers/pr_33174/en/model_doc/auto#transformers.AutoImageProcessor">AutoImageProcessor</a>. See | |
| <a href="/docs/transformers/pr_33174/en/model_doc/layoutlmv2#transformers.LayoutLMv2FeatureExtractor.__call__">CLIPImageProcessor.<strong>call</strong>()</a> for details.`,name:"pixel_values"},{anchor:"transformers.GroupViTModel.forward.return_loss",description:`<strong>return_loss</strong> (<code>bool</code>, <em>optional</em>) — | |
| Whether or not to return the contrastive loss.`,name:"return_loss"},{anchor:"transformers.GroupViTModel.forward.output_attentions",description:`<strong>output_attentions</strong> (<code>bool</code>, <em>optional</em>) — | |
| Whether or not to return the attentions tensors of all attention layers. See <code>attentions</code> under returned | |
| tensors for more detail.`,name:"output_attentions"},{anchor:"transformers.GroupViTModel.forward.output_hidden_states",description:`<strong>output_hidden_states</strong> (<code>bool</code>, <em>optional</em>) — | |
| Whether or not to return the hidden states of all layers. See <code>hidden_states</code> under returned tensors for | |
| more detail.`,name:"output_hidden_states"},{anchor:"transformers.GroupViTModel.forward.return_dict",description:`<strong>return_dict</strong> (<code>bool</code>, <em>optional</em>) — | |
| Whether or not to return a <a href="/docs/transformers/pr_33174/en/main_classes/output#transformers.utils.ModelOutput">ModelOutput</a> instead of a plain tuple.`,name:"return_dict"}],source:"https://github.com/huggingface/transformers/blob/vr_33174/src/transformers/models/groupvit/modeling_groupvit.py#L1440",returnDescription:`<script context="module">export const metadata = 'undefined';<\/script> | |
| <p>A <code>transformers.models.groupvit.modeling_groupvit.GroupViTModelOutput</code> or a tuple of | |
| <code>torch.FloatTensor</code> (if <code>return_dict=False</code> is passed or when <code>config.return_dict=False</code>) comprising various | |
| elements depending on the configuration (<code><class 'transformers.models.groupvit.configuration_groupvit.GroupViTConfig'></code>) and inputs.</p> | |
| <ul> | |
| <li> | |
| <p><strong>loss</strong> (<code>torch.FloatTensor</code> of shape <code>(1,)</code>, <em>optional</em>, returned when <code>return_loss</code> is <code>True</code>) — Contrastive loss for image-text similarity.</p> | |
| </li> | |
| <li> | |
| <p><strong>logits_per_image</strong> (<code>torch.FloatTensor</code> of shape <code>(image_batch_size, text_batch_size)</code>) — The scaled dot product scores between <code>image_embeds</code> and <code>text_embeds</code>. This represents the image-text | |
| similarity scores.</p> | |
| </li> | |
| <li> | |
| <p><strong>logits_per_text</strong> (<code>torch.FloatTensor</code> of shape <code>(text_batch_size, image_batch_size)</code>) — The scaled dot product scores between <code>text_embeds</code> and <code>image_embeds</code>. This represents the text-image | |
| similarity scores.</p> | |
| </li> | |
| <li> | |
| <p><strong>segmentation_logits</strong> (<code>torch.FloatTensor</code> of shape <code>(batch_size, config.num_labels, logits_height, logits_width)</code>) — Classification scores for each pixel.</p> | |
| <Tip warning={true}> | |
| <p>The logits returned do not necessarily have the same size as the <code>pixel_values</code> passed as inputs. This is | |
| to avoid doing two interpolations and lose some quality when a user needs to resize the logits to the | |
| original image size as post-processing. You should always check your logits shape and resize as needed.</p> | |
| </Tip> | |
| </li> | |
| <li> | |
| <p><strong>text_embeds</strong> (<code>torch.FloatTensor</code> of shape <code>(batch_size, output_dim</code>) — The text embeddings obtained by applying the projection layer to the pooled output of | |
| <a | |
| href="/docs/transformers/pr_33174/en/model_doc/groupvit#transformers.GroupViTTextModel" | |
| >GroupViTTextModel</a>.</p> | |
| </li> | |
| <li> | |
| <p><strong>image_embeds</strong> (<code>torch.FloatTensor</code> of shape <code>(batch_size, output_dim</code>) — The image embeddings obtained by applying the projection layer to the pooled output of | |
| <a | |
| href="/docs/transformers/pr_33174/en/model_doc/groupvit#transformers.GroupViTVisionModel" | |
| >GroupViTVisionModel</a>.</p> | |
| </li> | |
| <li> | |
| <p><strong>text_model_output</strong> (<code>BaseModelOutputWithPooling</code>) — The output of the <a | |
| href="/docs/transformers/pr_33174/en/model_doc/groupvit#transformers.GroupViTTextModel" | |
| >GroupViTTextModel</a>.</p> | |
| </li> | |
| <li> | |
| <p><strong>vision_model_output</strong> (<code>BaseModelOutputWithPooling</code>) — The output of the <a | |
| href="/docs/transformers/pr_33174/en/model_doc/groupvit#transformers.GroupViTVisionModel" | |
| >GroupViTVisionModel</a>.</p> | |
| </li> | |
| </ul> | |
| `,returnType:`<script context="module">export const metadata = 'undefined';<\/script> | |
| <p><code>transformers.models.groupvit.modeling_groupvit.GroupViTModelOutput</code> or <code>tuple(torch.FloatTensor)</code></p> | |
| `}}),j=new et({props:{$$slots:{default:[mt]},$$scope:{ctx:w}}}),re=new Xe({props:{anchor:"transformers.GroupViTModel.forward.example",$$slots:{default:[ft]},$$scope:{ctx:w}}}),S=new pe({props:{name:"get_text_features",anchor:"transformers.GroupViTModel.get_text_features",parameters:[{name:"input_ids",val:": Optional = None"},{name:"attention_mask",val:": Optional = None"},{name:"position_ids",val:": Optional = None"},{name:"output_attentions",val:": Optional = None"},{name:"output_hidden_states",val:": Optional = None"},{name:"return_dict",val:": Optional = None"}],parametersDescription:[{anchor:"transformers.GroupViTModel.get_text_features.input_ids",description:`<strong>input_ids</strong> (<code>torch.LongTensor</code> of shape <code>(batch_size, sequence_length)</code>) — | |
| Indices of input sequence tokens in the vocabulary. Padding will be ignored by default should you provide | |
| it.</p> | |
| <p>Indices can be obtained using <a href="/docs/transformers/pr_33174/en/model_doc/clip#transformers.CLIPTokenizer">CLIPTokenizer</a>. See <a href="/docs/transformers/pr_33174/en/internal/tokenization_utils#transformers.PreTrainedTokenizerBase.encode">PreTrainedTokenizer.encode()</a> and | |
| <a href="/docs/transformers/pr_33174/en/internal/tokenization_utils#transformers.PreTrainedTokenizerBase.__call__">PreTrainedTokenizer.<strong>call</strong>()</a> for details.</p> | |
| <p><a href="../glossary#input-ids">What are input IDs?</a>`,name:"input_ids"},{anchor:"transformers.GroupViTModel.get_text_features.attention_mask",description:`<strong>attention_mask</strong> (<code>torch.Tensor</code> of shape <code>(batch_size, sequence_length)</code>, <em>optional</em>) — | |
| Mask to avoid performing attention on padding token indices. Mask values selected in <code>[0, 1]</code>:</p> | |
| <ul> | |
| <li>1 for tokens that are <strong>not masked</strong>,</li> | |
| <li>0 for tokens that are <strong>masked</strong>.</li> | |
| </ul> | |
| <p><a href="../glossary#attention-mask">What are attention masks?</a>`,name:"attention_mask"},{anchor:"transformers.GroupViTModel.get_text_features.position_ids",description:`<strong>position_ids</strong> (<code>torch.LongTensor</code> of shape <code>(batch_size, sequence_length)</code>, <em>optional</em>) — | |
| Indices of positions of each input sequence tokens in the position embeddings. Selected in the range <code>[0, config.max_position_embeddings - 1]</code>.</p> | |
| <p><a href="../glossary#position-ids">What are position IDs?</a>`,name:"position_ids"},{anchor:"transformers.GroupViTModel.get_text_features.output_attentions",description:`<strong>output_attentions</strong> (<code>bool</code>, <em>optional</em>) — | |
| Whether or not to return the attentions tensors of all attention layers. See <code>attentions</code> under returned | |
| tensors for more detail.`,name:"output_attentions"},{anchor:"transformers.GroupViTModel.get_text_features.output_hidden_states",description:`<strong>output_hidden_states</strong> (<code>bool</code>, <em>optional</em>) — | |
| Whether or not to return the hidden states of all layers. See <code>hidden_states</code> under returned tensors for | |
| more detail.`,name:"output_hidden_states"},{anchor:"transformers.GroupViTModel.get_text_features.return_dict",description:`<strong>return_dict</strong> (<code>bool</code>, <em>optional</em>) — | |
| Whether or not to return a <a href="/docs/transformers/pr_33174/en/main_classes/output#transformers.utils.ModelOutput">ModelOutput</a> instead of a plain tuple.`,name:"return_dict"}],source:"https://github.com/huggingface/transformers/blob/vr_33174/src/transformers/models/groupvit/modeling_groupvit.py#L1344",returnDescription:`<script context="module">export const metadata = 'undefined';<\/script> | |
| <p>The text embeddings obtained by | |
| applying the projection layer to the pooled output of <a | |
| href="/docs/transformers/pr_33174/en/model_doc/groupvit#transformers.GroupViTTextModel" | |
| >GroupViTTextModel</a>.</p> | |
| `,returnType:`<script context="module">export const metadata = 'undefined';<\/script> | |
| <p>text_features (<code>torch.FloatTensor</code> of shape <code>(batch_size, output_dim</code>)</p> | |
| `}}),Y=new et({props:{$$slots:{default:[gt]},$$scope:{ctx:w}}}),ie=new Xe({props:{anchor:"transformers.GroupViTModel.get_text_features.example",$$slots:{default:[ht]},$$scope:{ctx:w}}}),Q=new pe({props:{name:"get_image_features",anchor:"transformers.GroupViTModel.get_image_features",parameters:[{name:"pixel_values",val:": Optional = None"},{name:"output_attentions",val:": Optional = None"},{name:"output_hidden_states",val:": Optional = None"},{name:"return_dict",val:": Optional = None"}],parametersDescription:[{anchor:"transformers.GroupViTModel.get_image_features.pixel_values",description:`<strong>pixel_values</strong> (<code>torch.FloatTensor</code> of shape <code>(batch_size, num_channels, height, width)</code>) — | |
| Pixel values. Padding will be ignored by default should you provide it. Pixel values can be obtained using | |
| <a href="/docs/transformers/pr_33174/en/model_doc/auto#transformers.AutoImageProcessor">AutoImageProcessor</a>. See <a href="/docs/transformers/pr_33174/en/model_doc/layoutlmv2#transformers.LayoutLMv2FeatureExtractor.__call__">CLIPImageProcessor.<strong>call</strong>()</a> for details.`,name:"pixel_values"},{anchor:"transformers.GroupViTModel.get_image_features.output_attentions",description:`<strong>output_attentions</strong> (<code>bool</code>, <em>optional</em>) — | |
| Whether or not to return the attentions tensors of all attention layers. See <code>attentions</code> under returned | |
| tensors for more detail.`,name:"output_attentions"},{anchor:"transformers.GroupViTModel.get_image_features.output_hidden_states",description:`<strong>output_hidden_states</strong> (<code>bool</code>, <em>optional</em>) — | |
| Whether or not to return the hidden states of all layers. See <code>hidden_states</code> under returned tensors for | |
| more detail.`,name:"output_hidden_states"},{anchor:"transformers.GroupViTModel.get_image_features.return_dict",description:`<strong>return_dict</strong> (<code>bool</code>, <em>optional</em>) — | |
| Whether or not to return a <a href="/docs/transformers/pr_33174/en/main_classes/output#transformers.utils.ModelOutput">ModelOutput</a> instead of a plain tuple.`,name:"return_dict"}],source:"https://github.com/huggingface/transformers/blob/vr_33174/src/transformers/models/groupvit/modeling_groupvit.py#L1391",returnDescription:`<script context="module">export const metadata = 'undefined';<\/script> | |
| <p>The image embeddings obtained by | |
| applying the projection layer to the pooled output of <a | |
| href="/docs/transformers/pr_33174/en/model_doc/groupvit#transformers.GroupViTVisionModel" | |
| >GroupViTVisionModel</a>.</p> | |
| `,returnType:`<script context="module">export const metadata = 'undefined';<\/script> | |
| <p>image_features (<code>torch.FloatTensor</code> of shape <code>(batch_size, output_dim</code>)</p> | |
| `}}),A=new et({props:{$$slots:{default:[_t]},$$scope:{ctx:w}}}),R=new Xe({props:{anchor:"transformers.GroupViTModel.get_image_features.example",$$slots:{default:[Tt]},$$scope:{ctx:w}}}),ve=new Le({props:{title:"GroupViTTextModel",local:"transformers.GroupViTTextModel",headingTag:"h2"}}),H=new pe({props:{name:"class transformers.GroupViTTextModel",anchor:"transformers.GroupViTTextModel",parameters:[{name:"config",val:": GroupViTTextConfig"}],source:"https://github.com/huggingface/transformers/blob/vr_33174/src/transformers/models/groupvit/modeling_groupvit.py#L1134"}}),O=new pe({props:{name:"forward",anchor:"transformers.GroupViTTextModel.forward",parameters:[{name:"input_ids",val:": Optional = None"},{name:"attention_mask",val:": Optional = None"},{name:"position_ids",val:": Optional = None"},{name:"output_attentions",val:": Optional = None"},{name:"output_hidden_states",val:": Optional = None"},{name:"return_dict",val:": Optional = None"}],parametersDescription:[{anchor:"transformers.GroupViTTextModel.forward.input_ids",description:`<strong>input_ids</strong> (<code>torch.LongTensor</code> of shape <code>(batch_size, sequence_length)</code>) — | |
| Indices of input sequence tokens in the vocabulary. Padding will be ignored by default should you provide | |
| it.</p> | |
| <p>Indices can be obtained using <a href="/docs/transformers/pr_33174/en/model_doc/clip#transformers.CLIPTokenizer">CLIPTokenizer</a>. See <a href="/docs/transformers/pr_33174/en/internal/tokenization_utils#transformers.PreTrainedTokenizerBase.encode">PreTrainedTokenizer.encode()</a> and | |
| <a href="/docs/transformers/pr_33174/en/internal/tokenization_utils#transformers.PreTrainedTokenizerBase.__call__">PreTrainedTokenizer.<strong>call</strong>()</a> for details.</p> | |
| <p><a href="../glossary#input-ids">What are input IDs?</a>`,name:"input_ids"},{anchor:"transformers.GroupViTTextModel.forward.attention_mask",description:`<strong>attention_mask</strong> (<code>torch.Tensor</code> of shape <code>(batch_size, sequence_length)</code>, <em>optional</em>) — | |
| Mask to avoid performing attention on padding token indices. Mask values selected in <code>[0, 1]</code>:</p> | |
| <ul> | |
| <li>1 for tokens that are <strong>not masked</strong>,</li> | |
| <li>0 for tokens that are <strong>masked</strong>.</li> | |
| </ul> | |
| <p><a href="../glossary#attention-mask">What are attention masks?</a>`,name:"attention_mask"},{anchor:"transformers.GroupViTTextModel.forward.position_ids",description:`<strong>position_ids</strong> (<code>torch.LongTensor</code> of shape <code>(batch_size, sequence_length)</code>, <em>optional</em>) — | |
| Indices of positions of each input sequence tokens in the position embeddings. Selected in the range <code>[0, config.max_position_embeddings - 1]</code>.</p> | |
| <p><a href="../glossary#position-ids">What are position IDs?</a>`,name:"position_ids"},{anchor:"transformers.GroupViTTextModel.forward.output_attentions",description:`<strong>output_attentions</strong> (<code>bool</code>, <em>optional</em>) — | |
| Whether or not to return the attentions tensors of all attention layers. See <code>attentions</code> under returned | |
| tensors for more detail.`,name:"output_attentions"},{anchor:"transformers.GroupViTTextModel.forward.output_hidden_states",description:`<strong>output_hidden_states</strong> (<code>bool</code>, <em>optional</em>) — | |
| Whether or not to return the hidden states of all layers. See <code>hidden_states</code> under returned tensors for | |
| more detail.`,name:"output_hidden_states"},{anchor:"transformers.GroupViTTextModel.forward.return_dict",description:`<strong>return_dict</strong> (<code>bool</code>, <em>optional</em>) — | |
| Whether or not to return a <a href="/docs/transformers/pr_33174/en/main_classes/output#transformers.utils.ModelOutput">ModelOutput</a> instead of a plain tuple.`,name:"return_dict"}],source:"https://github.com/huggingface/transformers/blob/vr_33174/src/transformers/models/groupvit/modeling_groupvit.py#L1149",returnDescription:`<script context="module">export const metadata = 'undefined';<\/script> | |
| <p>A <a | |
| href="/docs/transformers/pr_33174/en/main_classes/output#transformers.modeling_outputs.BaseModelOutputWithPooling" | |
| >transformers.modeling_outputs.BaseModelOutputWithPooling</a> or a tuple of | |
| <code>torch.FloatTensor</code> (if <code>return_dict=False</code> is passed or when <code>config.return_dict=False</code>) comprising various | |
| elements depending on the configuration (<code><class 'transformers.models.groupvit.configuration_groupvit.GroupViTTextConfig'></code>) and inputs.</p> | |
| <ul> | |
| <li> | |
| <p><strong>last_hidden_state</strong> (<code>torch.FloatTensor</code> of shape <code>(batch_size, sequence_length, hidden_size)</code>) — Sequence of hidden-states at the output of the last layer of the model.</p> | |
| </li> | |
| <li> | |
| <p><strong>pooler_output</strong> (<code>torch.FloatTensor</code> of shape <code>(batch_size, hidden_size)</code>) — Last layer hidden-state of the first token of the sequence (classification token) after further processing | |
| through the layers used for the auxiliary pretraining task. E.g. for BERT-family of models, this returns | |
| the classification token after processing through a linear layer and a tanh activation function. The linear | |
| layer weights are trained from the next sentence prediction (classification) objective during pretraining.</p> | |
| </li> | |
| <li> | |
| <p><strong>hidden_states</strong> (<code>tuple(torch.FloatTensor)</code>, <em>optional</em>, returned when <code>output_hidden_states=True</code> is passed or when <code>config.output_hidden_states=True</code>) — Tuple of <code>torch.FloatTensor</code> (one for the output of the embeddings, if the model has an embedding layer, + | |
| one for the output of each layer) of shape <code>(batch_size, sequence_length, hidden_size)</code>.</p> | |
| <p>Hidden-states of the model at the output of each layer plus the optional initial embedding outputs.</p> | |
| </li> | |
| <li> | |
| <p><strong>attentions</strong> (<code>tuple(torch.FloatTensor)</code>, <em>optional</em>, returned when <code>output_attentions=True</code> is passed or when <code>config.output_attentions=True</code>) — Tuple of <code>torch.FloatTensor</code> (one for each layer) of shape <code>(batch_size, num_heads, sequence_length, sequence_length)</code>.</p> | |
| <p>Attentions weights after the attention softmax, used to compute the weighted average in the self-attention | |
| heads.</p> | |
| </li> | |
| </ul> | |
| `,returnType:`<script context="module">export const metadata = 'undefined';<\/script> | |
| <p><a | |
| href="/docs/transformers/pr_33174/en/main_classes/output#transformers.modeling_outputs.BaseModelOutputWithPooling" | |
| >transformers.modeling_outputs.BaseModelOutputWithPooling</a> or <code>tuple(torch.FloatTensor)</code></p> | |
| `}}),ee=new et({props:{$$slots:{default:[Mt]},$$scope:{ctx:w}}}),le=new Xe({props:{anchor:"transformers.GroupViTTextModel.forward.example",$$slots:{default:[yt]},$$scope:{ctx:w}}}),ge=new Le({props:{title:"GroupViTVisionModel",local:"transformers.GroupViTVisionModel",headingTag:"h2"}}),he=new pe({props:{name:"class transformers.GroupViTVisionModel",anchor:"transformers.GroupViTVisionModel",parameters:[{name:"config",val:": GroupViTVisionConfig"}],source:"https://github.com/huggingface/transformers/blob/vr_33174/src/transformers/models/groupvit/modeling_groupvit.py#L1245"}}),Ze=new pe({props:{name:"forward",anchor:"transformers.GroupViTVisionModel.forward",parameters:[{name:"pixel_values",val:": Optional = None"},{name:"output_attentions",val:": Optional = None"},{name:"output_hidden_states",val:": Optional = None"},{name:"return_dict",val:": Optional = None"}],parametersDescription:[{anchor:"transformers.GroupViTVisionModel.forward.pixel_values",description:`<strong>pixel_values</strong> (<code>torch.FloatTensor</code> of shape <code>(batch_size, num_channels, height, width)</code>) — | |
| Pixel values. Padding will be ignored by default should you provide it. Pixel values can be obtained using | |
| <a href="/docs/transformers/pr_33174/en/model_doc/auto#transformers.AutoImageProcessor">AutoImageProcessor</a>. See <a href="/docs/transformers/pr_33174/en/model_doc/layoutlmv2#transformers.LayoutLMv2FeatureExtractor.__call__">CLIPImageProcessor.<strong>call</strong>()</a> for details.`,name:"pixel_values"},{anchor:"transformers.GroupViTVisionModel.forward.output_attentions",description:`<strong>output_attentions</strong> (<code>bool</code>, <em>optional</em>) — | |
| Whether or not to return the attentions tensors of all attention layers. See <code>attentions</code> under returned | |
| tensors for more detail.`,name:"output_attentions"},{anchor:"transformers.GroupViTVisionModel.forward.output_hidden_states",description:`<strong>output_hidden_states</strong> (<code>bool</code>, <em>optional</em>) — | |
| Whether or not to return the hidden states of all layers. See <code>hidden_states</code> under returned tensors for | |
| more detail.`,name:"output_hidden_states"},{anchor:"transformers.GroupViTVisionModel.forward.return_dict",description:`<strong>return_dict</strong> (<code>bool</code>, <em>optional</em>) — | |
| Whether or not to return a <a href="/docs/transformers/pr_33174/en/main_classes/output#transformers.utils.ModelOutput">ModelOutput</a> instead of a plain tuple.`,name:"return_dict"}],source:"https://github.com/huggingface/transformers/blob/vr_33174/src/transformers/models/groupvit/modeling_groupvit.py#L1258",returnDescription:`<script context="module">export const metadata = 'undefined';<\/script> | |
| <p>A <a | |
| href="/docs/transformers/pr_33174/en/main_classes/output#transformers.modeling_outputs.BaseModelOutputWithPooling" | |
| >transformers.modeling_outputs.BaseModelOutputWithPooling</a> or a tuple of | |
| <code>torch.FloatTensor</code> (if <code>return_dict=False</code> is passed or when <code>config.return_dict=False</code>) comprising various | |
| elements depending on the configuration (<code><class 'transformers.models.groupvit.configuration_groupvit.GroupViTVisionConfig'></code>) and inputs.</p> | |
| <ul> | |
| <li> | |
| <p><strong>last_hidden_state</strong> (<code>torch.FloatTensor</code> of shape <code>(batch_size, sequence_length, hidden_size)</code>) — Sequence of hidden-states at the output of the last layer of the model.</p> | |
| </li> | |
| <li> | |
| <p><strong>pooler_output</strong> (<code>torch.FloatTensor</code> of shape <code>(batch_size, hidden_size)</code>) — Last layer hidden-state of the first token of the sequence (classification token) after further processing | |
| through the layers used for the auxiliary pretraining task. E.g. for BERT-family of models, this returns | |
| the classification token after processing through a linear layer and a tanh activation function. The linear | |
| layer weights are trained from the next sentence prediction (classification) objective during pretraining.</p> | |
| </li> | |
| <li> | |
| <p><strong>hidden_states</strong> (<code>tuple(torch.FloatTensor)</code>, <em>optional</em>, returned when <code>output_hidden_states=True</code> is passed or when <code>config.output_hidden_states=True</code>) — Tuple of <code>torch.FloatTensor</code> (one for the output of the embeddings, if the model has an embedding layer, + | |
| one for the output of each layer) of shape <code>(batch_size, sequence_length, hidden_size)</code>.</p> | |
| <p>Hidden-states of the model at the output of each layer plus the optional initial embedding outputs.</p> | |
| </li> | |
| <li> | |
| <p><strong>attentions</strong> (<code>tuple(torch.FloatTensor)</code>, <em>optional</em>, returned when <code>output_attentions=True</code> is passed or when <code>config.output_attentions=True</code>) — Tuple of <code>torch.FloatTensor</code> (one for each layer) of shape <code>(batch_size, num_heads, sequence_length, sequence_length)</code>.</p> | |
| <p>Attentions weights after the attention softmax, used to compute the weighted average in the self-attention | |
| heads.</p> | |
| </li> | |
| </ul> | |
| `,returnType:`<script context="module">export const metadata = 'undefined';<\/script> | |
| <p><a | |
| href="/docs/transformers/pr_33174/en/main_classes/output#transformers.modeling_outputs.BaseModelOutputWithPooling" | |
| >transformers.modeling_outputs.BaseModelOutputWithPooling</a> or <code>tuple(torch.FloatTensor)</code></p> | |
| `}}),oe=new et({props:{$$slots:{default:[bt]},$$scope:{ctx:w}}}),q=new Xe({props:{anchor:"transformers.GroupViTVisionModel.forward.example",$$slots:{default:[vt]},$$scope:{ctx:w}}}),{c(){h(e.$$.fragment),p=a(),o=f("div"),h(n.$$.fragment),m=a(),t=f("p"),t.innerHTML=$,Ue=a(),k=f("div"),h(X.$$.fragment),Ce=a(),U=f("p"),U.innerHTML=Ve,W=a(),h(j.$$.fragment),se=a(),h(re.$$.fragment),Be=a(),ce=f("div"),h(S.$$.fragment),ze=a(),ae=f("p"),ae.innerHTML=Re,ue=a(),h(Y.$$.fragment),We=a(),h(ie.$$.fragment),He=a(),me=f("div"),h(Q.$$.fragment),Ie=a(),be=f("p"),be.innerHTML=Ye,I=a(),h(A.$$.fragment),D=a(),h(R.$$.fragment),Qe=a(),h(ve.$$.fragment),ke=a(),xe=f("div"),h(H.$$.fragment),Ae=a(),F=f("div"),h(O.$$.fragment),K=a(),$e=f("p"),$e.innerHTML=qe,fe=a(),h(ee.$$.fragment),Fe=a(),h(le.$$.fragment),te=a(),h(ge.$$.fragment),Ge=a(),de=f("div"),h(he.$$.fragment),Pe=a(),C=f("div"),h(Ze.$$.fragment),je=a(),E=f("p"),E.innerHTML=De,Z=a(),h(oe.$$.fragment),ne=a(),h(q.$$.fragment),this.h()},l(d){_(e.$$.fragment,d),p=i(d),o=g(d,"DIV",{class:!0});var V=L(o);_(n.$$.fragment,V),m=i(V),t=g(V,"P",{"data-svelte-h":!0}),G(t)!=="svelte-1gjh92c"&&(t.innerHTML=$),Ue=i(V),k=g(V,"DIV",{class:!0});var _e=L(k);_(X.$$.fragment,_e),Ce=i(_e),U=g(_e,"P",{"data-svelte-h":!0}),G(U)!=="svelte-22nl9z"&&(U.innerHTML=Ve),W=i(_e),_(j.$$.fragment,_e),se=i(_e),_(re.$$.fragment,_e),_e.forEach(r),Be=i(V),ce=g(V,"DIV",{class:!0});var z=L(ce);_(S.$$.fragment,z),ze=i(z),ae=g(z,"P",{"data-svelte-h":!0}),G(ae)!=="svelte-22nl9z"&&(ae.innerHTML=Re),ue=i(z),_(Y.$$.fragment,z),We=i(z),_(ie.$$.fragment,z),z.forEach(r),He=i(V),me=g(V,"DIV",{class:!0});var Te=L(me);_(Q.$$.fragment,Te),Ie=i(Te),be=g(Te,"P",{"data-svelte-h":!0}),G(be)!=="svelte-22nl9z"&&(be.innerHTML=Ye),I=i(Te),_(A.$$.fragment,Te),D=i(Te),_(R.$$.fragment,Te),Te.forEach(r),V.forEach(r),Qe=i(d),_(ve.$$.fragment,d),ke=i(d),xe=g(d,"DIV",{class:!0});var l=L(xe);_(H.$$.fragment,l),Ae=i(l),F=g(l,"DIV",{class:!0});var v=L(F);_(O.$$.fragment,v),K=i(v),$e=g(v,"P",{"data-svelte-h":!0}),G($e)!=="svelte-1xbv1sr"&&($e.innerHTML=qe),fe=i(v),_(ee.$$.fragment,v),Fe=i(v),_(le.$$.fragment,v),v.forEach(r),l.forEach(r),te=i(d),_(ge.$$.fragment,d),Ge=i(d),de=g(d,"DIV",{class:!0});var B=L(de);_(he.$$.fragment,B),Pe=i(B),C=g(B,"DIV",{class:!0});var J=L(C);_(Ze.$$.fragment,J),je=i(J),E=g(J,"P",{"data-svelte-h":!0}),G(E)!=="svelte-18bakez"&&(E.innerHTML=De),Z=i(J),_(oe.$$.fragment,J),ne=i(J),_(q.$$.fragment,J),J.forEach(r),B.forEach(r),this.h()},h(){P(k,"class","docstring border-l-2 border-t-2 pl-4 pt-3.5 border-gray-100 rounded-tl-xl mb-6 mt-8"),P(ce,"class","docstring border-l-2 border-t-2 pl-4 pt-3.5 border-gray-100 rounded-tl-xl mb-6 mt-8"),P(me,"class","docstring border-l-2 border-t-2 pl-4 pt-3.5 border-gray-100 rounded-tl-xl mb-6 mt-8"),P(o,"class","docstring border-l-2 border-t-2 pl-4 pt-3.5 border-gray-100 rounded-tl-xl mb-6 mt-8"),P(F,"class","docstring border-l-2 border-t-2 pl-4 pt-3.5 border-gray-100 rounded-tl-xl mb-6 mt-8"),P(xe,"class","docstring border-l-2 border-t-2 pl-4 pt-3.5 border-gray-100 rounded-tl-xl mb-6 mt-8"),P(C,"class","docstring border-l-2 border-t-2 pl-4 pt-3.5 border-gray-100 rounded-tl-xl mb-6 mt-8"),P(de,"class","docstring border-l-2 border-t-2 pl-4 pt-3.5 border-gray-100 rounded-tl-xl mb-6 mt-8")},m(d,V){T(e,d,V),c(d,p,V),c(d,o,V),T(n,o,null),u(o,m),u(o,t),u(o,Ue),u(o,k),T(X,k,null),u(k,Ce),u(k,U),u(k,W),T(j,k,null),u(k,se),T(re,k,null),u(o,Be),u(o,ce),T(S,ce,null),u(ce,ze),u(ce,ae),u(ce,ue),T(Y,ce,null),u(ce,We),T(ie,ce,null),u(o,He),u(o,me),T(Q,me,null),u(me,Ie),u(me,be),u(me,I),T(A,me,null),u(me,D),T(R,me,null),c(d,Qe,V),T(ve,d,V),c(d,ke,V),c(d,xe,V),T(H,xe,null),u(xe,Ae),u(xe,F),T(O,F,null),u(F,K),u(F,$e),u(F,fe),T(ee,F,null),u(F,Fe),T(le,F,null),c(d,te,V),T(ge,d,V),c(d,Ge,V),c(d,de,V),T(he,de,null),u(de,Pe),u(de,C),T(Ze,C,null),u(C,je),u(C,E),u(C,Z),T(oe,C,null),u(C,ne),T(q,C,null),Oe=!0},p(d,V){const _e={};V&2&&(_e.$$scope={dirty:V,ctx:d}),j.$set(_e);const z={};V&2&&(z.$$scope={dirty:V,ctx:d}),re.$set(z);const Te={};V&2&&(Te.$$scope={dirty:V,ctx:d}),Y.$set(Te);const l={};V&2&&(l.$$scope={dirty:V,ctx:d}),ie.$set(l);const v={};V&2&&(v.$$scope={dirty:V,ctx:d}),A.$set(v);const B={};V&2&&(B.$$scope={dirty:V,ctx:d}),R.$set(B);const J={};V&2&&(J.$$scope={dirty:V,ctx:d}),ee.$set(J);const Me={};V&2&&(Me.$$scope={dirty:V,ctx:d}),le.$set(Me);const we={};V&2&&(we.$$scope={dirty:V,ctx:d}),oe.$set(we);const ye={};V&2&&(ye.$$scope={dirty:V,ctx:d}),q.$set(ye)},i(d){Oe||(M(e.$$.fragment,d),M(n.$$.fragment,d),M(X.$$.fragment,d),M(j.$$.fragment,d),M(re.$$.fragment,d),M(S.$$.fragment,d),M(Y.$$.fragment,d),M(ie.$$.fragment,d),M(Q.$$.fragment,d),M(A.$$.fragment,d),M(R.$$.fragment,d),M(ve.$$.fragment,d),M(H.$$.fragment,d),M(O.$$.fragment,d),M(ee.$$.fragment,d),M(le.$$.fragment,d),M(ge.$$.fragment,d),M(he.$$.fragment,d),M(Ze.$$.fragment,d),M(oe.$$.fragment,d),M(q.$$.fragment,d),Oe=!0)},o(d){y(e.$$.fragment,d),y(n.$$.fragment,d),y(X.$$.fragment,d),y(j.$$.fragment,d),y(re.$$.fragment,d),y(S.$$.fragment,d),y(Y.$$.fragment,d),y(ie.$$.fragment,d),y(Q.$$.fragment,d),y(A.$$.fragment,d),y(R.$$.fragment,d),y(ve.$$.fragment,d),y(H.$$.fragment,d),y(O.$$.fragment,d),y(ee.$$.fragment,d),y(le.$$.fragment,d),y(ge.$$.fragment,d),y(he.$$.fragment,d),y(Ze.$$.fragment,d),y(oe.$$.fragment,d),y(q.$$.fragment,d),Oe=!1},d(d){d&&(r(p),r(o),r(Qe),r(ke),r(xe),r(te),r(Ge),r(de)),b(e,d),b(n),b(X),b(j),b(re),b(S),b(Y),b(ie),b(Q),b(A),b(R),b(ve,d),b(H),b(O),b(ee),b(le),b(ge,d),b(he),b(Ze),b(oe),b(q)}}}function wt(w){let e,p;return e=new nt({props:{$$slots:{default:[$t]},$$scope:{ctx:w}}}),{c(){h(e.$$.fragment)},l(o){_(e.$$.fragment,o)},m(o,n){T(e,o,n),p=!0},p(o,n){const m={};n&2&&(m.$$scope={dirty:n,ctx:o}),e.$set(m)},i(o){p||(M(e.$$.fragment,o),p=!0)},o(o){y(e.$$.fragment,o),p=!1},d(o){b(e,o)}}}function Vt(w){let e,p="TF 2.0 models accepts two formats as inputs:",o,n,m="<li>having all inputs as keyword arguments (like PyTorch models), or</li> <li>having all inputs as a list, tuple or dict in the first positional arguments.</li>",t,$,Ue=`This second option is useful when using <code>keras.Model.fit</code> method which currently requires having all the | |
| tensors in the first argument of the model call function: <code>model(inputs)</code>.`,k,X,Ce=`If you choose this second option, there are three possibilities you can use to gather all the input Tensors in the | |
| first positional argument :`,U,Ve,W=`<li>a single Tensor with <code>input_ids</code> only and nothing else: <code>model(input_ids)</code></li> <li>a list of varying length with one or several input Tensors IN THE ORDER given in the docstring: | |
| <code>model([input_ids, attention_mask])</code> or <code>model([input_ids, attention_mask, token_type_ids])</code></li> <li>a dictionary with one or several input Tensors associated to the input names given in the docstring: | |
| <code>model({"input_ids": input_ids, "token_type_ids": token_type_ids})</code></li>`;return{c(){e=f("p"),e.textContent=p,o=a(),n=f("ul"),n.innerHTML=m,t=a(),$=f("p"),$.innerHTML=Ue,k=a(),X=f("p"),X.textContent=Ce,U=a(),Ve=f("ul"),Ve.innerHTML=W},l(j){e=g(j,"P",{"data-svelte-h":!0}),G(e)!=="svelte-ha0dwg"&&(e.textContent=p),o=i(j),n=g(j,"UL",{"data-svelte-h":!0}),G(n)!=="svelte-1ar3osv"&&(n.innerHTML=m),t=i(j),$=g(j,"P",{"data-svelte-h":!0}),G($)!=="svelte-14kkttf"&&($.innerHTML=Ue),k=i(j),X=g(j,"P",{"data-svelte-h":!0}),G(X)!=="svelte-11o7mts"&&(X.textContent=Ce),U=i(j),Ve=g(j,"UL",{"data-svelte-h":!0}),G(Ve)!=="svelte-15scerc"&&(Ve.innerHTML=W)},m(j,se){c(j,e,se),c(j,o,se),c(j,n,se),c(j,t,se),c(j,$,se),c(j,k,se),c(j,X,se),c(j,U,se),c(j,Ve,se)},p:N,d(j){j&&(r(e),r(o),r(n),r(t),r($),r(k),r(X),r(U),r(Ve))}}}function xt(w){let e,p=`Although the recipe for forward pass needs to be defined within this function, one should call the <code>Module</code> | |
| instance afterwards instead of this since the former takes care of running the pre and post processing steps while | |
| the latter silently ignores them.`;return{c(){e=f("p"),e.innerHTML=p},l(o){e=g(o,"P",{"data-svelte-h":!0}),G(e)!=="svelte-fincs2"&&(e.innerHTML=p)},m(o,n){c(o,e,n)},p:N,d(o){o&&r(e)}}}function Gt(w){let e,p="Examples:",o,n,m;return n=new Se({props:{code:"ZnJvbSUyMFBJTCUyMGltcG9ydCUyMEltYWdlJTBBaW1wb3J0JTIwcmVxdWVzdHMlMEFmcm9tJTIwdHJhbnNmb3JtZXJzJTIwaW1wb3J0JTIwQXV0b1Byb2Nlc3NvciUyQyUyMFRGR3JvdXBWaVRNb2RlbCUwQWltcG9ydCUyMHRlbnNvcmZsb3clMjBhcyUyMHRmJTBBJTBBbW9kZWwlMjAlM0QlMjBURkdyb3VwVmlUTW9kZWwuZnJvbV9wcmV0cmFpbmVkKCUyMm52aWRpYSUyRmdyb3Vwdml0LWdjYy15ZmNjJTIyKSUwQXByb2Nlc3NvciUyMCUzRCUyMEF1dG9Qcm9jZXNzb3IuZnJvbV9wcmV0cmFpbmVkKCUyMm52aWRpYSUyRmdyb3Vwdml0LWdjYy15ZmNjJTIyKSUwQSUwQXVybCUyMCUzRCUyMCUyMmh0dHAlM0ElMkYlMkZpbWFnZXMuY29jb2RhdGFzZXQub3JnJTJGdmFsMjAxNyUyRjAwMDAwMDAzOTc2OS5qcGclMjIlMEFpbWFnZSUyMCUzRCUyMEltYWdlLm9wZW4ocmVxdWVzdHMuZ2V0KHVybCUyQyUyMHN0cmVhbSUzRFRydWUpLnJhdyklMEElMEFpbnB1dHMlMjAlM0QlMjBwcm9jZXNzb3IoJTBBJTIwJTIwJTIwJTIwdGV4dCUzRCU1QiUyMmElMjBwaG90byUyMG9mJTIwYSUyMGNhdCUyMiUyQyUyMCUyMmElMjBwaG90byUyMG9mJTIwYSUyMGRvZyUyMiU1RCUyQyUyMGltYWdlcyUzRGltYWdlJTJDJTIwcmV0dXJuX3RlbnNvcnMlM0QlMjJ0ZiUyMiUyQyUyMHBhZGRpbmclM0RUcnVlJTBBKSUwQSUwQW91dHB1dHMlMjAlM0QlMjBtb2RlbCgqKmlucHV0cyklMEFsb2dpdHNfcGVyX2ltYWdlJTIwJTNEJTIwb3V0cHV0cy5sb2dpdHNfcGVyX2ltYWdlJTIwJTIwJTIzJTIwdGhpcyUyMGlzJTIwdGhlJTIwaW1hZ2UtdGV4dCUyMHNpbWlsYXJpdHklMjBzY29yZSUwQXByb2JzJTIwJTNEJTIwdGYubWF0aC5zb2Z0bWF4KGxvZ2l0c19wZXJfaW1hZ2UlMkMlMjBheGlzJTNEMSklMjAlMjAlMjMlMjB3ZSUyMGNhbiUyMHRha2UlMjB0aGUlMjBzb2Z0bWF4JTIwdG8lMjBnZXQlMjB0aGUlMjBsYWJlbCUyMHByb2JhYmlsaXRpZXM=",highlighted:`<span class="hljs-meta">>>> </span><span class="hljs-keyword">from</span> PIL <span class="hljs-keyword">import</span> Image | |
| <span class="hljs-meta">>>> </span><span class="hljs-keyword">import</span> requests | |
| <span class="hljs-meta">>>> </span><span class="hljs-keyword">from</span> transformers <span class="hljs-keyword">import</span> AutoProcessor, TFGroupViTModel | |
| <span class="hljs-meta">>>> </span><span class="hljs-keyword">import</span> tensorflow <span class="hljs-keyword">as</span> tf | |
| <span class="hljs-meta">>>> </span>model = TFGroupViTModel.from_pretrained(<span class="hljs-string">"nvidia/groupvit-gcc-yfcc"</span>) | |
| <span class="hljs-meta">>>> </span>processor = AutoProcessor.from_pretrained(<span class="hljs-string">"nvidia/groupvit-gcc-yfcc"</span>) | |
| <span class="hljs-meta">>>> </span>url = <span class="hljs-string">"http://images.cocodataset.org/val2017/000000039769.jpg"</span> | |
| <span class="hljs-meta">>>> </span>image = Image.<span class="hljs-built_in">open</span>(requests.get(url, stream=<span class="hljs-literal">True</span>).raw) | |
| <span class="hljs-meta">>>> </span>inputs = processor( | |
| <span class="hljs-meta">... </span> text=[<span class="hljs-string">"a photo of a cat"</span>, <span class="hljs-string">"a photo of a dog"</span>], images=image, return_tensors=<span class="hljs-string">"tf"</span>, padding=<span class="hljs-literal">True</span> | |
| <span class="hljs-meta">... </span>) | |
| <span class="hljs-meta">>>> </span>outputs = model(**inputs) | |
| <span class="hljs-meta">>>> </span>logits_per_image = outputs.logits_per_image <span class="hljs-comment"># this is the image-text similarity score</span> | |
| <span class="hljs-meta">>>> </span>probs = tf.math.softmax(logits_per_image, axis=<span class="hljs-number">1</span>) <span class="hljs-comment"># we can take the softmax to get the label probabilities</span>`,wrap:!1}}),{c(){e=f("p"),e.textContent=p,o=a(),h(n.$$.fragment)},l(t){e=g(t,"P",{"data-svelte-h":!0}),G(e)!=="svelte-kvfsh7"&&(e.textContent=p),o=i(t),_(n.$$.fragment,t)},m(t,$){c(t,e,$),c(t,o,$),T(n,t,$),m=!0},p:N,i(t){m||(M(n.$$.fragment,t),m=!0)},o(t){y(n.$$.fragment,t),m=!1},d(t){t&&(r(e),r(o)),b(n,t)}}}function jt(w){let e,p=`Although the recipe for forward pass needs to be defined within this function, one should call the <code>Module</code> | |
| instance afterwards instead of this since the former takes care of running the pre and post processing steps while | |
| the latter silently ignores them.`;return{c(){e=f("p"),e.innerHTML=p},l(o){e=g(o,"P",{"data-svelte-h":!0}),G(e)!=="svelte-fincs2"&&(e.innerHTML=p)},m(o,n){c(o,e,n)},p:N,d(o){o&&r(e)}}}function kt(w){let e,p="Examples:",o,n,m;return n=new Se({props:{code:"ZnJvbSUyMHRyYW5zZm9ybWVycyUyMGltcG9ydCUyMENMSVBUb2tlbml6ZXIlMkMlMjBURkdyb3VwVmlUTW9kZWwlMEElMEFtb2RlbCUyMCUzRCUyMFRGR3JvdXBWaVRNb2RlbC5mcm9tX3ByZXRyYWluZWQoJTIybnZpZGlhJTJGZ3JvdXB2aXQtZ2NjLXlmY2MlMjIpJTBBdG9rZW5pemVyJTIwJTNEJTIwQ0xJUFRva2VuaXplci5mcm9tX3ByZXRyYWluZWQoJTIybnZpZGlhJTJGZ3JvdXB2aXQtZ2NjLXlmY2MlMjIpJTBBJTBBaW5wdXRzJTIwJTNEJTIwdG9rZW5pemVyKCU1QiUyMmElMjBwaG90byUyMG9mJTIwYSUyMGNhdCUyMiUyQyUyMCUyMmElMjBwaG90byUyMG9mJTIwYSUyMGRvZyUyMiU1RCUyQyUyMHBhZGRpbmclM0RUcnVlJTJDJTIwcmV0dXJuX3RlbnNvcnMlM0QlMjJ0ZiUyMiklMEF0ZXh0X2ZlYXR1cmVzJTIwJTNEJTIwbW9kZWwuZ2V0X3RleHRfZmVhdHVyZXMoKippbnB1dHMp",highlighted:`<span class="hljs-meta">>>> </span><span class="hljs-keyword">from</span> transformers <span class="hljs-keyword">import</span> CLIPTokenizer, TFGroupViTModel | |
| <span class="hljs-meta">>>> </span>model = TFGroupViTModel.from_pretrained(<span class="hljs-string">"nvidia/groupvit-gcc-yfcc"</span>) | |
| <span class="hljs-meta">>>> </span>tokenizer = CLIPTokenizer.from_pretrained(<span class="hljs-string">"nvidia/groupvit-gcc-yfcc"</span>) | |
| <span class="hljs-meta">>>> </span>inputs = tokenizer([<span class="hljs-string">"a photo of a cat"</span>, <span class="hljs-string">"a photo of a dog"</span>], padding=<span class="hljs-literal">True</span>, return_tensors=<span class="hljs-string">"tf"</span>) | |
| <span class="hljs-meta">>>> </span>text_features = model.get_text_features(**inputs)`,wrap:!1}}),{c(){e=f("p"),e.textContent=p,o=a(),h(n.$$.fragment)},l(t){e=g(t,"P",{"data-svelte-h":!0}),G(e)!=="svelte-kvfsh7"&&(e.textContent=p),o=i(t),_(n.$$.fragment,t)},m(t,$){c(t,e,$),c(t,o,$),T(n,t,$),m=!0},p:N,i(t){m||(M(n.$$.fragment,t),m=!0)},o(t){y(n.$$.fragment,t),m=!1},d(t){t&&(r(e),r(o)),b(n,t)}}}function Jt(w){let e,p=`Although the recipe for forward pass needs to be defined within this function, one should call the <code>Module</code> | |
| instance afterwards instead of this since the former takes care of running the pre and post processing steps while | |
| the latter silently ignores them.`;return{c(){e=f("p"),e.innerHTML=p},l(o){e=g(o,"P",{"data-svelte-h":!0}),G(e)!=="svelte-fincs2"&&(e.innerHTML=p)},m(o,n){c(o,e,n)},p:N,d(o){o&&r(e)}}}function Ut(w){let e,p="Examples:",o,n,m;return n=new Se({props:{code:"ZnJvbSUyMFBJTCUyMGltcG9ydCUyMEltYWdlJTBBaW1wb3J0JTIwcmVxdWVzdHMlMEFmcm9tJTIwdHJhbnNmb3JtZXJzJTIwaW1wb3J0JTIwQXV0b1Byb2Nlc3NvciUyQyUyMFRGR3JvdXBWaVRNb2RlbCUwQSUwQW1vZGVsJTIwJTNEJTIwVEZHcm91cFZpVE1vZGVsLmZyb21fcHJldHJhaW5lZCglMjJudmlkaWElMkZncm91cHZpdC1nY2MteWZjYyUyMiklMEFwcm9jZXNzb3IlMjAlM0QlMjBBdXRvUHJvY2Vzc29yLmZyb21fcHJldHJhaW5lZCglMjJudmlkaWElMkZncm91cHZpdC1nY2MteWZjYyUyMiklMEElMEF1cmwlMjAlM0QlMjAlMjJodHRwJTNBJTJGJTJGaW1hZ2VzLmNvY29kYXRhc2V0Lm9yZyUyRnZhbDIwMTclMkYwMDAwMDAwMzk3NjkuanBnJTIyJTBBaW1hZ2UlMjAlM0QlMjBJbWFnZS5vcGVuKHJlcXVlc3RzLmdldCh1cmwlMkMlMjBzdHJlYW0lM0RUcnVlKS5yYXcpJTBBJTBBaW5wdXRzJTIwJTNEJTIwcHJvY2Vzc29yKGltYWdlcyUzRGltYWdlJTJDJTIwcmV0dXJuX3RlbnNvcnMlM0QlMjJ0ZiUyMiklMEElMEFpbWFnZV9mZWF0dXJlcyUyMCUzRCUyMG1vZGVsLmdldF9pbWFnZV9mZWF0dXJlcygqKmlucHV0cyk=",highlighted:`<span class="hljs-meta">>>> </span><span class="hljs-keyword">from</span> PIL <span class="hljs-keyword">import</span> Image | |
| <span class="hljs-meta">>>> </span><span class="hljs-keyword">import</span> requests | |
| <span class="hljs-meta">>>> </span><span class="hljs-keyword">from</span> transformers <span class="hljs-keyword">import</span> AutoProcessor, TFGroupViTModel | |
| <span class="hljs-meta">>>> </span>model = TFGroupViTModel.from_pretrained(<span class="hljs-string">"nvidia/groupvit-gcc-yfcc"</span>) | |
| <span class="hljs-meta">>>> </span>processor = AutoProcessor.from_pretrained(<span class="hljs-string">"nvidia/groupvit-gcc-yfcc"</span>) | |
| <span class="hljs-meta">>>> </span>url = <span class="hljs-string">"http://images.cocodataset.org/val2017/000000039769.jpg"</span> | |
| <span class="hljs-meta">>>> </span>image = Image.<span class="hljs-built_in">open</span>(requests.get(url, stream=<span class="hljs-literal">True</span>).raw) | |
| <span class="hljs-meta">>>> </span>inputs = processor(images=image, return_tensors=<span class="hljs-string">"tf"</span>) | |
| <span class="hljs-meta">>>> </span>image_features = model.get_image_features(**inputs)`,wrap:!1}}),{c(){e=f("p"),e.textContent=p,o=a(),h(n.$$.fragment)},l(t){e=g(t,"P",{"data-svelte-h":!0}),G(e)!=="svelte-kvfsh7"&&(e.textContent=p),o=i(t),_(n.$$.fragment,t)},m(t,$){c(t,e,$),c(t,o,$),T(n,t,$),m=!0},p:N,i(t){m||(M(n.$$.fragment,t),m=!0)},o(t){y(n.$$.fragment,t),m=!1},d(t){t&&(r(e),r(o)),b(n,t)}}}function Ct(w){let e,p=`Although the recipe for forward pass needs to be defined within this function, one should call the <code>Module</code> | |
| instance afterwards instead of this since the former takes care of running the pre and post processing steps while | |
| the latter silently ignores them.`;return{c(){e=f("p"),e.innerHTML=p},l(o){e=g(o,"P",{"data-svelte-h":!0}),G(e)!=="svelte-fincs2"&&(e.innerHTML=p)},m(o,n){c(o,e,n)},p:N,d(o){o&&r(e)}}}function zt(w){let e,p="Examples:",o,n,m;return n=new Se({props:{code:"ZnJvbSUyMHRyYW5zZm9ybWVycyUyMGltcG9ydCUyMENMSVBUb2tlbml6ZXIlMkMlMjBURkdyb3VwVmlUVGV4dE1vZGVsJTBBJTBBdG9rZW5pemVyJTIwJTNEJTIwQ0xJUFRva2VuaXplci5mcm9tX3ByZXRyYWluZWQoJTIybnZpZGlhJTJGZ3JvdXB2aXQtZ2NjLXlmY2MlMjIpJTBBbW9kZWwlMjAlM0QlMjBURkdyb3VwVmlUVGV4dE1vZGVsLmZyb21fcHJldHJhaW5lZCglMjJudmlkaWElMkZncm91cHZpdC1nY2MteWZjYyUyMiklMEElMEFpbnB1dHMlMjAlM0QlMjB0b2tlbml6ZXIoJTVCJTIyYSUyMHBob3RvJTIwb2YlMjBhJTIwY2F0JTIyJTJDJTIwJTIyYSUyMHBob3RvJTIwb2YlMjBhJTIwZG9nJTIyJTVEJTJDJTIwcGFkZGluZyUzRFRydWUlMkMlMjByZXR1cm5fdGVuc29ycyUzRCUyMnRmJTIyKSUwQSUwQW91dHB1dHMlMjAlM0QlMjBtb2RlbCgqKmlucHV0cyklMEFsYXN0X2hpZGRlbl9zdGF0ZSUyMCUzRCUyMG91dHB1dHMubGFzdF9oaWRkZW5fc3RhdGUlMEFwb29sZWRfb3V0cHV0JTIwJTNEJTIwb3V0cHV0cy5wb29sZXJfb3V0cHV0JTIwJTIwJTIzJTIwcG9vbGVkJTIwKEVPUyUyMHRva2VuKSUyMHN0YXRlcw==",highlighted:`<span class="hljs-meta">>>> </span><span class="hljs-keyword">from</span> transformers <span class="hljs-keyword">import</span> CLIPTokenizer, TFGroupViTTextModel | |
| <span class="hljs-meta">>>> </span>tokenizer = CLIPTokenizer.from_pretrained(<span class="hljs-string">"nvidia/groupvit-gcc-yfcc"</span>) | |
| <span class="hljs-meta">>>> </span>model = TFGroupViTTextModel.from_pretrained(<span class="hljs-string">"nvidia/groupvit-gcc-yfcc"</span>) | |
| <span class="hljs-meta">>>> </span>inputs = tokenizer([<span class="hljs-string">"a photo of a cat"</span>, <span class="hljs-string">"a photo of a dog"</span>], padding=<span class="hljs-literal">True</span>, return_tensors=<span class="hljs-string">"tf"</span>) | |
| <span class="hljs-meta">>>> </span>outputs = model(**inputs) | |
| <span class="hljs-meta">>>> </span>last_hidden_state = outputs.last_hidden_state | |
| <span class="hljs-meta">>>> </span>pooled_output = outputs.pooler_output <span class="hljs-comment"># pooled (EOS token) states</span>`,wrap:!1}}),{c(){e=f("p"),e.textContent=p,o=a(),h(n.$$.fragment)},l(t){e=g(t,"P",{"data-svelte-h":!0}),G(e)!=="svelte-kvfsh7"&&(e.textContent=p),o=i(t),_(n.$$.fragment,t)},m(t,$){c(t,e,$),c(t,o,$),T(n,t,$),m=!0},p:N,i(t){m||(M(n.$$.fragment,t),m=!0)},o(t){y(n.$$.fragment,t),m=!1},d(t){t&&(r(e),r(o)),b(n,t)}}}function Wt(w){let e,p=`Although the recipe for forward pass needs to be defined within this function, one should call the <code>Module</code> | |
| instance afterwards instead of this since the former takes care of running the pre and post processing steps while | |
| the latter silently ignores them.`;return{c(){e=f("p"),e.innerHTML=p},l(o){e=g(o,"P",{"data-svelte-h":!0}),G(e)!=="svelte-fincs2"&&(e.innerHTML=p)},m(o,n){c(o,e,n)},p:N,d(o){o&&r(e)}}}function It(w){let e,p="Examples:",o,n,m;return n=new Se({props:{code:"ZnJvbSUyMFBJTCUyMGltcG9ydCUyMEltYWdlJTBBaW1wb3J0JTIwcmVxdWVzdHMlMEFmcm9tJTIwdHJhbnNmb3JtZXJzJTIwaW1wb3J0JTIwQXV0b1Byb2Nlc3NvciUyQyUyMFRGR3JvdXBWaVRWaXNpb25Nb2RlbCUwQSUwQXByb2Nlc3NvciUyMCUzRCUyMEF1dG9Qcm9jZXNzb3IuZnJvbV9wcmV0cmFpbmVkKCUyMm52aWRpYSUyRmdyb3Vwdml0LWdjYy15ZmNjJTIyKSUwQW1vZGVsJTIwJTNEJTIwVEZHcm91cFZpVFZpc2lvbk1vZGVsLmZyb21fcHJldHJhaW5lZCglMjJudmlkaWElMkZncm91cHZpdC1nY2MteWZjYyUyMiklMEElMEF1cmwlMjAlM0QlMjAlMjJodHRwJTNBJTJGJTJGaW1hZ2VzLmNvY29kYXRhc2V0Lm9yZyUyRnZhbDIwMTclMkYwMDAwMDAwMzk3NjkuanBnJTIyJTBBaW1hZ2UlMjAlM0QlMjBJbWFnZS5vcGVuKHJlcXVlc3RzLmdldCh1cmwlMkMlMjBzdHJlYW0lM0RUcnVlKS5yYXcpJTBBJTBBaW5wdXRzJTIwJTNEJTIwcHJvY2Vzc29yKGltYWdlcyUzRGltYWdlJTJDJTIwcmV0dXJuX3RlbnNvcnMlM0QlMjJ0ZiUyMiklMEElMEFvdXRwdXRzJTIwJTNEJTIwbW9kZWwoKippbnB1dHMpJTBBbGFzdF9oaWRkZW5fc3RhdGUlMjAlM0QlMjBvdXRwdXRzLmxhc3RfaGlkZGVuX3N0YXRlJTBBcG9vbGVkX291dHB1dCUyMCUzRCUyMG91dHB1dHMucG9vbGVyX291dHB1dCUyMCUyMCUyMyUyMHBvb2xlZCUyMENMUyUyMHN0YXRlcw==",highlighted:`<span class="hljs-meta">>>> </span><span class="hljs-keyword">from</span> PIL <span class="hljs-keyword">import</span> Image | |
| <span class="hljs-meta">>>> </span><span class="hljs-keyword">import</span> requests | |
| <span class="hljs-meta">>>> </span><span class="hljs-keyword">from</span> transformers <span class="hljs-keyword">import</span> AutoProcessor, TFGroupViTVisionModel | |
| <span class="hljs-meta">>>> </span>processor = AutoProcessor.from_pretrained(<span class="hljs-string">"nvidia/groupvit-gcc-yfcc"</span>) | |
| <span class="hljs-meta">>>> </span>model = TFGroupViTVisionModel.from_pretrained(<span class="hljs-string">"nvidia/groupvit-gcc-yfcc"</span>) | |
| <span class="hljs-meta">>>> </span>url = <span class="hljs-string">"http://images.cocodataset.org/val2017/000000039769.jpg"</span> | |
| <span class="hljs-meta">>>> </span>image = Image.<span class="hljs-built_in">open</span>(requests.get(url, stream=<span class="hljs-literal">True</span>).raw) | |
| <span class="hljs-meta">>>> </span>inputs = processor(images=image, return_tensors=<span class="hljs-string">"tf"</span>) | |
| <span class="hljs-meta">>>> </span>outputs = model(**inputs) | |
| <span class="hljs-meta">>>> </span>last_hidden_state = outputs.last_hidden_state | |
| <span class="hljs-meta">>>> </span>pooled_output = outputs.pooler_output <span class="hljs-comment"># pooled CLS states</span>`,wrap:!1}}),{c(){e=f("p"),e.textContent=p,o=a(),h(n.$$.fragment)},l(t){e=g(t,"P",{"data-svelte-h":!0}),G(e)!=="svelte-kvfsh7"&&(e.textContent=p),o=i(t),_(n.$$.fragment,t)},m(t,$){c(t,e,$),c(t,o,$),T(n,t,$),m=!0},p:N,i(t){m||(M(n.$$.fragment,t),m=!0)},o(t){y(n.$$.fragment,t),m=!1},d(t){t&&(r(e),r(o)),b(n,t)}}}function Ft(w){let e,p,o,n,m,t,$=`This model inherits from <a href="/docs/transformers/pr_33174/en/main_classes/model#transformers.TFPreTrainedModel">TFPreTrainedModel</a>. Check the superclass documentation for the generic methods the | |
| library implements for all its model (such as downloading or saving, resizing the input embeddings, pruning heads | |
| etc.)`,Ue,k,X=`This model is also a <a href="https://www.tensorflow.org/api_docs/python/tf/keras/Model" rel="nofollow">keras.Model</a> subclass. Use it | |
| as a regular TF 2.0 Keras Model and refer to the TF 2.0 documentation for all matter related to general usage and | |
| behavior.`,Ce,U,Ve,W,j,se,re,Be='The <a href="/docs/transformers/pr_33174/en/model_doc/groupvit#transformers.TFGroupViTModel">TFGroupViTModel</a> forward method, overrides the <code>__call__</code> special method.',ce,S,ze,ae,Re,ue,Y,We,ie,He='The <a href="/docs/transformers/pr_33174/en/model_doc/groupvit#transformers.TFGroupViTModel">TFGroupViTModel</a> forward method, overrides the <code>__call__</code> special method.',me,Q,Ie,be,Ye,I,A,D,R,Qe='The <a href="/docs/transformers/pr_33174/en/model_doc/groupvit#transformers.TFGroupViTModel">TFGroupViTModel</a> forward method, overrides the <code>__call__</code> special method.',ve,ke,xe,H,Ae,F,O,K,$e,qe,fe,ee,Fe,le,te='The <a href="/docs/transformers/pr_33174/en/model_doc/groupvit#transformers.TFGroupViTTextModel">TFGroupViTTextModel</a> forward method, overrides the <code>__call__</code> special method.',ge,Ge,de,he,Pe,C,Ze,je,E,De,Z,oe,ne,q,Oe='The <a href="/docs/transformers/pr_33174/en/model_doc/groupvit#transformers.TFGroupViTVisionModel">TFGroupViTVisionModel</a> forward method, overrides the <code>__call__</code> special method.',d,V,_e,z,Te;return e=new Le({props:{title:"TFGroupViTModel",local:"transformers.TFGroupViTModel",headingTag:"h2"}}),n=new pe({props:{name:"class transformers.TFGroupViTModel",anchor:"transformers.TFGroupViTModel",parameters:[{name:"config",val:": GroupViTConfig"},{name:"*inputs",val:""},{name:"**kwargs",val:""}],parametersDescription:[{anchor:"transformers.TFGroupViTModel.config",description:`<strong>config</strong> (<a href="/docs/transformers/pr_33174/en/model_doc/groupvit#transformers.GroupViTConfig">GroupViTConfig</a>) — Model configuration class with all the parameters of the model. | |
| Initializing with a config file does not load the weights associated with the model, only the | |
| configuration. Check out the <a href="/docs/transformers/pr_33174/en/main_classes/model#transformers.PreTrainedModel.from_pretrained">from_pretrained()</a> method to load the model weights.`,name:"config"}],source:"https://github.com/huggingface/transformers/blob/vr_33174/src/transformers/models/groupvit/modeling_tf_groupvit.py#L1976"}}),U=new et({props:{$$slots:{default:[Vt]},$$scope:{ctx:w}}}),j=new pe({props:{name:"call",anchor:"transformers.TFGroupViTModel.call",parameters:[{name:"input_ids",val:": TFModelInputType | None = None"},{name:"pixel_values",val:": TFModelInputType | None = None"},{name:"attention_mask",val:": np.ndarray | tf.Tensor | None = None"},{name:"position_ids",val:": np.ndarray | tf.Tensor | None = None"},{name:"return_loss",val:": Optional[bool] = None"},{name:"output_attentions",val:": Optional[bool] = None"},{name:"output_hidden_states",val:": Optional[bool] = None"},{name:"output_segmentation",val:": Optional[bool] = None"},{name:"return_dict",val:": Optional[bool] = None"},{name:"training",val:": bool = False"}],parametersDescription:[{anchor:"transformers.TFGroupViTModel.call.input_ids",description:`<strong>input_ids</strong> (<code>np.ndarray</code>, <code>tf.Tensor</code>, <code>List[tf.Tensor]</code> \`<code>Dict[str, tf.Tensor]</code> or <code>Dict[str, np.ndarray]</code> and each example must have the shape <code>(batch_size, sequence_length)</code>) — | |
| Indices of input sequence tokens in the vocabulary.</p> | |
| <p>Indices can be obtained using <a href="/docs/transformers/pr_33174/en/model_doc/auto#transformers.AutoTokenizer">AutoTokenizer</a>. See <a href="/docs/transformers/pr_33174/en/internal/tokenization_utils#transformers.PreTrainedTokenizerBase.__call__">PreTrainedTokenizer.<strong>call</strong>()</a> and | |
| <a href="/docs/transformers/pr_33174/en/internal/tokenization_utils#transformers.PreTrainedTokenizerBase.encode">PreTrainedTokenizer.encode()</a> for details.</p> | |
| <p><a href="../glossary#input-ids">What are input IDs?</a>`,name:"input_ids"},{anchor:"transformers.TFGroupViTModel.call.pixel_values",description:`<strong>pixel_values</strong> (<code>np.ndarray</code>, <code>tf.Tensor</code>, <code>List[tf.Tensor]</code> <code>Dict[str, tf.Tensor]</code> or <code>Dict[str, np.ndarray]</code> and each example must have the shape <code>(batch_size, num_channels, height, width)</code>) — | |
| Pixel values. Pixel values can be obtained using <a href="/docs/transformers/pr_33174/en/model_doc/auto#transformers.AutoImageProcessor">AutoImageProcessor</a>. See | |
| <a href="/docs/transformers/pr_33174/en/model_doc/layoutlmv2#transformers.LayoutLMv2FeatureExtractor.__call__">CLIPImageProcessor.<strong>call</strong>()</a> for details.`,name:"pixel_values"},{anchor:"transformers.TFGroupViTModel.call.attention_mask",description:`<strong>attention_mask</strong> (<code>np.ndarray</code> or <code>tf.Tensor</code> of shape <code>(batch_size, sequence_length)</code>, <em>optional</em>) — | |
| Mask to avoid performing attention on padding token indices. Mask values selected in <code>[0, 1]</code>:</p> | |
| <ul> | |
| <li>1 for tokens that are <strong>not masked</strong>,</li> | |
| <li>0 for tokens that are <strong>masked</strong>.</li> | |
| </ul> | |
| <p><a href="../glossary#attention-mask">What are attention masks?</a>`,name:"attention_mask"},{anchor:"transformers.TFGroupViTModel.call.position_ids",description:`<strong>position_ids</strong> (<code>np.ndarray</code> or <code>tf.Tensor</code> of shape <code>(batch_size, sequence_length)</code>, <em>optional</em>) — | |
| Indices of positions of each input sequence tokens in the position embeddings. Selected in the range <code>[0, config.max_position_embeddings - 1]</code>.</p> | |
| <p><a href="../glossary#position-ids">What are position IDs?</a>`,name:"position_ids"},{anchor:"transformers.TFGroupViTModel.call.return_loss",description:`<strong>return_loss</strong> (<code>bool</code>, <em>optional</em>) — | |
| Whether or not to return the contrastive loss.`,name:"return_loss"},{anchor:"transformers.TFGroupViTModel.call.output_attentions",description:`<strong>output_attentions</strong> (<code>bool</code>, <em>optional</em>) — | |
| Whether or not to return the attentions tensors of all attention layers. See <code>attentions</code> under returned | |
| tensors for more detail. This argument can be used only in eager mode, in graph mode the value in the | |
| config will be used instead.`,name:"output_attentions"},{anchor:"transformers.TFGroupViTModel.call.output_hidden_states",description:`<strong>output_hidden_states</strong> (<code>bool</code>, <em>optional</em>) — | |
| Whether or not to return the hidden states of all layers. See <code>hidden_states</code> under returned tensors for | |
| more detail. This argument can be used only in eager mode, in graph mode the value in the config will be | |
| used instead.`,name:"output_hidden_states"},{anchor:"transformers.TFGroupViTModel.call.return_dict",description:`<strong>return_dict</strong> (<code>bool</code>, <em>optional</em>) — | |
| Whether or not to return a <a href="/docs/transformers/pr_33174/en/main_classes/output#transformers.utils.ModelOutput">ModelOutput</a> instead of a plain tuple. This argument can be used in | |
| eager mode, in graph mode the value will always be set to True.`,name:"return_dict"},{anchor:"transformers.TFGroupViTModel.call.training",description:`<strong>training</strong> (<code>bool</code>, <em>optional</em>, defaults to \`False“) — | |
| Whether or not to use the model in training mode (some modules like dropout modules have different | |
| behaviors between training and evaluation).`,name:"training"}],source:"https://github.com/huggingface/transformers/blob/vr_33174/src/transformers/models/groupvit/modeling_tf_groupvit.py#L2069",returnDescription:`<script context="module">export const metadata = 'undefined';<\/script> | |
| <p>A <code>transformers.models.groupvit.modeling_tf_groupvit.TFGroupViTModelOutput</code> or a tuple of <code>tf.Tensor</code> (if | |
| <code>return_dict=False</code> is passed or when <code>config.return_dict=False</code>) comprising various elements depending on the | |
| configuration (<code><class 'transformers.models.groupvit.configuration_groupvit.GroupViTConfig'></code>) and inputs.</p> | |
| <ul> | |
| <li> | |
| <p><strong>loss</strong> (<code>tf.Tensor</code> of shape <code>(1,)</code>, <em>optional</em>, returned when <code>return_loss</code> is <code>True</code>) — Contrastive loss for image-text similarity.</p> | |
| </li> | |
| <li> | |
| <p><strong>logits_per_image</strong> (<code>tf.Tensor</code> of shape <code>(image_batch_size, text_batch_size)</code>) — The scaled dot product scores between <code>image_embeds</code> and <code>text_embeds</code>. This represents the image-text | |
| similarity scores.</p> | |
| </li> | |
| <li> | |
| <p><strong>logits_per_text</strong> (<code>tf.Tensor</code> of shape <code>(text_batch_size, image_batch_size)</code>) — The scaled dot product scores between <code>text_embeds</code> and <code>image_embeds</code>. This represents the text-image | |
| similarity scores.</p> | |
| </li> | |
| <li> | |
| <p><strong>segmentation_logits</strong> (<code>tf.Tensor</code> of shape <code>(batch_size, config.num_labels, logits_height, logits_width)</code>) — Classification scores for each pixel.</p> | |
| <Tip warning={true}> | |
| <p>The logits returned do not necessarily have the same size as the <code>pixel_values</code> passed as inputs. This is | |
| to avoid doing two interpolations and lose some quality when a user needs to resize the logits to the | |
| original image size as post-processing. You should always check your logits shape and resize as needed.</p> | |
| </Tip> | |
| </li> | |
| <li> | |
| <p><strong>text_embeds</strong> (<code>tf.Tensor</code> of shape <code>(batch_size, output_dim</code>) — The text embeddings obtained by applying the projection layer to the pooled output of | |
| <a | |
| href="/docs/transformers/pr_33174/en/model_doc/groupvit#transformers.TFGroupViTTextModel" | |
| >TFGroupViTTextModel</a>.</p> | |
| </li> | |
| <li> | |
| <p><strong>image_embeds</strong> (<code>tf.Tensor</code> of shape <code>(batch_size, output_dim</code>) — The image embeddings obtained by applying the projection layer to the pooled output of | |
| <a | |
| href="/docs/transformers/pr_33174/en/model_doc/groupvit#transformers.TFGroupViTVisionModel" | |
| >TFGroupViTVisionModel</a>.</p> | |
| </li> | |
| <li> | |
| <p><strong>text_model_output</strong> (<code>TFBaseModelOutputWithPooling</code>) — The output of the <a | |
| href="/docs/transformers/pr_33174/en/model_doc/groupvit#transformers.TFGroupViTTextModel" | |
| >TFGroupViTTextModel</a>.</p> | |
| </li> | |
| <li> | |
| <p><strong>vision_model_output</strong> (<code>TFBaseModelOutputWithPooling</code>) — The output of the <a | |
| href="/docs/transformers/pr_33174/en/model_doc/groupvit#transformers.TFGroupViTVisionModel" | |
| >TFGroupViTVisionModel</a>.</p> | |
| </li> | |
| </ul> | |
| `,returnType:`<script context="module">export const metadata = 'undefined';<\/script> | |
| <p><code>transformers.models.groupvit.modeling_tf_groupvit.TFGroupViTModelOutput</code> or <code>tuple(tf.Tensor)</code></p> | |
| `}}),S=new et({props:{$$slots:{default:[xt]},$$scope:{ctx:w}}}),ae=new Xe({props:{anchor:"transformers.TFGroupViTModel.call.example",$$slots:{default:[Gt]},$$scope:{ctx:w}}}),Y=new pe({props:{name:"get_text_features",anchor:"transformers.TFGroupViTModel.get_text_features",parameters:[{name:"input_ids",val:": TFModelInputType | None = None"},{name:"attention_mask",val:": np.ndarray | tf.Tensor | None = None"},{name:"position_ids",val:": np.ndarray | tf.Tensor | None = None"},{name:"output_attentions",val:": Optional[bool] = None"},{name:"output_hidden_states",val:": Optional[bool] = None"},{name:"return_dict",val:": Optional[bool] = None"},{name:"training",val:": bool = False"}],parametersDescription:[{anchor:"transformers.TFGroupViTModel.get_text_features.input_ids",description:`<strong>input_ids</strong> (<code>np.ndarray</code>, <code>tf.Tensor</code>, <code>List[tf.Tensor]</code> \`<code>Dict[str, tf.Tensor]</code> or <code>Dict[str, np.ndarray]</code> and each example must have the shape <code>(batch_size, sequence_length)</code>) — | |
| Indices of input sequence tokens in the vocabulary.</p> | |
| <p>Indices can be obtained using <a href="/docs/transformers/pr_33174/en/model_doc/auto#transformers.AutoTokenizer">AutoTokenizer</a>. See <a href="/docs/transformers/pr_33174/en/internal/tokenization_utils#transformers.PreTrainedTokenizerBase.__call__">PreTrainedTokenizer.<strong>call</strong>()</a> and | |
| <a href="/docs/transformers/pr_33174/en/internal/tokenization_utils#transformers.PreTrainedTokenizerBase.encode">PreTrainedTokenizer.encode()</a> for details.</p> | |
| <p><a href="../glossary#input-ids">What are input IDs?</a>`,name:"input_ids"},{anchor:"transformers.TFGroupViTModel.get_text_features.attention_mask",description:`<strong>attention_mask</strong> (<code>np.ndarray</code> or <code>tf.Tensor</code> of shape <code>(batch_size, sequence_length)</code>, <em>optional</em>) — | |
| Mask to avoid performing attention on padding token indices. Mask values selected in <code>[0, 1]</code>:</p> | |
| <ul> | |
| <li>1 for tokens that are <strong>not masked</strong>,</li> | |
| <li>0 for tokens that are <strong>masked</strong>.</li> | |
| </ul> | |
| <p><a href="../glossary#attention-mask">What are attention masks?</a>`,name:"attention_mask"},{anchor:"transformers.TFGroupViTModel.get_text_features.position_ids",description:`<strong>position_ids</strong> (<code>np.ndarray</code> or <code>tf.Tensor</code> of shape <code>(batch_size, sequence_length)</code>, <em>optional</em>) — | |
| Indices of positions of each input sequence tokens in the position embeddings. Selected in the range <code>[0, config.max_position_embeddings - 1]</code>.</p> | |
| <p><a href="../glossary#position-ids">What are position IDs?</a>`,name:"position_ids"},{anchor:"transformers.TFGroupViTModel.get_text_features.output_attentions",description:`<strong>output_attentions</strong> (<code>bool</code>, <em>optional</em>) — | |
| Whether or not to return the attentions tensors of all attention layers. See <code>attentions</code> under returned | |
| tensors for more detail. This argument can be used only in eager mode, in graph mode the value in the | |
| config will be used instead.`,name:"output_attentions"},{anchor:"transformers.TFGroupViTModel.get_text_features.output_hidden_states",description:`<strong>output_hidden_states</strong> (<code>bool</code>, <em>optional</em>) — | |
| Whether or not to return the hidden states of all layers. See <code>hidden_states</code> under returned tensors for | |
| more detail. This argument can be used only in eager mode, in graph mode the value in the config will be | |
| used instead.`,name:"output_hidden_states"},{anchor:"transformers.TFGroupViTModel.get_text_features.return_dict",description:`<strong>return_dict</strong> (<code>bool</code>, <em>optional</em>) — | |
| Whether or not to return a <a href="/docs/transformers/pr_33174/en/main_classes/output#transformers.utils.ModelOutput">ModelOutput</a> instead of a plain tuple. This argument can be used in | |
| eager mode, in graph mode the value will always be set to True.`,name:"return_dict"},{anchor:"transformers.TFGroupViTModel.get_text_features.training",description:`<strong>training</strong> (<code>bool</code>, <em>optional</em>, defaults to \`False“) — | |
| Whether or not to use the model in training mode (some modules like dropout modules have different | |
| behaviors between training and evaluation).`,name:"training"}],source:"https://github.com/huggingface/transformers/blob/vr_33174/src/transformers/models/groupvit/modeling_tf_groupvit.py#L1985",returnDescription:`<script context="module">export const metadata = 'undefined';<\/script> | |
| <p>The text embeddings obtained by applying | |
| the projection layer to the pooled output of <a | |
| href="/docs/transformers/pr_33174/en/model_doc/groupvit#transformers.TFGroupViTTextModel" | |
| >TFGroupViTTextModel</a>.</p> | |
| `,returnType:`<script context="module">export const metadata = 'undefined';<\/script> | |
| <p>text_features (<code>tf.Tensor</code> of shape <code>(batch_size, output_dim</code>)</p> | |
| `}}),Q=new et({props:{$$slots:{default:[jt]},$$scope:{ctx:w}}}),be=new Xe({props:{anchor:"transformers.TFGroupViTModel.get_text_features.example",$$slots:{default:[kt]},$$scope:{ctx:w}}}),A=new pe({props:{name:"get_image_features",anchor:"transformers.TFGroupViTModel.get_image_features",parameters:[{name:"pixel_values",val:": TFModelInputType | None = None"},{name:"output_attentions",val:": Optional[bool] = None"},{name:"output_hidden_states",val:": Optional[bool] = None"},{name:"return_dict",val:": Optional[bool] = None"},{name:"training",val:": bool = False"}],parametersDescription:[{anchor:"transformers.TFGroupViTModel.get_image_features.pixel_values",description:`<strong>pixel_values</strong> (<code>np.ndarray</code>, <code>tf.Tensor</code>, <code>List[tf.Tensor]</code>, <code>Dict[str, tf.Tensor]</code> or <code>Dict[str, np.ndarray]</code> and each example must have the shape <code>(batch_size, num_channels, height, width)</code>) — | |
| Pixel values. Pixel values can be obtained using <a href="/docs/transformers/pr_33174/en/model_doc/auto#transformers.AutoImageProcessor">AutoImageProcessor</a>. See | |
| <a href="/docs/transformers/pr_33174/en/model_doc/layoutlmv2#transformers.LayoutLMv2FeatureExtractor.__call__">CLIPImageProcessor.<strong>call</strong>()</a> for details.`,name:"pixel_values"},{anchor:"transformers.TFGroupViTModel.get_image_features.output_attentions",description:`<strong>output_attentions</strong> (<code>bool</code>, <em>optional</em>) — | |
| Whether or not to return the attentions tensors of all attention layers. See <code>attentions</code> under returned | |
| tensors for more detail. This argument can be used only in eager mode, in graph mode the value in the | |
| config will be used instead.`,name:"output_attentions"},{anchor:"transformers.TFGroupViTModel.get_image_features.output_hidden_states",description:`<strong>output_hidden_states</strong> (<code>bool</code>, <em>optional</em>) — | |
| Whether or not to return the hidden states of all layers. See <code>hidden_states</code> under returned tensors for | |
| more detail. This argument can be used only in eager mode, in graph mode the value in the config will be | |
| used instead.`,name:"output_hidden_states"},{anchor:"transformers.TFGroupViTModel.get_image_features.return_dict",description:`<strong>return_dict</strong> (<code>bool</code>, <em>optional</em>) — | |
| Whether or not to return a <a href="/docs/transformers/pr_33174/en/main_classes/output#transformers.utils.ModelOutput">ModelOutput</a> instead of a plain tuple. This argument can be used in | |
| eager mode, in graph mode the value will always be set to True.`,name:"return_dict"},{anchor:"transformers.TFGroupViTModel.get_image_features.training",description:`<strong>training</strong> (<code>bool</code>, <em>optional</em>, defaults to \`False“) — | |
| Whether or not to use the model in training mode (some modules like dropout modules have different | |
| behaviors between training and evaluation).`,name:"training"}],source:"https://github.com/huggingface/transformers/blob/vr_33174/src/transformers/models/groupvit/modeling_tf_groupvit.py#L2026",returnDescription:`<script context="module">export const metadata = 'undefined';<\/script> | |
| <p>The image embeddings obtained by applying | |
| the projection layer to the pooled output of <a | |
| href="/docs/transformers/pr_33174/en/model_doc/groupvit#transformers.TFGroupViTVisionModel" | |
| >TFGroupViTVisionModel</a>.</p> | |
| `,returnType:`<script context="module">export const metadata = 'undefined';<\/script> | |
| <p>image_features (<code>tf.Tensor</code> of shape <code>(batch_size, output_dim</code>)</p> | |
| `}}),ke=new et({props:{$$slots:{default:[Jt]},$$scope:{ctx:w}}}),H=new Xe({props:{anchor:"transformers.TFGroupViTModel.get_image_features.example",$$slots:{default:[Ut]},$$scope:{ctx:w}}}),F=new Le({props:{title:"TFGroupViTTextModel",local:"transformers.TFGroupViTTextModel",headingTag:"h2"}}),$e=new pe({props:{name:"class transformers.TFGroupViTTextModel",anchor:"transformers.TFGroupViTTextModel",parameters:[{name:"config",val:": GroupViTTextConfig"},{name:"*inputs",val:""},{name:"**kwargs",val:""}],source:"https://github.com/huggingface/transformers/blob/vr_33174/src/transformers/models/groupvit/modeling_tf_groupvit.py#L1853"}}),ee=new pe({props:{name:"call",anchor:"transformers.TFGroupViTTextModel.call",parameters:[{name:"input_ids",val:": TFModelInputType | None = None"},{name:"attention_mask",val:": np.ndarray | tf.Tensor | None = None"},{name:"position_ids",val:": np.ndarray | tf.Tensor | None = None"},{name:"output_attentions",val:": Optional[bool] = None"},{name:"output_hidden_states",val:": Optional[bool] = None"},{name:"return_dict",val:": Optional[bool] = None"},{name:"training",val:": bool = False"}],parametersDescription:[{anchor:"transformers.TFGroupViTTextModel.call.input_ids",description:`<strong>input_ids</strong> (<code>np.ndarray</code>, <code>tf.Tensor</code>, <code>List[tf.Tensor]</code> \`<code>Dict[str, tf.Tensor]</code> or <code>Dict[str, np.ndarray]</code> and each example must have the shape <code>(batch_size, sequence_length)</code>) — | |
| Indices of input sequence tokens in the vocabulary.</p> | |
| <p>Indices can be obtained using <a href="/docs/transformers/pr_33174/en/model_doc/auto#transformers.AutoTokenizer">AutoTokenizer</a>. See <a href="/docs/transformers/pr_33174/en/internal/tokenization_utils#transformers.PreTrainedTokenizerBase.__call__">PreTrainedTokenizer.<strong>call</strong>()</a> and | |
| <a href="/docs/transformers/pr_33174/en/internal/tokenization_utils#transformers.PreTrainedTokenizerBase.encode">PreTrainedTokenizer.encode()</a> for details.</p> | |
| <p><a href="../glossary#input-ids">What are input IDs?</a>`,name:"input_ids"},{anchor:"transformers.TFGroupViTTextModel.call.attention_mask",description:`<strong>attention_mask</strong> (<code>np.ndarray</code> or <code>tf.Tensor</code> of shape <code>(batch_size, sequence_length)</code>, <em>optional</em>) — | |
| Mask to avoid performing attention on padding token indices. Mask values selected in <code>[0, 1]</code>:</p> | |
| <ul> | |
| <li>1 for tokens that are <strong>not masked</strong>,</li> | |
| <li>0 for tokens that are <strong>masked</strong>.</li> | |
| </ul> | |
| <p><a href="../glossary#attention-mask">What are attention masks?</a>`,name:"attention_mask"},{anchor:"transformers.TFGroupViTTextModel.call.position_ids",description:`<strong>position_ids</strong> (<code>np.ndarray</code> or <code>tf.Tensor</code> of shape <code>(batch_size, sequence_length)</code>, <em>optional</em>) — | |
| Indices of positions of each input sequence tokens in the position embeddings. Selected in the range <code>[0, config.max_position_embeddings - 1]</code>.</p> | |
| <p><a href="../glossary#position-ids">What are position IDs?</a>`,name:"position_ids"},{anchor:"transformers.TFGroupViTTextModel.call.output_attentions",description:`<strong>output_attentions</strong> (<code>bool</code>, <em>optional</em>) — | |
| Whether or not to return the attentions tensors of all attention layers. See <code>attentions</code> under returned | |
| tensors for more detail. This argument can be used only in eager mode, in graph mode the value in the | |
| config will be used instead.`,name:"output_attentions"},{anchor:"transformers.TFGroupViTTextModel.call.output_hidden_states",description:`<strong>output_hidden_states</strong> (<code>bool</code>, <em>optional</em>) — | |
| Whether or not to return the hidden states of all layers. See <code>hidden_states</code> under returned tensors for | |
| more detail. This argument can be used only in eager mode, in graph mode the value in the config will be | |
| used instead.`,name:"output_hidden_states"},{anchor:"transformers.TFGroupViTTextModel.call.return_dict",description:`<strong>return_dict</strong> (<code>bool</code>, <em>optional</em>) — | |
| Whether or not to return a <a href="/docs/transformers/pr_33174/en/main_classes/output#transformers.utils.ModelOutput">ModelOutput</a> instead of a plain tuple. This argument can be used in | |
| eager mode, in graph mode the value will always be set to True.`,name:"return_dict"},{anchor:"transformers.TFGroupViTTextModel.call.training",description:`<strong>training</strong> (<code>bool</code>, <em>optional</em>, defaults to \`False“) — | |
| Whether or not to use the model in training mode (some modules like dropout modules have different | |
| behaviors between training and evaluation).`,name:"training"}],source:"https://github.com/huggingface/transformers/blob/vr_33174/src/transformers/models/groupvit/modeling_tf_groupvit.py#L1862",returnDescription:`<script context="module">export const metadata = 'undefined';<\/script> | |
| <p>A <a | |
| href="/docs/transformers/pr_33174/en/main_classes/output#transformers.modeling_tf_outputs.TFBaseModelOutputWithPooling" | |
| >transformers.modeling_tf_outputs.TFBaseModelOutputWithPooling</a> or a tuple of <code>tf.Tensor</code> (if | |
| <code>return_dict=False</code> is passed or when <code>config.return_dict=False</code>) comprising various elements depending on the | |
| configuration (<code><class 'transformers.models.groupvit.configuration_groupvit.GroupViTTextConfig'></code>) and inputs.</p> | |
| <ul> | |
| <li> | |
| <p><strong>last_hidden_state</strong> (<code>tf.Tensor</code> of shape <code>(batch_size, sequence_length, hidden_size)</code>) — Sequence of hidden-states at the output of the last layer of the model.</p> | |
| </li> | |
| <li> | |
| <p><strong>pooler_output</strong> (<code>tf.Tensor</code> of shape <code>(batch_size, hidden_size)</code>) — Last layer hidden-state of the first token of the sequence (classification token) further processed by a | |
| Linear layer and a Tanh activation function. The Linear layer weights are trained from the next sentence | |
| prediction (classification) objective during pretraining.</p> | |
| <p>This output is usually <em>not</em> a good summary of the semantic content of the input, you’re often better with | |
| averaging or pooling the sequence of hidden-states for the whole input sequence.</p> | |
| </li> | |
| <li> | |
| <p><strong>hidden_states</strong> (<code>tuple(tf.Tensor)</code>, <em>optional</em>, returned when <code>output_hidden_states=True</code> is passed or when <code>config.output_hidden_states=True</code>) — Tuple of <code>tf.Tensor</code> (one for the output of the embeddings + one for the output of each layer) of shape | |
| <code>(batch_size, sequence_length, hidden_size)</code>.</p> | |
| <p>Hidden-states of the model at the output of each layer plus the initial embedding outputs.</p> | |
| </li> | |
| <li> | |
| <p><strong>attentions</strong> (<code>tuple(tf.Tensor)</code>, <em>optional</em>, returned when <code>output_attentions=True</code> is passed or when <code>config.output_attentions=True</code>) — Tuple of <code>tf.Tensor</code> (one for each layer) of shape <code>(batch_size, num_heads, sequence_length, sequence_length)</code>.</p> | |
| <p>Attentions weights after the attention softmax, used to compute the weighted average in the self-attention | |
| heads.</p> | |
| </li> | |
| </ul> | |
| `,returnType:`<script context="module">export const metadata = 'undefined';<\/script> | |
| <p><a | |
| href="/docs/transformers/pr_33174/en/main_classes/output#transformers.modeling_tf_outputs.TFBaseModelOutputWithPooling" | |
| >transformers.modeling_tf_outputs.TFBaseModelOutputWithPooling</a> or <code>tuple(tf.Tensor)</code></p> | |
| `}}),Ge=new et({props:{$$slots:{default:[Ct]},$$scope:{ctx:w}}}),he=new Xe({props:{anchor:"transformers.TFGroupViTTextModel.call.example",$$slots:{default:[zt]},$$scope:{ctx:w}}}),C=new Le({props:{title:"TFGroupViTVisionModel",local:"transformers.TFGroupViTVisionModel",headingTag:"h2"}}),E=new pe({props:{name:"class transformers.TFGroupViTVisionModel",anchor:"transformers.TFGroupViTVisionModel",parameters:[{name:"config",val:": GroupViTVisionConfig"},{name:"*inputs",val:""},{name:"**kwargs",val:""}],source:"https://github.com/huggingface/transformers/blob/vr_33174/src/transformers/models/groupvit/modeling_tf_groupvit.py#L1914"}}),oe=new pe({props:{name:"call",anchor:"transformers.TFGroupViTVisionModel.call",parameters:[{name:"pixel_values",val:": TFModelInputType | None = None"},{name:"output_attentions",val:": Optional[bool] = None"},{name:"output_hidden_states",val:": Optional[bool] = None"},{name:"return_dict",val:": Optional[bool] = None"},{name:"training",val:": bool = False"}],parametersDescription:[{anchor:"transformers.TFGroupViTVisionModel.call.pixel_values",description:`<strong>pixel_values</strong> (<code>np.ndarray</code>, <code>tf.Tensor</code>, <code>List[tf.Tensor]</code>, <code>Dict[str, tf.Tensor]</code> or <code>Dict[str, np.ndarray]</code> and each example must have the shape <code>(batch_size, num_channels, height, width)</code>) — | |
| Pixel values. Pixel values can be obtained using <a href="/docs/transformers/pr_33174/en/model_doc/auto#transformers.AutoImageProcessor">AutoImageProcessor</a>. See | |
| <a href="/docs/transformers/pr_33174/en/model_doc/layoutlmv2#transformers.LayoutLMv2FeatureExtractor.__call__">CLIPImageProcessor.<strong>call</strong>()</a> for details.`,name:"pixel_values"},{anchor:"transformers.TFGroupViTVisionModel.call.output_attentions",description:`<strong>output_attentions</strong> (<code>bool</code>, <em>optional</em>) — | |
| Whether or not to return the attentions tensors of all attention layers. See <code>attentions</code> under returned | |
| tensors for more detail. This argument can be used only in eager mode, in graph mode the value in the | |
| config will be used instead.`,name:"output_attentions"},{anchor:"transformers.TFGroupViTVisionModel.call.output_hidden_states",description:`<strong>output_hidden_states</strong> (<code>bool</code>, <em>optional</em>) — | |
| Whether or not to return the hidden states of all layers. See <code>hidden_states</code> under returned tensors for | |
| more detail. This argument can be used only in eager mode, in graph mode the value in the config will be | |
| used instead.`,name:"output_hidden_states"},{anchor:"transformers.TFGroupViTVisionModel.call.return_dict",description:`<strong>return_dict</strong> (<code>bool</code>, <em>optional</em>) — | |
| Whether or not to return a <a href="/docs/transformers/pr_33174/en/main_classes/output#transformers.utils.ModelOutput">ModelOutput</a> instead of a plain tuple. This argument can be used in | |
| eager mode, in graph mode the value will always be set to True.`,name:"return_dict"},{anchor:"transformers.TFGroupViTVisionModel.call.training",description:`<strong>training</strong> (<code>bool</code>, <em>optional</em>, defaults to \`False“) — | |
| Whether or not to use the model in training mode (some modules like dropout modules have different | |
| behaviors between training and evaluation).`,name:"training"}],source:"https://github.com/huggingface/transformers/blob/vr_33174/src/transformers/models/groupvit/modeling_tf_groupvit.py#L1923",returnDescription:`<script context="module">export const metadata = 'undefined';<\/script> | |
| <p>A <a | |
| href="/docs/transformers/pr_33174/en/main_classes/output#transformers.modeling_tf_outputs.TFBaseModelOutputWithPooling" | |
| >transformers.modeling_tf_outputs.TFBaseModelOutputWithPooling</a> or a tuple of <code>tf.Tensor</code> (if | |
| <code>return_dict=False</code> is passed or when <code>config.return_dict=False</code>) comprising various elements depending on the | |
| configuration (<code><class 'transformers.models.groupvit.configuration_groupvit.GroupViTVisionConfig'></code>) and inputs.</p> | |
| <ul> | |
| <li> | |
| <p><strong>last_hidden_state</strong> (<code>tf.Tensor</code> of shape <code>(batch_size, sequence_length, hidden_size)</code>) — Sequence of hidden-states at the output of the last layer of the model.</p> | |
| </li> | |
| <li> | |
| <p><strong>pooler_output</strong> (<code>tf.Tensor</code> of shape <code>(batch_size, hidden_size)</code>) — Last layer hidden-state of the first token of the sequence (classification token) further processed by a | |
| Linear layer and a Tanh activation function. The Linear layer weights are trained from the next sentence | |
| prediction (classification) objective during pretraining.</p> | |
| <p>This output is usually <em>not</em> a good summary of the semantic content of the input, you’re often better with | |
| averaging or pooling the sequence of hidden-states for the whole input sequence.</p> | |
| </li> | |
| <li> | |
| <p><strong>hidden_states</strong> (<code>tuple(tf.Tensor)</code>, <em>optional</em>, returned when <code>output_hidden_states=True</code> is passed or when <code>config.output_hidden_states=True</code>) — Tuple of <code>tf.Tensor</code> (one for the output of the embeddings + one for the output of each layer) of shape | |
| <code>(batch_size, sequence_length, hidden_size)</code>.</p> | |
| <p>Hidden-states of the model at the output of each layer plus the initial embedding outputs.</p> | |
| </li> | |
| <li> | |
| <p><strong>attentions</strong> (<code>tuple(tf.Tensor)</code>, <em>optional</em>, returned when <code>output_attentions=True</code> is passed or when <code>config.output_attentions=True</code>) — Tuple of <code>tf.Tensor</code> (one for each layer) of shape <code>(batch_size, num_heads, sequence_length, sequence_length)</code>.</p> | |
| <p>Attentions weights after the attention softmax, used to compute the weighted average in the self-attention | |
| heads.</p> | |
| </li> | |
| </ul> | |
| `,returnType:`<script context="module">export const metadata = 'undefined';<\/script> | |
| <p><a | |
| href="/docs/transformers/pr_33174/en/main_classes/output#transformers.modeling_tf_outputs.TFBaseModelOutputWithPooling" | |
| >transformers.modeling_tf_outputs.TFBaseModelOutputWithPooling</a> or <code>tuple(tf.Tensor)</code></p> | |
| `}}),V=new et({props:{$$slots:{default:[Wt]},$$scope:{ctx:w}}}),z=new Xe({props:{anchor:"transformers.TFGroupViTVisionModel.call.example",$$slots:{default:[It]},$$scope:{ctx:w}}}),{c(){h(e.$$.fragment),p=a(),o=f("div"),h(n.$$.fragment),m=a(),t=f("p"),t.innerHTML=$,Ue=a(),k=f("p"),k.innerHTML=X,Ce=a(),h(U.$$.fragment),Ve=a(),W=f("div"),h(j.$$.fragment),se=a(),re=f("p"),re.innerHTML=Be,ce=a(),h(S.$$.fragment),ze=a(),h(ae.$$.fragment),Re=a(),ue=f("div"),h(Y.$$.fragment),We=a(),ie=f("p"),ie.innerHTML=He,me=a(),h(Q.$$.fragment),Ie=a(),h(be.$$.fragment),Ye=a(),I=f("div"),h(A.$$.fragment),D=a(),R=f("p"),R.innerHTML=Qe,ve=a(),h(ke.$$.fragment),xe=a(),h(H.$$.fragment),Ae=a(),h(F.$$.fragment),O=a(),K=f("div"),h($e.$$.fragment),qe=a(),fe=f("div"),h(ee.$$.fragment),Fe=a(),le=f("p"),le.innerHTML=te,ge=a(),h(Ge.$$.fragment),de=a(),h(he.$$.fragment),Pe=a(),h(C.$$.fragment),Ze=a(),je=f("div"),h(E.$$.fragment),De=a(),Z=f("div"),h(oe.$$.fragment),ne=a(),q=f("p"),q.innerHTML=Oe,d=a(),h(V.$$.fragment),_e=a(),h(z.$$.fragment),this.h()},l(l){_(e.$$.fragment,l),p=i(l),o=g(l,"DIV",{class:!0});var v=L(o);_(n.$$.fragment,v),m=i(v),t=g(v,"P",{"data-svelte-h":!0}),G(t)!=="svelte-54c7p6"&&(t.innerHTML=$),Ue=i(v),k=g(v,"P",{"data-svelte-h":!0}),G(k)!=="svelte-1be7e3c"&&(k.innerHTML=X),Ce=i(v),_(U.$$.fragment,v),Ve=i(v),W=g(v,"DIV",{class:!0});var B=L(W);_(j.$$.fragment,B),se=i(B),re=g(B,"P",{"data-svelte-h":!0}),G(re)!=="svelte-1esq7lb"&&(re.innerHTML=Be),ce=i(B),_(S.$$.fragment,B),ze=i(B),_(ae.$$.fragment,B),B.forEach(r),Re=i(v),ue=g(v,"DIV",{class:!0});var J=L(ue);_(Y.$$.fragment,J),We=i(J),ie=g(J,"P",{"data-svelte-h":!0}),G(ie)!=="svelte-1esq7lb"&&(ie.innerHTML=He),me=i(J),_(Q.$$.fragment,J),Ie=i(J),_(be.$$.fragment,J),J.forEach(r),Ye=i(v),I=g(v,"DIV",{class:!0});var Me=L(I);_(A.$$.fragment,Me),D=i(Me),R=g(Me,"P",{"data-svelte-h":!0}),G(R)!=="svelte-1esq7lb"&&(R.innerHTML=Qe),ve=i(Me),_(ke.$$.fragment,Me),xe=i(Me),_(H.$$.fragment,Me),Me.forEach(r),v.forEach(r),Ae=i(l),_(F.$$.fragment,l),O=i(l),K=g(l,"DIV",{class:!0});var we=L(K);_($e.$$.fragment,we),qe=i(we),fe=g(we,"DIV",{class:!0});var ye=L(fe);_(ee.$$.fragment,ye),Fe=i(ye),le=g(ye,"P",{"data-svelte-h":!0}),G(le)!=="svelte-1nfcz8r"&&(le.innerHTML=te),ge=i(ye),_(Ge.$$.fragment,ye),de=i(ye),_(he.$$.fragment,ye),ye.forEach(r),we.forEach(r),Pe=i(l),_(C.$$.fragment,l),Ze=i(l),je=g(l,"DIV",{class:!0});var Ne=L(je);_(E.$$.fragment,Ne),De=i(Ne),Z=g(Ne,"DIV",{class:!0});var Je=L(Z);_(oe.$$.fragment,Je),ne=i(Je),q=g(Je,"P",{"data-svelte-h":!0}),G(q)!=="svelte-5ub1xv"&&(q.innerHTML=Oe),d=i(Je),_(V.$$.fragment,Je),_e=i(Je),_(z.$$.fragment,Je),Je.forEach(r),Ne.forEach(r),this.h()},h(){P(W,"class","docstring border-l-2 border-t-2 pl-4 pt-3.5 border-gray-100 rounded-tl-xl mb-6 mt-8"),P(ue,"class","docstring border-l-2 border-t-2 pl-4 pt-3.5 border-gray-100 rounded-tl-xl mb-6 mt-8"),P(I,"class","docstring border-l-2 border-t-2 pl-4 pt-3.5 border-gray-100 rounded-tl-xl mb-6 mt-8"),P(o,"class","docstring border-l-2 border-t-2 pl-4 pt-3.5 border-gray-100 rounded-tl-xl mb-6 mt-8"),P(fe,"class","docstring border-l-2 border-t-2 pl-4 pt-3.5 border-gray-100 rounded-tl-xl mb-6 mt-8"),P(K,"class","docstring border-l-2 border-t-2 pl-4 pt-3.5 border-gray-100 rounded-tl-xl mb-6 mt-8"),P(Z,"class","docstring border-l-2 border-t-2 pl-4 pt-3.5 border-gray-100 rounded-tl-xl mb-6 mt-8"),P(je,"class","docstring border-l-2 border-t-2 pl-4 pt-3.5 border-gray-100 rounded-tl-xl mb-6 mt-8")},m(l,v){T(e,l,v),c(l,p,v),c(l,o,v),T(n,o,null),u(o,m),u(o,t),u(o,Ue),u(o,k),u(o,Ce),T(U,o,null),u(o,Ve),u(o,W),T(j,W,null),u(W,se),u(W,re),u(W,ce),T(S,W,null),u(W,ze),T(ae,W,null),u(o,Re),u(o,ue),T(Y,ue,null),u(ue,We),u(ue,ie),u(ue,me),T(Q,ue,null),u(ue,Ie),T(be,ue,null),u(o,Ye),u(o,I),T(A,I,null),u(I,D),u(I,R),u(I,ve),T(ke,I,null),u(I,xe),T(H,I,null),c(l,Ae,v),T(F,l,v),c(l,O,v),c(l,K,v),T($e,K,null),u(K,qe),u(K,fe),T(ee,fe,null),u(fe,Fe),u(fe,le),u(fe,ge),T(Ge,fe,null),u(fe,de),T(he,fe,null),c(l,Pe,v),T(C,l,v),c(l,Ze,v),c(l,je,v),T(E,je,null),u(je,De),u(je,Z),T(oe,Z,null),u(Z,ne),u(Z,q),u(Z,d),T(V,Z,null),u(Z,_e),T(z,Z,null),Te=!0},p(l,v){const B={};v&2&&(B.$$scope={dirty:v,ctx:l}),U.$set(B);const J={};v&2&&(J.$$scope={dirty:v,ctx:l}),S.$set(J);const Me={};v&2&&(Me.$$scope={dirty:v,ctx:l}),ae.$set(Me);const we={};v&2&&(we.$$scope={dirty:v,ctx:l}),Q.$set(we);const ye={};v&2&&(ye.$$scope={dirty:v,ctx:l}),be.$set(ye);const Ne={};v&2&&(Ne.$$scope={dirty:v,ctx:l}),ke.$set(Ne);const Je={};v&2&&(Je.$$scope={dirty:v,ctx:l}),H.$set(Je);const s={};v&2&&(s.$$scope={dirty:v,ctx:l}),Ge.$set(s);const x={};v&2&&(x.$$scope={dirty:v,ctx:l}),he.$set(x);const Ee={};v&2&&(Ee.$$scope={dirty:v,ctx:l}),V.$set(Ee);const tt={};v&2&&(tt.$$scope={dirty:v,ctx:l}),z.$set(tt)},i(l){Te||(M(e.$$.fragment,l),M(n.$$.fragment,l),M(U.$$.fragment,l),M(j.$$.fragment,l),M(S.$$.fragment,l),M(ae.$$.fragment,l),M(Y.$$.fragment,l),M(Q.$$.fragment,l),M(be.$$.fragment,l),M(A.$$.fragment,l),M(ke.$$.fragment,l),M(H.$$.fragment,l),M(F.$$.fragment,l),M($e.$$.fragment,l),M(ee.$$.fragment,l),M(Ge.$$.fragment,l),M(he.$$.fragment,l),M(C.$$.fragment,l),M(E.$$.fragment,l),M(oe.$$.fragment,l),M(V.$$.fragment,l),M(z.$$.fragment,l),Te=!0)},o(l){y(e.$$.fragment,l),y(n.$$.fragment,l),y(U.$$.fragment,l),y(j.$$.fragment,l),y(S.$$.fragment,l),y(ae.$$.fragment,l),y(Y.$$.fragment,l),y(Q.$$.fragment,l),y(be.$$.fragment,l),y(A.$$.fragment,l),y(ke.$$.fragment,l),y(H.$$.fragment,l),y(F.$$.fragment,l),y($e.$$.fragment,l),y(ee.$$.fragment,l),y(Ge.$$.fragment,l),y(he.$$.fragment,l),y(C.$$.fragment,l),y(E.$$.fragment,l),y(oe.$$.fragment,l),y(V.$$.fragment,l),y(z.$$.fragment,l),Te=!1},d(l){l&&(r(p),r(o),r(Ae),r(O),r(K),r(Pe),r(Ze),r(je)),b(e,l),b(n),b(U),b(j),b(S),b(ae),b(Y),b(Q),b(be),b(A),b(ke),b(H),b(F,l),b($e),b(ee),b(Ge),b(he),b(C,l),b(E),b(oe),b(V),b(z)}}}function Zt(w){let e,p;return e=new nt({props:{$$slots:{default:[Ft]},$$scope:{ctx:w}}}),{c(){h(e.$$.fragment)},l(o){_(e.$$.fragment,o)},m(o,n){T(e,o,n),p=!0},p(o,n){const m={};n&2&&(m.$$scope={dirty:n,ctx:o}),e.$set(m)},i(o){p||(M(e.$$.fragment,o),p=!0)},o(o){y(e.$$.fragment,o),p=!1},d(o){b(e,o)}}}function Bt(w){let e,p,o,n,m,t,$,Ue,k,X=`The GroupViT model was proposed in <a href="https://arxiv.org/abs/2202.11094" rel="nofollow">GroupViT: Semantic Segmentation Emerges from Text Supervision</a> by Jiarui Xu, Shalini De Mello, Sifei Liu, Wonmin Byeon, Thomas Breuel, Jan Kautz, Xiaolong Wang. | |
| Inspired by <a href="clip">CLIP</a>, GroupViT is a vision-language model that can perform zero-shot semantic segmentation on any given vocabulary categories.`,Ce,U,Ve="The abstract from the paper is the following:",W,j,se="<em>Grouping and recognition are important components of visual scene understanding, e.g., for object detection and semantic segmentation. With end-to-end deep learning systems, grouping of image regions usually happens implicitly via top-down supervision from pixel-level recognition labels. Instead, in this paper, we propose to bring back the grouping mechanism into deep networks, which allows semantic segments to emerge automatically with only text supervision. We propose a hierarchical Grouping Vision Transformer (GroupViT), which goes beyond the regular grid structure representation and learns to group image regions into progressively larger arbitrary-shaped segments. We train GroupViT jointly with a text encoder on a large-scale image-text dataset via contrastive losses. With only text supervision and without any pixel-level annotations, GroupViT learns to group together semantic regions and successfully transfers to the task of semantic segmentation in a zero-shot manner, i.e., without any further fine-tuning. It achieves a zero-shot accuracy of 52.3% mIoU on the PASCAL VOC 2012 and 22.4% mIoU on PASCAL Context datasets, and performs competitively to state-of-the-art transfer-learning methods requiring greater levels of supervision.</em>",re,Be,ce=`This model was contributed by <a href="https://huggingface.co/xvjiarui" rel="nofollow">xvjiarui</a>. The TensorFlow version was contributed by <a href="https://huggingface.co/ariG23498" rel="nofollow">ariG23498</a> with the help of <a href="https://huggingface.co/ydshieh" rel="nofollow">Yih-Dar SHIEH</a>, <a href="https://huggingface.co/amyeroberts" rel="nofollow">Amy Roberts</a>, and <a href="https://huggingface.co/joaogante" rel="nofollow">Joao Gante</a>. | |
| The original code can be found <a href="https://github.com/NVlabs/GroupViT" rel="nofollow">here</a>.`,S,ze,ae,Re,ue="<li>You may specify <code>output_segmentation=True</code> in the forward of <code>GroupViTModel</code> to get the segmentation logits of input texts.</li>",Y,We,ie,He,me="A list of official Hugging Face and community (indicated by 🌎) resources to help you get started with GroupViT.",Q,Ie,be='<li>The quickest way to get started with GroupViT is by checking the <a href="https://github.com/xvjiarui/GroupViT/blob/main/demo/GroupViT_hf_inference_notebook.ipynb" rel="nofollow">example notebooks</a> (which showcase zero-shot segmentation inference).</li> <li>One can also check out the <a href="https://huggingface.co/spaces/xvjiarui/GroupViT" rel="nofollow">HuggingFace Spaces demo</a> to play with GroupViT.</li>',Ye,I,A,D,R,Qe,ve,ke=`<a href="/docs/transformers/pr_33174/en/model_doc/groupvit#transformers.GroupViTConfig">GroupViTConfig</a> is the configuration class to store the configuration of a <a href="/docs/transformers/pr_33174/en/model_doc/groupvit#transformers.GroupViTModel">GroupViTModel</a>. It is used to | |
| instantiate a GroupViT model according to the specified arguments, defining the text model and vision model | |
| configs. Instantiating a configuration with the defaults will yield a similar configuration to that of the GroupViT | |
| <a href="https://huggingface.co/nvidia/groupvit-gcc-yfcc" rel="nofollow">nvidia/groupvit-gcc-yfcc</a> architecture.`,xe,H,Ae=`Configuration objects inherit from <a href="/docs/transformers/pr_33174/en/main_classes/configuration#transformers.PretrainedConfig">PretrainedConfig</a> and can be used to control the model outputs. Read the | |
| documentation from <a href="/docs/transformers/pr_33174/en/main_classes/configuration#transformers.PretrainedConfig">PretrainedConfig</a> for more information.`,F,O,K,$e,qe,fe=`Instantiate a <a href="/docs/transformers/pr_33174/en/model_doc/groupvit#transformers.GroupViTConfig">GroupViTConfig</a> (or a derived class) from groupvit text model configuration and groupvit | |
| vision model configuration.`,ee,Fe,le,te,ge,Ge,de,he=`This is the configuration class to store the configuration of a <a href="/docs/transformers/pr_33174/en/model_doc/groupvit#transformers.GroupViTTextModel">GroupViTTextModel</a>. It is used to instantiate an | |
| GroupViT model according to the specified arguments, defining the model architecture. Instantiating a configuration | |
| with the defaults will yield a similar configuration to that of the GroupViT | |
| <a href="https://huggingface.co/nvidia/groupvit-gcc-yfcc" rel="nofollow">nvidia/groupvit-gcc-yfcc</a> architecture.`,Pe,C,Ze=`Configuration objects inherit from <a href="/docs/transformers/pr_33174/en/main_classes/configuration#transformers.PretrainedConfig">PretrainedConfig</a> and can be used to control the model outputs. Read the | |
| documentation from <a href="/docs/transformers/pr_33174/en/main_classes/configuration#transformers.PretrainedConfig">PretrainedConfig</a> for more information.`,je,E,De,Z,oe,ne,q,Oe,d,V=`This is the configuration class to store the configuration of a <a href="/docs/transformers/pr_33174/en/model_doc/groupvit#transformers.GroupViTVisionModel">GroupViTVisionModel</a>. It is used to instantiate | |
| an GroupViT model according to the specified arguments, defining the model architecture. Instantiating a | |
| configuration with the defaults will yield a similar configuration to that of the GroupViT | |
| <a href="https://huggingface.co/nvidia/groupvit-gcc-yfcc" rel="nofollow">nvidia/groupvit-gcc-yfcc</a> architecture.`,_e,z,Te=`Configuration objects inherit from <a href="/docs/transformers/pr_33174/en/main_classes/configuration#transformers.PretrainedConfig">PretrainedConfig</a> and can be used to control the model outputs. Read the | |
| documentation from <a href="/docs/transformers/pr_33174/en/main_classes/configuration#transformers.PretrainedConfig">PretrainedConfig</a> for more information.`,l,v,B,J,Me,we,ye,Ne,Je;return m=new Le({props:{title:"GroupViT",local:"groupvit",headingTag:"h1"}}),$=new Le({props:{title:"Overview",local:"overview",headingTag:"h2"}}),ze=new Le({props:{title:"Usage tips",local:"usage-tips",headingTag:"h2"}}),We=new Le({props:{title:"Resources",local:"resources",headingTag:"h2"}}),I=new Le({props:{title:"GroupViTConfig",local:"transformers.GroupViTConfig",headingTag:"h2"}}),R=new pe({props:{name:"class transformers.GroupViTConfig",anchor:"transformers.GroupViTConfig",parameters:[{name:"text_config",val:" = None"},{name:"vision_config",val:" = None"},{name:"projection_dim",val:" = 256"},{name:"projection_intermediate_dim",val:" = 4096"},{name:"logit_scale_init_value",val:" = 2.6592"},{name:"**kwargs",val:""}],parametersDescription:[{anchor:"transformers.GroupViTConfig.text_config",description:`<strong>text_config</strong> (<code>dict</code>, <em>optional</em>) — | |
| Dictionary of configuration options used to initialize <a href="/docs/transformers/pr_33174/en/model_doc/groupvit#transformers.GroupViTTextConfig">GroupViTTextConfig</a>.`,name:"text_config"},{anchor:"transformers.GroupViTConfig.vision_config",description:`<strong>vision_config</strong> (<code>dict</code>, <em>optional</em>) — | |
| Dictionary of configuration options used to initialize <a href="/docs/transformers/pr_33174/en/model_doc/groupvit#transformers.GroupViTVisionConfig">GroupViTVisionConfig</a>.`,name:"vision_config"},{anchor:"transformers.GroupViTConfig.projection_dim",description:`<strong>projection_dim</strong> (<code>int</code>, <em>optional</em>, defaults to 256) — | |
| Dimensionality of text and vision projection layers.`,name:"projection_dim"},{anchor:"transformers.GroupViTConfig.projection_intermediate_dim",description:`<strong>projection_intermediate_dim</strong> (<code>int</code>, <em>optional</em>, defaults to 4096) — | |
| Dimensionality of intermediate layer of text and vision projection layers.`,name:"projection_intermediate_dim"},{anchor:"transformers.GroupViTConfig.logit_scale_init_value",description:`<strong>logit_scale_init_value</strong> (<code>float</code>, <em>optional</em>, defaults to 2.6592) — | |
| The initial value of the <em>logit_scale</em> parameter. Default is used as per the original GroupViT | |
| implementation.`,name:"logit_scale_init_value"},{anchor:"transformers.GroupViTConfig.kwargs",description:`<strong>kwargs</strong> (<em>optional</em>) — | |
| Dictionary of keyword arguments.`,name:"kwargs"}],source:"https://github.com/huggingface/transformers/blob/vr_33174/src/transformers/models/groupvit/configuration_groupvit.py#L268"}}),K=new pe({props:{name:"from_text_vision_configs",anchor:"transformers.GroupViTConfig.from_text_vision_configs",parameters:[{name:"text_config",val:": GroupViTTextConfig"},{name:"vision_config",val:": GroupViTVisionConfig"},{name:"**kwargs",val:""}],source:"https://github.com/huggingface/transformers/blob/vr_33174/src/transformers/models/groupvit/configuration_groupvit.py#L393",returnDescription:`<script context="module">export const metadata = 'undefined';<\/script> | |
| <p>An instance of a configuration object</p> | |
| `,returnType:`<script context="module">export const metadata = 'undefined';<\/script> | |
| <p><a | |
| href="/docs/transformers/pr_33174/en/model_doc/groupvit#transformers.GroupViTConfig" | |
| >GroupViTConfig</a></p> | |
| `}}),Fe=new Le({props:{title:"GroupViTTextConfig",local:"transformers.GroupViTTextConfig",headingTag:"h2"}}),ge=new pe({props:{name:"class transformers.GroupViTTextConfig",anchor:"transformers.GroupViTTextConfig",parameters:[{name:"vocab_size",val:" = 49408"},{name:"hidden_size",val:" = 256"},{name:"intermediate_size",val:" = 1024"},{name:"num_hidden_layers",val:" = 12"},{name:"num_attention_heads",val:" = 4"},{name:"max_position_embeddings",val:" = 77"},{name:"hidden_act",val:" = 'quick_gelu'"},{name:"layer_norm_eps",val:" = 1e-05"},{name:"dropout",val:" = 0.0"},{name:"attention_dropout",val:" = 0.0"},{name:"initializer_range",val:" = 0.02"},{name:"initializer_factor",val:" = 1.0"},{name:"pad_token_id",val:" = 1"},{name:"bos_token_id",val:" = 49406"},{name:"eos_token_id",val:" = 49407"},{name:"**kwargs",val:""}],parametersDescription:[{anchor:"transformers.GroupViTTextConfig.vocab_size",description:`<strong>vocab_size</strong> (<code>int</code>, <em>optional</em>, defaults to 49408) — | |
| Vocabulary size of the GroupViT text model. Defines the number of different tokens that can be represented | |
| by the <code>inputs_ids</code> passed when calling <a href="/docs/transformers/pr_33174/en/model_doc/groupvit#transformers.GroupViTModel">GroupViTModel</a>.`,name:"vocab_size"},{anchor:"transformers.GroupViTTextConfig.hidden_size",description:`<strong>hidden_size</strong> (<code>int</code>, <em>optional</em>, defaults to 256) — | |
| Dimensionality of the encoder layers and the pooler layer.`,name:"hidden_size"},{anchor:"transformers.GroupViTTextConfig.intermediate_size",description:`<strong>intermediate_size</strong> (<code>int</code>, <em>optional</em>, defaults to 1024) — | |
| Dimensionality of the “intermediate” (i.e., feed-forward) layer in the Transformer encoder.`,name:"intermediate_size"},{anchor:"transformers.GroupViTTextConfig.num_hidden_layers",description:`<strong>num_hidden_layers</strong> (<code>int</code>, <em>optional</em>, defaults to 12) — | |
| Number of hidden layers in the Transformer encoder.`,name:"num_hidden_layers"},{anchor:"transformers.GroupViTTextConfig.num_attention_heads",description:`<strong>num_attention_heads</strong> (<code>int</code>, <em>optional</em>, defaults to 4) — | |
| Number of attention heads for each attention layer in the Transformer encoder.`,name:"num_attention_heads"},{anchor:"transformers.GroupViTTextConfig.max_position_embeddings",description:`<strong>max_position_embeddings</strong> (<code>int</code>, <em>optional</em>, defaults to 77) — | |
| The maximum sequence length that this model might ever be used with. Typically set this to something large | |
| just in case (e.g., 512 or 1024 or 2048).`,name:"max_position_embeddings"},{anchor:"transformers.GroupViTTextConfig.hidden_act",description:`<strong>hidden_act</strong> (<code>str</code> or <code>function</code>, <em>optional</em>, defaults to <code>"quick_gelu"</code>) — | |
| The non-linear activation function (function or string) in the encoder and pooler. If string, <code>"gelu"</code>, | |
| <code>"relu"</code>, <code>"selu"</code> and <code>"gelu_new"</code> <code>"quick_gelu"</code> are supported.`,name:"hidden_act"},{anchor:"transformers.GroupViTTextConfig.layer_norm_eps",description:`<strong>layer_norm_eps</strong> (<code>float</code>, <em>optional</em>, defaults to 1e-5) — | |
| The epsilon used by the layer normalization layers.`,name:"layer_norm_eps"},{anchor:"transformers.GroupViTTextConfig.attention_dropout",description:`<strong>attention_dropout</strong> (<code>float</code>, <em>optional</em>, defaults to 0.0) — | |
| The dropout ratio for the attention probabilities.`,name:"attention_dropout"},{anchor:"transformers.GroupViTTextConfig.dropout",description:`<strong>dropout</strong> (<code>float</code>, <em>optional</em>, defaults to 0.0) — | |
| The dropout probability for all fully connected layers in the embeddings, encoder, and pooler.`,name:"dropout"},{anchor:"transformers.GroupViTTextConfig.initializer_range",description:`<strong>initializer_range</strong> (<code>float</code>, <em>optional</em>, defaults to 0.02) — | |
| The standard deviation of the truncated_normal_initializer for initializing all weight matrices.`,name:"initializer_range"},{anchor:"transformers.GroupViTTextConfig.initializer_factor",description:`<strong>initializer_factor</strong> (<code>float</code>, <em>optional</em>, defaults to 1.0) — | |
| A factor for initializing all weight matrices (should be kept to 1, used internally for initialization | |
| testing).`,name:"initializer_factor"}],source:"https://github.com/huggingface/transformers/blob/vr_33174/src/transformers/models/groupvit/configuration_groupvit.py#L34"}}),E=new Xe({props:{anchor:"transformers.GroupViTTextConfig.example",$$slots:{default:[ct]},$$scope:{ctx:w}}}),Z=new Le({props:{title:"GroupViTVisionConfig",local:"transformers.GroupViTVisionConfig",headingTag:"h2"}}),q=new pe({props:{name:"class transformers.GroupViTVisionConfig",anchor:"transformers.GroupViTVisionConfig",parameters:[{name:"hidden_size",val:" = 384"},{name:"intermediate_size",val:" = 1536"},{name:"depths",val:" = [6, 3, 3]"},{name:"num_hidden_layers",val:" = 12"},{name:"num_group_tokens",val:" = [64, 8, 0]"},{name:"num_output_groups",val:" = [64, 8, 8]"},{name:"num_attention_heads",val:" = 6"},{name:"image_size",val:" = 224"},{name:"patch_size",val:" = 16"},{name:"num_channels",val:" = 3"},{name:"hidden_act",val:" = 'gelu'"},{name:"layer_norm_eps",val:" = 1e-05"},{name:"dropout",val:" = 0.0"},{name:"attention_dropout",val:" = 0.0"},{name:"initializer_range",val:" = 0.02"},{name:"initializer_factor",val:" = 1.0"},{name:"assign_eps",val:" = 1.0"},{name:"assign_mlp_ratio",val:" = [0.5, 4]"},{name:"**kwargs",val:""}],parametersDescription:[{anchor:"transformers.GroupViTVisionConfig.hidden_size",description:`<strong>hidden_size</strong> (<code>int</code>, <em>optional</em>, defaults to 384) — | |
| Dimensionality of the encoder layers and the pooler layer.`,name:"hidden_size"},{anchor:"transformers.GroupViTVisionConfig.intermediate_size",description:`<strong>intermediate_size</strong> (<code>int</code>, <em>optional</em>, defaults to 1536) — | |
| Dimensionality of the “intermediate” (i.e., feed-forward) layer in the Transformer encoder.`,name:"intermediate_size"},{anchor:"transformers.GroupViTVisionConfig.depths",description:`<strong>depths</strong> (<code>List[int]</code>, <em>optional</em>, defaults to [6, 3, 3]) — | |
| The number of layers in each encoder block.`,name:"depths"},{anchor:"transformers.GroupViTVisionConfig.num_group_tokens",description:`<strong>num_group_tokens</strong> (<code>List[int]</code>, <em>optional</em>, defaults to [64, 8, 0]) — | |
| The number of group tokens for each stage.`,name:"num_group_tokens"},{anchor:"transformers.GroupViTVisionConfig.num_output_groups",description:`<strong>num_output_groups</strong> (<code>List[int]</code>, <em>optional</em>, defaults to [64, 8, 8]) — | |
| The number of output groups for each stage, 0 means no group.`,name:"num_output_groups"},{anchor:"transformers.GroupViTVisionConfig.num_attention_heads",description:`<strong>num_attention_heads</strong> (<code>int</code>, <em>optional</em>, defaults to 6) — | |
| Number of attention heads for each attention layer in the Transformer encoder.`,name:"num_attention_heads"},{anchor:"transformers.GroupViTVisionConfig.image_size",description:`<strong>image_size</strong> (<code>int</code>, <em>optional</em>, defaults to 224) — | |
| The size (resolution) of each image.`,name:"image_size"},{anchor:"transformers.GroupViTVisionConfig.patch_size",description:`<strong>patch_size</strong> (<code>int</code>, <em>optional</em>, defaults to 16) — | |
| The size (resolution) of each patch.`,name:"patch_size"},{anchor:"transformers.GroupViTVisionConfig.hidden_act",description:`<strong>hidden_act</strong> (<code>str</code> or <code>function</code>, <em>optional</em>, defaults to <code>"gelu"</code>) — | |
| The non-linear activation function (function or string) in the encoder and pooler. If string, <code>"gelu"</code>, | |
| <code>"relu"</code>, <code>"selu"</code> and <code>"gelu_new"</code> <code>"quick_gelu"</code> are supported.`,name:"hidden_act"},{anchor:"transformers.GroupViTVisionConfig.layer_norm_eps",description:`<strong>layer_norm_eps</strong> (<code>float</code>, <em>optional</em>, defaults to 1e-5) — | |
| The epsilon used by the layer normalization layers.`,name:"layer_norm_eps"},{anchor:"transformers.GroupViTVisionConfig.dropout",description:`<strong>dropout</strong> (<code>float</code>, <em>optional</em>, defaults to 0.0) — | |
| The dropout probability for all fully connected layers in the embeddings, encoder, and pooler.`,name:"dropout"},{anchor:"transformers.GroupViTVisionConfig.attention_dropout",description:`<strong>attention_dropout</strong> (<code>float</code>, <em>optional</em>, defaults to 0.0) — | |
| The dropout ratio for the attention probabilities.`,name:"attention_dropout"},{anchor:"transformers.GroupViTVisionConfig.initializer_range",description:`<strong>initializer_range</strong> (<code>float</code>, <em>optional</em>, defaults to 0.02) — | |
| The standard deviation of the truncated_normal_initializer for initializing all weight matrices.`,name:"initializer_range"},{anchor:"transformers.GroupViTVisionConfig.initializer_factor",description:`<strong>initializer_factor</strong> (<code>float</code>, <em>optional</em>, defaults to 1.0) — | |
| A factor for initializing all weight matrices (should be kept to 1, used internally for initialization | |
| testing).`,name:"initializer_factor"}],source:"https://github.com/huggingface/transformers/blob/vr_33174/src/transformers/models/groupvit/configuration_groupvit.py#L143"}}),v=new Xe({props:{anchor:"transformers.GroupViTVisionConfig.example",$$slots:{default:[ut]},$$scope:{ctx:w}}}),J=new dt({props:{pytorch:!0,tensorflow:!0,jax:!1,$$slots:{tensorflow:[Zt],pytorch:[wt]},$$scope:{ctx:w}}}),we=new pt({props:{source:"https://github.com/huggingface/transformers/blob/main/docs/source/en/model_doc/groupvit.md"}}),{c(){e=f("meta"),p=a(),o=f("p"),n=a(),h(m.$$.fragment),t=a(),h($.$$.fragment),Ue=a(),k=f("p"),k.innerHTML=X,Ce=a(),U=f("p"),U.textContent=Ve,W=a(),j=f("p"),j.innerHTML=se,re=a(),Be=f("p"),Be.innerHTML=ce,S=a(),h(ze.$$.fragment),ae=a(),Re=f("ul"),Re.innerHTML=ue,Y=a(),h(We.$$.fragment),ie=a(),He=f("p"),He.textContent=me,Q=a(),Ie=f("ul"),Ie.innerHTML=be,Ye=a(),h(I.$$.fragment),A=a(),D=f("div"),h(R.$$.fragment),Qe=a(),ve=f("p"),ve.innerHTML=ke,xe=a(),H=f("p"),H.innerHTML=Ae,F=a(),O=f("div"),h(K.$$.fragment),$e=a(),qe=f("p"),qe.innerHTML=fe,ee=a(),h(Fe.$$.fragment),le=a(),te=f("div"),h(ge.$$.fragment),Ge=a(),de=f("p"),de.innerHTML=he,Pe=a(),C=f("p"),C.innerHTML=Ze,je=a(),h(E.$$.fragment),De=a(),h(Z.$$.fragment),oe=a(),ne=f("div"),h(q.$$.fragment),Oe=a(),d=f("p"),d.innerHTML=V,_e=a(),z=f("p"),z.innerHTML=Te,l=a(),h(v.$$.fragment),B=a(),h(J.$$.fragment),Me=a(),h(we.$$.fragment),ye=a(),Ne=f("p"),this.h()},l(s){const x=lt("svelte-u9bgzb",document.head);e=g(x,"META",{name:!0,content:!0}),x.forEach(r),p=i(s),o=g(s,"P",{}),L(o).forEach(r),n=i(s),_(m.$$.fragment,s),t=i(s),_($.$$.fragment,s),Ue=i(s),k=g(s,"P",{"data-svelte-h":!0}),G(k)!=="svelte-9ila0d"&&(k.innerHTML=X),Ce=i(s),U=g(s,"P",{"data-svelte-h":!0}),G(U)!=="svelte-vfdo9a"&&(U.textContent=Ve),W=i(s),j=g(s,"P",{"data-svelte-h":!0}),G(j)!=="svelte-15lxkm3"&&(j.innerHTML=se),re=i(s),Be=g(s,"P",{"data-svelte-h":!0}),G(Be)!=="svelte-1d5dihc"&&(Be.innerHTML=ce),S=i(s),_(ze.$$.fragment,s),ae=i(s),Re=g(s,"UL",{"data-svelte-h":!0}),G(Re)!=="svelte-1u8mcsj"&&(Re.innerHTML=ue),Y=i(s),_(We.$$.fragment,s),ie=i(s),He=g(s,"P",{"data-svelte-h":!0}),G(He)!=="svelte-3razzh"&&(He.textContent=me),Q=i(s),Ie=g(s,"UL",{"data-svelte-h":!0}),G(Ie)!=="svelte-gxpanf"&&(Ie.innerHTML=be),Ye=i(s),_(I.$$.fragment,s),A=i(s),D=g(s,"DIV",{class:!0});var Ee=L(D);_(R.$$.fragment,Ee),Qe=i(Ee),ve=g(Ee,"P",{"data-svelte-h":!0}),G(ve)!=="svelte-z3zrv7"&&(ve.innerHTML=ke),xe=i(Ee),H=g(Ee,"P",{"data-svelte-h":!0}),G(H)!=="svelte-12x96jn"&&(H.innerHTML=Ae),F=i(Ee),O=g(Ee,"DIV",{class:!0});var tt=L(O);_(K.$$.fragment,tt),$e=i(tt),qe=g(tt,"P",{"data-svelte-h":!0}),G(qe)!=="svelte-jio8dw"&&(qe.innerHTML=fe),tt.forEach(r),Ee.forEach(r),ee=i(s),_(Fe.$$.fragment,s),le=i(s),te=g(s,"DIV",{class:!0});var Ke=L(te);_(ge.$$.fragment,Ke),Ge=i(Ke),de=g(Ke,"P",{"data-svelte-h":!0}),G(de)!=="svelte-g5zsm7"&&(de.innerHTML=he),Pe=i(Ke),C=g(Ke,"P",{"data-svelte-h":!0}),G(C)!=="svelte-12x96jn"&&(C.innerHTML=Ze),je=i(Ke),_(E.$$.fragment,Ke),Ke.forEach(r),De=i(s),_(Z.$$.fragment,s),oe=i(s),ne=g(s,"DIV",{class:!0});var ot=L(ne);_(q.$$.fragment,ot),Oe=i(ot),d=g(ot,"P",{"data-svelte-h":!0}),G(d)!=="svelte-6w2frn"&&(d.innerHTML=V),_e=i(ot),z=g(ot,"P",{"data-svelte-h":!0}),G(z)!=="svelte-12x96jn"&&(z.innerHTML=Te),l=i(ot),_(v.$$.fragment,ot),ot.forEach(r),B=i(s),_(J.$$.fragment,s),Me=i(s),_(we.$$.fragment,s),ye=i(s),Ne=g(s,"P",{}),L(Ne).forEach(r),this.h()},h(){P(e,"name","hf:doc:metadata"),P(e,"content",Rt),P(O,"class","docstring border-l-2 border-t-2 pl-4 pt-3.5 border-gray-100 rounded-tl-xl mb-6 mt-8"),P(D,"class","docstring border-l-2 border-t-2 pl-4 pt-3.5 border-gray-100 rounded-tl-xl mb-6 mt-8"),P(te,"class","docstring border-l-2 border-t-2 pl-4 pt-3.5 border-gray-100 rounded-tl-xl mb-6 mt-8"),P(ne,"class","docstring border-l-2 border-t-2 pl-4 pt-3.5 border-gray-100 rounded-tl-xl mb-6 mt-8")},m(s,x){u(document.head,e),c(s,p,x),c(s,o,x),c(s,n,x),T(m,s,x),c(s,t,x),T($,s,x),c(s,Ue,x),c(s,k,x),c(s,Ce,x),c(s,U,x),c(s,W,x),c(s,j,x),c(s,re,x),c(s,Be,x),c(s,S,x),T(ze,s,x),c(s,ae,x),c(s,Re,x),c(s,Y,x),T(We,s,x),c(s,ie,x),c(s,He,x),c(s,Q,x),c(s,Ie,x),c(s,Ye,x),T(I,s,x),c(s,A,x),c(s,D,x),T(R,D,null),u(D,Qe),u(D,ve),u(D,xe),u(D,H),u(D,F),u(D,O),T(K,O,null),u(O,$e),u(O,qe),c(s,ee,x),T(Fe,s,x),c(s,le,x),c(s,te,x),T(ge,te,null),u(te,Ge),u(te,de),u(te,Pe),u(te,C),u(te,je),T(E,te,null),c(s,De,x),T(Z,s,x),c(s,oe,x),c(s,ne,x),T(q,ne,null),u(ne,Oe),u(ne,d),u(ne,_e),u(ne,z),u(ne,l),T(v,ne,null),c(s,B,x),T(J,s,x),c(s,Me,x),T(we,s,x),c(s,ye,x),c(s,Ne,x),Je=!0},p(s,[x]){const Ee={};x&2&&(Ee.$$scope={dirty:x,ctx:s}),E.$set(Ee);const tt={};x&2&&(tt.$$scope={dirty:x,ctx:s}),v.$set(tt);const Ke={};x&2&&(Ke.$$scope={dirty:x,ctx:s}),J.$set(Ke)},i(s){Je||(M(m.$$.fragment,s),M($.$$.fragment,s),M(ze.$$.fragment,s),M(We.$$.fragment,s),M(I.$$.fragment,s),M(R.$$.fragment,s),M(K.$$.fragment,s),M(Fe.$$.fragment,s),M(ge.$$.fragment,s),M(E.$$.fragment,s),M(Z.$$.fragment,s),M(q.$$.fragment,s),M(v.$$.fragment,s),M(J.$$.fragment,s),M(we.$$.fragment,s),Je=!0)},o(s){y(m.$$.fragment,s),y($.$$.fragment,s),y(ze.$$.fragment,s),y(We.$$.fragment,s),y(I.$$.fragment,s),y(R.$$.fragment,s),y(K.$$.fragment,s),y(Fe.$$.fragment,s),y(ge.$$.fragment,s),y(E.$$.fragment,s),y(Z.$$.fragment,s),y(q.$$.fragment,s),y(v.$$.fragment,s),y(J.$$.fragment,s),y(we.$$.fragment,s),Je=!1},d(s){s&&(r(p),r(o),r(n),r(t),r(Ue),r(k),r(Ce),r(U),r(W),r(j),r(re),r(Be),r(S),r(ae),r(Re),r(Y),r(ie),r(He),r(Q),r(Ie),r(Ye),r(A),r(D),r(ee),r(le),r(te),r(De),r(oe),r(ne),r(B),r(Me),r(ye),r(Ne)),r(e),b(m,s),b($,s),b(ze,s),b(We,s),b(I,s),b(R),b(K),b(Fe,s),b(ge),b(E),b(Z,s),b(q),b(v),b(J,s),b(we,s)}}}const Rt='{"title":"GroupViT","local":"groupvit","sections":[{"title":"Overview","local":"overview","sections":[],"depth":2},{"title":"Usage tips","local":"usage-tips","sections":[],"depth":2},{"title":"Resources","local":"resources","sections":[],"depth":2},{"title":"GroupViTConfig","local":"transformers.GroupViTConfig","sections":[],"depth":2},{"title":"GroupViTTextConfig","local":"transformers.GroupViTTextConfig","sections":[],"depth":2},{"title":"GroupViTVisionConfig","local":"transformers.GroupViTVisionConfig","sections":[],"depth":2},{"title":"GroupViTModel","local":"transformers.GroupViTModel","sections":[],"depth":2},{"title":"GroupViTTextModel","local":"transformers.GroupViTTextModel","sections":[],"depth":2},{"title":"GroupViTVisionModel","local":"transformers.GroupViTVisionModel","sections":[],"depth":2},{"title":"TFGroupViTModel","local":"transformers.TFGroupViTModel","sections":[],"depth":2},{"title":"TFGroupViTTextModel","local":"transformers.TFGroupViTTextModel","sections":[],"depth":2},{"title":"TFGroupViTVisionModel","local":"transformers.TFGroupViTVisionModel","sections":[],"depth":2}],"depth":1}';function Ht(w){return rt(()=>{new URLSearchParams(window.location.search).get("fw")}),[]}class Qt extends at{constructor(e){super(),it(this,e,Ht,Bt,st,{})}}export{Qt as component}; | |
Xet Storage Details
- Size:
- 137 kB
- Xet hash:
- d22717459494b00d74ad30ff1f253944372746b3c091c3a004445ac8a41f8f8e
·
Xet efficiently stores files, intelligently splitting them into unique chunks and accelerating uploads and downloads. More info.