Tasks
Last updated
Last updated
Tasks, or pipeline types, describe the โshapeโ of each modelโs API (inputs and outputs) and are used to determine which Inference API and widget we want to display for any given model.
This classification is relatively coarse-grained (you can always add more fine-grained task names in your model tags), so you should rarely have to create a new task. If you want to add support for a new task, this document explains the required steps.
Having a new task integrated into the Hub means that:
Users can search for all models โ and datasets โ of a given task.
The Inference API supports the task.
Users can try out models directly with the widget. ๐
Note that you donโt need to implement all the steps by yourself. Adding a new task is a community effort, and multiple people can contribute. ๐งโ๐คโ๐ง
To begin the process, open a new issue in the huggingface_hub repository. Please use the โAdding a new taskโ template. โ ๏ธBefore doing any coding, itโs suggested to go over this document. โ ๏ธ
The first step is to upload a model for your proposed task. Once you have a model in the Hub for the new task, the next step is to enable it in the Inference API. There are three types of support that you can choose from:
๐ using a transformers
model
๐ณ using a model from an officially supported library
๐จ๏ธ using a model with custom inference code. This experimental option has downsides, so we recommend using one of the other approaches.
Finally, you can add a couple of UI elements, such as the task icon and the widget, that complete the integration in the Hub. ๐ท
Some steps are orthogonal; you donโt need to do them in order. You donโt need the Inference API to add the icon. This means that, even if there isnโt full integration yet, users can still search for models of a given task.
If your model is a transformers
-based model, there is a 1:1 mapping between the Inference API task and a pipeline
class. Here are some example PRs from the transformers
library:
Once the pipeline is submitted and deployed, you should be able to use the Inference API for your model.
The Hub also supports over 10 open-source libraries in the Community Inference API.
Adding a new task is relatively straightforward and requires 2 PRs:
PR 1: Add the new task to the API validation. This code ensures that the inference input is valid for a given task. Some PR examples:
PR 2: Add the new task to a library docker image. You should also add a template to docker_images/common/app/pipelines
to facilitate integrating the task in other libraries. Here is an example PR:
My model is not supported by any library. Am I doomed? ๐ฑ
No, youโre not! The generic Inference API is an experimental Docker image for quickly prototyping new tasks and introducing new libraries, which should allow you to have a new task in production with very little development from your side.
How does it work from the userโs point of view? Users create a copy of a template repo for their given task. Users then need to define their requirements.txt
and fill pipeline.py
. Note that this is intended for quick experimentation and prototyping instead of fast production use-cases.
The Hub allows users to filter models by a given task. To do this, you need to add the task to several places. Youโll also get to pick an icon for the task!
Add the task type to Types.ts
In interfaces/Types.ts, you need to do a couple of things
Add the type to PIPELINE_DATA
. Note that pipeline types are sorted into different categories (NLP, Audio, Computer Vision, and others).
You will also need to fill minor changes in the following files:
Choose an icon
You can add an icon in the lib/Icons directory. We usually choose carbon icons from https://icones.js.org/collection/carbon. Also add the icon to PipelineIcon.
Once the task is in production, what could be more exciting than implementing some way for users to play directly with the models in their browser? ๐คฉ You can find all the widgets here.
If you would be interested in contributing with a widget, you can look at the implementation of all the widgets. You can also find WIP documentation on implementing a widget in https://github.com/boincai/hub-docs/tree/main/js.