SentencePieceTokenizer
类keras_nlp.tokenizers.SentencePieceTokenizer(
proto=None,
sequence_length=None,
dtype="int32",
add_bos=False,
add_eos=False,
**kwargs
)
SentencePiece 分词器层。
该层提供了 SentencePiece 分词的实现,如 SentencePiece 论文 和 SentencePiece 包 中所述。分词将在 Tensorflow 图中完全运行,并且可以保存在 keras.Model
中。
默认情况下,该层将输出一个 tf.RaggedTensor
,其中输出的最后一个维度在空格拆分和子词分词后是不规则的。如果设置了 sequence_length
,该层将输出一个密集的 tf.Tensor
,其中所有输入都已填充或截断到 sequence_length
。输出数据类型可以通过 dtype
参数控制,该参数应该是整数或字符串类型。
参数
string
路径,或包含序列化 SentencePiece proto 的 bytes
对象。有关格式的更多详细信息,请参阅 SentencePiece 存储库。sequence_length
。sequence_length
,则始终截断标记。参考
示例
从字节。
def train_sentence_piece_bytes(ds, size):
bytes_io = io.BytesIO()
sentencepiece.SentencePieceTrainer.train(
sentence_iterator=ds.as_numpy_iterator(),
model_writer=bytes_io,
vocab_size=size,
)
return bytes_io.getvalue()
# Train a sentencepiece proto.
ds = tf.data.Dataset.from_tensor_slices(["the quick brown fox."])
proto = train_sentence_piece_bytes(ds, 20)
# Tokenize inputs.
tokenizer = keras_nlp.tokenizers.SentencePieceTokenizer(proto=proto)
ds = ds.map(tokenizer)
从文件。
def train_sentence_piece_file(ds, path, size):
with open(path, "wb") as model_file:
sentencepiece.SentencePieceTrainer.train(
sentence_iterator=ds.as_numpy_iterator(),
model_writer=model_file,
vocab_size=size,
)
# Train a sentencepiece proto.
ds = tf.data.Dataset.from_tensor_slices(["the quick brown fox."])
proto = train_sentence_piece_file(ds, "model.spm", 20)
# Tokenize inputs.
tokenizer = keras_nlp.tokenizers.SentencePieceTokenizer(proto="model.spm")
ds = ds.map(tokenizer)
tokenize
方法SentencePieceTokenizer.tokenize(inputs)
将输入字符串张量转换为输出标记。
参数
detokenize
方法SentencePieceTokenizer.detokenize(inputs)
将标记转换回字符串。
参数
get_vocabulary
方法SentencePieceTokenizer.get_vocabulary()
获取分词器词汇表。
vocabulary_size
方法SentencePieceTokenizer.vocabulary_size()
获取分词器词汇表的整数大小。
token_to_id
方法SentencePieceTokenizer.token_to_id(token)
将字符串标记转换为整数 ID。
id_to_token
方法SentencePieceTokenizer.id_to_token(id)
将整数 ID 转换为字符串标记。