cybertron

module
v0.0.0-...-53a6fda Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Aug 6, 2024 License: BSD-2-Clause

README

Cybertron

Cybertron is a package in pure Go built upon spaGO that provides Go developers with an easy interface to use NLP technologies, without needing other programming languages or complex frameworks. It's designed for using pre-trained Transformer models available on the HuggingFace models repository.

The package is primarily aimed at running inference with the possibility of adding fine-tuning in the future.

The team is open to contributors to expedite its growth.

Supported models

  • BERT
  • ELECTRA
  • BART
  • PEGASUS
  • MarianMT

Supported tasks

  • Masked Language Modeling
  • Supervised and Zero-Shot Text Classification (Sentiment Analysis, Topic Classification, Intent Detection, ...)
  • Token Classification (Named Entity Recognition, Part-of-Speech Tagging, ...)
  • Extractive and Abstractive Question-Answering
  • Text Encoding (Text Embedding, Semantic Search, ...)
  • Text Generation (Translation, Paraphrasing, Summarization, ...)
  • Relation Extraction

Usage

Requirements:

Clone this repo or get the library:

go get -u github.com/yinziyang/cybertron

Cybertron supports two main use cases, which are explained more in detail in the following.

Server mode

Settings are configured in a .env file, which is automatically loaded by Cybertron. Alternatively, it also accepts configurations via flags.

For a complete list run:

GOARCH=amd64 go run ./cmd/server -h

Output:

Usage of server:
  -address value
        server listening address
  -allowed-origins value
        allowed origins (comma separated)
  -loglevel value
        zerolog global level
  -model value
        model name (and sub-path of models-dir)
  -model-conversion value
        model conversion policy ("always"|"missing"|"never")
  -model-conversion-precision value
        floating-point bits of precision to use if the model is converted ("32"|"64")
  -model-download value
        model downloading policy ("always"|"missing"|"never")
  -models-dir value
        models's base directory
  -network value
        network type for server listening
  -task value
        type of inference/computation that the model can fulfill ("textgeneration"|"zero-shot-classification"|"question-answering"|"text-classification"|"token-classification"|"text-encoding")
  -tls value
        whether to enable TLS ("true"|"false")
  -tls-cert value
        TLS cert filename
  -tls-key value
        TLS key filename

For example, to run Cybertron in server mode for Machine Translation (e.g. en to it) with default settings, simply create a .env file in the current directory:

echo "CYBERTRON_MODEL=Helsinki-NLP/opus-mt-en-it" > .env
echo "CYBERTRON_MODELS_DIR=models" >> .env
echo "CYBERTRON_MODEL_TASK=text-generation" >> .env

and execute the following command:

GOARCH=amd64 go run ./cmd/server -address 0.0.0.0:8080

To test the server, run:

curl -X 'POST' \
  '0.0.0.0:8080/v1/generate' \
  -H 'accept: application/json' \
  -H 'Content-Type: application/json' \
  -d '{
  "input": "You must be the change you wish to see in the world.",
  "parameters": {}
}'

Library mode

Several examples can be leveraged to tour the current NLP capabilities in Cybertron. A list of the demos now follows.

Machine Translation (En -> It)
GOARCH=amd64 go run ./examples/textgeneration
Zero-Shot Text Classification

⚠️ If the model specified in .env file is not compatible, an error will be returned. In this case, remove the specified model from the configuration file, so the default one will be used.

GOARCH=amd64 go run ./examples/zeroshotclassification politics,business,science,technology,health,culture,sports

Dependencies

Cybertron's pricipal dependencies are:

  • Spago - a lightweight self-contained machine learning framework in pure Go
  • GoPickle - a Go module for loading Python's data serialized with pickle and PyTorch module files
  • GoTokenizers - Go implementation of today's most used tokenizers

The rest are mainly for gRPC and HTTP API developments.

Dev Tools

This section is intended for developers who want to change or enrich the Cybertron gRPC and HTTP APIs.

To get started, you need buf installed in your machine.

Then install the following tools:

go install github.com/grpc-ecosystem/grpc-gateway/v2/protoc-gen-grpc-gateway \
  github.com/grpc-ecosystem/grpc-gateway/v2/protoc-gen-openapiv2 \
  google.golang.org/protobuf/cmd/protoc-gen-go \
  google.golang.org/grpc/cmd/protoc-gen-go-grpc

Then run the following command to generate the gRPC and HTTP APIs:

go generate ./...

Directories

Path Synopsis
cmd
pkg
generationutils
Package generationutils implements a decoding search algorithm for conditional generation.
Package generationutils implements a decoding search algorithm for conditional generation.
models/bart
Package bart implements the transformer model introduced by Mike et al., 2019.
Package bart implements the transformer model introduced by Mike et al., 2019.
server/gen/proto/go/languagemodeling/v1
Package languagemodelingv1 is a reverse proxy.
Package languagemodelingv1 is a reverse proxy.
server/gen/proto/go/questionanswering/v1
Package questionansweringv1 is a reverse proxy.
Package questionansweringv1 is a reverse proxy.
server/gen/proto/go/textclassification/v1
Package textclassificationv1 is a reverse proxy.
Package textclassificationv1 is a reverse proxy.
server/gen/proto/go/textencoding/v1
Package textencodingv1 is a reverse proxy.
Package textencodingv1 is a reverse proxy.
server/gen/proto/go/textgeneration/v1
Package textgenerationv1 is a reverse proxy.
Package textgenerationv1 is a reverse proxy.
server/gen/proto/go/tokenclassification/v1
Package tokenclassificationv1 is a reverse proxy.
Package tokenclassificationv1 is a reverse proxy.
server/gen/proto/go/zeroshot/v1
Package zeroshotv1 is a reverse proxy.
Package zeroshotv1 is a reverse proxy.
tokenizers
Package tokenizers is an interim solution while developing `gotokenizers` (https://github.com/nlpodyssey/gotokenizers).
Package tokenizers is an interim solution while developing `gotokenizers` (https://github.com/nlpodyssey/gotokenizers).
tokenizers/basetokenizer
Package basetokenizer provides an implementations of a very simple tokenizer that splits by white-spaces (and alike) and punctuation symbols.
Package basetokenizer provides an implementations of a very simple tokenizer that splits by white-spaces (and alike) and punctuation symbols.
tokenizers/sentencepiece/internal/sentencepiece
Package sentencepiece implements the SentencePiece encoder (Kudo and Richardson, 2018).
Package sentencepiece implements the SentencePiece encoder (Kudo and Richardson, 2018).
utils/sliceutils
Package sliceutils provides types and functions for various operations over sliceutils of different types.
Package sliceutils provides types and functions for various operations over sliceutils of different types.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL