Buckets:
| import{s as xe,f as we,n as Ae,o as qe}from"../chunks/scheduler.37c15a92.js";import{S as ze,i as $e,g as o,s as a,r as d,m as Se,A as Xe,h as r,f as t,c as n,j as R,u as y,x as m,n as Re,k as i,y as Ye,a as l,v as h,d as j,t as w,w as f}from"../chunks/index.2bf4358c.js";import{C as fe}from"../chunks/CodeBlock.4e987730.js";import{C as _e}from"../chunks/CourseFloatingBanner.6add7356.js";import{H as je,E as Fe}from"../chunks/getInferenceSnippets.24b50994.js";function Ve(Je){let M,Y,S,_,J,F,b,V,U,be="Maintenant que nous pouvons construire et partager une interface de base, explorons quelques fonctionnalités plus avancées comme l’état, l’interprétation et l’authentification.",H,T,L,g,Ue="<em>Gradio</em> supporte <em>l’état de session</em> où les données persistent à travers plusieurs soumissions dans un chargement de page. L’état de session est utile pour construire des démos où vous souhaitez faire persister les données au fur et à mesure que l’utilisateur interagit avec le modèle (par exemple des chatbots). Notez que l’état de session ne partage pas les données entre les différents utilisateurs de votre modèle.",K,I,Te="Pour stocker des données dans un état de session, vous devez faire trois choses :",P,G,ge="<li>Passez un <em>paramètre supplémentaire</em> dans votre fonction, qui représente l’état de l’interface.</li> <li>A la fin de la fonction, renvoyer la valeur mise à jour de l’état comme une <em>valeur de retour supplémentaire</em>.</li> <li>Ajoutez les composants “state” input et “state” output lors de la création de votre <code>Interface</code>.</li>",D,C,Ie="Voir l’exemple de chatbot ci-dessous :",O,v,ee,p,Ge,se,k,te,B,Ce="La plupart des modèles d’apprentissage automatique sont des boîtes noires et la logique interne de la fonction est cachée à l’utilisateur final. Pour encourager la transparence, nous avons fait en sorte qu’il soit très facile d’ajouter l’interprétation à votre modèle en définissant simplement le mot-clé interprétation dans la classe Interface par défaut. Cela permet à vos utilisateurs de comprendre quelles parties de l’entrée sont responsables de la sortie. Jetez un coup d’œil à l’interface simple ci-dessous qui montre un classifieur d’images incluant l’interprétation :",le,Z,ae,E,ve="Testez la fonction d’interprétation en soumettant une entrée puis en cliquant sur « Interpréter » sous le composant de sortie.",ne,c,ke,ie,N,Be=`En plus de la méthode d’interprétation par défaut fournie par <em>Gradio</em>, vous pouvez également spécifier <code>shap</code> pour le paramètre <code>interpretation</code> et définir le paramètre <code>num_shap</code>. Ceci utilise l’interprétation basée sur Shapley, dont vous pouvez lire plus sur <a href="https://christophm.github.io/interpretable-ml-book/shap.html" rel="nofollow">ici</a>. | |
| Enfin, vous pouvez aussi passer votre propre fonction d’interprétation dans le paramètre <code>interpretation</code>. Vous trouverez un exemple dans la page de démarrage de <em>Gradio</em> <a href="https://gradio.app/getting_started/" rel="nofollow">ici</a>.`,oe,Q,re,W,Ze="Vous pouvez vouloir ajouter une authentification à votre interface <em>Gradio</em> afin de contrôler qui peut accéder et utiliser votre démo.",pe,x,Ee="L’authentification peut être ajoutée en fournissant une liste de tuples de nom d’utilisateur/mot de passe au paramètre <code>auth</code> de la méthode <code>launch()</code>. Pour une gestion plus complexe de l’authentification, vous pouvez passer une fonction qui prend un nom d’utilisateur et un mot de passe comme arguments, et retourne <code>True</code> pour permettre l’authentification, <code>False</code> sinon.",ce,A,Ne="Prenons la démo de classification d’images ci-dessus et ajoutons l’authentification :",ue,q,me,u,Qe,Me,z,We="Ceci conclut notre plongée dans la classe <code>Interface</code> de <em>Gradio</em>. Comme nous l’avons vu, cette classe permet de créer facilement des démos d’apprentissage automatique en quelques lignes de code Python. Cependant, vous voudrez parfois personnaliser votre démo en changeant la mise en page ou en enchaînant plusieurs fonctions de prédiction. Ne serait-il pas agréable de pouvoir diviser l’interface en blocs personnalisables ? Heureusement, c’est possible ! C’est le sujet de la dernière section.",de,$,ye,X,he;return J=new je({props:{title:"Fonctionnalités avancées de l’interface",local:"fonctionnalités-avancées-de-linterface",headingTag:"h1"}}),b=new _e({props:{chapter:9,classNames:"absolute z-10 right-0 top-0",notebooks:[{label:"English",value:"https://colab.research.google.com/github/huggingface/notebooks/blob/master/course/en/chapter9/section6.ipynb"},{label:"Français",value:"https://colab.research.google.com/github/huggingface/notebooks/blob/master/course/fr/chapter9/section6.ipynb"},{label:"English",value:"https://studiolab.sagemaker.aws/import/github/huggingface/notebooks/blob/master/course/en/chapter9/section6.ipynb"},{label:"Français",value:"https://studiolab.sagemaker.aws/import/github/huggingface/notebooks/blob/master/course/fr/chapter9/section6.ipynb"}]}}),T=new je({props:{title:"Utilisation de l’état pour faire persister les données",local:"utilisation-de-létat-pour-faire-persister-les-données",headingTag:"h3"}}),v=new fe({props:{code:"aW1wb3J0JTIwcmFuZG9tJTBBJTBBaW1wb3J0JTIwZ3JhZGlvJTIwYXMlMjBnciUwQSUwQSUwQWRlZiUyMGNoYXQobWVzc2FnZSUyQyUyMGhpc3RvcnkpJTNBJTBBJTIwJTIwJTIwJTIwaGlzdG9yeSUyMCUzRCUyMGhpc3RvcnklMjBvciUyMCU1QiU1RCUwQSUyMCUyMCUyMCUyMGlmJTIwbWVzc2FnZS5zdGFydHN3aXRoKCUyMkhvdyUyMG1hbnklMjIpJTNBJTBBJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwcmVzcG9uc2UlMjAlM0QlMjByYW5kb20ucmFuZGludCgxJTJDJTIwMTApJTBBJTIwJTIwJTIwJTIwZWxpZiUyMG1lc3NhZ2Uuc3RhcnRzd2l0aCglMjJIb3clMjIpJTNBJTBBJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwcmVzcG9uc2UlMjAlM0QlMjByYW5kb20uY2hvaWNlKCU1QiUyMkdyZWF0JTIyJTJDJTIwJTIyR29vZCUyMiUyQyUyMCUyMk9rYXklMjIlMkMlMjAlMjJCYWQlMjIlNUQpJTBBJTIwJTIwJTIwJTIwZWxpZiUyMG1lc3NhZ2Uuc3RhcnRzd2l0aCglMjJXaGVyZSUyMiklM0ElMEElMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjByZXNwb25zZSUyMCUzRCUyMHJhbmRvbS5jaG9pY2UoJTVCJTIySGVyZSUyMiUyQyUyMCUyMlRoZXJlJTIyJTJDJTIwJTIyU29tZXdoZXJlJTIyJTVEKSUwQSUyMCUyMCUyMCUyMGVsc2UlM0ElMEElMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjByZXNwb25zZSUyMCUzRCUyMCUyMkklMjBkb24ndCUyMGtub3clMjIlMEElMjAlMjAlMjAlMjBoaXN0b3J5LmFwcGVuZCgobWVzc2FnZSUyQyUyMHJlc3BvbnNlKSklMEElMjAlMjAlMjAlMjByZXR1cm4lMjBoaXN0b3J5JTJDJTIwaGlzdG9yeSUwQSUwQSUwQWlmYWNlJTIwJTNEJTIwZ3IuSW50ZXJmYWNlKCUwQSUyMCUyMCUyMCUyMGNoYXQlMkMlMEElMjAlMjAlMjAlMjAlNUIlMjJ0ZXh0JTIyJTJDJTIwJTIyc3RhdGUlMjIlNUQlMkMlMEElMjAlMjAlMjAlMjAlNUIlMjJjaGF0Ym90JTIyJTJDJTIwJTIyc3RhdGUlMjIlNUQlMkMlMEElMjAlMjAlMjAlMjBhbGxvd19zY3JlZW5zaG90JTNERmFsc2UlMkMlMEElMjAlMjAlMjAlMjBhbGxvd19mbGFnZ2luZyUzRCUyMm5ldmVyJTIyJTJDJTBBKSUwQWlmYWNlLmxhdW5jaCgp",highlighted:`<span class="hljs-keyword">import</span> random | |
| <span class="hljs-keyword">import</span> gradio <span class="hljs-keyword">as</span> gr | |
| <span class="hljs-keyword">def</span> <span class="hljs-title function_">chat</span>(<span class="hljs-params">message, history</span>): | |
| history = history <span class="hljs-keyword">or</span> [] | |
| <span class="hljs-keyword">if</span> message.startswith(<span class="hljs-string">"How many"</span>): | |
| response = random.randint(<span class="hljs-number">1</span>, <span class="hljs-number">10</span>) | |
| <span class="hljs-keyword">elif</span> message.startswith(<span class="hljs-string">"How"</span>): | |
| response = random.choice([<span class="hljs-string">"Great"</span>, <span class="hljs-string">"Good"</span>, <span class="hljs-string">"Okay"</span>, <span class="hljs-string">"Bad"</span>]) | |
| <span class="hljs-keyword">elif</span> message.startswith(<span class="hljs-string">"Where"</span>): | |
| response = random.choice([<span class="hljs-string">"Here"</span>, <span class="hljs-string">"There"</span>, <span class="hljs-string">"Somewhere"</span>]) | |
| <span class="hljs-keyword">else</span>: | |
| response = <span class="hljs-string">"I don't know"</span> | |
| history.append((message, response)) | |
| <span class="hljs-keyword">return</span> history, history | |
| iface = gr.Interface( | |
| chat, | |
| [<span class="hljs-string">"text"</span>, <span class="hljs-string">"state"</span>], | |
| [<span class="hljs-string">"chatbot"</span>, <span class="hljs-string">"state"</span>], | |
| allow_screenshot=<span class="hljs-literal">False</span>, | |
| allow_flagging=<span class="hljs-string">"never"</span>, | |
| ) | |
| iface.launch()`,wrap:!1}}),k=new je({props:{title:"Utilisation de l’interprétation pour comprendre les prédictions",local:"utilisation-de-linterprétation-pour-comprendre-les-prédictions",headingTag:"h3"}}),Z=new fe({props:{code:"aW1wb3J0JTIwcmVxdWVzdHMlMEFpbXBvcnQlMjB0ZW5zb3JmbG93JTIwYXMlMjB0ZiUwQSUwQWltcG9ydCUyMGdyYWRpbyUyMGFzJTIwZ3IlMEElMEFpbmNlcHRpb25fbmV0JTIwJTNEJTIwdGYua2VyYXMuYXBwbGljYXRpb25zLk1vYmlsZU5ldFYyKCklMjAlMjAlMjMlMjBjaGFyZ2VyJTIwbGUlMjBtb2QlQzMlQThsZSUwQSUwQSUyMyUyMFQlQzMlQTlsJUMzJUE5Y2hhcmdlciUyMGRlcyUyMCVDMyVBOXRpcXVldHRlcyUyMGxpc2libGVzJTIwcGFyJTIwbCdob21tZSUyMHBvdXIlMjBJbWFnZU5ldCUwQXJlc3BvbnNlJTIwJTNEJTIwcmVxdWVzdHMuZ2V0KCUyMmh0dHBzJTNBJTJGJTJGZ2l0LmlvJTJGSkprWU4lMjIpJTBBbGFiZWxzJTIwJTNEJTIwcmVzcG9uc2UudGV4dC5zcGxpdCglMjIlNUNuJTIyKSUwQSUwQSUwQWRlZiUyMGNsYXNzaWZ5X2ltYWdlKGlucCklM0ElMEElMjAlMjAlMjAlMjBpbnAlMjAlM0QlMjBpbnAucmVzaGFwZSgoLTElMkMlMjAyMjQlMkMlMjAyMjQlMkMlMjAzKSklMEElMjAlMjAlMjAlMjBpbnAlMjAlM0QlMjB0Zi5rZXJhcy5hcHBsaWNhdGlvbnMubW9iaWxlbmV0X3YyLnByZXByb2Nlc3NfaW5wdXQoaW5wKSUwQSUyMCUyMCUyMCUyMHByZWRpY3Rpb24lMjAlM0QlMjBpbmNlcHRpb25fbmV0LnByZWRpY3QoaW5wKS5mbGF0dGVuKCklMEElMjAlMjAlMjAlMjByZXR1cm4lMjAlN0JsYWJlbHMlNUJpJTVEJTNBJTIwZmxvYXQocHJlZGljdGlvbiU1QmklNUQpJTIwZm9yJTIwaSUyMGluJTIwcmFuZ2UoMTAwMCklN0QlMEElMEElMEFpbWFnZSUyMCUzRCUyMGdyLkltYWdlKHNoYXBlJTNEKDIyNCUyQyUyMDIyNCkpJTBBbGFiZWwlMjAlM0QlMjBnci5MYWJlbChudW1fdG9wX2NsYXNzZXMlM0QzKSUwQSUwQXRpdGxlJTIwJTNEJTIwJTIyR3JhZGlvJTIwSW1hZ2UlMjBDbGFzc2lmaWN0aW9uJTIwJTJCJTIwSW50ZXJwcmV0YXRpb24lMjBFeGFtcGxlJTIyJTBBZ3IuSW50ZXJmYWNlKCUwQSUyMCUyMCUyMCUyMGZuJTNEY2xhc3NpZnlfaW1hZ2UlMkMlMjBpbnB1dHMlM0RpbWFnZSUyQyUyMG91dHB1dHMlM0RsYWJlbCUyQyUyMGludGVycHJldGF0aW9uJTNEJTIyZGVmYXVsdCUyMiUyQyUyMHRpdGxlJTNEdGl0bGUlMEEpLmxhdW5jaCgp",highlighted:`<span class="hljs-keyword">import</span> requests | |
| <span class="hljs-keyword">import</span> tensorflow <span class="hljs-keyword">as</span> tf | |
| <span class="hljs-keyword">import</span> gradio <span class="hljs-keyword">as</span> gr | |
| inception_net = tf.keras.applications.MobileNetV2() <span class="hljs-comment"># charger le modèle</span> | |
| <span class="hljs-comment"># Télécharger des étiquettes lisibles par l'homme pour ImageNet</span> | |
| response = requests.get(<span class="hljs-string">"https://git.io/JJkYN"</span>) | |
| labels = response.text.split(<span class="hljs-string">"\\n"</span>) | |
| <span class="hljs-keyword">def</span> <span class="hljs-title function_">classify_image</span>(<span class="hljs-params">inp</span>): | |
| inp = inp.reshape((-<span class="hljs-number">1</span>, <span class="hljs-number">224</span>, <span class="hljs-number">224</span>, <span class="hljs-number">3</span>)) | |
| inp = tf.keras.applications.mobilenet_v2.preprocess_input(inp) | |
| prediction = inception_net.predict(inp).flatten() | |
| <span class="hljs-keyword">return</span> {labels[i]: <span class="hljs-built_in">float</span>(prediction[i]) <span class="hljs-keyword">for</span> i <span class="hljs-keyword">in</span> <span class="hljs-built_in">range</span>(<span class="hljs-number">1000</span>)} | |
| image = gr.Image(shape=(<span class="hljs-number">224</span>, <span class="hljs-number">224</span>)) | |
| label = gr.Label(num_top_classes=<span class="hljs-number">3</span>) | |
| title = <span class="hljs-string">"Gradio Image Classifiction + Interpretation Example"</span> | |
| gr.Interface( | |
| fn=classify_image, inputs=image, outputs=label, interpretation=<span class="hljs-string">"default"</span>, title=title | |
| ).launch()`,wrap:!1}}),Q=new je({props:{title:"Ajouter l’authentification",local:"ajouter-lauthentification",headingTag:"h3"}}),q=new fe({props:{code:"aW1wb3J0JTIwcmVxdWVzdHMlMEFpbXBvcnQlMjB0ZW5zb3JmbG93JTIwYXMlMjB0ZiUwQSUwQWltcG9ydCUyMGdyYWRpbyUyMGFzJTIwZ3IlMEElMEFpbmNlcHRpb25fbmV0JTIwJTNEJTIwdGYua2VyYXMuYXBwbGljYXRpb25zLk1vYmlsZU5ldFYyKCklMjAlMjAlMjMlMjBjaGFyZ2VyJTIwbGUlMjBtb2QlQzMlQThsZSUwQSUwQSUyMyUyMFQlQzMlQTlsJUMzJUE5Y2hhcmdlciUyMGRlcyUyMCVDMyVBOXRpcXVldHRlcyUyMGxpc2libGVzJTIwcGFyJTIwbCdob21tZSUyMHBvdXIlMjBJbWFnZU5ldCUwQXJlc3BvbnNlJTIwJTNEJTIwcmVxdWVzdHMuZ2V0KCUyMmh0dHBzJTNBJTJGJTJGZ2l0LmlvJTJGSkprWU4lMjIpJTBBbGFiZWxzJTIwJTNEJTIwcmVzcG9uc2UudGV4dC5zcGxpdCglMjIlNUNuJTIyKSUwQSUwQSUwQWRlZiUyMGNsYXNzaWZ5X2ltYWdlKGlucCklM0ElMEElMjAlMjAlMjAlMjBpbnAlMjAlM0QlMjBpbnAucmVzaGFwZSgoLTElMkMlMjAyMjQlMkMlMjAyMjQlMkMlMjAzKSklMEElMjAlMjAlMjAlMjBpbnAlMjAlM0QlMjB0Zi5rZXJhcy5hcHBsaWNhdGlvbnMubW9iaWxlbmV0X3YyLnByZXByb2Nlc3NfaW5wdXQoaW5wKSUwQSUyMCUyMCUyMCUyMHByZWRpY3Rpb24lMjAlM0QlMjBpbmNlcHRpb25fbmV0LnByZWRpY3QoaW5wKS5mbGF0dGVuKCklMEElMjAlMjAlMjAlMjByZXR1cm4lMjAlN0JsYWJlbHMlNUJpJTVEJTNBJTIwZmxvYXQocHJlZGljdGlvbiU1QmklNUQpJTIwZm9yJTIwaSUyMGluJTIwcmFuZ2UoMTAwMCklN0QlMEElMEElMEFpbWFnZSUyMCUzRCUyMGdyLkltYWdlKHNoYXBlJTNEKDIyNCUyQyUyMDIyNCkpJTBBbGFiZWwlMjAlM0QlMjBnci5MYWJlbChudW1fdG9wX2NsYXNzZXMlM0QzKSUwQSUwQXRpdGxlJTIwJTNEJTIwJTIyR3JhZGlvJTIwSW1hZ2UlMjBDbGFzc2lmaWN0aW9uJTIwJTJCJTIwSW50ZXJwcmV0YXRpb24lMjBFeGFtcGxlJTIyJTBBZ3IuSW50ZXJmYWNlKCUwQSUyMCUyMCUyMCUyMGZuJTNEY2xhc3NpZnlfaW1hZ2UlMkMlMjBpbnB1dHMlM0RpbWFnZSUyQyUyMG91dHB1dHMlM0RsYWJlbCUyQyUyMGludGVycHJldGF0aW9uJTNEJTIyZGVmYXVsdCUyMiUyQyUyMHRpdGxlJTNEdGl0bGUlMEEpLmxhdW5jaChhdXRoJTNEKCUyMmFkbWluJTIyJTJDJTIwJTIycGFzczEyMzQlMjIpKQ==",highlighted:`<span class="hljs-keyword">import</span> requests | |
| <span class="hljs-keyword">import</span> tensorflow <span class="hljs-keyword">as</span> tf | |
| <span class="hljs-keyword">import</span> gradio <span class="hljs-keyword">as</span> gr | |
| inception_net = tf.keras.applications.MobileNetV2() <span class="hljs-comment"># charger le modèle</span> | |
| <span class="hljs-comment"># Télécharger des étiquettes lisibles par l'homme pour ImageNet</span> | |
| response = requests.get(<span class="hljs-string">"https://git.io/JJkYN"</span>) | |
| labels = response.text.split(<span class="hljs-string">"\\n"</span>) | |
| <span class="hljs-keyword">def</span> <span class="hljs-title function_">classify_image</span>(<span class="hljs-params">inp</span>): | |
| inp = inp.reshape((-<span class="hljs-number">1</span>, <span class="hljs-number">224</span>, <span class="hljs-number">224</span>, <span class="hljs-number">3</span>)) | |
| inp = tf.keras.applications.mobilenet_v2.preprocess_input(inp) | |
| prediction = inception_net.predict(inp).flatten() | |
| <span class="hljs-keyword">return</span> {labels[i]: <span class="hljs-built_in">float</span>(prediction[i]) <span class="hljs-keyword">for</span> i <span class="hljs-keyword">in</span> <span class="hljs-built_in">range</span>(<span class="hljs-number">1000</span>)} | |
| image = gr.Image(shape=(<span class="hljs-number">224</span>, <span class="hljs-number">224</span>)) | |
| label = gr.Label(num_top_classes=<span class="hljs-number">3</span>) | |
| title = <span class="hljs-string">"Gradio Image Classifiction + Interpretation Example"</span> | |
| gr.Interface( | |
| fn=classify_image, inputs=image, outputs=label, interpretation=<span class="hljs-string">"default"</span>, title=title | |
| ).launch(auth=(<span class="hljs-string">"admin"</span>, <span class="hljs-string">"pass1234"</span>))`,wrap:!1}}),$=new Fe({props:{source:"https://github.com/huggingface/course/blob/main/chapters/fr/chapter9/6.mdx"}}),{c(){M=o("meta"),Y=a(),S=o("p"),_=a(),d(J.$$.fragment),F=a(),d(b.$$.fragment),V=a(),U=o("p"),U.textContent=be,H=a(),d(T.$$.fragment),L=a(),g=o("p"),g.innerHTML=Ue,K=a(),I=o("p"),I.textContent=Te,P=a(),G=o("ul"),G.innerHTML=ge,D=a(),C=o("p"),C.textContent=Ie,O=a(),d(v.$$.fragment),ee=a(),p=o("iframe"),se=Se(` | |
| Remarquez comment l'état du composant de sortie persiste entre les soumissions. | |
| Remarque : vous pouvez transmettre une valeur par défaut au paramètre state, qui est utilisée comme valeur initiale de l'état. | |
| `),d(k.$$.fragment),te=a(),B=o("p"),B.textContent=Ce,le=a(),d(Z.$$.fragment),ae=a(),E=o("p"),E.textContent=ve,ne=a(),c=o("iframe"),ie=a(),N=o("p"),N.innerHTML=Be,oe=a(),d(Q.$$.fragment),re=a(),W=o("p"),W.innerHTML=Ze,pe=a(),x=o("p"),x.innerHTML=Ee,ce=a(),A=o("p"),A.textContent=Ne,ue=a(),d(q.$$.fragment),me=a(),u=o("iframe"),Me=a(),z=o("p"),z.innerHTML=We,de=a(),d($.$$.fragment),ye=a(),X=o("p"),this.h()},l(e){const s=Xe("svelte-u9bgzb",document.head);M=r(s,"META",{name:!0,content:!0}),s.forEach(t),Y=n(e),S=r(e,"P",{}),R(S).forEach(t),_=n(e),y(J.$$.fragment,e),F=n(e),y(b.$$.fragment,e),V=n(e),U=r(e,"P",{"data-svelte-h":!0}),m(U)!=="svelte-zqxtni"&&(U.textContent=be),H=n(e),y(T.$$.fragment,e),L=n(e),g=r(e,"P",{"data-svelte-h":!0}),m(g)!=="svelte-n0aljj"&&(g.innerHTML=Ue),K=n(e),I=r(e,"P",{"data-svelte-h":!0}),m(I)!=="svelte-qw2g3t"&&(I.textContent=Te),P=n(e),G=r(e,"UL",{"data-svelte-h":!0}),m(G)!=="svelte-na9fa2"&&(G.innerHTML=ge),D=n(e),C=r(e,"P",{"data-svelte-h":!0}),m(C)!=="svelte-1o5953u"&&(C.textContent=Ie),O=n(e),y(v.$$.fragment,e),ee=n(e),p=r(e,"IFRAME",{src:!0,frameborder:!0,height:!0,title:!0,class:!0,allow:!0,sandbox:!0}),R(p).forEach(t),se=Re(e,` | |
| Remarquez comment l'état du composant de sortie persiste entre les soumissions. | |
| Remarque : vous pouvez transmettre une valeur par défaut au paramètre state, qui est utilisée comme valeur initiale de l'état. | |
| `),y(k.$$.fragment,e),te=n(e),B=r(e,"P",{"data-svelte-h":!0}),m(B)!=="svelte-1yno0pv"&&(B.textContent=Ce),le=n(e),y(Z.$$.fragment,e),ae=n(e),E=r(e,"P",{"data-svelte-h":!0}),m(E)!=="svelte-187nyfe"&&(E.textContent=ve),ne=n(e),c=r(e,"IFRAME",{src:!0,frameborder:!0,height:!0,title:!0,class:!0,allow:!0,sandbox:!0}),R(c).forEach(t),ie=n(e),N=r(e,"P",{"data-svelte-h":!0}),m(N)!=="svelte-sqkay3"&&(N.innerHTML=Be),oe=n(e),y(Q.$$.fragment,e),re=n(e),W=r(e,"P",{"data-svelte-h":!0}),m(W)!=="svelte-ilc63s"&&(W.innerHTML=Ze),pe=n(e),x=r(e,"P",{"data-svelte-h":!0}),m(x)!=="svelte-3v0gyq"&&(x.innerHTML=Ee),ce=n(e),A=r(e,"P",{"data-svelte-h":!0}),m(A)!=="svelte-gt112h"&&(A.textContent=Ne),ue=n(e),y(q.$$.fragment,e),me=n(e),u=r(e,"IFRAME",{src:!0,frameborder:!0,height:!0,title:!0,class:!0,allow:!0,sandbox:!0}),R(u).forEach(t),Me=n(e),z=r(e,"P",{"data-svelte-h":!0}),m(z)!=="svelte-vb0n92"&&(z.innerHTML=We),de=n(e),y($.$$.fragment,e),ye=n(e),X=r(e,"P",{}),R(X).forEach(t),this.h()},h(){i(M,"name","hf:doc:metadata"),i(M,"content",He),we(p.src,Ge="https://course-demos-Chatbot-Demo.hf.space")||i(p,"src",Ge),i(p,"frameborder","0"),i(p,"height","350"),i(p,"title","Gradio app"),i(p,"class","container p-0 flex-grow space-iframe"),i(p,"allow","accelerometer; ambient-light-sensor; autoplay; battery; camera; document-domain; encrypted-media; fullscreen; geolocation; gyroscope; layout-animations; legacy-image-formats; magnetometer; microphone; midi; oversized-images; payment; picture-in-picture; publickey-credentials-get; sync-xhr; usb; vr ; wake-lock; xr-spatial-tracking"),i(p,"sandbox","allow-forms allow-modals allow-popups allow-popups-to-escape-sandbox allow-same-origin allow-scripts allow-downloads"),we(c.src,ke="https://hf.space/gradioiframe/akhaliq/gradio-image-interpretation/+")||i(c,"src",ke),i(c,"frameborder","0"),i(c,"height","570"),i(c,"title","Gradio app"),i(c,"class","container p-0 flex-grow space-iframe"),i(c,"allow","accelerometer; ambient-light-sensor; autoplay; battery; camera; document-domain; encrypted-media; fullscreen; geolocation; gyroscope; layout-animations; legacy-image-formats; magnetometer; microphone; midi; oversized-images; payment; picture-in-picture; publickey-credentials-get; sync-xhr; usb; vr ; wake-lock; xr-spatial-tracking"),i(c,"sandbox","allow-forms allow-modals allow-popups allow-popups-to-escape-sandbox allow-same-origin allow-scripts allow-downloads"),we(u.src,Qe="https://course-demos-gradio-image-interpretation.hf.space")||i(u,"src",Qe),i(u,"frameborder","0"),i(u,"height","570"),i(u,"title","Gradio app"),i(u,"class","container p-0 flex-grow space-iframe"),i(u,"allow","accelerometer; ambient-light-sensor; autoplay; battery; camera; document-domain; encrypted-media; fullscreen; geolocation; gyroscope; layout-animations; legacy-image-formats; magnetometer; microphone; midi; oversized-images; payment; picture-in-picture; publickey-credentials-get; sync-xhr; usb; vr ; wake-lock; xr-spatial-tracking"),i(u,"sandbox","allow-forms allow-modals allow-popups allow-popups-to-escape-sandbox allow-same-origin allow-scripts allow-downloads")},m(e,s){Ye(document.head,M),l(e,Y,s),l(e,S,s),l(e,_,s),h(J,e,s),l(e,F,s),h(b,e,s),l(e,V,s),l(e,U,s),l(e,H,s),h(T,e,s),l(e,L,s),l(e,g,s),l(e,K,s),l(e,I,s),l(e,P,s),l(e,G,s),l(e,D,s),l(e,C,s),l(e,O,s),h(v,e,s),l(e,ee,s),l(e,p,s),l(e,se,s),h(k,e,s),l(e,te,s),l(e,B,s),l(e,le,s),h(Z,e,s),l(e,ae,s),l(e,E,s),l(e,ne,s),l(e,c,s),l(e,ie,s),l(e,N,s),l(e,oe,s),h(Q,e,s),l(e,re,s),l(e,W,s),l(e,pe,s),l(e,x,s),l(e,ce,s),l(e,A,s),l(e,ue,s),h(q,e,s),l(e,me,s),l(e,u,s),l(e,Me,s),l(e,z,s),l(e,de,s),h($,e,s),l(e,ye,s),l(e,X,s),he=!0},p:Ae,i(e){he||(j(J.$$.fragment,e),j(b.$$.fragment,e),j(T.$$.fragment,e),j(v.$$.fragment,e),j(k.$$.fragment,e),j(Z.$$.fragment,e),j(Q.$$.fragment,e),j(q.$$.fragment,e),j($.$$.fragment,e),he=!0)},o(e){w(J.$$.fragment,e),w(b.$$.fragment,e),w(T.$$.fragment,e),w(v.$$.fragment,e),w(k.$$.fragment,e),w(Z.$$.fragment,e),w(Q.$$.fragment,e),w(q.$$.fragment,e),w($.$$.fragment,e),he=!1},d(e){e&&(t(Y),t(S),t(_),t(F),t(V),t(U),t(H),t(L),t(g),t(K),t(I),t(P),t(G),t(D),t(C),t(O),t(ee),t(p),t(se),t(te),t(B),t(le),t(ae),t(E),t(ne),t(c),t(ie),t(N),t(oe),t(re),t(W),t(pe),t(x),t(ce),t(A),t(ue),t(me),t(u),t(Me),t(z),t(de),t(ye),t(X)),t(M),f(J,e),f(b,e),f(T,e),f(v,e),f(k,e),f(Z,e),f(Q,e),f(q,e),f($,e)}}}const He='{"title":"Fonctionnalités avancées de l’interface","local":"fonctionnalités-avancées-de-linterface","sections":[{"title":"Utilisation de l’état pour faire persister les données","local":"utilisation-de-létat-pour-faire-persister-les-données","sections":[],"depth":3},{"title":"Utilisation de l’interprétation pour comprendre les prédictions","local":"utilisation-de-linterprétation-pour-comprendre-les-prédictions","sections":[],"depth":3},{"title":"Ajouter l’authentification","local":"ajouter-lauthentification","sections":[],"depth":3}],"depth":1}';function Le(Je){return qe(()=>{new URLSearchParams(window.location.search).get("fw")}),[]}class ss extends ze{constructor(M){super(),$e(this,M,Le,Ve,xe,{})}}export{ss as component}; | |
Xet Storage Details
- Size:
- 22.8 kB
- Xet hash:
- 82593c1be6e7572525f705a63f3f7279a85d127fa413676fc9a136fe46bf3c79
·
Xet efficiently stores files, intelligently splitting them into unique chunks and accelerating uploads and downloads. More info.