Skip to content

kensho-technologies/timtc_vocabs_models

Repository files navigation

Vocabulary, Models, and Token Counts for the paper TIMTC

This repository contains the vocabularies and language models to accompany the paper Tokenization Is More Than Compression by Craig W. Schmidt, Varshini Reddy, Haoran Zhang, Alec Alameddine, Omri Uzan, Yuval Pinter, Chris Tanner. This paper will be presented at EMNLP 2024.

Please direct any questions about this repo to [email protected]

These files are intended to stimulate academic research, but are not being actively developed at Kensho any longer.

Abstract of the paper

Tokenization is a foundational step in natural language processing (NLP) tasks, bridging raw text and language models. Existing tokenization approaches like Byte-Pair Encoding (BPE) originate from the field of data compression, and it has been suggested that the effectiveness of BPE stems from its ability to condense text into a relatively small number of tokens. We test the hypothesis that fewer tokens lead to better downstream performance by introducing PathPiece, a new tokenizer that segments a document's text into the minimum number of tokens for a given vocabulary. Through extensive experimentation we find this hypothesis not to be the case, casting doubt on the understanding of the reasons for effective tokenization. To examine which other factors play a role, we evaluate design decisions across all three phases of tokenization: pre-tokenization, vocabulary construction, and segmentation, offering new insights into the design of effective tokenizers. Specifically, we illustrate the importance of pre-tokenization and the benefits of using BPE to initialize vocabulary construction. We train 64 language models with varying tokenization, ranging in size from 350M to 2.4B parameters, all of which are made publicly available.

Installation

The model files are quite large, so this repo used git lfs to store the large *.bin and model.safetensor model files. You will first need to install git lfs. The particular instructions depend on your platform, but for example on Debian you would do sudo apt install git-lfs. Then do git lfs install to set things up within git.

When cloning the repo it will first clone the smaller files, and then download the larger model files, which are stored outside the repo. Please note that this repo will use 115G of disk space to clone!

You may prefer to clone the repository without automatically downloading the large files, to save on time and disk space. To do so, set the GIT_LFS_SKIP_SMUDGE variable before cloning like this:

GIT_LFS_SKIP_SMUDGE=1 git clone [email protected]:kensho-technologies/timtc_vocabs_models.git

Then you can download an individual .bin or model.safetensor file with git lfs pull --include="path/to/file", or all of the files with git lfs pull.

See below for a list of files using lfs.

Files that are too big for GitHub

Sadly, GitHub has a 2GB limit on files in lfs, so the following files were too large:

models/1.3b/sage_initbpe_firstspace_6_40960/pytorch_model.bin
models/1.3b/pathpiecel_initngram_firstspacedigit_15_40960/pytorch_model.bin
models/1.3b/bpe_merge_3_40960/pytorch_model.bin
models/1.3b/pathpiecel_initbpe_firstspace_1_40960/pytorch_model.bin
models/1.3b/unigram_likelihood_2_40960/pytorch_model.bin
models/1.3b/sage_initngram_firstspacedigit_11_40960/pytorch_model.bin
models/350m/pathpiecel_spacedigit_40960/pytorch_model.bin

If you are interested in any of these models, please contact us and we'll figure out some other way for you to get them. Perhaps HuggingFace would have been a better way to go.

vocabularies directory

This contains the 54 vocabulary files used in the experiments. See Table 1 in the paper for the corresponding runs. The filenames take the form bpe_greedy_4_32768.vocab is a BPE run with Greedy segmentation, where 4 refers to the rank column in Table 1, and 32768 is the vocabulary size. Vocabulary files ending in .vocab should be used with the Huggingface tokenizer with byte level pre-tokenization for segmentation. Those ending in .vocab should be used with the PathPiece tokenizer, released as a separate repo as part of this paper. The .vocab format just contains a separate token of bytes on each line, encoded in hexadecimal.

All files in this directory are released under the CC BY 4.0.

models directory

