davanstrien's picture
davanstrien HF Staff
Initial: HumanSignal huggingface_ner example patched for HF Spaces
52c4067 verified
metadata
title: LS Hugging Face NER Backend
emoji: 🏷️
colorFrom: purple
colorTo: pink
sdk: docker
app_port: 9090
pinned: false
license: apache-2.0
short_description: HF NER models as a Label Studio ML backend

LS Hugging Face NER Backend (Hugging Face Spaces)

This Space wraps HumanSignal's huggingface_ner ML backend example as a Hugging Face Space, so it can be used as a /predict backend for a Label Studio instance.

Patches from the upstream example (minimal):

  • Added Spaces SDK frontmatter at the top of this README.
  • Removed docker-compose.yml (not used on Spaces).

The Dockerfile already binds to $PORT and listens on 0.0.0.0, so it deploys as-is. Default base is python:3.11-slim (CPU) — fine for small NER models like dslim/bert-base-NER. For larger models, upgrade hardware to a GPU tier.

Connect from Label Studio: set the ML backend URL to https://davanstrien-ls-huggingface-ner-backend.hf.space.


Hugging Face NER model with Label Studio

This project uses a custom machine learning backend model for Named Entity Recognition (NER) with Hugging Face's transformers and Label Studio.

The model instantiates AutoModelForTokenClassification from Hugging Face's transformers library and fine-tunes it on the NER task.

  • If you want to use this model only in inference mode, it serves predictions from the pre-trained model.
  • If you want to fine-tune the model, you can use the Label Studio interface to provide training data and train the model.

Read more about the compatible models from Hugging Face's official documentation.

Before you begin

Before you begin, you must install the Label Studio ML backend.

This tutorial uses the huggingface_ner example.

Labeling configuration

This ML backend works with the default NER template from Label Studio. You can find this by selecting Label Studio's pre-built NER template when configuring the labeling interface. It is available under Natural Language Processing > Named Entity Recognition:

<View>
  <Labels name="label" toName="text">
    <Label value="PER" background="red"/>
    <Label value="ORG" background="darkorange"/>
    <Label value="LOC" background="orange"/>
    <Label value="MISC" background="green"/>
  </Labels>

  <Text name="text" value="$text"/>
</View>

You can then customize the template to suit your needs (for example, modifying the label names). However, note the model outputs compatibility:

If you plan to use your model only for the inference, make sure the output label names are compatible with what is listed in XML labeling configuration. If you plan to train the model, you have to provide the baseline pretrained model that can be fine-tuned (i.e. where the last layer can be trained, for example, distilbert/distilbert-base-uncased). Otherwise, you may see the error about tensor sizes mismatch during training.

Running with Docker (recommended)

  1. Start the Machine Learning backend on http://localhost:9090 with the prebuilt image:
docker-compose up
  1. Validate that backend is running
$ curl http://localhost:9090/
{"status":"UP"}
  1. Create a project in Label Studio. Then from the Model page in the project settings, connect the model. The default URL is http://localhost:9090.

Building from source (advanced)

To build the ML backend from source, you have to clone the repository and build the Docker image:

docker-compose build

Running without Docker (advanced)

To run the ML backend without Docker, you have to clone the repository and install all dependencies using pip:

python -m venv ml-backend
source ml-backend/bin/activate
pip install -r requirements.txt

Then you can start the ML backend:

label-studio-ml start ./huggingface_ner

Configuration

Parameters can be set in docker-compose.yml before running the container.

The following common parameters are available:

  • BASIC_AUTH_USER - Specify the basic auth user for the model server
  • BASIC_AUTH_PASS - Specify the basic auth password for the model server
  • LOG_LEVEL - Set the log level for the model server
  • WORKERS - Specify the number of workers for the model server
  • THREADS - Specify the number of threads for the model server
  • BASELINE_MODEL_NAME: The name of the baseline model to use. Default is dslim/bert-base-NER.
  • FINETUNED_MODEL_NAME: The name of the fine-tuned model. Default is finetuned_model.
  • LABEL_STUDIO_HOST: The host of the Label Studio instance. Default is 'http://localhost:8080'.
  • LABEL_STUDIO_API_KEY: The API key for the Label Studio instance.
  • START_TRAINING_EACH_N_UPDATES: The number of updates after which to start training. Default is 10.
  • LEARNING_RATE: The learning rate for the model. Default is 1e-3.
  • NUM_TRAIN_EPOCHS: The number of training epochs. Default is 10.
  • WEIGHT_DECAY: The weight decay for the model. Default is 0.01.
  • MODEL_DIR: The directory where the model is stored. Default is './results'.

Note: The LABEL_STUDIO_API_KEY is required for training the model. This can be found by logging into Label Studio and going to the Account & Settings page.

Customization

The ML backend can be customized by adding your own models and logic inside ./huggingface_ner/model.py.

Modify the predict() and fit() methods to implement your own logic.