Buckets:
| # Интеграция с Hugging Face Hub[[integrations-with-the-hugging-face-hub]] | |
| <CourseFloatingBanner chapter={9} | |
| classNames="absolute z-10 right-0 top-0" | |
| notebooks={[ | |
| {label: "Google Colab", value: "https://colab.research.google.com/github/huggingface/notebooks/blob/master/course/en/chapter9/section5.ipynb"}, | |
| {label: "Aws Studio", value: "https://studiolab.sagemaker.aws/import/github/huggingface/notebooks/blob/master/course/en/chapter9/section5.ipynb"}, | |
| ]} /> | |
| Чтобы сделать вашу жизнь еще проще, Gradio напрямую интегрируется с Hugging Face Hub и Hugging Face Spaces. | |
| Вы можете загружать демо из Hub и Spaces, используя всего *одну строку кода*. | |
| ### Загрузка моделей из Hugging Face Hub[[loading-models-from-the-hugging-face-hub]] | |
| Для начала выберите одну из тысяч моделей, которые Hugging Face предлагает в Hub, как описано в [Главе 4](../chapter4/2). | |
| Используя специальный метод `Interface.load()`, вы передаете `"model/"` (или, эквивалентно, `"huggingface/"`) | |
| после чего следует имя модели. | |
| Например, здесь приведен код для создания демо для [GPT-J](https://huggingface.co/EleutherAI/gpt-j-6B), большой языковой модели, добавьте пару примеров ввода: | |
| ```py | |
| import gradio as gr | |
| title = "GPT-J-6B" | |
| description = "Gradio Demo for GPT-J 6B, a transformer model trained using Ben Wang's Mesh Transformer JAX. 'GPT-J' refers to the class of model, while '6B' represents the number of trainable parameters. To use it, simply add your text, or click one of the examples to load them. Read more at the links below." | |
| article = "<p style='text-align: center'><a href='https://github.com/kingoflolz/mesh-transformer-jax' target='_blank'>GPT-J-6B: A 6 Billion Parameter Autoregressive Language Model</a></p>" | |
| gr.Interface.load( | |
| "huggingface/EleutherAI/gpt-j-6B", | |
| inputs=gr.Textbox(lines=5, label="Input Text"), | |
| title=title, | |
| description=description, | |
| article=article, | |
| ).launch() | |
| ``` | |
| Код, приведенный выше, приведет к созданию интерфейса, представленного ниже: | |
| <iframe src="https://course-demos-gpt-j-6B.hf.space" frameBorder="0" height="750" title="Gradio app" class="container p-0 flex-grow space-iframe" 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" sandbox="allow-forms allow-modals allow-popups allow-popups-to-escape-sandbox allow-same-origin allow-scripts allow-downloads"></iframe> | |
| Загрузка модели таким образом использует [Inference API](https://huggingface.co/inference-api) Hugging Face, | |
| вместо того, чтобы загружать модель в память. Это идеально подходит для огромных моделей, таких как GPT-J или T0pp, которые | |
| которые требуют много RAM. | |
| ### Загрузка с Hugging Face Spaces[[loading-from-hugging-face-spaces]] | |
| Чтобы загрузить любое пространство (Space) из Hugging Face Hub и воссоздать его локально, вы можете передать `spaces/` в `Interface`, за которым следует имя пространства. | |
| Помните демо из раздела 1, которое удаляет фон изображения? Давайте загрузим его из Hugging Face Spaces: | |
| ```py | |
| gr.Interface.load("spaces/abidlabs/remove-bg").launch() | |
| ``` | |
| <iframe src="https://course-demos-remove-bg-original.hf.space" frameBorder="0" height="650" title="Gradio app" class="container p-0 flex-grow space-iframe" 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" sandbox="allow-forms allow-modals allow-popups allow-popups-to-escape-sandbox allow-same-origin allow-scripts allow-downloads"></iframe> | |
| Одна из особенностей загрузки демо из Hub или Spaces заключается в том, что вы можете настраивать их | |
| переопределив любой из | |
| параметров. Здесь мы добавим заголовок и задействуем веб-камеру: | |
| ```py | |
| gr.Interface.load( | |
| "spaces/abidlabs/remove-bg", inputs="webcam", title="Remove your webcam background!" | |
| ).launch() | |
| ``` | |
| <iframe src="https://course-demos-Remove-bg.hf.space" frameBorder="0" height="550" title="Gradio app" class="container p-0 flex-grow space-iframe" 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" sandbox="allow-forms allow-modals allow-popups allow-popups-to-escape-sandbox allow-same-origin allow-scripts allow-downloads"></iframe> | |
| Теперь, когда мы изучили несколько способов интеграции Gradio с Hugging Face Hub, давайте рассмотрим некоторые дополнительные возможности класса `Interface`. Этому будет посвящен следующий раздел! | |
| <EditOnGithub source="https://github.com/huggingface/course/blob/main/chapters/ru/chapter9/5.mdx" /> |
Xet Storage Details
- Size:
- 6.22 kB
- Xet hash:
- 225712c14450b4c3c87318dfabc5b23fdf1652b66e85a2678de85aa8f611dc06
·
Xet efficiently stores files, intelligently splitting them into unique chunks and accelerating uploads and downloads. More info.