This directory contains the trained Language Models (LM's), in Huggingface format. There are subdirectories for the 350M and 1.3B parameter models. The filenames correspond to the names in the vocabularies directory.

All files in this directory are released under the AI Pubs Open Rail-M license.

tokencounts directory

Many intrinsic tokenization metrics can be computed off the counts of each token over a training corpus. For convenience, we have included the counts of each token for each vocabulary, over the MiniPile dataset. This is the same dataset used to train each vocabulary. The hope is to stimulate research into finding a metric that is a function of these counts that correlated better with the downstream performance presented in the paper. These .tsv files contain the token and count separated by a tab, in decreasing order by count.

All files in this directory are released under the CC BY 4.0.

util directory

The byte-level tokens in the tokencounts directory use the same encoding as the byte-level pretokenizion used by Hugginface. For your convience, this directory has a utility file defining the frombytes and tobytes function, for converting back and forth between this encoding and a python bytes object. It also has the very simple fromhex and tohex functions to convert the tokens in the.vocab files.

The util.py file is released under the AI Pubs Open Rail-S license.

LFS files

The following files are using lfs:

models/350m/bpe_greedy_4_32768/model.safetensors
models/350m/bpe_greedy_4_32768/pytorch_model.bin
models/350m/bpe_greedy_4_40960/model.safetensors
models/350m/bpe_greedy_4_40960/pytorch_model.bin
models/350m/bpe_greedy_4_49152/model.safetensors
models/350m/bpe_greedy_4_49152/pytorch_model.bin
models/350m/bpe_merge_3_32768/pytorch_model.bin
models/350m/bpe_merge_3_40960/pytorch_model.bin
models/350m/bpe_merge_3_49152/pytorch_model.bin
models/350m/bpe_pathpiecel_13_32768/pytorch_model.bin
models/350m/bpe_pathpiecel_13_40960/pytorch_model.bin
models/350m/bpe_pathpiecel_13_49152/pytorch_model.bin
models/350m/pathpiecel_initbpe_firstspace_1_32768/100000/pytorch_model.bin
models/350m/pathpiecel_initbpe_firstspace_1_32768/pytorch_model.bin
models/350m/pathpiecel_initbpe_firstspace_1_40960/pytorch_model.bin
models/350m/pathpiecel_initbpe_firstspace_1_49152/pytorch_model.bin
models/350m/pathpiecel_initngram_firstspace_16_32768/pytorch_model.bin
models/350m/pathpiecel_initngram_firstspace_16_40960/pytorch_model.bin
models/350m/pathpiecel_initngram_firstspace_16_49152/pytorch_model.bin
models/350m/pathpiecel_initngram_firstspacedigit_15_32768/model.safetensors
models/350m/pathpiecel_initngram_firstspacedigit_15_32768/pytorch_model.bin
models/350m/pathpiecel_initngram_firstspacedigit_15_40960/pytorch_model.bin
models/350m/pathpiecel_initngram_firstspacedigit_15_49152/pytorch_model.bin
models/350m/pathpiecel_initunigram_firstspace_9_32768/pytorch_model.bin
models/350m/pathpiecel_initunigram_firstspace_9_40960/pytorch_model.bin
models/350m/pathpiecel_initunigram_firstspace_9_49152/pytorch_model.bin
models/350m/pathpiecer_firstspacedigit_14_32768/pytorch_model.bin
models/350m/pathpiecer_firstspacedigit_14_40960/pytorch_model.bin
models/350m/pathpiecer_firstspacedigit_14_49152/pytorch_model.bin
models/350m/pathpiecer_none_18_32768/pytorch_model.bin
models/350m/pathpiecer_none_18_40960/pytorch_model.bin
models/350m/pathpiecer_none_18_49152/pytorch_model.bin
models/350m/pathpiecer_spacedigit_12_32768/pytorch_model.bin
models/350m/pathpiecer_spacedigit_12_40960/model.safetensors
models/350m/pathpiecer_spacedigit_12_40960/pytorch_model.bin
models/350m/pathpiecer_spacedigit_12_49152/pytorch_model.bin
models/350m/sage_initbpe_firstspace_6_32768/pytorch_model.bin
models/350m/sage_initbpe_firstspace_6_40960/pytorch_model.bin
models/350m/sage_initbpe_firstspace_6_49152/pytorch_model.bin
models/350m/sage_initngram_firstspace_8_32768/model.safetensors
models/350m/sage_initngram_firstspace_8_32768/pytorch_model.bin
models/350m/sage_initngram_firstspace_8_40960/pytorch_model.bin
models/350m/sage_initngram_firstspace_8_49152/pytorch_model.bin
models/350m/sage_initngram_firstspacedigit_11_32768/pytorch_model.bin
models/350m/sage_initngram_firstspacedigit_11_40960/pytorch_model.bin
models/350m/sage_initngram_firstspacedigit_11_49152/pytorch_model.bin
models/350m/sage_initunigram_firstspace_10_32768/pytorch_model.bin
models/350m/sage_initunigram_firstspace_10_40960/pytorch_model.bin
models/350m/sage_initunigram_firstspace_10_49152/pytorch_model.bin
models/350m/unigram_greedy_7_32768/model.safetensors
models/350m/unigram_greedy_7_32768/pytorch_model.bin
models/350m/unigram_greedy_7_40960/model.safetensors
models/350m/unigram_greedy_7_40960/pytorch_model.bin
models/350m/unigram_greedy_7_49152/model.safetensors
models/350m/unigram_greedy_7_49152/pytorch_model.bin
models/350m/unigram_likelihood_2_32768/pytorch_model.bin
models/350m/unigram_likelihood_2_40960/pytorch_model.bin
models/350m/unigram_likelihood_2_49152/pytorch_model.bin
models/350m/unigram_pathpiecel_17_32768/pytorch_model.bin
models/350m/unigram_pathpiecel_17_40960/pytorch_model.bin
models/350m/unigram_pathpiecel_17_49152/pytorch_model.bin
models/350m/wordpiece_5_32768/pytorch_model.bin
models/350m/wordpiece_5_40960/pytorch_model.bin
models/350m/wordpiece_5_49152/pytorch_model.bin

License

As already mentioned, the various directories are covered by different licenses.

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.

© 2023-present Kensho Technologies, LLC. The present date is determined by the timestamp of the most recent commit in the repository.

About

No description, website, or topics provided.

Resources

License

Code of conduct

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages