A simple toolkit to train and evaluate language models.
To cite our languagemodels toolkit, use the following bibtex:
@Misc{peft,
title = {languagemodels: A simple toolkit to train and evaluate language models},
author = {Julius Steuer, Marius Mosbach, Dietrich Klakow},
howpublished = {\url{https://github.com/uds-lsv/languagemodels}},
year = {2023}
}
To cite the LSV LM-GUI, use the following bibtex:
@Misc{peft,
title = {LM-GUI: A graphical user interface for n-gram language models},
author = {Adam Kusmirek, Clayton Greenberg, Youssef Oualil, Dietrich Klakow},
howpublished = {\url{https://github.com/uds-lsv/languagemodels}},
year = {2023}
}
- Create a new virtual environment:
python3 -m venv ./languagemodels-venv
- Activate the virtual environment:
source languagemodels-venv/bin/activate
- Create a new virtual environment:
conda create --name languagemodels python=3.7
- Activate the virtual environment:
conda activate languagemodels
- Upgrade pip:
pip install --upgrade pip
- Install package & requirements:
pip install -e .
- Install the appropriate version of Pytorch before installing the package: https://pytorch.org/get-started/locally/
In order to log your runs with wandb, source the setup.sh
script in the examples/scripts
folder at the beginning of your bash scripts. You will need to enter your user and team name as well as the API key to the script first:
export WANDB_API_KEY=<API key>
export WANDB_USERNAME=<username>
export WANDB_ENTITY=<username>
Wandb will log the runs to the folders indicated in the folders exported at the start of setup.sh
. You have to create these folders before first using wandb (i.e. manually).
export CACHE_BASE_DIR=/data/users/$USER/logs/your_project/logfiles
export OUTPUT_DIR=/data/users/$USER/logs/your_project/logfiles
-
Once the virtual environment is activated and the package has been installed, Python scripts from
languagemodels/
can be run from the command line usingpython3 <name of script> <arguments>
, e.g.:python3 eval_lm -h
. -
Sample scripts for training a tokenizer (
train_tokenizer.sh
), model (train_lm.sh
) and using it to annotate surprisal on the test (eval_lm.sh
) set can be found inexamples/scripts/wikitext-103
. These can be run usingsh <path to script>
, e.g.sh examples/scripts/wikitext-103/eval_lm.sh
.
CL Argument | Description | Example |
---|---|---|
--tokenizer_type |
Type of the tokenizer. | See supported tokenizers section. |
--input_files_dir |
Path to a directory with input files (can be |
/data/corpora/wikitext-103-v1 |
--input_files_type |
File ending of the input files; will be used for processing. E.g. if the input files are in CoNLLU format, you can define a function that extracts the word column from each file. | txt |
--vocab_size |
The tokenizer's vocabulary size. | |
--block_size |
The tokenizer's 'maximal' output size. Will be used with the truncation=True parameter of the tokenizer. |
Should be |
--output_dir |
Directory in which the tokenizer files will be saved. | /data/users/$USER/tokenizers/your_project/ |
--eos_token |
The tokenizer's EOS (end-of-sequence) token. Don't change this if you don't want to do something specific. Will be prefixed to every sequence. | </s> |
--unk_token |
The tokenizer's UNK (unknown) token. Don't change this if you don't want to do something specific. | <unk> |
--pad_token |
The tokenizer's PAD (padding) token. Don't change this if you don't want to do something specific. | <pad> |
All other CL arguments are identical to the HuggingFace transformers TrainingArguments.
Tokenizer | Description | Pre-Tokenizer |
---|---|---|
unigram |
HuggingFace implementation of the Unigram algorithm. | Metaspace |
bpe |
HuggingFace implementation of byte pair encodings. | ByteLevel |
word-level |
HuggingFace implementation of a word-level tokenizer. | Whitespace |
CL Argument | Description | Example |
---|---|---|
--input_files_path |
Path to train, validation and test files. | /data/corpora/wikitext-103-v1/ |
--train_file_name |
File to train data with one sequence per line. Preferably in /data/corpora/ . |
train.txt |
--validation_file_name |
File to validation data with one sequence per line. Preferably in /data/corpora/ . |
validation.txt |
--config_name_or_path |
Either a path to the config JSON file. Must be (compatible with) a config class inheriting from transformers.PreTrainedConfig |
See examples/configs/lstm/basic_lstm.json |
--model_type |
Which auto model class to use. Will be processed by languagemodels.lm_factory to load the config and model classes. |
causal for a causal language model (e.g. GPT-2), masked for a masked language model (e.g. BERT), or seq2seq for a sequence-to-sequence model (e.g. T5). |
--model_name_or_path |
Path to a trained model (e.g. in case of custom models) or name of a HuggingFace model. | gpt2 in combination with --model_type=causal . |
--tokenizer_name_or_path |
Either a path to a pretrained tokenizer or the name of a HuggingFace tokenizer. | bert-base-uncased |
--seed |
Random seed for PyTorch, Cuda, Numpy etc. | 42 |
--wandb_project_name |
Identifier of the wandb project. | languagemodels for the b4 languagemodels project. |
--wandb_group_name |
Used to group runs below the project level. Typically this should identify the experiment you are running, with the run names differentiating (e.g.) between models and random seeds. | |
--use_early_stopping |
Whether to use the EarlyStoppingCallback class or not. |
|
--early_stopping_patience |
Number of evaluations to wait without improvement in eval loss before stopping training. | |
--auto_model_class |
The automodel class to use. | --auto_model_class causal for AutoModelForCausalLM . |
Apart from models from the HuggingFace hub, the following custom models are supported:
CL Argument | Description | Example |
---|---|---|
bigram-lm |
Special implementation of a bigram language model. | |
rnn-lm |
Vanilla RNN, LSTM, GRU | |
opt-with-alibi |
Our custom OPT model with ALiBI instead of positional embeddings |
CL Argument | Description | Example |
---|---|---|
--input_files_path |
Path to the file with the sequences to be evaluated. | /data/corpora/wikitext-103-v1/ |
--eval_file_name |
File to evaluate data with one sequence per line. Preferably in /data/corpora/ . |
test.txt |
--eval_string |
This can be used to score a single sequence or multiple sequences given as a string of text in JSON-format. Primarily for use with the web interface. | '{"text": ["This a sequence.", "This is another sequence."]}' |
--model_name_or_path |
Path to a trained model (e.g. in case of custom models) or name of a HuggingFace model. | gpt2 |
--batch_size |
The maximum number of sequences evaluated per batch. | 8 |
--device |
Device used for training. |
cuda : Nvidia (or AMD) GPU; cpu : CPU. |
--tokenizer_name_or_path |
Either a path to a pretrained tokenizer or the name of a HuggingFace tokenizer. | bert-base-uncased |
--output_dir |
Evaluation results will be saved here. | trained_ models/ |
--output_file_name |
Name of the output file. Should have the .tsv file ending. |
eval_results.tsv |
--block_size |
Size to which the eval sequences will be reshaped, s.t. batches are of the shape |
|
--prepend_token |
Whether or not to prepend an eos token to each batch of sequences. This is necessary for some tokenizers, like those used by the pre-trained gpt2 model. |
- Use the lsv account
- ssh [email protected]
- Ids of workstations: 56, 26, 64, 77, 71, 76, 24, 31, 68, 66
- Go to student’s room 0.03 to check which ones are running
- Pattern: wsXXlx , where XX is one of the ids above
ssh wsXXls
(password is the lsv password)
- Set up an ssh key for GitLab, see GitLab documentation
- Clone the b4/languagemodels repo
- Make sure to checkout the right branch
- Install Miniconda:
- Navigate to your home directory /home/
- Download the installation file from here
- Run:
wget <linktofile>
- Install miniconda by running:
bash <filename>
- Upon successful installation, run
source .bashrc
to activate conda
- Create the environment:
conda create -n <myenv> python=[version]
- (note: you don’t need to have the version installed, conda will do that for you)
- (note 2: we’ve found that Python 3.8.13 works the best, i.e. no depreciation messages)
- Activate the environment: conda activate
- Install the project:
pip install -e . --user
- Use the Dockerfile inside the repo:
- run:
docker build -f [path_to_docker_file] --build-arg USER_UID=$UID --build-arg USER_NAME=$(id -un) -t docker.lsv.uni-saarland.de/[lsv_user_name]/[image_name]:[tag_name] .
- (make sure to change the
lsv_user_name
,image_name
,tag_name
) - (note: the -t flag is used to be able to identify our docker image in the registry)
- run:
- Push to LSV Docker registry:
docker push docker.lsv.uni-saarland.de/[lsv_user_name]/[image_name]:[tag_name]
NOTE:
To check images in the registry: docker image ls
To delete an image: docker image rm [image id]
- Create a .sh file:
- This specifies which of the bin scripts you want to run, i.e.
train_lm
,train_tokenizer
oreval_lm
- For examples see
examples/scripts/
- Make sure to specify paths to training data, output data, config files etc.
- This will call the binary that we want to execute, setting its arguments (e.g. hyperparameters)
- Source
setup.sh
for use of wandb before calling the binary
- This specifies which of the bin scripts you want to run, i.e.
- Create a submit file:
- Using the project’s docker file/image
- Specify which .sh you want to run, e.g. train_lm.sh (executable)
- Cluster breakdown:
- cl14, cl15 - smaller LSTMs (11GB VRAM)
- cl16 - larger models (32GB VRAM)
- cl18+ - needs a good reason to be used; e.g. >4 GPUs, or >32GB VRAM
ssh submit
- From here you can submit jobs via thesubmit file and HTCondor:
condor_submit <path/to/.sub>
- submit file needs to end with .sub
- Monitor jobs with
condor_q
- If the job is idle, wait
- If job is on hold:
condor_q -hold [job_id]
(this will display the errors causing the job to be on hold)
- Make sure to create a directory for your username under
/data/users
if not present- create path
/data/users/[username]/logs/languagemodels/logfiles
- Here, logfiles including a .err file will be stored, which contains important information about specific jobs. Format: [job_id]_[datetime].err
- create path
- Collect the output from the specified output directory once the job is done
- See
examples
Contributor | |
---|---|
Marius Mosbach | [email protected] |
Julius Steuer | [email protected] |
AriaRay Brown | [email protected] |